mirror of
				https://github.com/commons-app/apps-android-commons.git
				synced 2025-10-26 20:33:53 +01:00 
			
		
		
		
	
							parent
							
								
									38dceddbf5
								
							
						
					
					
						commit
						8e8558ae6d
					
				
					 10 changed files with 374 additions and 24 deletions
				
			
		|  | @ -109,6 +109,11 @@ | |||
|             android:label="@string/title_activity_featured_images" | ||||
|             android:parentActivityName=".contributions.MainActivity" /> | ||||
| 
 | ||||
|         <activity | ||||
|             android:name=".explore.categories.ExploreActivity" | ||||
|             android:label="@string/title_activity_explore" | ||||
|             android:parentActivityName=".contributions.MainActivity" /> | ||||
| 
 | ||||
|         <activity | ||||
|             android:name=".explore.SearchActivity" | ||||
|             android:label="@string/title_activity_search" | ||||
|  |  | |||
|  | @ -41,10 +41,9 @@ import fr.free.nrw.commons.PageTitle; | |||
| import fr.free.nrw.commons.R; | ||||
| import fr.free.nrw.commons.Utils; | ||||
| import fr.free.nrw.commons.WelcomeActivity; | ||||
| import fr.free.nrw.commons.category.CategoryImagesActivity; | ||||
| import fr.free.nrw.commons.contributions.MainActivity; | ||||
| import fr.free.nrw.commons.di.ApplicationlessInjection; | ||||
| import fr.free.nrw.commons.kvstore.JsonKvStore; | ||||
| import fr.free.nrw.commons.explore.categories.ExploreActivity; | ||||
| import fr.free.nrw.commons.kvstore.JsonKvStore; | ||||
| import fr.free.nrw.commons.mwapi.MediaWikiApi; | ||||
| import fr.free.nrw.commons.theme.NavigationBaseActivity; | ||||
|  | @ -63,8 +62,6 @@ import static fr.free.nrw.commons.auth.AccountUtil.AUTH_TOKEN_TYPE; | |||
| 
 | ||||
