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

Unified Diff: chrome/browser/ui/cocoa/autofill/autofill_popup_view_bridge.mm

Issue 267183002: Password manager: Implement password generation UI for Mac. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: More implementation Created 6 years, 7 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/autofill/autofill_popup_view_bridge.mm
diff --git a/chrome/browser/ui/cocoa/autofill/autofill_popup_view_bridge.mm b/chrome/browser/ui/cocoa/autofill/autofill_popup_view_bridge.mm
index d173e32b084ca2887c8a68aaff78eb52ba0a0c04..b623ea0c933c781bc495822638a3caf83d4e3cb2 100644
--- a/chrome/browser/ui/cocoa/autofill/autofill_popup_view_bridge.mm
+++ b/chrome/browser/ui/cocoa/autofill/autofill_popup_view_bridge.mm
@@ -8,74 +8,43 @@
#include "base/logging.h"
#include "chrome/browser/ui/autofill/autofill_popup_controller.h"
+#include "chrome/browser/ui/autofill/autofill_popup_view_delegate.h"
#import "chrome/browser/ui/cocoa/autofill/autofill_popup_view_cocoa.h"
-#include "ui/base/cocoa/window_size_constants.h"
#include "ui/gfx/rect.h"
namespace autofill {
AutofillPopupViewBridge::AutofillPopupViewBridge(
- AutofillPopupController* controller)
- : controller_(controller) {
- window_ =
- [[NSWindow alloc] initWithContentRect:ui::kWindowSizeDeterminedLater
- styleMask:NSBorderlessWindowMask
- backing:NSBackingStoreBuffered
- defer:YES];
- // Telling Cocoa that the window is opaque enables some drawing optimizations.
- [window_ setOpaque:YES];
-
- view_ = [[[AutofillPopupViewCocoa alloc]
- initWithController:controller_
- frame:NSZeroRect] autorelease];
- [window_ setContentView:view_];
+ AutofillPopupViewCocoa* view, AutofillPopupController* controller)
+ : view_(view), controller_(controller) {
}
AutofillPopupViewBridge::~AutofillPopupViewBridge() {
- [view_ controllerDestroyed];
-
- // Remove the child window before closing, otherwise it can mess up
- // display ordering.
- [[window_ parentWindow] removeChildWindow:window_];
-
- [window_ close];
}
void AutofillPopupViewBridge::Hide() {
- delete this;
+ [view_ hidePopup];
}
void AutofillPopupViewBridge::Show() {
- UpdateBoundsAndRedrawPopup();
- [[controller_->container_view() window] addChildWindow:window_
- ordered:NSWindowAbove];
+ [view_ showPopup];
}
void AutofillPopupViewBridge::InvalidateRow(size_t row) {
- NSRect dirty_rect =
- NSRectFromCGRect(controller_->GetRowBounds(row).ToCGRect());
- [view_ setNeedsDisplayInRect:dirty_rect];
+ [view_ invalidateRow:row];
}
void AutofillPopupViewBridge::UpdateBoundsAndRedrawPopup() {
- NSRect frame = NSRectFromCGRect(controller_->popup_bounds().ToCGRect());
-
- // Flip coordinates back into Cocoa-land. The controller's platform-neutral
- // coordinate space places the origin at the top-left of the first screen,
- // whereas Cocoa's coordinate space expects the origin to be at the
- // bottom-left of this same screen.
- NSScreen* screen = [[NSScreen screens] objectAtIndex:0];
- frame.origin.y = NSMaxY([screen frame]) - NSMaxY(frame);
-
- // TODO(isherman): The view should support scrolling if the popup gets too
- // big to fit on the screen.
- [window_ setFrame:frame display:YES];
- [view_ setNeedsDisplay:YES];
+ [view_ updateBoundsAndRedrawPopup];
}
AutofillPopupView* AutofillPopupView::Create(
AutofillPopupController* controller) {
- return new AutofillPopupViewBridge(controller);
+ AutofillPopupViewCocoa* view =
+ [[[AutofillPopupViewCocoa alloc]
+ initWithController:controller
+ frame:NSZeroRect] autorelease];
+ return new AutofillPopupViewBridge(view, controller);
}
} // namespace autofill

Powered by Google App Engine
This is Rietveld 408576698