* Media Details UI changed - XML file * Onclicks added, design updated * Removed bookmark item from media detail menu * Update in XML
|  | @ -2,20 +2,24 @@ package fr.free.nrw.commons.media; | ||||||
| 
 | 
 | ||||||
| import android.annotation.SuppressLint; | import android.annotation.SuppressLint; | ||||||
| import android.app.AlertDialog; | import android.app.AlertDialog; | ||||||
|  | import android.app.DownloadManager; | ||||||
| import android.content.Intent; | import android.content.Intent; | ||||||
| import android.database.DataSetObserver; | import android.database.DataSetObserver; | ||||||
| import android.net.Uri; | import android.net.Uri; | ||||||
| import android.os.Bundle; | import android.os.Bundle; | ||||||
|  | import android.os.Environment; | ||||||
| import android.text.Editable; | import android.text.Editable; | ||||||
| import android.text.TextWatcher; | import android.text.TextWatcher; | ||||||
| import android.util.TypedValue; | import android.util.TypedValue; | ||||||
| import android.view.LayoutInflater; | import android.view.LayoutInflater; | ||||||
|  | import android.view.MenuItem; | ||||||
| import android.view.View; | import android.view.View; | ||||||
| import android.view.ViewGroup; | import android.view.ViewGroup; | ||||||
| import android.view.ViewTreeObserver; | import android.view.ViewTreeObserver; | ||||||
| import android.widget.ArrayAdapter; | import android.widget.ArrayAdapter; | ||||||
| import android.widget.Button; | import android.widget.Button; | ||||||
| import android.widget.EditText; | import android.widget.EditText; | ||||||
|  | import android.widget.ImageView; | ||||||
| import android.widget.LinearLayout; | import android.widget.LinearLayout; | ||||||
| import android.widget.ScrollView; | import android.widget.ScrollView; | ||||||
| import android.widget.Spinner; | import android.widget.Spinner; | ||||||
|  | @ -44,6 +48,9 @@ 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; | import fr.free.nrw.commons.Utils; | ||||||
|  | import fr.free.nrw.commons.bookmarks.Bookmark; | ||||||
|  | import fr.free.nrw.commons.bookmarks.pictures.BookmarkPicturesContentProvider; | ||||||
|  | import fr.free.nrw.commons.bookmarks.pictures.BookmarkPicturesDao; | ||||||
| import fr.free.nrw.commons.category.CategoryDetailsActivity; | import fr.free.nrw.commons.category.CategoryDetailsActivity; | ||||||
| import fr.free.nrw.commons.contributions.ContributionsFragment; | import fr.free.nrw.commons.contributions.ContributionsFragment; | ||||||
| import fr.free.nrw.commons.delete.DeleteHelper; | import fr.free.nrw.commons.delete.DeleteHelper; | ||||||
|  | @ -51,6 +58,9 @@ import fr.free.nrw.commons.delete.ReasonBuilder; | ||||||
| import fr.free.nrw.commons.di.CommonsDaggerSupportFragment; | import fr.free.nrw.commons.di.CommonsDaggerSupportFragment; | ||||||
| import fr.free.nrw.commons.ui.widget.CompatTextView; | import fr.free.nrw.commons.ui.widget.CompatTextView; | ||||||
| import fr.free.nrw.commons.ui.widget.HtmlTextView; | import fr.free.nrw.commons.ui.widget.HtmlTextView; | ||||||
|  | import fr.free.nrw.commons.utils.NetworkUtils; | ||||||
|  | import fr.free.nrw.commons.utils.PermissionUtils; | ||||||
|  | import fr.free.nrw.commons.utils.ViewUtil; | ||||||
| import fr.free.nrw.commons.utils.ViewUtilWrapper; | import fr.free.nrw.commons.utils.ViewUtilWrapper; | ||||||
| import io.reactivex.Single; | import io.reactivex.Single; | ||||||
| import io.reactivex.android.schedulers.AndroidSchedulers; | import io.reactivex.android.schedulers.AndroidSchedulers; | ||||||
|  | @ -61,6 +71,8 @@ import org.wikipedia.util.DateUtil; | ||||||
| import org.wikipedia.util.StringUtil; | import org.wikipedia.util.StringUtil; | ||||||
| import timber.log.Timber; | import timber.log.Timber; | ||||||
| 
 | 
 | ||||||
|  | import static android.Manifest.permission.WRITE_EXTERNAL_STORAGE; | ||||||
|  | import static android.content.Context.DOWNLOAD_SERVICE; | ||||||
| import static android.view.View.GONE; | import static android.view.View.GONE; | ||||||
| import static android.view.View.VISIBLE; | import static android.view.View.VISIBLE; | ||||||
| 
 | 
 | ||||||