| public class LoginActivity extends AccountAuthenticatorActivity { | ||||
| 
 | ||||
|     private static final String FEATURED_IMAGES_CATEGORY = "Category:Featured_pictures_on_Wikimedia_Commons"; | ||||
| 
 | ||||
|     @Inject MediaWikiApi mwApi; | ||||
|     @Inject SessionManager sessionManager; | ||||
|     @Inject | ||||
|  | @ -155,7 +152,7 @@ public class LoginActivity extends AccountAuthenticatorActivity { | |||
|      */ | ||||
|     private void skipLogin() { | ||||
|         applicationKvStore.putBoolean("login_skipped", true); | ||||
|         CategoryImagesActivity.startYourself(this, getString(R.string.title_activity_explore), FEATURED_IMAGES_CATEGORY); | ||||
|         ExploreActivity.startYourself(this); | ||||
|         finish(); | ||||
| 
 | ||||
|     } | ||||
|  |  | |||
|  | @ -25,6 +25,7 @@ import butterknife.ButterKnife; | |||
| import dagger.android.support.DaggerFragment; | ||||
| import fr.free.nrw.commons.Media; | ||||
| import fr.free.nrw.commons.R; | ||||
| import fr.free.nrw.commons.explore.categories.ExploreActivity; | ||||
| import fr.free.nrw.commons.kvstore.JsonKvStore; | ||||
| import fr.free.nrw.commons.utils.NetworkUtils; | ||||
| import fr.free.nrw.commons.utils.ViewUtil; | ||||
|  | @ -251,6 +252,11 @@ public class CategoryImagesListFragment extends DaggerFragment { | |||
|             }catch (Exception e){ | ||||
|                 e.printStackTrace(); | ||||
|             } | ||||
|             try { | ||||
|                 ((ExploreActivity) getContext()).viewPagerNotifyDataSetChanged(); | ||||
|             }catch (Exception e){ | ||||
|                 e.printStackTrace(); | ||||
|             } | ||||
|         } | ||||
|         progressBar.setVisibility(GONE); | ||||
|         isLoading = false; | ||||
|  |  | |||
|  | @ -13,6 +13,7 @@ import fr.free.nrw.commons.contributions.MainActivity; | |||
| import fr.free.nrw.commons.category.CategoryImagesActivity; | ||||
| import fr.free.nrw.commons.explore.SearchActivity; | ||||
| 
 | ||||
| import fr.free.nrw.commons.explore.categories.ExploreActivity; | ||||
| import fr.free.nrw.commons.notification.NotificationActivity; | ||||
| import fr.free.nrw.commons.settings.SettingsActivity; | ||||
| import fr.free.nrw.commons.upload.UploadActivity; | ||||
|  | @ -54,6 +55,9 @@ public abstract class ActivityBuilderModule { | |||
|     @ContributesAndroidInjector | ||||
|     abstract CategoryDetailsActivity bindCategoryDetailsActivity(); | ||||
| 
 | ||||
|     @ContributesAndroidInjector | ||||
|     abstract ExploreActivity bindExploreActivity(); | ||||
| 
 | ||||
|     @ContributesAndroidInjector | ||||
|     abstract AchievementsActivity bindAchievementsActivity(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -0,0 +1,276 @@ | |||
| package fr.free.nrw.commons.explore.categories; | ||||
| 
 | ||||
| import android.content.Context; | ||||
| import android.content.Intent; | ||||
| import android.database.DataSetObserver; | ||||
| import android.os.Bundle; | ||||
| import android.view.Menu; | ||||
| import android.view.MenuInflater; | ||||
| import android.view.MenuItem; | ||||
| import android.view.View; | ||||
| import android.widget.AdapterView; | ||||
| import android.widget.FrameLayout; | ||||
| 
 | ||||
| import com.google.android.material.tabs.TabLayout; | ||||
| 
 | ||||
| import java.util.ArrayList; | ||||
| import java.util.List; | ||||
| 
 | ||||
| import androidx.fragment.app.Fragment; | ||||
| import androidx.fragment.app.FragmentManager; | ||||
| import androidx.viewpager.widget.ViewPager; | ||||
| import butterknife.BindView; | ||||
| import butterknife.ButterKnife; | ||||
| import fr.free.nrw.commons.Media; | ||||
| import fr.free.nrw.commons.R; | ||||
| import fr.free.nrw.commons.category.CategoryImagesListFragment; | ||||
| import fr.free.nrw.commons.explore.SearchActivity; | ||||
| import fr.free.nrw.commons.explore.ViewPagerAdapter; | ||||
| import fr.free.nrw.commons.media.MediaDetailPagerFragment; | ||||
| import fr.free.nrw.commons.theme.NavigationBaseActivity; | ||||
| 
 | ||||
| /** | ||||
|  * This activity displays featured images and images uploaded via mobile | ||||
|  */ | ||||
| 
 | ||||
| 
 | ||||
| public class ExploreActivity | ||||
|         extends NavigationBaseActivity | ||||
|         implements MediaDetailPagerFragment.MediaDetailProvider, | ||||
|         AdapterView.OnItemClickListener { | ||||
| 
 | ||||
|     private static final String FEATURED_IMAGES_CATEGORY = "Category:Featured_pictures_on_Wikimedia_Commons"; | ||||
|     private static final String MOBILE_UPLOADS_CATEGORY = "Category:Uploaded_with_Mobile/Android"; | ||||
| 
 | ||||
| 
 | ||||
|     @BindView(R.id.mediaContainer) | ||||
|     FrameLayout mediaContainer; | ||||
|     @BindView(R.id.tab_layout) | ||||
|     TabLayout tabLayout; | ||||
|     @BindView(R.id.viewPager) | ||||
|     ViewPager viewPager; | ||||
|     ViewPagerAdapter viewPagerAdapter; | ||||
|     private FragmentManager supportFragmentManager; | ||||
|     private MediaDetailPagerFragment mediaDetails; | ||||
|     private CategoryImagesListFragment mobileImagesListFragment; | ||||
|     private CategoryImagesListFragment featuredImagesListFragment; | ||||
| 
 | ||||
|     /** | ||||
|      * Consumers should be simply using this method to use this activity. | ||||
|      * | ||||
|      * @param context A Context of the application package implementing this class. | ||||
|      */ | ||||
|     public static void startYourself(Context context) { | ||||
|         Intent intent = new Intent(context, ExploreActivity.class); | ||||
|         intent.addFlags(Intent.FLAG_ACTIVITY_REORDER_TO_FRONT | Intent.FLAG_ACTIVITY_SINGLE_TOP); | ||||
|         context.startActivity(intent); | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     protected void onCreate(Bundle savedInstanceState) { | ||||
|         super.onCreate(savedInstanceState); | ||||
|         setContentView(R.layout.activity_explore); | ||||
|         ButterKnife.bind(this); | ||||
|         initDrawer(); | ||||
|         setTitle(getString(R.string.title_activity_explore)); | ||||
|         supportFragmentManager = getSupportFragmentManager(); | ||||
|         viewPagerAdapter = new ViewPagerAdapter(getSupportFragmentManager()); | ||||
|         viewPager.setAdapter(viewPagerAdapter); | ||||
|         tabLayout.setupWithViewPager(viewPager); | ||||
|         setTabs(); | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Sets the titles in the tabLayout and fragments in the viewPager | ||||
|      */ | ||||
|     public void setTabs() { | ||||
|         List<Fragment> fragmentList = new ArrayList<>(); | ||||
|         List<String> titleList = new ArrayList<>(); | ||||
| 
 | ||||
|         featuredImagesListFragment = new CategoryImagesListFragment(); | ||||
|         Bundle featuredArguments = new Bundle(); | ||||
|         featuredArguments.putString("categoryName", FEATURED_IMAGES_CATEGORY); | ||||
|         featuredImagesListFragment.setArguments(featuredArguments); | ||||
|         fragmentList.add(featuredImagesListFragment); | ||||
|         titleList.add(getString(R.string.explore_tab_title_featured)); | ||||
| 
 | ||||
|         mobileImagesListFragment = new CategoryImagesListFragment(); | ||||
|         Bundle mobileArguments = new Bundle(); | ||||
|         mobileArguments.putString("categoryName", MOBILE_UPLOADS_CATEGORY); | ||||
|         mobileImagesListFragment.setArguments(mobileArguments); | ||||
|         fragmentList.add(mobileImagesListFragment); | ||||
|         titleList.add(getString(R.string.explore_tab_title_mobile)); | ||||
| 
 | ||||
|         viewPagerAdapter.setTabData(fragmentList, titleList); | ||||
|         viewPagerAdapter.notifyDataSetChanged(); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * This method is called mediaDetailPagerFragment. It returns the Media Object at that Index | ||||
|      * | ||||
|      * @param i It is the index of which media object is to be returned which is same as | ||||
|      *          current index of viewPager. | ||||
|      * @return Media Object | ||||
|      */ | ||||
|     @Override | ||||
|     public Media getMediaAtPosition(int i) { | ||||
|         if (mobileImagesListFragment.getAdapter() != null && tabLayout.getSelectedTabPosition() == 1) { | ||||
|             return (Media) mobileImagesListFragment.getAdapter().getItem(i); | ||||
|         } else if (featuredImagesListFragment.getAdapter() != null && tabLayout.getSelectedTabPosition() == 0) { | ||||
|             return (Media) featuredImagesListFragment.getAdapter().getItem(i); | ||||
|         } else { | ||||
|             return null; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * This method is called on from getCount of MediaDetailPagerFragment | ||||
|      * The viewpager will contain same number of media items as that of media elements in adapter. | ||||
|      * | ||||
|      * @return Total Media count in the adapter | ||||
|      */ | ||||
|     @Override | ||||
|     public int getTotalMediaCount() { | ||||
|         if (mobileImagesListFragment.getAdapter() != null && tabLayout.getSelectedTabPosition() == 1) { | ||||
|             return mobileImagesListFragment.getAdapter().getCount(); | ||||
|         } else if (featuredImagesListFragment.getAdapter() != null && tabLayout.getSelectedTabPosition() == 0) { | ||||
|             return featuredImagesListFragment.getAdapter().getCount(); | ||||
|         } else { | ||||
|             return 0; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * This method is never called but it was in MediaDetailProvider Interface | ||||
|      * so it needs to be overrided. | ||||
|      */ | ||||
|     @Override | ||||
|     public void notifyDatasetChanged() { | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * This method is called on success of API call for featured images or mobile uploads. | ||||
|      * The viewpager will notified that number of items have changed. | ||||
|      */ | ||||
|     public void viewPagerNotifyDataSetChanged() { | ||||
|         if (mediaDetails != null) { | ||||
|             mediaDetails.notifyDataSetChanged(); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * This method is never called but it was in MediaDetailProvider Interface | ||||
|      * so it needs to be overrided. | ||||
|      */ | ||||
|     @Override | ||||
|     public void registerDataSetObserver(DataSetObserver observer) { | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * This method is never called but it was in MediaDetailProvider Interface | ||||
|      * so it needs to be overrided. | ||||
|      */ | ||||
|     @Override | ||||
|     public void unregisterDataSetObserver(DataSetObserver observer) { | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * This method is called on Screen Rotation | ||||
|      */ | ||||
|     @Override | ||||
|     protected void onResume() { | ||||
|         if (supportFragmentManager.getBackStackEntryCount() == 1) { | ||||
|             //FIXME: Temporary fix for screen rotation inside media details. If we don't call onBackPressed then fragment stack is increasing every time. | ||||
|             //FIXME: Similar issue like this https://github.com/commons-app/apps-android-commons/issues/894 | ||||
|             // | ||||
|             onBackPressed(); | ||||
|         } | ||||
|         super.onResume(); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * This method is called on backPressed of anyFragment in the activity. | ||||
|      * If condition is called when mediaDetailFragment is opened. | ||||
|      */ | ||||
|     @Override | ||||
|     public void onBackPressed() { | ||||
|         if (supportFragmentManager.getBackStackEntryCount() == 1) { | ||||
|             tabLayout.setVisibility(View.VISIBLE); | ||||
|             viewPager.setVisibility(View.VISIBLE); | ||||
|             mediaContainer.setVisibility(View.GONE); | ||||
|         } | ||||
|         initDrawer(); | ||||
|         super.onBackPressed(); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     /** | ||||
|      * This method is called when viewPager has reached its end. | ||||
|      * Fetches more images and adds them to the recycler view and viewpager adapter | ||||
|      */ | ||||
|     public void requestMoreImages() { | ||||
|         if (mobileImagesListFragment != null && tabLayout.getSelectedTabPosition() == 1) { | ||||
|             mobileImagesListFragment.fetchMoreImagesViewPager(); | ||||
|         } else if (featuredImagesListFragment != null && tabLayout.getSelectedTabPosition() == 0) { | ||||
|             featuredImagesListFragment.fetchMoreImagesViewPager(); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * This method is called onClick of media inside category featured images or mobile uploads. | ||||
|      */ | ||||
|     @Override | ||||
|     public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) { | ||||
|         tabLayout.setVisibility(View.GONE); | ||||
|         viewPager.setVisibility(View.GONE); | ||||
|         mediaContainer.setVisibility(View.VISIBLE); | ||||
|         if (mediaDetails == null || !mediaDetails.isVisible()) { | ||||
|             // set isFeaturedImage true for featured images, to include author field on media detail | ||||
|             mediaDetails = new MediaDetailPagerFragment(false, true); | ||||
|             FragmentManager supportFragmentManager = getSupportFragmentManager(); | ||||
|             supportFragmentManager | ||||
|                     .beginTransaction() | ||||
|                     .hide(supportFragmentManager.getFragments().get(supportFragmentManager.getBackStackEntryCount())) | ||||
|                     .add(R.id.mediaContainer, mediaDetails) | ||||
|                     .addToBackStack(null) | ||||
|                     .commit(); | ||||
|             // Reason for using hide, add instead of replace is to maintain scroll position after | ||||
|             // coming back to the explore activity. See https://github.com/commons-app/apps-android-commons/issues/1631 | ||||
|             // https://stackoverflow.com/questions/11353075/how-can-i-maintain-fragment-state-when-added-to-the-back-stack/19022550#19022550            supportFragmentManager.executePendingTransactions(); | ||||
|         } | ||||
|         mediaDetails.showImage(i); | ||||
|         forceInitBackButton(); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * This method inflates the menu in the toolbar | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean onCreateOptionsMenu(Menu menu) { | ||||
|         MenuInflater inflater = getMenuInflater(); | ||||
|         inflater.inflate(R.menu.menu_search, menu); | ||||
|         return super.onCreateOptionsMenu(menu); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * This method handles the logic on ItemSelect in toolbar menu | ||||
|      * Currently only 1 choice is available to open search page of the app | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean onOptionsItemSelected(MenuItem item) { | ||||
| 
 | ||||
|         // Handle item selection | ||||
|         switch (item.getItemId()) { | ||||
|             case R.id.action_search: | ||||
|                 NavigationBaseActivity.startActivityWithFlags(this, SearchActivity.class); | ||||
|                 return true; | ||||
|             default: | ||||
|                 return super.onOptionsItemSelected(item); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
|  | @ -39,7 +39,7 @@ import fr.free.nrw.commons.category.CategoryImagesActivity; | |||
| import fr.free.nrw.commons.contributions.Contribution; | ||||
| import fr.free.nrw.commons.di.CommonsDaggerSupportFragment; | ||||
| import fr.free.nrw.commons.explore.SearchActivity; | ||||
| import fr.free.nrw.commons.kvstore.JsonKvStore; | ||||
| import fr.free.nrw.commons.explore.categories.ExploreActivity; | ||||
| import fr.free.nrw.commons.kvstore.JsonKvStore; | ||||
| import fr.free.nrw.commons.mwapi.MediaWikiApi; | ||||
| import fr.free.nrw.commons.utils.ImageUtils; | ||||
|  | @ -347,6 +347,11 @@ public class MediaDetailPagerFragment extends CommonsDaggerSupportFragment imple | |||
|             }catch (Exception e){ | ||||
|                 e.printStackTrace(); | ||||
|             } | ||||
|             try{ | ||||
|                 ((ExploreActivity) getContext()).requestMoreImages(); | ||||
|             }catch (Exception e){ | ||||
|                 e.printStackTrace(); | ||||
|             } | ||||
|         } | ||||
|         getActivity().invalidateOptionsMenu(); | ||||
|     } | ||||
|  |  | |||
|  | @ -35,8 +35,8 @@ import fr.free.nrw.commons.WelcomeActivity; | |||
| import fr.free.nrw.commons.achievements.AchievementsActivity; | ||||
| import fr.free.nrw.commons.auth.LoginActivity; | ||||
| import fr.free.nrw.commons.bookmarks.BookmarksActivity; | ||||
| import fr.free.nrw.commons.category.CategoryImagesActivity; | ||||
| import fr.free.nrw.commons.contributions.MainActivity; | ||||
| import fr.free.nrw.commons.explore.categories.ExploreActivity; | ||||
| import fr.free.nrw.commons.kvstore.JsonKvStore; | ||||
| import fr.free.nrw.commons.logging.CommonsLogSender; | ||||
| import fr.free.nrw.commons.settings.SettingsActivity; | ||||
|  | @ -45,7 +45,6 @@ import timber.log.Timber; | |||
| public abstract class NavigationBaseActivity extends BaseActivity | ||||
|         implements NavigationView.OnNavigationItemSelectedListener { | ||||
| 
 | ||||
|     private static final String FEATURED_IMAGES_CATEGORY = "Category:Featured_pictures_on_Wikimedia_Commons"; | ||||
|     private boolean isRestoredToTop; | ||||
| 
 | ||||
|     @BindView(R.id.toolbar) | ||||
|  | @ -222,7 +221,7 @@ public abstract class NavigationBaseActivity extends BaseActivity | |||
|                 return true; | ||||
|             case R.id.action_explore: | ||||
|                 drawerLayout.closeDrawer(navigationView); | ||||
|                 CategoryImagesActivity.startYourself(this, getString(R.string.title_activity_explore), FEATURED_IMAGES_CATEGORY); | ||||
|                 ExploreActivity.startYourself(this); | ||||
|                 return true; | ||||
|             case R.id.action_bookmarks: | ||||
|                 drawerLayout.closeDrawer(navigationView); | ||||
|  |  | |||
|  | @ -12,8 +12,9 @@ | |||
|         <com.google.android.material.appbar.AppBarLayout | ||||
|             android:id="@+id/toolbar_layout" | ||||
|             android:layout_width="match_parent" | ||||
|             android:background="@color/primaryDarkColor" | ||||
|             android:layout_height="wrap_content"> | ||||
|             android:layout_height="wrap_content" | ||||
|             android:background="@color/primaryDarkColor"> | ||||
| 
 | ||||
|             <include | ||||
|                 android:id="@+id/toolbar" | ||||
|                 layout="@layout/toolbar" | ||||
|  | @ -24,31 +25,27 @@ | |||
|                 android:id="@+id/tab_layout" | ||||
|                 android:layout_width="match_parent" | ||||
|                 android:layout_height="wrap_content" | ||||
|                 android:layout_below="@id/toolbar" | ||||
|                 android:background="?attr/tabBackground" | ||||
|                 app:tabIndicatorColor="?attr/tabIndicatorColor" | ||||
|                 app:tabSelectedTextColor="?attr/tabSelectedTextColor" | ||||
|                 app:tabTextColor="?attr/tabTextColor" | ||||
|                 app:tabMode="scrollable" | ||||
|                 android:layout_below="@id/toolbar" | ||||
|                 /> | ||||
|                 app:tabSelectedTextColor="?attr/tabSelectedTextColor" | ||||
|                 app:tabTextColor="?attr/tabTextColor" /> | ||||
|         </com.google.android.material.appbar.AppBarLayout> | ||||
| 
 | ||||
|         <FrameLayout | ||||
|             android:visibility="gone" | ||||
|             xmlns:android="http://schemas.android.com/apk/res/android" | ||||
|         <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||||
|             android:id="@+id/mediaContainer" | ||||
|             android:layout_width="match_parent" | ||||
|             android:layout_height="match_parent" | ||||
|             android:id="@+id/mediaContainer" | ||||
|             android:orientation="horizontal" | ||||
|             android:layout_below="@id/toolbar_layout" | ||||
|             /> | ||||
|             android:orientation="horizontal" | ||||
|             android:visibility="gone" /> | ||||
| 
 | ||||
|         <androidx.viewpager.widget.ViewPager | ||||
|             android:id="@+id/viewPager" | ||||
|             android:layout_width="match_parent" | ||||
|             android:layout_height="match_parent" | ||||
|             android:layout_below="@id/toolbar_layout" | ||||
|             /> | ||||
|             android:layout_below="@id/toolbar_layout" /> | ||||
|     </RelativeLayout> | ||||
| 
 | ||||
|     <com.google.android.material.navigation.NavigationView | ||||
|  | @ -57,6 +54,6 @@ | |||
|         android:layout_height="match_parent" | ||||
|         android:layout_gravity="start" | ||||
|         app:headerLayout="@layout/drawer_header" | ||||
|         app:menu="@menu/drawer"/> | ||||
|         app:menu="@menu/drawer" /> | ||||
| 
 | ||||
| </androidx.drawerlayout.widget.DrawerLayout> | ||||
							
								
								
									
										59
									
								
								app/src/main/res/layout/activity_explore.xml
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								app/src/main/res/layout/activity_explore.xml
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,59 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | ||||
| <androidx.drawerlayout.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||||
|     xmlns:app="http://schemas.android.com/apk/res-auto" | ||||
|     android:id="@+id/drawer_layout" | ||||
|     android:layout_width="match_parent" | ||||
|     android:layout_height="match_parent"> | ||||
| 
 | ||||
|     <RelativeLayout | ||||
|         android:layout_width="match_parent" | ||||
|         android:layout_height="match_parent"> | ||||
| 
 | ||||
|         <com.google.android.material.appbar.AppBarLayout | ||||
|             android:id="@+id/toolbar_layout" | ||||
|             android:layout_width="match_parent" | ||||
|             android:layout_height="wrap_content" | ||||
|             android:background="@color/primaryDarkColor"> | ||||
| 
 | ||||
|             <include | ||||
|                 android:id="@+id/toolbar" | ||||
|                 layout="@layout/toolbar" | ||||
|                 android:layout_width="match_parent" | ||||
|                 android:layout_height="wrap_content" /> | ||||
| 
 | ||||
|             <com.google.android.material.tabs.TabLayout | ||||
|                 android:id="@+id/tab_layout" | ||||
|                 android:layout_width="match_parent" | ||||
|                 android:layout_height="wrap_content" | ||||
|                 android:layout_below="@id/toolbar" | ||||
|                 android:background="?attr/tabBackground" | ||||
|                 app:tabIndicatorColor="?attr/tabIndicatorColor" | ||||
|                 app:tabMode="fixed" | ||||
|                 app:tabSelectedTextColor="?attr/tabSelectedTextColor" | ||||
|                 app:tabTextColor="?attr/tabTextColor" /> | ||||
|         </com.google.android.material.appbar.AppBarLayout> | ||||
| 
 | ||||
|         <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||||
|             android:id="@+id/mediaContainer" | ||||
|             android:layout_width="match_parent" | ||||
|             android:layout_height="match_parent" | ||||
|             android:layout_below="@id/toolbar_layout" | ||||
|             android:orientation="horizontal" | ||||
|             android:visibility="gone" /> | ||||
| 
 | ||||
|         <androidx.viewpager.widget.ViewPager | ||||
|             android:id="@+id/viewPager" | ||||
|             android:layout_width="match_parent" | ||||
|             android:layout_height="match_parent" | ||||
|             android:layout_below="@id/toolbar_layout" /> | ||||
|     </RelativeLayout> | ||||
| 
 | ||||
|     <com.google.android.material.navigation.NavigationView | ||||
|         android:id="@+id/navigation_view" | ||||
|         android:layout_width="wrap_content" | ||||
|         android:layout_height="match_parent" | ||||
|         android:layout_gravity="start" | ||||
|         app:headerLayout="@layout/drawer_header" | ||||
|         app:menu="@menu/drawer" /> | ||||
| 
 | ||||
| </androidx.drawerlayout.widget.DrawerLayout> | ||||
|  | @ -317,6 +317,8 @@ | |||
|   <string name="error_loading_subcategories">Error occurred while loading subcategories.</string> | ||||
|   <string name="search_tab_title_media">MEDIA</string> | ||||
|   <string name="search_tab_title_categories">CATEGORIES</string> | ||||
|   <string name="explore_tab_title_featured">FEATURED</string> | ||||
|   <string name="explore_tab_title_mobile">UPLOADED VIA MOBILE</string> | ||||
| 
 | ||||
|   <string name="successful_wikidata_edit">Image successfully added to %1$s on Wikidata!</string> | ||||
|   <string name="wikidata_edit_failure">Failed to update corresponding Wikidata entity!</string> | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Brenda Jerop
						Brenda Jerop