mirror of
https://github.com/commons-app/apps-android-commons.git
synced 2025-10-26 12:23:58 +01:00
Break up MediaDetailPagerFragment to make it easier to convert to kotlin
This commit is contained in:
parent
840f4fd44e
commit
4564d5570a
14 changed files with 138 additions and 127 deletions
|
|
@ -22,6 +22,7 @@ import fr.free.nrw.commons.contributions.MainActivity;
|
||||||
import fr.free.nrw.commons.databinding.FragmentFeaturedRootBinding;
|
import fr.free.nrw.commons.databinding.FragmentFeaturedRootBinding;
|
||||||
import fr.free.nrw.commons.di.CommonsDaggerSupportFragment;
|
import fr.free.nrw.commons.di.CommonsDaggerSupportFragment;
|
||||||
import fr.free.nrw.commons.media.MediaDetailPagerFragment;
|
import fr.free.nrw.commons.media.MediaDetailPagerFragment;
|
||||||
|
import fr.free.nrw.commons.media.MediaDetailProvider;
|
||||||
import fr.free.nrw.commons.navtab.NavTab;
|
import fr.free.nrw.commons.navtab.NavTab;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
|
@ -29,7 +30,7 @@ import timber.log.Timber;
|
||||||
|
|
||||||
public class BookmarkListRootFragment extends CommonsDaggerSupportFragment implements
|
public class BookmarkListRootFragment extends CommonsDaggerSupportFragment implements
|
||||||
FragmentManager.OnBackStackChangedListener,
|
FragmentManager.OnBackStackChangedListener,
|
||||||
MediaDetailPagerFragment.MediaDetailProvider,
|
MediaDetailProvider,
|
||||||
AdapterView.OnItemClickListener, CategoryImagesCallback {
|
AdapterView.OnItemClickListener, CategoryImagesCallback {
|
||||||
|
|
||||||
private MediaDetailPagerFragment mediaDetails;
|
private MediaDetailPagerFragment mediaDetails;
|
||||||
|
|
|
||||||
|
|
@ -8,7 +8,6 @@ import android.view.Menu
|
||||||
import android.view.MenuItem
|
import android.view.MenuItem
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import androidx.activity.viewModels
|
import androidx.activity.viewModels
|
||||||
import androidx.fragment.app.Fragment
|
|
||||||
import androidx.fragment.app.FragmentManager
|
import androidx.fragment.app.FragmentManager
|
||||||
import androidx.lifecycle.Lifecycle
|
import androidx.lifecycle.Lifecycle
|
||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
|
|
@ -22,6 +21,7 @@ import fr.free.nrw.commons.explore.categories.media.CategoriesMediaFragment
|
||||||
import fr.free.nrw.commons.explore.categories.parent.ParentCategoriesFragment
|
import fr.free.nrw.commons.explore.categories.parent.ParentCategoriesFragment
|
||||||
import fr.free.nrw.commons.explore.categories.sub.SubCategoriesFragment
|
import fr.free.nrw.commons.explore.categories.sub.SubCategoriesFragment
|
||||||
import fr.free.nrw.commons.media.MediaDetailPagerFragment
|
import fr.free.nrw.commons.media.MediaDetailPagerFragment
|
||||||
|
import fr.free.nrw.commons.media.MediaDetailProvider
|
||||||
import fr.free.nrw.commons.theme.BaseActivity
|
import fr.free.nrw.commons.theme.BaseActivity
|
||||||
import fr.free.nrw.commons.utils.handleWebUrl
|
import fr.free.nrw.commons.utils.handleWebUrl
|
||||||
import fr.free.nrw.commons.wikidata.model.WikiSite
|
import fr.free.nrw.commons.wikidata.model.WikiSite
|
||||||
|
|
@ -36,7 +36,7 @@ import javax.inject.Inject
|
||||||
* a particular category on wikimedia commons.
|
* a particular category on wikimedia commons.
|
||||||
*/
|
*/
|
||||||
class CategoryDetailsActivity : BaseActivity(),
|
class CategoryDetailsActivity : BaseActivity(),
|
||||||
MediaDetailPagerFragment.MediaDetailProvider,
|
MediaDetailProvider,
|
||||||
CategoryImagesCallback {
|
CategoryImagesCallback {
|
||||||
|
|
||||||
private lateinit var supportFragmentManager: FragmentManager
|
private lateinit var supportFragmentManager: FragmentManager
|
||||||
|
|
|
||||||
|
|
@ -43,7 +43,7 @@ import fr.free.nrw.commons.location.LatLng
|
||||||
import fr.free.nrw.commons.location.LocationServiceManager
|
import fr.free.nrw.commons.location.LocationServiceManager
|
||||||
import fr.free.nrw.commons.location.LocationUpdateListener
|
import fr.free.nrw.commons.location.LocationUpdateListener
|
||||||
import fr.free.nrw.commons.media.MediaDetailPagerFragment
|
import fr.free.nrw.commons.media.MediaDetailPagerFragment
|
||||||
import fr.free.nrw.commons.media.MediaDetailPagerFragment.MediaDetailProvider
|
import fr.free.nrw.commons.media.MediaDetailProvider
|
||||||
import fr.free.nrw.commons.mwapi.OkHttpJsonApiClient
|
import fr.free.nrw.commons.mwapi.OkHttpJsonApiClient
|
||||||
import fr.free.nrw.commons.nearby.NearbyController
|
import fr.free.nrw.commons.nearby.NearbyController
|
||||||
import fr.free.nrw.commons.nearby.NearbyNotificationCardView
|
import fr.free.nrw.commons.nearby.NearbyNotificationCardView
|
||||||
|
|
@ -72,7 +72,6 @@ import io.reactivex.disposables.CompositeDisposable
|
||||||
import io.reactivex.schedulers.Schedulers
|
import io.reactivex.schedulers.Schedulers
|
||||||
import timber.log.Timber
|
import timber.log.Timber
|
||||||
import java.util.Calendar
|
import java.util.Calendar
|
||||||
import java.util.Date
|
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
import javax.inject.Named
|
import javax.inject.Named
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,6 @@ import android.os.Bundle;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.widget.FrameLayout;
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.fragment.app.Fragment;
|
import androidx.fragment.app.Fragment;
|
||||||
|
|
@ -17,10 +16,11 @@ import fr.free.nrw.commons.databinding.FragmentFeaturedRootBinding;
|
||||||
import fr.free.nrw.commons.di.CommonsDaggerSupportFragment;
|
import fr.free.nrw.commons.di.CommonsDaggerSupportFragment;
|
||||||
import fr.free.nrw.commons.explore.categories.media.CategoriesMediaFragment;
|
import fr.free.nrw.commons.explore.categories.media.CategoriesMediaFragment;
|
||||||
import fr.free.nrw.commons.media.MediaDetailPagerFragment;
|
import fr.free.nrw.commons.media.MediaDetailPagerFragment;
|
||||||
|
import fr.free.nrw.commons.media.MediaDetailProvider;
|
||||||
import fr.free.nrw.commons.navtab.NavTab;
|
import fr.free.nrw.commons.navtab.NavTab;
|
||||||
|
|
||||||
public class ExploreListRootFragment extends CommonsDaggerSupportFragment implements
|
public class ExploreListRootFragment extends CommonsDaggerSupportFragment implements
|
||||||
MediaDetailPagerFragment.MediaDetailProvider, CategoryImagesCallback {
|
MediaDetailProvider, CategoryImagesCallback {
|
||||||
|
|
||||||
private MediaDetailPagerFragment mediaDetails;
|
private MediaDetailPagerFragment mediaDetails;
|
||||||
private CategoriesMediaFragment listFragment;
|
private CategoriesMediaFragment listFragment;
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,6 @@ import android.os.Bundle;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.widget.FrameLayout;
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.fragment.app.Fragment;
|
import androidx.fragment.app.Fragment;
|
||||||
|
|
@ -17,10 +16,11 @@ import fr.free.nrw.commons.databinding.FragmentFeaturedRootBinding;
|
||||||
import fr.free.nrw.commons.di.CommonsDaggerSupportFragment;
|
import fr.free.nrw.commons.di.CommonsDaggerSupportFragment;
|
||||||
import fr.free.nrw.commons.explore.map.ExploreMapFragment;
|
import fr.free.nrw.commons.explore.map.ExploreMapFragment;
|
||||||
import fr.free.nrw.commons.media.MediaDetailPagerFragment;
|
import fr.free.nrw.commons.media.MediaDetailPagerFragment;
|
||||||
|
import fr.free.nrw.commons.media.MediaDetailProvider;
|
||||||
import fr.free.nrw.commons.navtab.NavTab;
|
import fr.free.nrw.commons.navtab.NavTab;
|
||||||
|
|
||||||
public class ExploreMapRootFragment extends CommonsDaggerSupportFragment implements
|
public class ExploreMapRootFragment extends CommonsDaggerSupportFragment implements
|
||||||
MediaDetailPagerFragment.MediaDetailProvider, CategoryImagesCallback {
|
MediaDetailProvider, CategoryImagesCallback {
|
||||||
|
|
||||||
private MediaDetailPagerFragment mediaDetails;
|
private MediaDetailPagerFragment mediaDetails;
|
||||||
private ExploreMapFragment mapFragment;
|
private ExploreMapFragment mapFragment;
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,6 @@ import android.os.Bundle;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.fragment.app.Fragment;
|
|
||||||
import androidx.fragment.app.FragmentManager;
|
import androidx.fragment.app.FragmentManager;
|
||||||
import androidx.fragment.app.FragmentTransaction;
|
import androidx.fragment.app.FragmentTransaction;
|
||||||
import com.jakewharton.rxbinding2.view.RxView;
|
import com.jakewharton.rxbinding2.view.RxView;
|
||||||
|
|
@ -23,18 +22,14 @@ import fr.free.nrw.commons.explore.models.RecentSearch;
|
||||||
import fr.free.nrw.commons.explore.recentsearches.RecentSearchesDao;
|
import fr.free.nrw.commons.explore.recentsearches.RecentSearchesDao;
|
||||||
import fr.free.nrw.commons.explore.recentsearches.RecentSearchesFragment;
|
import fr.free.nrw.commons.explore.recentsearches.RecentSearchesFragment;
|
||||||
import fr.free.nrw.commons.media.MediaDetailPagerFragment;
|
import fr.free.nrw.commons.media.MediaDetailPagerFragment;
|
||||||
|
import fr.free.nrw.commons.media.MediaDetailProvider;
|
||||||
import fr.free.nrw.commons.theme.BaseActivity;
|
import fr.free.nrw.commons.theme.BaseActivity;
|
||||||
import fr.free.nrw.commons.utils.FragmentUtils;
|
import fr.free.nrw.commons.utils.FragmentUtils;
|
||||||
import fr.free.nrw.commons.utils.ViewUtil;
|
import fr.free.nrw.commons.utils.ViewUtil;
|
||||||
import io.reactivex.android.schedulers.AndroidSchedulers;
|
import io.reactivex.android.schedulers.AndroidSchedulers;
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Locale;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
import kotlin.Pair;
|
|
||||||
import timber.log.Timber;
|
import timber.log.Timber;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -42,7 +37,7 @@ import timber.log.Timber;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class SearchActivity extends BaseActivity
|
public class SearchActivity extends BaseActivity
|
||||||
implements MediaDetailPagerFragment.MediaDetailProvider, CategoryImagesCallback {
|
implements MediaDetailProvider, CategoryImagesCallback {
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
RecentSearchesDao recentSearchesDao;
|
RecentSearchesDao recentSearchesDao;
|
||||||
|
|
|
||||||
|
|
@ -11,7 +11,6 @@ import android.view.Menu;
|
||||||
import android.view.MenuInflater;
|
import android.view.MenuInflater;
|
||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import androidx.fragment.app.Fragment;
|
|
||||||
import androidx.fragment.app.FragmentManager;
|
import androidx.fragment.app.FragmentManager;
|
||||||
import com.google.android.material.snackbar.Snackbar;
|
import com.google.android.material.snackbar.Snackbar;
|
||||||
import fr.free.nrw.commons.Media;
|
import fr.free.nrw.commons.Media;
|
||||||
|
|
@ -24,6 +23,7 @@ import fr.free.nrw.commons.explore.depictions.child.ChildDepictionsFragment;
|
||||||
import fr.free.nrw.commons.explore.depictions.media.DepictedImagesFragment;
|
import fr.free.nrw.commons.explore.depictions.media.DepictedImagesFragment;
|
||||||
import fr.free.nrw.commons.explore.depictions.parent.ParentDepictionsFragment;
|
import fr.free.nrw.commons.explore.depictions.parent.ParentDepictionsFragment;
|
||||||
import fr.free.nrw.commons.media.MediaDetailPagerFragment;
|
import fr.free.nrw.commons.media.MediaDetailPagerFragment;
|
||||||
|
import fr.free.nrw.commons.media.MediaDetailProvider;
|
||||||
import fr.free.nrw.commons.theme.BaseActivity;
|
import fr.free.nrw.commons.theme.BaseActivity;
|
||||||
import fr.free.nrw.commons.upload.structure.depictions.DepictModel;
|
import fr.free.nrw.commons.upload.structure.depictions.DepictModel;
|
||||||
import fr.free.nrw.commons.upload.structure.depictions.DepictedItem;
|
import fr.free.nrw.commons.upload.structure.depictions.DepictedItem;
|
||||||
|
|
@ -31,16 +31,12 @@ import fr.free.nrw.commons.wikidata.WikidataConstants;
|
||||||
import io.reactivex.android.schedulers.AndroidSchedulers;
|
import io.reactivex.android.schedulers.AndroidSchedulers;
|
||||||
import io.reactivex.disposables.CompositeDisposable;
|
import io.reactivex.disposables.CompositeDisposable;
|
||||||
import io.reactivex.schedulers.Schedulers;
|
import io.reactivex.schedulers.Schedulers;
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.List;
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
import kotlin.Pair;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Activity to show depiction media, parent classes and child classes of depicted items in Explore
|
* Activity to show depiction media, parent classes and child classes of depicted items in Explore
|
||||||
*/
|
*/
|
||||||
public class WikidataItemDetailsActivity extends BaseActivity implements MediaDetailPagerFragment.MediaDetailProvider,
|
public class WikidataItemDetailsActivity extends BaseActivity implements MediaDetailProvider,
|
||||||
CategoryImagesCallback {
|
CategoryImagesCallback {
|
||||||
private FragmentManager supportFragmentManager;
|
private FragmentManager supportFragmentManager;
|
||||||
private DepictedImagesFragment depictionImagesListFragment;
|
private DepictedImagesFragment depictionImagesListFragment;
|
||||||
|
|
|
||||||
|
|
@ -8,7 +8,7 @@ import fr.free.nrw.commons.MediaDataExtractor
|
||||||
import fr.free.nrw.commons.R
|
import fr.free.nrw.commons.R
|
||||||
import fr.free.nrw.commons.category.CategoryImagesCallback
|
import fr.free.nrw.commons.category.CategoryImagesCallback
|
||||||
import fr.free.nrw.commons.explore.paging.BasePagingFragment
|
import fr.free.nrw.commons.explore.paging.BasePagingFragment
|
||||||
import fr.free.nrw.commons.media.MediaDetailPagerFragment.MediaDetailProvider
|
import fr.free.nrw.commons.media.MediaDetailProvider
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
abstract class PageableMediaFragment :
|
abstract class PageableMediaFragment :
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,95 @@
|
||||||
|
package fr.free.nrw.commons.media;
|
||||||
|
|
||||||
|
import android.view.ViewGroup;
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
import androidx.fragment.app.Fragment;
|
||||||
|
import androidx.fragment.app.FragmentManager;
|
||||||
|
import androidx.fragment.app.FragmentStatePagerAdapter;
|
||||||
|
import timber.log.Timber;
|
||||||
|
|
||||||
|
//FragmentStatePagerAdapter allows user to swipe across collection of images (no. of images undetermined)
|
||||||
|
class MediaDetailAdapter extends FragmentStatePagerAdapter {
|
||||||
|
|
||||||
|
final MediaDetailPagerFragment mediaDetailPagerFragment;
|
||||||
|
/**
|
||||||
|
* Keeps track of the current displayed fragment.
|
||||||
|
*/
|
||||||
|
private Fragment mCurrentFragment;
|
||||||
|
|
||||||
|
public MediaDetailAdapter(MediaDetailPagerFragment mediaDetailPagerFragment,
|
||||||
|
FragmentManager fm) {
|
||||||
|
super(fm);
|
||||||
|
this.mediaDetailPagerFragment = mediaDetailPagerFragment;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Fragment getItem(int i) {
|
||||||
|
if (i == 0) {
|
||||||
|
// See bug https://code.google.com/p/android/issues/detail?id=27526
|
||||||
|
if (mediaDetailPagerFragment.getActivity() == null) {
|
||||||
|
Timber.d("Skipping getItem. Returning as activity is destroyed!");
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
mediaDetailPagerFragment.binding.mediaDetailsPager.postDelayed(
|
||||||
|
() -> mediaDetailPagerFragment.getActivity().invalidateOptionsMenu(), 5);
|
||||||
|
}
|
||||||
|
if (mediaDetailPagerFragment.isFromFeaturedRootFragment) {
|
||||||
|
return MediaDetailFragment.forMedia(mediaDetailPagerFragment.position + i,
|
||||||
|
mediaDetailPagerFragment.editable, mediaDetailPagerFragment.isFeaturedImage,
|
||||||
|
mediaDetailPagerFragment.isWikipediaButtonDisplayed);
|
||||||
|
} else {
|
||||||
|
return MediaDetailFragment.forMedia(i, mediaDetailPagerFragment.editable,
|
||||||
|
mediaDetailPagerFragment.isFeaturedImage,
|
||||||
|
mediaDetailPagerFragment.isWikipediaButtonDisplayed);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getCount() {
|
||||||
|
if (mediaDetailPagerFragment.getActivity() == null) {
|
||||||
|
Timber.d("Skipping getCount. Returning as activity is destroyed!");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return mediaDetailPagerFragment.provider.getTotalMediaCount();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the currently displayed fragment.
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Fragment getCurrentFragment() {
|
||||||
|
return mCurrentFragment;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If current fragment is of type MediaDetailFragment, return it, otherwise return null.
|
||||||
|
*
|
||||||
|
* @return MediaDetailFragment
|
||||||
|
*/
|
||||||
|
public MediaDetailFragment getCurrentMediaDetailFragment() {
|
||||||
|
if (mCurrentFragment instanceof MediaDetailFragment) {
|
||||||
|
return (MediaDetailFragment) mCurrentFragment;
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called to inform the adapter of which item is currently considered to be the "primary", that
|
||||||
|
* is the one show to the user as the current page.
|
||||||
|
*
|
||||||
|
* @param container
|
||||||
|
* @param position
|
||||||
|
* @param object
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void setPrimaryItem(@NonNull final ViewGroup container, final int position,
|
||||||
|
@NonNull final Object object) {
|
||||||
|
// Update the current fragment if changed
|
||||||
|
if (getCurrentFragment() != object) {
|
||||||
|
mCurrentFragment = ((Fragment) object);
|
||||||
|
}
|
||||||
|
super.setPrimaryItem(container, position, object);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -77,7 +77,6 @@ import fr.free.nrw.commons.CommonsApplication.Companion.instance
|
||||||
import fr.free.nrw.commons.Media
|
import fr.free.nrw.commons.Media
|
||||||
import fr.free.nrw.commons.MediaDataExtractor
|
import fr.free.nrw.commons.MediaDataExtractor
|
||||||
import fr.free.nrw.commons.R
|
import fr.free.nrw.commons.R
|
||||||
import fr.free.nrw.commons.utils.UnderlineUtils
|
|
||||||
import fr.free.nrw.commons.actions.ThanksClient
|
import fr.free.nrw.commons.actions.ThanksClient
|
||||||
import fr.free.nrw.commons.auth.SessionManager
|
import fr.free.nrw.commons.auth.SessionManager
|
||||||
import fr.free.nrw.commons.auth.csrf.InvalidLoginTokenException
|
import fr.free.nrw.commons.auth.csrf.InvalidLoginTokenException
|
||||||
|
|
@ -102,7 +101,6 @@ import fr.free.nrw.commons.kvstore.JsonKvStore
|
||||||
import fr.free.nrw.commons.language.AppLanguageLookUpTable
|
import fr.free.nrw.commons.language.AppLanguageLookUpTable
|
||||||
import fr.free.nrw.commons.location.LocationServiceManager
|
import fr.free.nrw.commons.location.LocationServiceManager
|
||||||
import fr.free.nrw.commons.locationpicker.LocationPicker
|
import fr.free.nrw.commons.locationpicker.LocationPicker
|
||||||
import fr.free.nrw.commons.media.MediaDetailPagerFragment.MediaDetailProvider
|
|
||||||
import fr.free.nrw.commons.profile.ProfileActivity
|
import fr.free.nrw.commons.profile.ProfileActivity
|
||||||
import fr.free.nrw.commons.review.ReviewHelper
|
import fr.free.nrw.commons.review.ReviewHelper
|
||||||
import fr.free.nrw.commons.settings.Prefs
|
import fr.free.nrw.commons.settings.Prefs
|
||||||
|
|
|
||||||
|
|
@ -21,11 +21,8 @@ import android.widget.Toast;
|
||||||
import androidx.appcompat.app.ActionBar;
|
import androidx.appcompat.app.ActionBar;
|
||||||
import androidx.appcompat.app.AlertDialog;
|
import androidx.appcompat.app.AlertDialog;
|
||||||
import androidx.appcompat.app.AppCompatActivity;
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
import androidx.annotation.NonNull;
|
|
||||||
import androidx.core.content.ContextCompat;
|
import androidx.core.content.ContextCompat;
|
||||||
import androidx.fragment.app.Fragment;
|
|
||||||
import androidx.fragment.app.FragmentManager;
|
import androidx.fragment.app.FragmentManager;
|
||||||
import androidx.fragment.app.FragmentStatePagerAdapter;
|
|
||||||
import androidx.viewpager.widget.ViewPager;
|
import androidx.viewpager.widget.ViewPager;
|
||||||
import com.google.android.material.snackbar.Snackbar;
|
import com.google.android.material.snackbar.Snackbar;
|
||||||
import fr.free.nrw.commons.CommonsApplication;
|
import fr.free.nrw.commons.CommonsApplication;
|
||||||
|
|
@ -69,23 +66,23 @@ public class MediaDetailPagerFragment extends CommonsDaggerSupportFragment imple
|
||||||
|
|
||||||
private static CompositeDisposable compositeDisposable = new CompositeDisposable();
|
private static CompositeDisposable compositeDisposable = new CompositeDisposable();
|
||||||
|
|
||||||
private FragmentMediaDetailPagerBinding binding;
|
FragmentMediaDetailPagerBinding binding;
|
||||||
|
|
||||||
private boolean editable;
|
boolean editable;
|
||||||
private boolean isFeaturedImage;
|
boolean isFeaturedImage;
|
||||||
private boolean isWikipediaButtonDisplayed;
|
boolean isWikipediaButtonDisplayed;
|
||||||
MediaDetailAdapter adapter;
|
MediaDetailAdapter adapter;
|
||||||
private Bookmark bookmark;
|
Bookmark bookmark;
|
||||||
private MediaDetailProvider provider;
|
MediaDetailProvider provider;
|
||||||
private boolean isFromFeaturedRootFragment;
|
boolean isFromFeaturedRootFragment;
|
||||||
private int position;
|
int position;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ProgressBar used to indicate the loading status of media items.
|
* ProgressBar used to indicate the loading status of media items.
|
||||||
*/
|
*/
|
||||||
private ProgressBar imageProgressBar;
|
ProgressBar imageProgressBar;
|
||||||
|
|
||||||
private ArrayList<Integer> removedItems=new ArrayList<Integer>();
|
ArrayList<Integer> removedItems=new ArrayList<Integer>();
|
||||||
|
|
||||||
public void clearRemoved(){
|
public void clearRemoved(){
|
||||||
removedItems.clear();
|
removedItems.clear();
|
||||||
|
|
@ -127,7 +124,7 @@ public class MediaDetailPagerFragment extends CommonsDaggerSupportFragment imple
|
||||||
binding.mediaDetailsPager.addOnPageChangeListener(this);
|
binding.mediaDetailsPager.addOnPageChangeListener(this);
|
||||||
// Initialize the ProgressBar by finding it in the layout
|
// Initialize the ProgressBar by finding it in the layout
|
||||||
imageProgressBar = binding.getRoot().findViewById(R.id.itemProgressBar);
|
imageProgressBar = binding.getRoot().findViewById(R.id.itemProgressBar);
|
||||||
adapter = new MediaDetailAdapter(getChildFragmentManager());
|
adapter = new MediaDetailAdapter(this, getChildFragmentManager());
|
||||||
|
|
||||||
// ActionBar is now supported in both activities - if this crashes something is quite wrong
|
// ActionBar is now supported in both activities - if this crashes something is quite wrong
|
||||||
final ActionBar actionBar = ((AppCompatActivity) getActivity()).getSupportActionBar();
|
final ActionBar actionBar = ((AppCompatActivity) getActivity()).getSupportActionBar();
|
||||||
|
|
@ -589,90 +586,4 @@ public class MediaDetailPagerFragment extends CommonsDaggerSupportFragment imple
|
||||||
provider.refreshNominatedMedia(index);
|
provider.refreshNominatedMedia(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
public interface MediaDetailProvider {
|
|
||||||
Media getMediaAtPosition(int i);
|
|
||||||
|
|
||||||
int getTotalMediaCount();
|
|
||||||
|
|
||||||
Integer getContributionStateAt(int position);
|
|
||||||
|
|
||||||
// Reload media detail fragment once media is nominated
|
|
||||||
void refreshNominatedMedia(int index);
|
|
||||||
}
|
|
||||||
|
|
||||||
//FragmentStatePagerAdapter allows user to swipe across collection of images (no. of images undetermined)
|
|
||||||
private class MediaDetailAdapter extends FragmentStatePagerAdapter {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Keeps track of the current displayed fragment.
|
|
||||||
*/
|
|
||||||
private Fragment mCurrentFragment;
|
|
||||||
|
|
||||||
public MediaDetailAdapter(FragmentManager fm) {
|
|
||||||
super(fm);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Fragment getItem(int i) {
|
|
||||||
if (i == 0) {
|
|
||||||
// See bug https://code.google.com/p/android/issues/detail?id=27526
|
|
||||||
if(getActivity() == null) {
|
|
||||||
Timber.d("Skipping getItem. Returning as activity is destroyed!");
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
binding.mediaDetailsPager.postDelayed(() -> getActivity().invalidateOptionsMenu(), 5);
|
|
||||||
}
|
|
||||||
if (isFromFeaturedRootFragment) {
|
|
||||||
return MediaDetailFragment.forMedia(position+i, editable, isFeaturedImage, isWikipediaButtonDisplayed);
|
|
||||||
} else {
|
|
||||||
return MediaDetailFragment.forMedia(i, editable, isFeaturedImage, isWikipediaButtonDisplayed);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getCount() {
|
|
||||||
if (getActivity() == null) {
|
|
||||||
Timber.d("Skipping getCount. Returning as activity is destroyed!");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
return provider.getTotalMediaCount();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the currently displayed fragment.
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Fragment getCurrentFragment() {
|
|
||||||
return mCurrentFragment;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* If current fragment is of type MediaDetailFragment, return it, otherwise return null.
|
|
||||||
* @return MediaDetailFragment
|
|
||||||
*/
|
|
||||||
public MediaDetailFragment getCurrentMediaDetailFragment() {
|
|
||||||
if (mCurrentFragment instanceof MediaDetailFragment) {
|
|
||||||
return (MediaDetailFragment) mCurrentFragment;
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Called to inform the adapter of which item is currently considered to be the "primary",
|
|
||||||
* that is the one show to the user as the current page.
|
|
||||||
* @param container
|
|
||||||
* @param position
|
|
||||||
* @param object
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public void setPrimaryItem(@NonNull final ViewGroup container, final int position,
|
|
||||||
@NonNull final Object object) {
|
|
||||||
// Update the current fragment if changed
|
|
||||||
if(getCurrentFragment() != object) {
|
|
||||||
mCurrentFragment = ((Fragment)object);
|
|
||||||
}
|
|
||||||
super.setPrimaryItem(container, position, object);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,15 @@
|
||||||
|
package fr.free.nrw.commons.media;
|
||||||
|
|
||||||
|
import fr.free.nrw.commons.Media;
|
||||||
|
|
||||||
|
public interface MediaDetailProvider {
|
||||||
|
|
||||||
|
Media getMediaAtPosition(int i);
|
||||||
|
|
||||||
|
int getTotalMediaCount();
|
||||||
|
|
||||||
|
Integer getContributionStateAt(int position);
|
||||||
|
|
||||||
|
// Reload media detail fragment once media is nominated
|
||||||
|
void refreshNominatedMedia(int index);
|
||||||
|
}
|
||||||
|
|
@ -74,6 +74,7 @@ import fr.free.nrw.commons.location.LocationServiceManager.LocationChangeType
|
||||||
import fr.free.nrw.commons.location.LocationUpdateListener
|
import fr.free.nrw.commons.location.LocationUpdateListener
|
||||||
import fr.free.nrw.commons.media.MediaClient
|
import fr.free.nrw.commons.media.MediaClient
|
||||||
import fr.free.nrw.commons.media.MediaDetailPagerFragment
|
import fr.free.nrw.commons.media.MediaDetailPagerFragment
|
||||||
|
import fr.free.nrw.commons.media.MediaDetailProvider
|
||||||
import fr.free.nrw.commons.navtab.NavTab
|
import fr.free.nrw.commons.navtab.NavTab
|
||||||
import fr.free.nrw.commons.nearby.BottomSheetAdapter
|
import fr.free.nrw.commons.nearby.BottomSheetAdapter
|
||||||
import fr.free.nrw.commons.nearby.BottomSheetAdapter.ItemClickListener
|
import fr.free.nrw.commons.nearby.BottomSheetAdapter.ItemClickListener
|
||||||
|
|
@ -150,7 +151,7 @@ class NearbyParentFragment : CommonsDaggerSupportFragment(),
|
||||||
LocationUpdateListener,
|
LocationUpdateListener,
|
||||||
LocationPermissionCallback,
|
LocationPermissionCallback,
|
||||||
ItemClickListener,
|
ItemClickListener,
|
||||||
MediaDetailPagerFragment.MediaDetailProvider {
|
MediaDetailProvider {
|
||||||
var binding: FragmentNearbyParentBinding? = null
|
var binding: FragmentNearbyParentBinding? = null
|
||||||
|
|
||||||
val mapEventsOverlay: MapEventsOverlay = MapEventsOverlay(object : MapEventsReceiver {
|
val mapEventsOverlay: MapEventsOverlay = MapEventsOverlay(object : MapEventsReceiver {
|
||||||
|
|
|
||||||
|
|
@ -132,7 +132,7 @@ class MediaDetailFragmentUnitTests {
|
||||||
private lateinit var button: Button
|
private lateinit var button: Button
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private lateinit var detailProvider: MediaDetailPagerFragment.MediaDetailProvider
|
private lateinit var detailProvider: MediaDetailProvider
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private lateinit var applicationKvStore: JsonKvStore
|
private lateinit var applicationKvStore: JsonKvStore
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue