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

Unified Diff: ios/chrome/browser/translate/translate_message_infobar_controller.mm

Issue 809333003: Upstream //ios/chrome/browser/translate (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Review comments Created 5 years, 11 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: ios/chrome/browser/translate/translate_message_infobar_controller.mm
diff --git a/ios/chrome/browser/translate/translate_message_infobar_controller.mm b/ios/chrome/browser/translate/translate_message_infobar_controller.mm
new file mode 100644
index 0000000000000000000000000000000000000000..f3466fcba578207dd835636384e77b8ca50f2794
--- /dev/null
+++ b/ios/chrome/browser/translate/translate_message_infobar_controller.mm
@@ -0,0 +1,82 @@
+// Copyright 2013 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.
+
+#include "ios/chrome/browser/translate/translate_message_infobar_controller.h"
+
+#include "base/strings/sys_string_conversions.h"
+#include "components/translate/core/browser/translate_infobar_delegate.h"
+#include "ios/chrome/browser/translate/translate_infobar_tags.h"
+#include "ios/public/provider/chrome/browser/chrome_browser_provider.h"
+#import "ios/public/provider/chrome/browser/ui/infobar_view_delegate.h"
+#import "ios/public/provider/chrome/browser/ui/infobar_view_protocol.h"
+#include "ui/gfx/image/image.h"
+
+@interface TranslateMessageInfoBarController ()
+
+// Action for any of the user defined buttons.
+- (void)infoBarButtonDidPress:(id)sender;
+
+@end
+
+@implementation TranslateMessageInfoBarController
+
+#pragma mark -
+#pragma mark InfoBarControllerProtocol
+
+- (void)layoutForDelegate:(infobars::InfoBarDelegate*)delegate
+ frame:(CGRect)frame {
+ translate::TranslateInfoBarDelegate* translateInfoBarDelegate =
+ delegate->AsTranslateInfoBarDelegate();
+ infobars::InfoBarDelegate* infoBarDelegate =
+ static_cast<infobars::InfoBarDelegate*>(translateInfoBarDelegate);
+ DCHECK(!infoBarView_);
+ infoBarView_.reset([ios::GetChromeBrowserProvider()->CreateInfoBarView()
+ initWithFrame:frame
+ delegate:delegate_
+ isWarning:infoBarDelegate->GetInfoBarType() ==
+ infobars::InfoBarDelegate::WARNING_TYPE]);
+ // Icon
+ gfx::Image icon = translateInfoBarDelegate->GetIcon();
+ if (!icon.IsEmpty())
+ [infoBarView_ addLeftIcon:icon.ToUIImage()];
+ // Text.
+ [infoBarView_
+ addLabel:base::SysUTF16ToNSString(
+ translateInfoBarDelegate->GetMessageInfoBarText())];
+ // Close button.
+ [infoBarView_ addCloseButtonWithTag:TranslateInfoBarIOSTag::CLOSE
+ target:self
+ action:@selector(infoBarButtonDidPress:)];
+ // Other button.
+ base::string16 buttonText(
+ translateInfoBarDelegate->GetMessageInfoBarButtonText());
+ if (!buttonText.empty()) {
+ [infoBarView_ addButton:base::SysUTF16ToNSString(buttonText)
+ tag:TranslateInfoBarIOSTag::MESSAGE
+ target:self
+ action:@selector(infoBarButtonDidPress:)];
+ }
+}
+
+#pragma mark - Handling of User Events
+
+- (void)infoBarButtonDidPress:(id)sender {
+ // This press might have occurred after the user has already pressed a button,
+ // in which case the view has been detached from the delegate and this press
+ // should be ignored.
+ if (!delegate_) {
+ return;
+ }
+ if ([sender isKindOfClass:[UIButton class]]) {
+ NSUInteger buttonId = static_cast<UIButton*>(sender).tag;
+ if (buttonId == TranslateInfoBarIOSTag::CLOSE) {
+ delegate_->InfoBarDidCancel();
+ } else {
+ DCHECK(buttonId == TranslateInfoBarIOSTag::MESSAGE);
+ delegate_->InfoBarButtonDidPress(buttonId);
+ }
+ }
+}
+
+@end

Powered by Google App Engine
This is Rietveld 408576698