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

Unified Diff: chrome/browser/ui/cocoa/passwords/manage_passwords_bubble_controller.mm

Issue 422233009: Add ManagePasswordsBubbleController and unit tests. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: NSWidth Created 6 years, 4 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/browser/ui/cocoa/passwords/manage_passwords_bubble_controller.mm
diff --git a/chrome/browser/ui/cocoa/passwords/manage_passwords_bubble_controller.mm b/chrome/browser/ui/cocoa/passwords/manage_passwords_bubble_controller.mm
new file mode 100644
index 0000000000000000000000000000000000000000..eec68a13bf1f74ba88c1aa68dfb49ee5ff08133c
--- /dev/null
+++ b/chrome/browser/ui/cocoa/passwords/manage_passwords_bubble_controller.mm
@@ -0,0 +1,111 @@
+// 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.
+
+#import "chrome/browser/ui/cocoa/passwords/manage_passwords_bubble_controller.h"
+
+#include "base/mac/scoped_nsobject.h"
+#import "chrome/browser/ui/cocoa/browser_window_controller.h"
+#import "chrome/browser/ui/cocoa/info_bubble_view.h"
+#import "chrome/browser/ui/cocoa/info_bubble_window.h"
+#include "chrome/browser/ui/cocoa/location_bar/location_bar_view_mac.h"
+#include "ui/base/cocoa/window_size_constants.h"
+
+@interface ManagePasswordsBubbleController ()
+// Updates the content view controller according to the current state.
+- (void)updateState;
+// Updates the content view controller and lays out the window.
+- (void)refresh;
+@end
+
+@implementation ManagePasswordsBubbleController
+- (id)initWithParentWindow:(NSWindow*)parentWindow
+ model:(ManagePasswordsBubbleModel*)model {
+ NSRect contentRect = ui::kWindowSizeDeterminedLater;
+ base::scoped_nsobject<InfoBubbleWindow> window(
+ [[InfoBubbleWindow alloc] initWithContentRect:contentRect
+ styleMask:NSBorderlessWindowMask
+ backing:NSBackingStoreBuffered
+ defer:NO]);
+ if ((self = [super initWithWindow:window
+ parentWindow:parentWindow
+ anchoredAt:NSZeroPoint])) {
+ model_ = model;
+ neverSave_ = false;
Scott Hess - ex-Googler 2014/08/07 23:54:14 And "NO" for false.
dconnelly 2014/08/08 09:03:15 Done.
+ [self refresh];
+ }
+ return self;
+}
+
+- (void)showWindow:(id)sender {
+ [self performLayout];
+ [super showWindow:sender];
+}
+
+- (void)updateState {
+ // Find the next view controller.
+ // TODO(dconnelly): Handle other states once they're implemented.
+ currentController_.reset();
+ if (password_manager::ui::IsPendingState(model_->state()) && !neverSave_) {
+ currentController_.reset([[ManagePasswordsBubblePendingViewController alloc]
+ initWithModel:model_
+ delegate:self]);
+ }
+}
+
+- (void)performLayout {
+ if (!currentController_)
+ return;
+
+ // Update the window.
+ NSWindow* window = [self window];
+ [[window contentView] setSubviews:@[ [currentController_ view] ]];
+
+ // Update the anchor.
+ BrowserWindowController* controller = [BrowserWindowController
+ browserWindowControllerForWindow:[self parentWindow]];
+ NSPoint anchorPoint =
+ [controller locationBarBridge]->GetManagePasswordsBubblePoint();
+ anchorPoint = [[self parentWindow] convertBaseToScreen:anchorPoint];
+ [self setAnchorPoint:anchorPoint];
+
+ // Update the frame.
+ CGFloat height = NSHeight([currentController_ view].frame) +
+ info_bubble::kBubbleArrowHeight;
+ CGFloat width = NSWidth([currentController_ view].frame);
+ CGFloat x = anchorPoint.x - width +
+ info_bubble::kBubbleArrowXOffset +
+ (0.5 * info_bubble::kBubbleArrowWidth);
+ CGFloat y = anchorPoint.y - height;
+ [window setFrame:NSMakeRect(x, y, width, height)
+ display:YES
+ animate:[[self window] isVisible]];
Scott Hess - ex-Googler 2014/08/07 23:54:14 [self window] => window.
dconnelly 2014/08/08 09:03:15 Done.
+}
+
+- (void)refresh {
+ [self updateState];
+ [self performLayout];
+}
+
+// ManagePasswordsBubbleContentViewDelegate
+
+- (void)viewShouldDismiss {
+ [self close];
+}
+
+// ManagePasswordsBubblePendingViewDelegate
+
+- (void)passwordShouldNeverBeSavedOnSiteWithExistingPasswords {
+ neverSave_ = true;
+ [self performLayout];
+}
+
+@end
+
+@implementation ManagePasswordsBubbleController (Testing)
+
+- (NSViewController*)currentController {
+ return currentController_.get();
+}
+
+@end

Powered by Google App Engine
This is Rietveld 408576698