Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1188)

Unified Diff: chrome/android/java/src/org/chromium/chrome/browser/infobar/DownloadOverwriteInfoBar.java

Issue 580043002: [Android] Prompt with infobar on filename conflict (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: full implementation Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/android/java/src/org/chromium/chrome/browser/infobar/DownloadOverwriteInfoBar.java
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/infobar/DownloadOverwriteInfoBar.java b/chrome/android/java/src/org/chromium/chrome/browser/infobar/DownloadOverwriteInfoBar.java
new file mode 100644
index 0000000000000000000000000000000000000000..6e3a5e45a54f546e759693e99b491027221162c5
--- /dev/null
+++ b/chrome/android/java/src/org/chromium/chrome/browser/infobar/DownloadOverwriteInfoBar.java
@@ -0,0 +1,99 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+package org.chromium.chrome.browser.infobar;
+
+import android.content.Context;
+import android.content.Intent;
+import android.graphics.Typeface;
+import android.net.Uri;
+import android.text.Spannable;
+import android.text.SpannableString;
+import android.text.TextUtils;
+import android.text.style.ClickableSpan;
+import android.text.style.StyleSpan;
+import android.view.View;
+
+import org.chromium.chrome.R;
+
+/**
+ * Java version of the translate infobar
Ted C 2014/10/14 01:25:37 this needs to be updated
Changwan Ryu 2014/10/14 04:04:39 Done.
+ */
+public class DownloadOverwriteInfoBar extends InfoBar {
Ted C 2014/10/14 01:25:37 This looks like a ConfirmInfoBar at least from the
Changwan Ryu 2014/10/14 04:04:40 The main reason for deviating from ConfirmInfoBar
+ private final String mFileName;
+ private final String mDirName;
+ private final String mDirFullPath;
+
+ public DownloadOverwriteInfoBar(
+ long nativeInfoBarPtr, String fileName, String dirName, String dirFullPath) {
+ super(null, R.drawable.infobar_multiple_downloads, null);
+ mFileName = fileName;
+ mDirName = dirName;
+ mDirFullPath = dirFullPath;
+ setNativeInfoBar(nativeInfoBarPtr);
+ }
+
+ @Override
+ public void onCloseButtonClicked() {
+ nativeOnCloseButtonClicked(mNativeInfoBarPtr);
+ }
+
+ @Override
+ public void onButtonClicked(boolean isPrimaryButton) {
+ int action = actionFor(isPrimaryButton);
+ nativeOnButtonClicked(mNativeInfoBarPtr, action, "");
+ }
+
+ private int actionFor(boolean isPrimaryButton) {
+ return isPrimaryButton ? InfoBar.ACTION_TYPE_OK : InfoBar.ACTION_TYPE_CANCEL;
+ }
+
+ private CharSequence getMessageText(Context context) {
+ String template = context.getString(R.string.download_overwrite_infobar_text);
+ Intent intent = getIntentForDirectoryLaunch(mDirFullPath);
+ return formatInfoBarMessage(context, template, mFileName, mDirName, intent);
+ }
+
+ private static Intent getIntentForDirectoryLaunch(String dirFullPath) {
+ Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
+ Uri uri = Uri.parse(dirFullPath);
+ if (uri == null) {
+ return null;
+ }
+ intent.setDataAndType(uri, "*/*");
+ return intent;
+ }
+
+ private String getPrimaryButtonText(Context context) {
+ return context.getString(R.string.download_overwrite_infobar_yes_replace_button);
+ }
+
+ private String getSecondaryButtonText(Context context) {
+ return context.getString(R.string.download_overwrite_infobar_no_thanks_button);
+ }
+
+ @Override
+ public void createContent(InfoBarLayout layout) {
+ Context context = layout.getContext();
+ layout.setMessage(getMessageText(context));
+ layout.setButtons(getPrimaryButtonText(context), getSecondaryButtonText(context));
+ }
+
+ private static CharSequence formatInfoBarMessage(final Context context, String template,
+ String fileName, String dirName, final Intent dirNameIntent) {
+ SpannableString formattedFileName = new SpannableString(fileName);
+ formattedFileName.setSpan(new StyleSpan(Typeface.BOLD),
+ 0, fileName.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
+
+ SpannableString formattedDirName = new SpannableString(dirName);
+ formattedDirName.setSpan(new ClickableSpan() {
+ @Override
+ public void onClick(View view) {
+ context.startActivity(dirNameIntent);
+ }
+ }, 0, dirName.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
+
+ return TextUtils.expandTemplate(template, formattedFileName, formattedDirName);
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698