|  | @ -97,8 +109,12 @@ public class MediaDetailFragment extends CommonsDaggerSupportFragment { | ||||||
|     DeleteHelper deleteHelper; |     DeleteHelper deleteHelper; | ||||||
|     @Inject |     @Inject | ||||||
|     ViewUtilWrapper viewUtil; |     ViewUtilWrapper viewUtil; | ||||||
|  |     @Inject | ||||||
|  |     BookmarkPicturesDao bookmarkDao; | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
|     private int initialListTop = 0; |     private int initialListTop = 0; | ||||||
|  |     private Bookmark bookmark; | ||||||
| 
 | 
 | ||||||
|     @BindView(R.id.mediaDetailImage) |     @BindView(R.id.mediaDetailImage) | ||||||
|     SimpleDraweeView image; |     SimpleDraweeView image; | ||||||
|  | @ -130,6 +146,8 @@ public class MediaDetailFragment extends CommonsDaggerSupportFragment { | ||||||
|     Button delete; |     Button delete; | ||||||
|     @BindView(R.id.mediaDetailScrollView) |     @BindView(R.id.mediaDetailScrollView) | ||||||
|     ScrollView scrollView; |     ScrollView scrollView; | ||||||
|  |     @BindView(R.id.iv_bookmark_icon) | ||||||
|  |     ImageView ivBookmarkIcon; | ||||||
| 
 | 
 | ||||||
|     private ArrayList<String> categoryNames; |     private ArrayList<String> categoryNames; | ||||||
|     private boolean categoriesLoaded = false; |     private boolean categoriesLoaded = false; | ||||||
|  | @ -276,6 +294,15 @@ public class MediaDetailFragment extends CommonsDaggerSupportFragment { | ||||||
|                 .observeOn(AndroidSchedulers.mainThread()) |                 .observeOn(AndroidSchedulers.mainThread()) | ||||||
|                 .subscribe(this::setTextFields); |                 .subscribe(this::setTextFields); | ||||||
|         compositeDisposable.add(disposable); |         compositeDisposable.add(disposable); | ||||||
|  | 
 | ||||||
|  |         // Initialize bookmark object | ||||||
|  |         bookmark = new Bookmark( | ||||||
|  |                 media.getFilename(), | ||||||
|  |                 media.getCreator(), | ||||||
|  |                 BookmarkPicturesContentProvider.uriForName(media.getFilename()) | ||||||
|  |         ); | ||||||
|  |         updateBookmarkState(); | ||||||
|  | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  | @ -445,6 +472,82 @@ public class MediaDetailFragment extends CommonsDaggerSupportFragment { | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @OnClick(R.id.ll_bookmark) | ||||||
|  |     public void onBookMarkClick(){ | ||||||
|  |         bookmarkDao.updateBookmark(bookmark); | ||||||
|  |         updateBookmarkState(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void updateBookmarkState() { | ||||||
|  |         boolean isBookmarked = bookmarkDao.findBookmark(bookmark); | ||||||
|  |         int icon = isBookmarked ? R.drawable.ic_star_filled_primary_dark_24dp : R.drawable.ic_star_border_primary_dark_24dp; | ||||||
|  |         ivBookmarkIcon.setImageResource(icon); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @OnClick(R.id.ll_share) | ||||||
|  |     public void onShareClick(){ | ||||||
|  |         Intent shareIntent = new Intent(Intent.ACTION_SEND); | ||||||
|  |         shareIntent.setType("text/plain"); | ||||||
|  |         shareIntent.putExtra(Intent.EXTRA_TEXT, media.getDisplayTitle() + " \n" + media.getPageTitle().getCanonicalUri()); | ||||||
|  |         startActivity(Intent.createChooser(shareIntent, "Share image via...")); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @OnClick(R.id.ll_download) | ||||||
|  |     public void onDownloadClick(){ | ||||||
|  |         if (!NetworkUtils.isInternetConnectionEstablished(getActivity())) { | ||||||
|  |             ViewUtil.showShortSnackbar(getView(), R.string.no_internet); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         downloadMedia(media); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Start the media file downloading to the local SD card/storage. | ||||||
|  |      * The file can then be opened in Gallery or other apps. | ||||||
|  |      * | ||||||
|  |      * @param m Media file to download | ||||||
|  |      */ | ||||||
|  |     private void downloadMedia(Media m) { | ||||||
|  |         String imageUrl = m.getImageUrl(), fileName = m.getFilename(); | ||||||
|  | 
 | ||||||
|  |         if (imageUrl == null | ||||||
|  |                 || fileName == null | ||||||
|  |                 || getContext() ==  null | ||||||
|  |                 || getActivity() == null) { | ||||||
|  |             Timber.d("Skipping download media as either imageUrl %s or filename %s activity is null", imageUrl, fileName); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // Strip 'File:' from beginning of filename, we really shouldn't store it | ||||||
|  |         fileName = fileName.replaceFirst("^File:", ""); | ||||||
|  | 
 | ||||||
|  |         Uri imageUri = Uri.parse(imageUrl); | ||||||
|  | 
 | ||||||
|  |         DownloadManager.Request req = new DownloadManager.Request(imageUri); | ||||||
|  |         //These are not the image title and description fields, they are download descs for notifications | ||||||
|  |         req.setDescription(getString(R.string.app_name)); | ||||||
|  |         req.setTitle(m.getDisplayTitle()); | ||||||
|  |         req.setDestinationInExternalPublicDir(Environment.DIRECTORY_DOWNLOADS, fileName); | ||||||
|  | 
 | ||||||
|  |         // Modern Android updates the gallery automatically. Yay! | ||||||
|  |         req.allowScanningByMediaScanner(); | ||||||
|  |         req.setNotificationVisibility(DownloadManager.Request.VISIBILITY_VISIBLE_NOTIFY_COMPLETED); | ||||||
|  |         PermissionUtils.checkPermissionsAndPerformAction(getActivity(), WRITE_EXTERNAL_STORAGE, | ||||||
|  |                 () -> enqueueRequest(req), () -> Toast.makeText(getContext(), | ||||||
|  |                         R.string.download_failed_we_cannot_download_the_file_without_storage_permission, | ||||||
|  |                         Toast.LENGTH_SHORT).show(), R.string.storage_permission, | ||||||
|  |                 R.string.write_storage_permission_rationale); | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void enqueueRequest(DownloadManager.Request req) { | ||||||
|  |         DownloadManager systemService = | ||||||
|  |                 (DownloadManager) getActivity().getSystemService(DOWNLOAD_SERVICE); | ||||||
|  |         if (systemService != null) { | ||||||
|  |             systemService.enqueue(req); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @OnClick(R.id.seeMore) |     @OnClick(R.id.seeMore) | ||||||
|     public void onSeeMoreClicked(){ |     public void onSeeMoreClicked(){ | ||||||
|         if (nominatedForDeletion.getVisibility() == VISIBLE && getActivity() != null) { |         if (nominatedForDeletion.getVisibility() == VISIBLE && getActivity() != null) { | ||||||
|  |  | ||||||
|  | @ -41,13 +41,8 @@ import fr.free.nrw.commons.explore.categories.ExploreActivity; | ||||||
| import fr.free.nrw.commons.kvstore.JsonKvStore; | import fr.free.nrw.commons.kvstore.JsonKvStore; | ||||||
| import fr.free.nrw.commons.mwapi.MediaWikiApi; | import fr.free.nrw.commons.mwapi.MediaWikiApi; | ||||||
| import fr.free.nrw.commons.utils.ImageUtils; | import fr.free.nrw.commons.utils.ImageUtils; | ||||||
| import fr.free.nrw.commons.utils.NetworkUtils; |  | ||||||
| import fr.free.nrw.commons.utils.PermissionUtils; |  | ||||||
| import fr.free.nrw.commons.utils.ViewUtil; |  | ||||||
| import timber.log.Timber; | import timber.log.Timber; | ||||||
| 
 | 
 | ||||||
| import static android.Manifest.permission.WRITE_EXTERNAL_STORAGE; |  | ||||||
| import static android.content.Context.DOWNLOAD_SERVICE; |  | ||||||
| import static fr.free.nrw.commons.Utils.handleWebUrl; | import static fr.free.nrw.commons.Utils.handleWebUrl; | ||||||
| 
 | 
 | ||||||
| public class MediaDetailPagerFragment extends CommonsDaggerSupportFragment implements ViewPager.OnPageChangeListener { | public class MediaDetailPagerFragment extends CommonsDaggerSupportFragment implements ViewPager.OnPageChangeListener { | ||||||
|  | @ -55,13 +50,11 @@ public class MediaDetailPagerFragment extends CommonsDaggerSupportFragment imple | ||||||
|     @Inject MediaWikiApi mwApi; |     @Inject MediaWikiApi mwApi; | ||||||
|     @Inject SessionManager sessionManager; |     @Inject SessionManager sessionManager; | ||||||
|     @Inject @Named("default_preferences") JsonKvStore store; |     @Inject @Named("default_preferences") JsonKvStore store; | ||||||
|     @Inject BookmarkPicturesDao bookmarkDao; |  | ||||||
| 
 | 
 | ||||||
|     @BindView(R.id.mediaDetailsPager) ViewPager pager; |     @BindView(R.id.mediaDetailsPager) ViewPager pager; | ||||||
|     private Boolean editable; |     private Boolean editable; | ||||||
|     private boolean isFeaturedImage; |     private boolean isFeaturedImage; | ||||||
|     MediaDetailAdapter adapter; |     MediaDetailAdapter adapter; | ||||||
|     private Bookmark bookmark; |  | ||||||
|     private MediaDetailProvider provider; |     private MediaDetailProvider provider; | ||||||
| 
 | 
 | ||||||
|     public MediaDetailPagerFragment() { |     public MediaDetailPagerFragment() { | ||||||
|  | @ -157,28 +150,10 @@ public class MediaDetailPagerFragment extends CommonsDaggerSupportFragment imple | ||||||
| 
 | 
 | ||||||
|         Media m = provider.getMediaAtPosition(pager.getCurrentItem()); |         Media m = provider.getMediaAtPosition(pager.getCurrentItem()); | ||||||
|         switch (item.getItemId()) { |         switch (item.getItemId()) { | ||||||
|             case R.id.menu_bookmark_current_image: |  | ||||||
|                 bookmarkDao.updateBookmark(bookmark); |  | ||||||
|                 updateBookmarkState(item); |  | ||||||
|                 return true; |  | ||||||
|             case R.id.menu_share_current_image: |  | ||||||
|                 Intent shareIntent = new Intent(Intent.ACTION_SEND); |  | ||||||
|                 shareIntent.setType("text/plain"); |  | ||||||
|                 shareIntent.putExtra(Intent.EXTRA_TEXT, m.getDisplayTitle() + " \n" + m.getPageTitle().getCanonicalUri()); |  | ||||||
|                 startActivity(Intent.createChooser(shareIntent, "Share image via...")); |  | ||||||
|                 return true; |  | ||||||
|             case R.id.menu_browser_current_image: |             case R.id.menu_browser_current_image: | ||||||
|                 // View in browser |                 // View in browser | ||||||
|                 handleWebUrl(requireContext(), Uri.parse(m.getPageTitle().getMobileUri())); |                 handleWebUrl(requireContext(), Uri.parse(m.getPageTitle().getMobileUri())); | ||||||
|                 return true; |                 return true; | ||||||
|             case R.id.menu_download_current_image: |  | ||||||
|                 // Download |  | ||||||
|                 if (!NetworkUtils.isInternetConnectionEstablished(getActivity())) { |  | ||||||
|                     ViewUtil.showShortSnackbar(getView(), R.string.no_internet); |  | ||||||
|                     return false; |  | ||||||
|                 } |  | ||||||
|                 downloadMedia(m); |  | ||||||
|                 return true; |  | ||||||
|             case R.id.menu_set_as_wallpaper: |             case R.id.menu_set_as_wallpaper: | ||||||
|                 // Set wallpaper |                 // Set wallpaper | ||||||
|                 setWallpaper(m); |                 setWallpaper(m); | ||||||
|  | @ -201,52 +176,6 @@ public class MediaDetailPagerFragment extends CommonsDaggerSupportFragment imple | ||||||
|         ImageUtils.setWallpaperFromImageUrl(getActivity(), Uri.parse(media.getImageUrl())); |         ImageUtils.setWallpaperFromImageUrl(getActivity(), Uri.parse(media.getImageUrl())); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * Start the media file downloading to the local SD card/storage. |  | ||||||
|      * The file can then be opened in Gallery or other apps. |  | ||||||
|      * |  | ||||||
|      * @param m Media file to download |  | ||||||
|      */ |  | ||||||
|     private void downloadMedia(Media m) { |  | ||||||
|         String imageUrl = m.getImageUrl(), fileName = m.getFilename(); |  | ||||||
| 
 |  | ||||||
|         if (imageUrl == null |  | ||||||
|                 || fileName == null |  | ||||||
|                 || getContext() ==  null |  | ||||||
|                 || getActivity() == null) { |  | ||||||
|             Timber.d("Skipping download media as either imageUrl %s or filename %s activity is null", imageUrl, fileName); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // Strip 'File:' from beginning of filename, we really shouldn't store it |  | ||||||
|         fileName = fileName.replaceFirst("^File:", ""); |  | ||||||
| 
 |  | ||||||
|         Uri imageUri = Uri.parse(imageUrl); |  | ||||||
| 
 |  | ||||||
|         DownloadManager.Request req = new DownloadManager.Request(imageUri); |  | ||||||
|         //These are not the image title and description fields, they are download descs for notifications |  | ||||||
|         req.setDescription(getString(R.string.app_name)); |  | ||||||
|         req.setTitle(m.getDisplayTitle()); |  | ||||||
|         req.setDestinationInExternalPublicDir(Environment.DIRECTORY_DOWNLOADS, fileName); |  | ||||||
| 
 |  | ||||||
|         // Modern Android updates the gallery automatically. Yay! |  | ||||||
|         req.allowScanningByMediaScanner(); |  | ||||||
|         req.setNotificationVisibility(DownloadManager.Request.VISIBILITY_VISIBLE_NOTIFY_COMPLETED); |  | ||||||
|         PermissionUtils.checkPermissionsAndPerformAction(getActivity(), WRITE_EXTERNAL_STORAGE, |  | ||||||
|             () -> enqueueRequest(req), () -> Toast.makeText(getContext(), |  | ||||||
|                 R.string.download_failed_we_cannot_download_the_file_without_storage_permission, |  | ||||||
|                 Toast.LENGTH_SHORT).show(), R.string.storage_permission, |  | ||||||
|             R.string.write_storage_permission_rationale); |  | ||||||
| 
 |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     private void enqueueRequest(DownloadManager.Request req) { |  | ||||||
|         DownloadManager systemService = |  | ||||||
|             (DownloadManager) getActivity().getSystemService(DOWNLOAD_SERVICE); |  | ||||||
|         if (systemService != null) { |  | ||||||
|             systemService.enqueue(req); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { |     public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { | ||||||
|  | @ -263,33 +192,16 @@ public class MediaDetailPagerFragment extends CommonsDaggerSupportFragment imple | ||||||
|                 if (m != null) { |                 if (m != null) { | ||||||
|                     // Enable default set of actions, then re-enable different set of actions only if it is a failed contrib |                     // Enable default set of actions, then re-enable different set of actions only if it is a failed contrib | ||||||
|                     menu.findItem(R.id.menu_browser_current_image).setEnabled(true).setVisible(true); |                     menu.findItem(R.id.menu_browser_current_image).setEnabled(true).setVisible(true); | ||||||
|                     menu.findItem(R.id.menu_share_current_image).setEnabled(true).setVisible(true); |  | ||||||
|                     menu.findItem(R.id.menu_download_current_image).setEnabled(true).setVisible(true); |  | ||||||
|                     menu.findItem(R.id.menu_bookmark_current_image).setEnabled(true).setVisible(true); |  | ||||||
| 
 |  | ||||||
|                     // Initialize bookmark object |  | ||||||
|                     bookmark = new Bookmark( |  | ||||||
|                             m.getFilename(), |  | ||||||
|                             m.getCreator(), |  | ||||||
|                             BookmarkPicturesContentProvider.uriForName(m.getFilename()) |  | ||||||
|                     ); |  | ||||||
|                     updateBookmarkState(menu.findItem(R.id.menu_bookmark_current_image)); |  | ||||||
| 
 | 
 | ||||||
|                     if (m instanceof Contribution ) { |                     if (m instanceof Contribution ) { | ||||||
|                         Contribution c = (Contribution) m; |                         Contribution c = (Contribution) m; | ||||||
|                         switch (c.getState()) { |                         switch (c.getState()) { | ||||||
|                             case Contribution.STATE_FAILED: |                             case Contribution.STATE_FAILED: | ||||||
|                                 menu.findItem(R.id.menu_browser_current_image).setEnabled(false).setVisible(false); |                                 menu.findItem(R.id.menu_browser_current_image).setEnabled(false).setVisible(false); | ||||||
|                                 menu.findItem(R.id.menu_share_current_image).setEnabled(false).setVisible(false); |  | ||||||
|                                 menu.findItem(R.id.menu_download_current_image).setEnabled(false).setVisible(false); |  | ||||||
|                                 menu.findItem(R.id.menu_bookmark_current_image).setEnabled(false).setVisible(false); |  | ||||||
|                                 break; |                                 break; | ||||||
|                             case Contribution.STATE_IN_PROGRESS: |                             case Contribution.STATE_IN_PROGRESS: | ||||||
|                             case Contribution.STATE_QUEUED: |                             case Contribution.STATE_QUEUED: | ||||||
|                                 menu.findItem(R.id.menu_browser_current_image).setEnabled(false).setVisible(false); |                                 menu.findItem(R.id.menu_browser_current_image).setEnabled(false).setVisible(false); | ||||||
|                                 menu.findItem(R.id.menu_share_current_image).setEnabled(false).setVisible(false); |  | ||||||
|                                 menu.findItem(R.id.menu_download_current_image).setEnabled(false).setVisible(false); |  | ||||||
|                                 menu.findItem(R.id.menu_bookmark_current_image).setEnabled(false).setVisible(false); |  | ||||||
|                                 break; |                                 break; | ||||||
|                             case Contribution.STATE_COMPLETED: |                             case Contribution.STATE_COMPLETED: | ||||||
|                                 // Default set of menu items works fine. Treat same as regular media object |                                 // Default set of menu items works fine. Treat same as regular media object | ||||||
|  | @ -301,12 +213,6 @@ public class MediaDetailPagerFragment extends CommonsDaggerSupportFragment imple | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void updateBookmarkState(MenuItem item) { |  | ||||||
|         boolean isBookmarked = bookmarkDao.findBookmark(bookmark); |  | ||||||
|         int icon = isBookmarked ? R.drawable.ic_round_star_filled_24px : R.drawable.ic_round_star_border_24px; |  | ||||||
|         item.setIcon(icon); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void showImage(int i) { |     public void showImage(int i) { | ||||||
|         Handler handler =  new Handler(); |         Handler handler =  new Handler(); | ||||||
|         handler.postDelayed(() -> pager.setCurrentItem(i), 5); |         handler.postDelayed(() -> pager.setCurrentItem(i), 5); | ||||||
|  |  | ||||||
| After Width: | Height: | Size: 300 B | 
| After Width: | Height: | Size: 638 B | 
| After Width: | Height: | Size: 459 B | 
| After Width: | Height: | Size: 216 B | 
| After Width: | Height: | Size: 409 B | 
| After Width: | Height: | Size: 306 B | 
| After Width: | Height: | Size: 341 B | 
| After Width: | Height: | Size: 827 B | 
| After Width: | Height: | Size: 593 B | 
| After Width: | Height: | Size: 467 B | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 878 B | 
| After Width: | Height: | Size: 532 B | 
| After Width: | Height: | Size: 1.6 KiB | 
| After Width: | Height: | Size: 1.2 KiB | 
|  | @ -9,12 +9,9 @@ | ||||||
|         <shape |         <shape | ||||||
|             android:shape="rectangle"> |             android:shape="rectangle"> | ||||||
|             <solid |             <solid | ||||||
|                 android:color="@color/deleteButton"/> |                 android:color="@color/deleteRed"/> | ||||||
|             <corners |             <corners | ||||||
|                 android:radius="3dp" /> |                 android:radius="2dp" /> | ||||||
|             <stroke |  | ||||||
|                 android:width="5px" |  | ||||||
|                 android:color="@color/deleteRed" /> |  | ||||||
|         </shape> |         </shape> | ||||||
|     </item> |     </item> | ||||||
| 
 | 
 | ||||||
|  | @ -25,7 +22,7 @@ | ||||||
|             <solid |             <solid | ||||||
|                 android:color="@color/deleteButtonDark"/> |                 android:color="@color/deleteButtonDark"/> | ||||||
|             <corners |             <corners | ||||||
|                 android:radius="3dp" /> |                 android:radius="2dp" /> | ||||||
|         </shape> |         </shape> | ||||||
|     </item> |     </item> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										18
									
								
								app/src/main/res/drawable/copy_to_wikitext_button.xml
									
										
									
									
									
										Normal file
									
								
							
							
						
						|  | @ -0,0 +1,18 @@ | ||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <selector | ||||||
|  |     android:layout_height="match_parent" | ||||||
|  |     android:layout_width="match_parent" | ||||||
|  |     xmlns:android="http://schemas.android.com/apk/res/android"> | ||||||
|  | 
 | ||||||
|  |     <item | ||||||
|  |         android:state_enabled="true" > | ||||||
|  |         <shape | ||||||
|  |             android:shape="rectangle"> | ||||||
|  |             <solid | ||||||
|  |                 android:color="@color/button_blue"/> | ||||||
|  |             <corners | ||||||
|  |                 android:radius="2dp" /> | ||||||
|  |         </shape> | ||||||
|  |     </item> | ||||||
|  | 
 | ||||||
|  | </selector> | ||||||
|  | @ -0,0 +1,4 @@ | ||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <vector xmlns:android="http://schemas.android.com/apk/res/android" android:height="24dp" android:viewportHeight="24.0" android:viewportWidth="24.0" android:width="24dp"> | ||||||
|  |     <path android:fillColor="#00376d" android:pathData="M19,9h-4V3H9v6H5l7,7 7,-7zM5,18v2h14v-2H5z"/> | ||||||
|  | </vector> | ||||||
							
								
								
									
										4
									
								
								app/src/main/res/drawable/ic_share_primary_dark_24dp.xml
									
										
									
									
									
										Normal file
									
								
							
							
						
						|  | @ -0,0 +1,4 @@ | ||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <vector xmlns:android="http://schemas.android.com/apk/res/android" android:height="24dp" android:viewportHeight="24.0" android:viewportWidth="24.0" android:width="24dp"> | ||||||
|  |     <path android:fillColor="#00376d" android:pathData="M18,16.08c-0.76,0 -1.44,0.3 -1.96,0.77L8.91,12.7c0.05,-0.23 0.09,-0.46 0.09,-0.7s-0.04,-0.47 -0.09,-0.7l7.05,-4.11c0.54,0.5 1.25,0.81 2.04,0.81 1.66,0 3,-1.34 3,-3s-1.34,-3 -3,-3 -3,1.34 -3,3c0,0.24 0.04,0.47 0.09,0.7L8.04,9.81C7.5,9.31 6.79,9 6,9c-1.66,0 -3,1.34 -3,3s1.34,3 3,3c0.79,0 1.5,-0.31 2.04,-0.81l7.12,4.16c-0.05,0.21 -0.08,0.43 -0.08,0.65 0,1.61 1.31,2.92 2.92,2.92 1.61,0 2.92,-1.31 2.92,-2.92s-1.31,-2.92 -2.92,-2.92z"/> | ||||||
|  | </vector> | ||||||
|  | @ -13,12 +13,9 @@ | ||||||
|         android:background="?attr/subBackground" |         android:background="?attr/subBackground" | ||||||
|         android:foreground="?attr/selectableItemBackground" |         android:foreground="?attr/selectableItemBackground" | ||||||
|         android:gravity="center_vertical" |         android:gravity="center_vertical" | ||||||
|         android:minHeight="@dimen/overflow_button_dimen" |         android:textColor="@color/linkColor" | ||||||
|         android:padding="@dimen/quarter_standard_height" |         android:paddingBottom="@dimen/small_gap" | ||||||
|         android:textColor="@android:color/white" |  | ||||||
|         android:textSize="@dimen/description_text_size" |         android:textSize="@dimen/description_text_size" | ||||||
|         app:drawablePadding="@dimen/small_gap" |  | ||||||
|         app:drawableStart="@drawable/ic_info_outline_24dp" |  | ||||||
|         /> |         /> | ||||||
| 
 | 
 | ||||||
| </LinearLayout> | </LinearLayout> | ||||||
|  |  | ||||||
|  | @ -8,6 +8,12 @@ | ||||||
|     android:background="?attr/mainBackground" |     android:background="?attr/mainBackground" | ||||||
|     > |     > | ||||||
| 
 | 
 | ||||||
|  |     <fr.free.nrw.commons.media.MediaDetailSpacer | ||||||
|  |         android:id="@+id/mediaDetailSpacer" | ||||||
|  |         android:layout_width="match_parent" | ||||||
|  |         android:layout_height="@dimen/standard_gap" /> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|     <ImageView |     <ImageView | ||||||
|         android:id="@+id/mediaDetailImageFailed" |         android:id="@+id/mediaDetailImageFailed" | ||||||
|         android:layout_height="wrap_content" |         android:layout_height="wrap_content" | ||||||
|  | @ -18,13 +24,6 @@ | ||||||
|         android:contentDescription="@string/mediaimage_failed" |         android:contentDescription="@string/mediaimage_failed" | ||||||
|         /> |         /> | ||||||
| 
 | 
 | ||||||
|     <com.facebook.drawee.view.SimpleDraweeView |  | ||||||
|         android:id="@+id/mediaDetailImage" |  | ||||||
|         android:layout_width="match_parent" |  | ||||||
|         android:layout_height="match_parent" |  | ||||||
|         app:actualImageScaleType="centerCrop" |  | ||||||
|         /> |  | ||||||
| 
 |  | ||||||
|     <ScrollView |     <ScrollView | ||||||
|         android:id="@+id/mediaDetailScrollView" |         android:id="@+id/mediaDetailScrollView" | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|  | @ -35,256 +34,393 @@ | ||||||
| 
 | 
 | ||||||
|         <LinearLayout |         <LinearLayout | ||||||
|             android:layout_width="match_parent" |             android:layout_width="match_parent" | ||||||
|             android:layout_height="wrap_content" |             android:background="@color/white" | ||||||
|  |             android:layout_height="match_parent" | ||||||
|             android:orientation="vertical"> |             android:orientation="vertical"> | ||||||
| 
 | 
 | ||||||
|             <!-- Placeholder. Height gets set at runtime based on container size; the initial value is a hack to keep | 
 | ||||||
|                  the detail info offscreen until it's placed properly. May be a better way to do this. --> |             <com.facebook.drawee.view.SimpleDraweeView | ||||||
|             <fr.free.nrw.commons.media.MediaDetailSpacer |                 android:id="@+id/mediaDetailImage" | ||||||
|                 android:id="@+id/mediaDetailSpacer" |  | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                 android:layout_height="@dimen/standard_gap" /> |                 android:layout_height="wrap_content" | ||||||
|  |                 android:adjustViewBounds="true" | ||||||
|  |                 android:scaleType="fitXY" | ||||||
|  |                 /> | ||||||
| 
 | 
 | ||||||
|             <LinearLayout |             <LinearLayout | ||||||
|  |                 android:padding="@dimen/standard_gap" | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                 android:layout_height="wrap_content" |                 android:layout_height="wrap_content" | ||||||
|                 android:background="?attr/fragmentCategorisationBackground" |                 android:background="@color/primaryDarkColor" | ||||||
|                 android:orientation="vertical" |                 > | ||||||
|                 android:padding="@dimen/standard_gap"> |  | ||||||
| 
 |  | ||||||
|                 <LinearLayout |  | ||||||
|                     android:layout_width="match_parent" |  | ||||||
|                     android:layout_height="wrap_content" |  | ||||||
|                     android:background="?attr/subBackground" |  | ||||||
|                     android:orientation="vertical" |  | ||||||
|                     android:padding="@dimen/standard_gap"> |  | ||||||
| 
 |  | ||||||
|                     <TextView |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:paddingBottom="@dimen/tiny_gap" |  | ||||||
|                         android:text="@string/media_detail_title" |  | ||||||
|                         android:textColor="@android:color/white" |  | ||||||
|                         android:textSize="@dimen/normal_text" |  | ||||||
|                         android:textStyle="bold" /> |  | ||||||
| 
 | 
 | ||||||
|                 <TextView |                 <TextView | ||||||
|                     android:id="@+id/mediaDetailTitle" |                     android:id="@+id/mediaDetailTitle" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|  |                     android:textColor="@color/white" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                         android:layout_gravity="start" |                     android:text="@string/media_detail_title" | ||||||
|                         android:background="?attr/subBackground" |                     /> | ||||||
|                         android:padding="@dimen/small_gap" |             </LinearLayout> | ||||||
|                         android:textColor="@android:color/white" |             <LinearLayout | ||||||
|                         android:textSize="@dimen/description_text_size" |                 android:id="@+id/ll_bookmark" | ||||||
|                         tools:text="Title of the media" /> |                 android:layout_width="match_parent" | ||||||
|  |                 android:layout_height="wrap_content" | ||||||
|  |                 android:background="@color/white" | ||||||
|  |                 android:orientation="horizontal" | ||||||
|  |                 android:weightSum="3" | ||||||
|  |                 > | ||||||
|  | 
 | ||||||
|  |                 <LinearLayout | ||||||
|  |                     android:layout_weight="1" | ||||||
|  |                     android:layout_width="0dp" | ||||||
|  |                     android:orientation="vertical" | ||||||
|  |                     android:layout_gravity="center" | ||||||
|  |                     android:gravity="center" | ||||||
|  |                     android:padding="@dimen/standard_gap" | ||||||
|  |                     android:layout_height="wrap_content"> | ||||||
|  | 
 | ||||||
|  |                     <ImageView | ||||||
|  |                         android:id="@+id/iv_bookmark_icon" | ||||||
|  |                         android:layout_width="24dp" | ||||||
|  |                         android:layout_height="24dp" | ||||||
|  |                         android:background="@drawable/ic_star_border_primary_dark_24dp"/> | ||||||
|  | 
 | ||||||
|  |                     <TextView | ||||||
|  |                         android:gravity="center" | ||||||
|  |                         android:layout_width="match_parent" | ||||||
|  |                         android:layout_height="wrap_content" | ||||||
|  |                         android:text="BOOKMARK" | ||||||
|  |                         android:textColor="@color/primaryDarkColor" | ||||||
|  |                         /> | ||||||
|  | 
 | ||||||
|  |                 </LinearLayout> | ||||||
|  |                 <LinearLayout | ||||||
|  |                     android:id="@+id/ll_download" | ||||||
|  |                     android:layout_weight="1" | ||||||
|  |                     android:layout_width="0dp" | ||||||
|  |                     android:orientation="vertical" | ||||||
|  |                     android:layout_gravity="center" | ||||||
|  |                     android:gravity="center" | ||||||
|  |                     android:layout_height="wrap_content"> | ||||||
|  | 
 | ||||||
|  |                     <ImageView | ||||||
|  |                         android:layout_width="24dp" | ||||||
|  |                         android:layout_height="24dp" | ||||||
|  |                         android:background="@drawable/ic_file_download_primary_dark_24dp"/> | ||||||
|  | 
 | ||||||
|  |                     <TextView | ||||||
|  |                         android:gravity="center" | ||||||
|  |                         android:layout_width="match_parent" | ||||||
|  |                         android:layout_height="wrap_content" | ||||||
|  |                         android:text="DOWNLOAD" | ||||||
|  |                         android:textColor="@color/primaryDarkColor" | ||||||
|  |                         /> | ||||||
|  | 
 | ||||||
|  |                 </LinearLayout> | ||||||
|  |                 <LinearLayout | ||||||
|  |                     android:id="@+id/ll_share" | ||||||
|  |                     android:layout_weight="1" | ||||||
|  |                     android:layout_width="0dp" | ||||||
|  |                     android:orientation="vertical" | ||||||
|  |                     android:layout_gravity="center" | ||||||
|  |                     android:gravity="center" | ||||||
|  |                     android:layout_height="wrap_content"> | ||||||
|  | 
 | ||||||
|  |                     <ImageView | ||||||
|  |                         android:layout_width="24dp" | ||||||
|  |                         android:layout_height="24dp" | ||||||
|  |                         android:background="@drawable/ic_share_primary_dark_24dp"/> | ||||||
|  | 
 | ||||||
|  |                     <TextView | ||||||
|  |                         android:gravity="center" | ||||||
|  |                         android:layout_width="match_parent" | ||||||
|  |                         android:layout_height="wrap_content" | ||||||
|  |                         android:text="SHARE" | ||||||
|  |                         android:textColor="@color/primaryDarkColor" | ||||||
|  |                         /> | ||||||
|  | 
 | ||||||
|                 </LinearLayout> |                 </LinearLayout> | ||||||
| 
 | 
 | ||||||
|                 <fr.free.nrw.commons.media.MediaDetailSpacer |             </LinearLayout> | ||||||
|  | 
 | ||||||
|  |             <View | ||||||
|  |                 android:background="@color/divider_grey" | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                     android:layout_height="@dimen/small_gap" /> |                 android:layout_height="2dp"/> | ||||||
| 
 | 
 | ||||||
|             <LinearLayout |             <LinearLayout | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                 android:weightSum="10" | ||||||
|                     android:id="@+id/authorLinearLayout" |                 android:paddingLeft="@dimen/standard_gap" | ||||||
|                     android:background="?attr/subBackground" |                 android:paddingRight="@dimen/standard_gap" | ||||||
|                     android:orientation="vertical" |                 android:paddingTop="@dimen/small_gap" | ||||||
|                     android:padding="@dimen/standard_gap"> |                 android:paddingBottom="@dimen/small_gap" | ||||||
|  |                 android:orientation="horizontal" | ||||||
|  |                 android:layout_height="wrap_content"> | ||||||
| 
 | 
 | ||||||
|                 <TextView |                 <TextView | ||||||
|                         android:layout_width="match_parent" |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="10" | ||||||
|  |                     android:textStyle="bold" | ||||||
|  |                     android:textColor="@color/black" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                         android:paddingBottom="@dimen/tiny_gap" |  | ||||||
|                         android:text="@string/media_detail_author" |  | ||||||
|                         android:textColor="@android:color/white" |  | ||||||
|                         android:textSize="@dimen/normal_text" |  | ||||||
|                         android:textStyle="bold" /> |  | ||||||
| 
 |  | ||||||
|                     <TextView |  | ||||||
|                         android:id="@+id/mediaDetailAuthor" |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:layout_gravity="start" |  | ||||||
|                         android:background="?attr/subBackground" |  | ||||||
|                         android:padding="@dimen/small_gap" |  | ||||||
|                         android:textColor="@android:color/white" |  | ||||||
|                         android:textSize="@dimen/description_text_size" |  | ||||||
|                         tools:text="Media author user name goes here." /> |  | ||||||
|                 </LinearLayout> |  | ||||||
| 
 |  | ||||||
|                 <fr.free.nrw.commons.media.MediaDetailSpacer |  | ||||||
|                     android:layout_width="match_parent" |  | ||||||
|                     android:layout_height="@dimen/small_gap" /> |  | ||||||
| 
 |  | ||||||
|                 <LinearLayout |  | ||||||
|                     android:layout_width="match_parent" |  | ||||||
|                     android:layout_height="wrap_content" |  | ||||||
|                     android:background="?attr/subBackground" |  | ||||||
|                     android:orientation="vertical" |  | ||||||
|                     android:padding="@dimen/standard_gap"> |  | ||||||
| 
 |  | ||||||
|                     <TextView |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:paddingBottom="@dimen/tiny_gap" |  | ||||||
|                     android:text="@string/media_detail_description" |                     android:text="@string/media_detail_description" | ||||||
|                         android:textColor="@android:color/white" |                     /> | ||||||
|                         android:textSize="@dimen/normal_text" | 
 | ||||||
|                         android:textStyle="bold" /> |                 <ImageView | ||||||
|  |                     android:src="@drawable/ic_mode_edit_primary_dark_24dp" | ||||||
|  |                     android:layout_width="@dimen/half_standard_height" | ||||||
|  |                     android:layout_height="@dimen/half_standard_height" /> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |             </LinearLayout> | ||||||
| 
 | 
 | ||||||
|             <fr.free.nrw.commons.ui.widget.HtmlTextView |             <fr.free.nrw.commons.ui.widget.HtmlTextView | ||||||
|  |                 android:paddingLeft="@dimen/standard_gap" | ||||||
|  |                 android:paddingRight="@dimen/standard_gap" | ||||||
|  |                 android:paddingBottom="@dimen/standard_gap" | ||||||
|                 android:id="@+id/mediaDetailDesc" |                 android:id="@+id/mediaDetailDesc" | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                 android:layout_height="wrap_content" |                 android:layout_height="wrap_content" | ||||||
|                 android:layout_gravity="start" |                 android:layout_gravity="start" | ||||||
|  |                 android:lineSpacingMultiplier="1.2" | ||||||
|                 android:background="?attr/subBackground" |                 android:background="?attr/subBackground" | ||||||
|                         android:padding="@dimen/small_gap" |                 android:textColor="@color/black" | ||||||
|                         android:textColor="@android:color/white" |  | ||||||
|                 android:textSize="@dimen/description_text_size" |                 android:textSize="@dimen/description_text_size" | ||||||
|                 tools:text="Description of the media goes here. This can potentially be fairly long, and will need to wrap across multiple lines. We hope it looks nice though." /> |                 tools:text="Description of the media goes here. This can potentially be fairly long, and will need to wrap across multiple lines. We hope it looks nice though." /> | ||||||
|                 </LinearLayout> |  | ||||||
| 
 | 
 | ||||||
|                 <fr.free.nrw.commons.media.MediaDetailSpacer |             <View | ||||||
|  |                 android:background="@color/divider_grey" | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                     android:layout_height="@dimen/small_gap" /> |                 android:layout_height="2dp"/> | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
|             <LinearLayout |             <LinearLayout | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                 android:weightSum="10" | ||||||
|                     android:background="?attr/subBackground" |                 android:paddingLeft="@dimen/standard_gap" | ||||||
|                     android:orientation="vertical" |                 android:paddingRight="@dimen/standard_gap" | ||||||
|                     android:padding="@dimen/standard_gap"> |                 android:paddingTop="@dimen/small_gap" | ||||||
|  |                 android:paddingBottom="@dimen/small_gap" | ||||||
|  |                 android:orientation="horizontal" | ||||||
|  |                 android:layout_height="wrap_content"> | ||||||
| 
 | 
 | ||||||
|                 <TextView |                 <TextView | ||||||
|                         android:layout_width="match_parent" |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="10" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                         android:paddingBottom="@dimen/tiny_gap" |                     android:textStyle="bold" | ||||||
|                         android:text="@string/media_detail_license" |                     android:textColor="@color/black" | ||||||
|                         android:textColor="@android:color/white" |                     android:text="Categories" | ||||||
|                         android:textSize="@dimen/normal_text" |                     /> | ||||||
|                         android:textStyle="bold" /> | 
 | ||||||
|  |                 <ImageView | ||||||
|  |                     android:src="@drawable/ic_mode_edit_primary_dark_24dp" | ||||||
|  |                     android:layout_width="@dimen/half_standard_height" | ||||||
|  |                     android:layout_height="@dimen/half_standard_height" /> | ||||||
| 
 | 
 | ||||||
|                     <fr.free.nrw.commons.ui.widget.CompatTextView |  | ||||||
|                         android:id="@+id/mediaDetailLicense" |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:layout_gravity="start" |  | ||||||
|                         android:background="?attr/subBackground" |  | ||||||
|                         android:foreground="?attr/selectableItemBackground" |  | ||||||
|                         android:gravity="center_vertical" |  | ||||||
|                         android:padding="@dimen/small_gap" |  | ||||||
|                         android:textColor="@android:color/white" |  | ||||||
|                         android:textSize="@dimen/description_text_size" |  | ||||||
|                         app:drawablePadding="@dimen/tiny_gap" |  | ||||||
|                         app:drawableStart="@drawable/ic_info_outline_24dp" |  | ||||||
|                         tools:text="License link" /> |  | ||||||
|             </LinearLayout> |             </LinearLayout> | ||||||
| 
 | 
 | ||||||
|                 <fr.free.nrw.commons.media.MediaDetailSpacer |  | ||||||
|                     android:layout_width="match_parent" |  | ||||||
|                     android:layout_height="@dimen/small_gap" /> |  | ||||||
| 
 |  | ||||||
|                 <LinearLayout |  | ||||||
|                     android:layout_width="match_parent" |  | ||||||
|                     android:layout_height="wrap_content" |  | ||||||
|                     android:background="?attr/subBackground" |  | ||||||
|                     android:orientation="vertical" |  | ||||||
|                     android:padding="@dimen/standard_gap"> |  | ||||||
| 
 |  | ||||||
|                     <TextView |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:paddingBottom="@dimen/tiny_gap" |  | ||||||
|                         android:text="@string/media_detail_coordinates" |  | ||||||
|                         android:textColor="@android:color/white" |  | ||||||
|                         android:textSize="@dimen/normal_text" |  | ||||||
|                         android:textStyle="bold" /> |  | ||||||
| 
 |  | ||||||
|                     <fr.free.nrw.commons.ui.widget.CompatTextView |  | ||||||
|                         android:id="@+id/mediaDetailCoordinates" |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:layout_gravity="start" |  | ||||||
|                         android:background="?attr/subBackground" |  | ||||||
|                         android:foreground="?attr/selectableItemBackground" |  | ||||||
|                         android:gravity="center_vertical" |  | ||||||
|                         android:padding="@dimen/small_gap" |  | ||||||
|                         android:textColor="@android:color/white" |  | ||||||
|                         android:textSize="@dimen/description_text_size" |  | ||||||
|                         app:drawablePadding="@dimen/tiny_gap" |  | ||||||
|                         app:drawableStart="@drawable/ic_map_white_24dp" |  | ||||||
|                         tools:text="Coordinates link" /> |  | ||||||
|                 </LinearLayout> |  | ||||||
| 
 |  | ||||||
|                 <fr.free.nrw.commons.media.MediaDetailSpacer |  | ||||||
|                     android:layout_width="match_parent" |  | ||||||
|                     android:layout_height="@dimen/small_gap" /> |  | ||||||
| 
 |  | ||||||
|                 <LinearLayout |  | ||||||
|                     android:layout_width="match_parent" |  | ||||||
|                     android:layout_height="wrap_content" |  | ||||||
|                     android:background="?attr/subBackground" |  | ||||||
|                     android:orientation="vertical" |  | ||||||
|                     android:padding="@dimen/standard_gap" |  | ||||||
|                     android:textStyle="bold"> |  | ||||||
| 
 |  | ||||||
|                     <TextView |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:layout_gravity="start" |  | ||||||
|                         android:paddingBottom="@dimen/tiny_gap" |  | ||||||
|                         android:text="@string/detail_panel_cats_label" |  | ||||||
|                         android:textColor="@android:color/white" |  | ||||||
|                         android:textSize="@dimen/normal_text" |  | ||||||
|                         android:textStyle="bold" /> |  | ||||||
| 
 |  | ||||||
|             <LinearLayout |             <LinearLayout | ||||||
|  |                 android:lineSpacingMultiplier="1.2" | ||||||
|  |                 android:paddingLeft="@dimen/standard_gap" | ||||||
|  |                 android:paddingRight="@dimen/standard_gap" | ||||||
|  |                 android:paddingBottom="@dimen/standard_gap" | ||||||
|                 android:id="@+id/mediaDetailCategoryContainer" |                 android:id="@+id/mediaDetailCategoryContainer" | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                 android:layout_height="wrap_content" |                 android:layout_height="wrap_content" | ||||||
|                 android:orientation="vertical" /> |                 android:orientation="vertical" /> | ||||||
|                 </LinearLayout> |  | ||||||
| 
 | 
 | ||||||
|                 <fr.free.nrw.commons.media.MediaDetailSpacer |             <View | ||||||
|  |                 android:background="@color/divider_grey" | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                     android:layout_height="@dimen/small_gap" /> |                 android:layout_height="2dp"/> | ||||||
|  | 
 | ||||||
|  |             <LinearLayout | ||||||
|  |                 android:id="@+id/authorLinearLayout" | ||||||
|  |                 android:layout_width="match_parent" | ||||||
|  |                 android:weightSum="10" | ||||||
|  |                 android:paddingLeft="@dimen/standard_gap" | ||||||
|  |                 android:paddingRight="@dimen/standard_gap" | ||||||
|  |                 android:paddingTop="@dimen/small_gap" | ||||||
|  |                 android:paddingBottom="@dimen/small_gap" | ||||||
|  |                 android:orientation="horizontal" | ||||||
|  |                 android:layout_height="wrap_content"> | ||||||
|  | 
 | ||||||
|  |                 <TextView | ||||||
|  |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="3" | ||||||
|  |                     android:layout_height="wrap_content" | ||||||
|  |                     android:text="@string/media_detail_author" | ||||||
|  |                     android:textColor="@color/black" | ||||||
|  |                     android:textStyle="bold" | ||||||
|  |                     /> | ||||||
|  | 
 | ||||||
|  |                 <TextView | ||||||
|  |                     android:id="@+id/mediaDetailAuthor" | ||||||
|  |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="7" | ||||||
|  |                     android:layout_height="wrap_content" | ||||||
|  |                     android:textColor="@color/black" | ||||||
|  |                     /> | ||||||
|  | 
 | ||||||
|  |             </LinearLayout> | ||||||
| 
 | 
 | ||||||
|             <LinearLayout |             <LinearLayout | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                 android:weightSum="10" | ||||||
|                     android:background="?attr/subBackground" |                 android:paddingLeft="@dimen/standard_gap" | ||||||
|                     android:orientation="vertical" |                 android:paddingRight="@dimen/standard_gap" | ||||||
|                     android:padding="@dimen/standard_gap"> |                 android:paddingTop="@dimen/small_gap" | ||||||
|  |                 android:paddingBottom="@dimen/small_gap" | ||||||
|  |                 android:orientation="horizontal" | ||||||
|  |                 android:layout_height="wrap_content"> | ||||||
| 
 | 
 | ||||||
|                 <TextView |                 <TextView | ||||||
|                         android:layout_width="match_parent" |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="3" | ||||||
|  |                     android:textColor="@color/black" | ||||||
|  |                     android:layout_height="wrap_content" | ||||||
|  |                     android:textStyle="bold" | ||||||
|  |                     android:text="@string/media_detail_license" | ||||||
|  |                     /> | ||||||
|  | 
 | ||||||
|  |                 <fr.free.nrw.commons.ui.widget.CompatTextView | ||||||
|  |                     android:id="@+id/mediaDetailLicense" | ||||||
|  |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="7" | ||||||
|  |                     android:layout_height="wrap_content" | ||||||
|  |                     android:layout_gravity="start" | ||||||
|  |                     android:gravity="center_vertical" | ||||||
|  |                     android:textColor="@android:color/black" | ||||||
|  |                     android:textSize="@dimen/description_text_size" | ||||||
|  |                     tools:text="License link" /> | ||||||
|  | 
 | ||||||
|  |             </LinearLayout> | ||||||
|  | 
 | ||||||
|  |             <LinearLayout | ||||||
|  |                 android:layout_width="match_parent" | ||||||
|  |                 android:weightSum="10" | ||||||
|  |                 android:paddingLeft="@dimen/standard_gap" | ||||||
|  |                 android:paddingRight="@dimen/standard_gap" | ||||||
|  |                 android:paddingTop="@dimen/small_gap" | ||||||
|  |                 android:paddingBottom="@dimen/small_gap" | ||||||
|  |                 android:orientation="horizontal" | ||||||
|  |                 android:layout_height="wrap_content"> | ||||||
|  | 
 | ||||||
|  |                 <TextView | ||||||
|  |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="3" | ||||||
|  |                     android:layout_height="wrap_content" | ||||||
|  |                     android:textStyle="bold" | ||||||
|  |                     android:textColor="@color/black" | ||||||
|  |                     android:text="@string/media_detail_coordinates" | ||||||
|  |                     /> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |                 <fr.free.nrw.commons.ui.widget.CompatTextView | ||||||
|  |                     android:id="@+id/mediaDetailCoordinates" | ||||||
|  |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="7" | ||||||
|  |                     android:layout_height="wrap_content" | ||||||
|  |                     android:layout_gravity="start" | ||||||
|  |                     android:gravity="center_vertical" | ||||||
|  |                     android:textColor="@color/black" | ||||||
|  |                     tools:text="Coordinates link" /> | ||||||
|  | 
 | ||||||
|  |             </LinearLayout> | ||||||
|  | 
 | ||||||
|  |             <LinearLayout | ||||||
|  |                 android:layout_width="match_parent" | ||||||
|  |                 android:weightSum="10" | ||||||
|  |                 android:paddingLeft="@dimen/standard_gap" | ||||||
|  |                 android:paddingRight="@dimen/standard_gap" | ||||||
|  |                 android:paddingTop="@dimen/small_gap" | ||||||
|  |                 android:paddingBottom="@dimen/small_gap" | ||||||
|  |                 android:orientation="horizontal" | ||||||
|  |                 android:layout_height="wrap_content"> | ||||||
|  | 
 | ||||||
|  |                 <TextView | ||||||
|  |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="3" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                         android:paddingBottom="@dimen/tiny_gap" |  | ||||||
|                     android:text="@string/media_detail_uploaded_date" |                     android:text="@string/media_detail_uploaded_date" | ||||||
|                         android:textColor="@android:color/white" |                     android:textStyle="bold" | ||||||
|                         android:textSize="@dimen/normal_text" |                     android:textColor="@color/black" | ||||||
|                         android:textStyle="bold" /> |                     /> | ||||||
| 
 | 
 | ||||||
|                 <TextView |                 <TextView | ||||||
|                     android:id="@+id/mediaDetailuploadeddate" |                     android:id="@+id/mediaDetailuploadeddate" | ||||||
|                         android:layout_width="match_parent" |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="7" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                         android:layout_gravity="start" |                     android:textColor="@color/black" | ||||||
|                         android:background="?attr/subBackground" |                     /> | ||||||
|                         android:padding="@dimen/small_gap" | 
 | ||||||
|                         android:textColor="@android:color/white" |  | ||||||
|                         android:textSize="@dimen/description_text_size" |  | ||||||
|                         tools:text="Uploaded date" /> |  | ||||||
|             </LinearLayout> |             </LinearLayout> | ||||||
| 
 | 
 | ||||||
|                 <fr.free.nrw.commons.media.MediaDetailSpacer | 
 | ||||||
|  |             <LinearLayout | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                     android:layout_height="@dimen/small_gap" /> |                 android:weightSum="10" | ||||||
|  |                 android:paddingLeft="@dimen/standard_gap" | ||||||
|  |                 android:paddingRight="@dimen/standard_gap" | ||||||
|  |                 android:paddingTop="@dimen/small_gap" | ||||||
|  |                 android:paddingBottom="@dimen/small_gap" | ||||||
|  |                 android:orientation="horizontal" | ||||||
|  |                 android:layout_height="wrap_content"> | ||||||
|  | 
 | ||||||
|  |                 <TextView | ||||||
|  |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="3" | ||||||
|  |                     android:layout_height="wrap_content" | ||||||
|  |                     android:text="@string/media_detail_discussion" | ||||||
|  |                     android:textStyle="bold" | ||||||
|  |                     android:textColor="@color/black" | ||||||
|  |                     /> | ||||||
|  | 
 | ||||||
|  |                 <TextView | ||||||
|  |                     android:id="@+id/mediaDetailDisc" | ||||||
|  |                     android:layout_width="0dp" | ||||||
|  |                     android:layout_weight="7" | ||||||
|  |                     android:layout_height="wrap_content" | ||||||
|  |                     android:textColor="@color/black" | ||||||
|  |                     /> | ||||||
|  | 
 | ||||||
|  |             </LinearLayout> | ||||||
|  | 
 | ||||||
|  |             <LinearLayout | ||||||
|  |                 android:paddingTop="@dimen/standard_gap" | ||||||
|  |                 android:layout_width="match_parent" | ||||||
|  |                 android:weightSum="2" | ||||||
|  |                 android:layout_height="wrap_content"> | ||||||
|  | 
 | ||||||
|  |                 <Button | ||||||
|  |                     android:layout_weight="1" | ||||||
|  |                     android:id="@+id/copyWikicode" | ||||||
|  |                     android:layout_width="match_parent" | ||||||
|  |                     android:layout_height="wrap_content" | ||||||
|  |                     android:layout_margin="@dimen/standard_gap" | ||||||
|  |                     android:background="@drawable/copy_to_wikitext_button" | ||||||
|  |                     android:text="COPY \n WIKITEXT" | ||||||
|  |                     android:textColor="@color/primaryTextColor" /> | ||||||
|  | 
 | ||||||
|  |                 <Button | ||||||
|  |                     android:layout_weight="1" | ||||||
|  |                     android:id="@+id/nominateDeletion" | ||||||
|  |                     android:layout_width="match_parent" | ||||||
|  |                     android:layout_height="wrap_content" | ||||||
|  |                     android:layout_margin="@dimen/standard_gap" | ||||||
|  |                     android:background="@drawable/bg_delete_button" | ||||||
|  |                     android:text="@string/nominate_deletion" | ||||||
|  |                     android:textColor="@color/primaryTextColor" /> | ||||||
|  | 
 | ||||||
|  |             </LinearLayout> | ||||||
| 
 | 
 | ||||||
|             <LinearLayout |             <LinearLayout | ||||||
|                 android:id="@+id/nominatedDeletionBanner" |                 android:id="@+id/nominatedDeletionBanner" | ||||||
|                     android:background="@color/deleteRed" |                 android:background="@color/white" | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                 android:layout_height="wrap_content" |                 android:layout_height="wrap_content" | ||||||
|                 android:orientation="vertical" |                 android:orientation="vertical" | ||||||
|  | @ -294,71 +430,23 @@ | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                     android:gravity="center" |                     android:gravity="center" | ||||||
|  |                     android:textColor="@color/deleteRed" | ||||||
|                     android:text="@string/nominated_for_deletion" |                     android:text="@string/nominated_for_deletion" | ||||||
|                         android:textColor="@color/primaryTextColor" |  | ||||||
|                     android:textSize="@dimen/normal_text" |                     android:textSize="@dimen/normal_text" | ||||||
|                         android:textStyle="bold"/> |                     /> | ||||||
|                 <TextView |                 <TextView | ||||||
|                     android:id="@+id/seeMore" |                     android:id="@+id/seeMore" | ||||||
|  |                     android:textColor="@color/deleteRed" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                     android:gravity="center" |                     android:gravity="center" | ||||||
|                     android:paddingTop="@dimen/standard_gap" |                     android:paddingTop="@dimen/standard_gap" | ||||||
|                         android:textColor="@color/primaryTextColor" |  | ||||||
|                     android:textSize="@dimen/normal_text" |                     android:textSize="@dimen/normal_text" | ||||||
|                         android:textStyle="bold"/> |                     /> | ||||||
|             </LinearLayout> |             </LinearLayout> | ||||||
| 
 | 
 | ||||||
|                 <fr.free.nrw.commons.media.MediaDetailSpacer |  | ||||||
|                     android:layout_width="match_parent" |  | ||||||
|                     android:layout_height="@dimen/small_gap" /> |  | ||||||
| 
 |  | ||||||
|                 <LinearLayout |  | ||||||
|                     android:layout_width="match_parent" |  | ||||||
|                     android:layout_height="wrap_content" |  | ||||||
|                     android:background="?attr/subBackground" |  | ||||||
|                     android:orientation="vertical" |  | ||||||
|                     android:padding="@dimen/standard_gap"> |  | ||||||
| 
 |  | ||||||
|                     <TextView |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:paddingBottom="@dimen/tiny_gap" |  | ||||||
|                         android:text="@string/media_detail_discussion" |  | ||||||
|                         android:textColor="@android:color/white" |  | ||||||
|                         android:textSize="@dimen/normal_text" |  | ||||||
|                         android:textStyle="bold" /> |  | ||||||
| 
 |  | ||||||
|                     <TextView |  | ||||||
|                         android:id="@+id/mediaDetailDisc" |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:layout_gravity="start" |  | ||||||
|                         android:background="?attr/subBackground" |  | ||||||
|                         android:padding="@dimen/small_gap" |  | ||||||
|                         android:textColor="@android:color/white" |  | ||||||
|                         android:textSize="@dimen/description_text_size" /> |  | ||||||
|         </LinearLayout> |         </LinearLayout> | ||||||
| 
 | 
 | ||||||
|                 <Button |  | ||||||
|                     android:id="@+id/copyWikicode" |  | ||||||
|                     android:layout_width="match_parent" |  | ||||||
|                     android:layout_height="wrap_content" |  | ||||||
|                     android:layout_margin="@dimen/standard_gap" |  | ||||||
|                     android:background="@color/button_blue" |  | ||||||
|                     android:text="@string/copy_wikicode" |  | ||||||
|                     android:textColor="@color/primaryTextColor" /> |  | ||||||
| 
 |  | ||||||
|                 <Button |  | ||||||
|                     android:id="@+id/nominateDeletion" |  | ||||||
|                     android:background="@drawable/bg_delete_button" |  | ||||||
|                     android:textColor="@color/primaryTextColor" |  | ||||||
|                     android:layout_margin="@dimen/standard_gap" |  | ||||||
|                     android:layout_width="match_parent" |  | ||||||
|                     android:layout_height="wrap_content" |  | ||||||
|                     android:text="@string/nominate_deletion"/> |  | ||||||
|             </LinearLayout> |  | ||||||
|         </LinearLayout> |  | ||||||
|     </ScrollView> |     </ScrollView> | ||||||
| 
 | 
 | ||||||
| </FrameLayout> | </FrameLayout> | ||||||
|  | @ -2,21 +2,6 @@ | ||||||
| 
 | 
 | ||||||
| <menu xmlns:android="http://schemas.android.com/apk/res/android" | <menu xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto"> |     xmlns:app="http://schemas.android.com/apk/res-auto"> | ||||||
|     <item |  | ||||||
|         android:id="@+id/menu_bookmark_current_image" |  | ||||||
|         android:icon="@drawable/ic_round_star_border_24px" |  | ||||||
|         android:title="@string/menu_bookmark" |  | ||||||
|         app:showAsAction="always" /> |  | ||||||
|     <item |  | ||||||
|         android:id="@+id/menu_share_current_image" |  | ||||||
|         android:icon="@drawable/ic_share_black_24dp" |  | ||||||
|         android:title="@string/menu_share" |  | ||||||
|         app:showAsAction="always" /> |  | ||||||
|     <item |  | ||||||
|         android:id="@+id/menu_download_current_image" |  | ||||||
|         android:icon="@drawable/ic_download_white_24dp" |  | ||||||
|         android:title="@string/menu_download" |  | ||||||
|         app:showAsAction="always" /> |  | ||||||
|     <item |     <item | ||||||
|         android:id="@+id/menu_browser_current_image" |         android:id="@+id/menu_browser_current_image" | ||||||
|         android:title="@string/menu_open_in_browser" |         android:title="@string/menu_open_in_browser" | ||||||
|  |  | ||||||
|  | @ -23,8 +23,9 @@ | ||||||
|     <color name="secondaryLightColor">#ffbc46</color> |     <color name="secondaryLightColor">#ffbc46</color> | ||||||
|     <color name="primaryTextColor">#ffffff</color> |     <color name="primaryTextColor">#ffffff</color> | ||||||
|     <color name="secondaryTextColor">#000000</color> |     <color name="secondaryTextColor">#000000</color> | ||||||
|  |     <color name="linkColor">#0c609c</color> | ||||||
| 
 | 
 | ||||||
|     <color name="deleteRed">#90960a0a</color> |     <color name="deleteRed">#d33</color> | ||||||
|     <color name="deleteButton">#44000000</color> |     <color name="deleteButton">#44000000</color> | ||||||
|     <color name="deleteButtonDark">#88000000</color> |     <color name="deleteButtonDark">#88000000</color> | ||||||
|     <color name="deleteButtonLight">#44ffffff</color> |     <color name="deleteButtonLight">#44ffffff</color> | ||||||
|  |  | ||||||
 Ujjwal Agrawal
						Ujjwal Agrawal