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

Unified Diff: ios/chrome/browser/passwords/update_password_infobar_controller.mm

Issue 2106413003: UpdatePasswordInfoBarController for update password UI (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@update_delegate
Patch Set: remove //weak Created 4 years, 5 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
« no previous file with comments | « ios/chrome/browser/passwords/update_password_infobar_controller.h ('k') | ios/chrome/ios_chrome.gyp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ios/chrome/browser/passwords/update_password_infobar_controller.mm
diff --git a/ios/chrome/browser/passwords/update_password_infobar_controller.mm b/ios/chrome/browser/passwords/update_password_infobar_controller.mm
new file mode 100644
index 0000000000000000000000000000000000000000..5eac335563f82b0286e2cbc4c8e263f11e4fae8e
--- /dev/null
+++ b/ios/chrome/browser/passwords/update_password_infobar_controller.mm
@@ -0,0 +1,77 @@
+// Copyright 2016 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.
+
+#import "ios/chrome/browser/passwords/update_password_infobar_controller.h"
+
+#include "base/strings/string_util.h"
+#include "base/strings/sys_string_conversions.h"
+#include "ios/chrome/browser/infobars/confirm_infobar_controller+protected.h"
+#include "ios/chrome/browser/passwords/ios_chrome_update_password_infobar_delegate.h"
+#import "ios/chrome/browser/ui/elements/selector_coordinator.h"
+#import "ios/public/provider/chrome/browser/ui/infobar_view_protocol.h"
+
+namespace {
+// Tag for the account link in the info bar message. Set to 10 to avoid conflict
+// with tags from superclass ConfirmInfoBarController, which uses tags 1-4.
+NSUInteger kAccountTag = 10;
+}
+
+@interface UpdatePasswordInfoBarController ()<SelectorCoordinatorDelegate> {
+ IOSChromeUpdatePasswordInfoBarDelegate* _delegate;
+}
+@end
+
+@implementation UpdatePasswordInfoBarController
+
+- (base::scoped_nsobject<UIView<InfoBarViewProtocol>>)
+viewForDelegate:(IOSChromeUpdatePasswordInfoBarDelegate*)delegate
+ frame:(CGRect)frame {
+ _delegate = delegate;
+ return [super viewForDelegate:delegate frame:frame];
+}
+
+- (void)updateInfobarLabel:(UIView<InfoBarViewProtocol>*)view {
+ [super updateInfobarLabel:view];
+
+ // Get the message text with current links marked.
+ base::string16 messageText = base::SysNSStringToUTF16(view.markedLabel);
+ // If there are multiple possible credentials, turn the account string into a
+ // link.
+ if (_delegate->ShowMultipleAccounts()) {
+ base::string16 usernameLink = base::SysNSStringToUTF16([[view class]
+ stringAsLink:base::SysUTF16ToNSString(_delegate->selected_account())
+ tag:kAccountTag]);
+ base::ReplaceFirstSubstringAfterOffset(
+ &messageText, 0, _delegate->selected_account(), usernameLink);
+ }
+
+ [view addLabel:base::SysUTF16ToNSString(messageText)
+ target:self
+ action:@selector(infobarLinkDidPress:)];
+}
+
+- (void)infobarLinkDidPress:(NSNumber*)tag {
+ [super infobarLinkDidPress:tag];
+ if ([tag unsignedIntegerValue] != kAccountTag)
+ return;
+
+ UIViewController* baseViewController =
+ [[UIApplication sharedApplication] keyWindow].rootViewController;
+ SelectorCoordinator* selectorCoordinator = [[[SelectorCoordinator alloc]
+ initWithBaseViewController:baseViewController] autorelease];
+ selectorCoordinator.delegate = self;
+ selectorCoordinator.options = [_delegate->GetAccounts() copy];
+ selectorCoordinator.defaultOption =
+ base::SysUTF16ToNSString(_delegate->selected_account());
+ [selectorCoordinator start];
+}
+
+#pragma mark SelectorCoordinatorDelegate
+
+- (void)selectorCoordinator:(SelectorCoordinator*)coordinator
+ didCompleteWithSelection:(NSString*)selection {
+ _delegate->set_selected_account(base::SysNSStringToUTF16(selection));
+}
+
+@end
« no previous file with comments | « ios/chrome/browser/passwords/update_password_infobar_controller.h ('k') | ios/chrome/ios_chrome.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698