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

Side by Side Diff: ios/chrome/browser/translate/after_translate_infobar_controller.mm

Issue 1161243002: Fixit: Cleanup of InfoBarController. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Adding mising forward declaration. Created 5 years, 6 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 unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "ios/chrome/browser/translate/after_translate_infobar_controller.h" 5 #include "ios/chrome/browser/translate/after_translate_infobar_controller.h"
6 6
7 #include "base/strings/sys_string_conversions.h" 7 #include "base/strings/sys_string_conversions.h"
8 #include "base/strings/utf_string_conversions.h" 8 #include "base/strings/utf_string_conversions.h"
9 #include "components/translate/core/browser/translate_infobar_delegate.h" 9 #include "components/translate/core/browser/translate_infobar_delegate.h"
10 #include "grit/components_strings.h" 10 #include "grit/components_strings.h"
(...skipping 12 matching lines...) Expand all
23 // Action for any of the user defined buttons. 23 // Action for any of the user defined buttons.
24 - (void)infoBarButtonDidPress:(id)sender; 24 - (void)infoBarButtonDidPress:(id)sender;
25 25
26 @end 26 @end
27 27
28 @implementation AfterTranslateInfoBarController 28 @implementation AfterTranslateInfoBarController
29 29
30 #pragma mark - 30 #pragma mark -
31 #pragma mark InfoBarControllerProtocol 31 #pragma mark InfoBarControllerProtocol
32 32
33 - (void)layoutForDelegate:(infobars::InfoBarDelegate*)delegate 33 - (base::scoped_nsobject<UIView<InfoBarViewProtocol>>)
34 frame:(CGRect)frame { 34 viewForDelegate:(infobars::InfoBarDelegate*)delegate
35 frame:(CGRect)frame {
36 base::scoped_nsobject<UIView<InfoBarViewProtocol>> infoBarView;
35 _translateInfoBarDelegate = delegate->AsTranslateInfoBarDelegate(); 37 _translateInfoBarDelegate = delegate->AsTranslateInfoBarDelegate();
36 DCHECK(_translateInfoBarDelegate); 38 DCHECK(_translateInfoBarDelegate);
37 DCHECK(!infoBarView_); 39 infoBarView.reset(
38 infoBarView_.reset([ios::GetChromeBrowserProvider()->CreateInfoBarView() 40 ios::GetChromeBrowserProvider()->CreateInfoBarView(frame, self.delegate));
39 initWithFrame:frame
40 delegate:delegate_]);
41 // Icon 41 // Icon
42 gfx::Image icon = _translateInfoBarDelegate->GetIcon(); 42 gfx::Image icon = _translateInfoBarDelegate->GetIcon();
43 if (!icon.IsEmpty()) 43 if (!icon.IsEmpty())
44 [infoBarView_ addLeftIcon:icon.ToUIImage()]; 44 [infoBarView addLeftIcon:icon.ToUIImage()];
45 // Main text. 45 // Main text.
46 const bool autodeterminedSourceLanguage = 46 const bool autodeterminedSourceLanguage =
47 _translateInfoBarDelegate->original_language_index() == 47 _translateInfoBarDelegate->original_language_index() ==
48 translate::TranslateInfoBarDelegate::kNoIndex; 48 translate::TranslateInfoBarDelegate::kNoIndex;
49 bool swappedLanguageButtons; 49 bool swappedLanguageButtons;
50 std::vector<base::string16> strings; 50 std::vector<base::string16> strings;
51 translate::TranslateInfoBarDelegate::GetAfterTranslateStrings( 51 translate::TranslateInfoBarDelegate::GetAfterTranslateStrings(
52 &strings, &swappedLanguageButtons, autodeterminedSourceLanguage); 52 &strings, &swappedLanguageButtons, autodeterminedSourceLanguage);
53 DCHECK_EQ(autodeterminedSourceLanguage ? 2U : 3U, strings.size()); 53 DCHECK_EQ(autodeterminedSourceLanguage ? 2U : 3U, strings.size());
54 NSString* label1 = base::SysUTF16ToNSString(strings[0]); 54 NSString* label1 = base::SysUTF16ToNSString(strings[0]);
55 NSString* label2 = base::SysUTF16ToNSString(strings[1]); 55 NSString* label2 = base::SysUTF16ToNSString(strings[1]);
56 NSString* label3 = autodeterminedSourceLanguage 56 NSString* label3 = autodeterminedSourceLanguage
57 ? @"" 57 ? @""
58 : base::SysUTF16ToNSString(strings[2]); 58 : base::SysUTF16ToNSString(strings[2]);
59 base::string16 stdOriginal = _translateInfoBarDelegate->language_name_at( 59 base::string16 stdOriginal = _translateInfoBarDelegate->language_name_at(
60 _translateInfoBarDelegate->original_language_index()); 60 _translateInfoBarDelegate->original_language_index());
61 NSString* original = base::SysUTF16ToNSString(stdOriginal); 61 NSString* original = base::SysUTF16ToNSString(stdOriginal);
62 NSString* target = 62 NSString* target =
63 base::SysUTF16ToNSString(_translateInfoBarDelegate->language_name_at( 63 base::SysUTF16ToNSString(_translateInfoBarDelegate->language_name_at(
64 _translateInfoBarDelegate->target_language_index())); 64 _translateInfoBarDelegate->target_language_index()));
65 base::scoped_nsobject<NSString> label( 65 base::scoped_nsobject<NSString> label(
66 [[NSString alloc] initWithFormat:@"%@ %@ %@%@ %@.", label1, original, 66 [[NSString alloc] initWithFormat:@"%@ %@ %@%@ %@.", label1, original,
67 label2, label3, target]); 67 label2, label3, target]);
68 [infoBarView_ addLabel:label]; 68 [infoBarView addLabel:label];
69 // Close button. 69 // Close button.
70 [infoBarView_ addCloseButtonWithTag:TranslateInfoBarIOSTag::CLOSE 70 [infoBarView addCloseButtonWithTag:TranslateInfoBarIOSTag::CLOSE
71 target:self 71 target:self
72 action:@selector(infoBarButtonDidPress:)]; 72 action:@selector(infoBarButtonDidPress:)];
73 // Other buttons. 73 // Other buttons.
74 NSString* buttonRevert = l10n_util::GetNSString(IDS_TRANSLATE_INFOBAR_REVERT); 74 NSString* buttonRevert = l10n_util::GetNSString(IDS_TRANSLATE_INFOBAR_REVERT);
75 NSString* buttonOptions = base::SysUTF16ToNSString( 75 NSString* buttonOptions = base::SysUTF16ToNSString(
76 ios::GetChromeBrowserProvider()->GetStringProvider()->GetDoneString()); 76 ios::GetChromeBrowserProvider()->GetStringProvider()->GetDoneString());
77 [infoBarView_ addButton1:buttonOptions 77 [infoBarView addButton1:buttonOptions
78 tag1:TranslateInfoBarIOSTag::AFTER_DONE 78 tag1:TranslateInfoBarIOSTag::AFTER_DONE
79 button2:buttonRevert 79 button2:buttonRevert
80 tag2:TranslateInfoBarIOSTag::AFTER_REVERT 80 tag2:TranslateInfoBarIOSTag::AFTER_REVERT
81 target:self 81 target:self
82 action:@selector(infoBarButtonDidPress:)]; 82 action:@selector(infoBarButtonDidPress:)];
83 // Always translate switch. 83 // Always translate switch.
84 if (_translateInfoBarDelegate->ShouldShowAlwaysTranslateShortcut()) { 84 if (_translateInfoBarDelegate->ShouldShowAlwaysTranslateShortcut()) {
85 base::string16 alwaysTranslate = l10n_util::GetStringFUTF16( 85 base::string16 alwaysTranslate = l10n_util::GetStringFUTF16(
86 IDS_TRANSLATE_INFOBAR_ALWAYS_TRANSLATE, stdOriginal); 86 IDS_TRANSLATE_INFOBAR_ALWAYS_TRANSLATE, stdOriginal);
87 const BOOL switchValue = _translateInfoBarDelegate->ShouldAlwaysTranslate(); 87 const BOOL switchValue = _translateInfoBarDelegate->ShouldAlwaysTranslate();
88 [infoBarView_ 88 [infoBarView
89 addSwitchWithLabel:base::SysUTF16ToNSString(alwaysTranslate) 89 addSwitchWithLabel:base::SysUTF16ToNSString(alwaysTranslate)
90 isOn:switchValue 90 isOn:switchValue
91 tag:TranslateInfoBarIOSTag::ALWAYS_TRANSLATE_SWITCH 91 tag:TranslateInfoBarIOSTag::ALWAYS_TRANSLATE_SWITCH
92 target:self 92 target:self
93 action:@selector(infoBarSwitchDidPress:)]; 93 action:@selector(infoBarSwitchDidPress:)];
94 } 94 }
95 return infoBarView;
95 } 96 }
96 97
97 #pragma mark - Handling of User Events 98 #pragma mark - Handling of User Events
98 99
99 - (void)infoBarButtonDidPress:(id)sender { 100 - (void)infoBarButtonDidPress:(id)sender {
100 // This press might have occurred after the user has already pressed a button, 101 // This press might have occurred after the user has already pressed a button,
101 // in which case the view has been detached from the delegate and this press 102 // in which case the view has been detached from the delegate and this press
102 // should be ignored. 103 // should be ignored.
103 if (!delegate_) { 104 if (!self.delegate) {
104 return; 105 return;
105 } 106 }
106 if ([sender isKindOfClass:[UIButton class]]) { 107 if ([sender isKindOfClass:[UIButton class]]) {
107 NSUInteger buttonId = static_cast<UIButton*>(sender).tag; 108 NSUInteger buttonId = static_cast<UIButton*>(sender).tag;
108 if (buttonId == TranslateInfoBarIOSTag::CLOSE) { 109 if (buttonId == TranslateInfoBarIOSTag::CLOSE) {
109 delegate_->InfoBarDidCancel(); 110 self.delegate->InfoBarDidCancel();
110 } else { 111 } else {
111 DCHECK(buttonId == TranslateInfoBarIOSTag::AFTER_REVERT || 112 DCHECK(buttonId == TranslateInfoBarIOSTag::AFTER_REVERT ||
112 buttonId == TranslateInfoBarIOSTag::AFTER_DONE); 113 buttonId == TranslateInfoBarIOSTag::AFTER_DONE);
113 delegate_->InfoBarButtonDidPress(buttonId); 114 self.delegate->InfoBarButtonDidPress(buttonId);
114 } 115 }
115 } 116 }
116 } 117 }
117 118
118 - (void)infoBarSwitchDidPress:(id)sender { 119 - (void)infoBarSwitchDidPress:(id)sender {
119 DCHECK_EQ(TranslateInfoBarIOSTag::ALWAYS_TRANSLATE_SWITCH, [sender tag]); 120 DCHECK_EQ(TranslateInfoBarIOSTag::ALWAYS_TRANSLATE_SWITCH, [sender tag]);
120 DCHECK([sender respondsToSelector:@selector(isOn)]); 121 DCHECK([sender respondsToSelector:@selector(isOn)]);
121 if (_translateInfoBarDelegate->ShouldAlwaysTranslate() != [sender isOn]) 122 if (_translateInfoBarDelegate->ShouldAlwaysTranslate() != [sender isOn])
122 _translateInfoBarDelegate->ToggleAlwaysTranslate(); 123 _translateInfoBarDelegate->ToggleAlwaysTranslate();
123 } 124 }
124 125
125 @end 126 @end
OLDNEW
« no previous file with comments | « ios/chrome/browser/infobars/infobar_controller.mm ('k') | ios/chrome/browser/translate/before_translate_infobar_controller.mm » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698