1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_UI_VIEWS_PASSWORDS_MANAGE_PASSWORDS_VIEW_H_
#define CHROME_BROWSER_UI_VIEWS_PASSWORDS_MANAGE_PASSWORDS_VIEW_H_
#include "base/memory/raw_ptr.h"
#include "base/timer/timer.h"
#include "chrome/browser/ui/passwords/bubble_controllers/manage_passwords_bubble_controller.h"
#include "chrome/browser/ui/views/passwords/password_bubble_view_base.h"
#include "components/password_manager/core/browser/password_form.h"
#include "ui/base/interaction/element_identifier.h"
class PageSwitcherView;
class ManagePasswordsListView;
class ManagePasswordsDetailsView;
// A dialog for managing stored password and federated login information for a
// specific site. A user can see the details of the passwords, and edit the
// stored password note. The view can show up as a list of credentials or
// presenting details of a `PasswordForm`. For the latter mode, the initial
// password form must be provided by the `PasswordsModelDelegate` (in this case
// it can be an arbitrary password form, not necessarily related to the websise)
// or the user selects a password form from the list.
class ManagePasswordsView : public PasswordBubbleViewBase {
METADATA_HEADER(ManagePasswordsView, PasswordBubbleViewBase)
public:
DECLARE_CLASS_ELEMENT_IDENTIFIER_VALUE(kTopView);
DECLARE_CLASS_ELEMENT_IDENTIFIER_VALUE(kFooterId);
ManagePasswordsView(content::WebContents* web_contents,
views::View* anchor_view);
ManagePasswordsView(const ManagePasswordsView&) = delete;
ManagePasswordsView& operator=(const ManagePasswordsView&) = delete;
~ManagePasswordsView() override;
// Changes the contents of the page to display the details of `password_form`.
// Used for testing only to bypass mocking authentication flow.
void DisplayDetailsOfPasswordForTesting(
password_manager::PasswordForm password_form);
bool HasPasswordDetailsViewForTesting() const {
return !!password_details_view_;
}
private:
// PasswordBubbleViewBase
PasswordBubbleControllerBase* GetController() override;
const PasswordBubbleControllerBase* GetController() const override;
ui::ImageModel GetWindowIcon() override;
void AddedToWidget() override;
bool Cancel() override;
bool Accept() override;
std::unique_ptr<ManagePasswordsListView> CreatePasswordListView();
std::unique_ptr<ManagePasswordsDetailsView> CreatePasswordDetailsView();
std::unique_ptr<views::View> CreateFooterView();
std::unique_ptr<views::View> CreateMovePasswordFooterView();
// Changes the contents of the page to either display the details of
// `details_bubble_credential_` or the list of passwords when
// `details_bubble_credential_` isn't set.
void RecreateLayout();
void SwitchToReadingMode();
void SwitchToListView();
// Resets `auth_timer_` to restart counting till auto-navigation to the list
// view. It should be called upon user activity to make sure the back
// navigation doesn't happen while the user is interacting with the bubble.
void ExtendAuthValidity();
// Called when the favicon is loaded. If |favicon| isn't empty, it sets
// |favicon_| and invokes RecreateLayout().
void OnFaviconReady(const gfx::Image& favicon);
// Returns the image model representing site favicon. If favicon is empty or
// not loaded yet, it returns the image model of the globe icon.
ui::ImageModel GetFaviconImageModel() const;
// Requests the controller to start an OS user reauth to display the details
// of `password_form`. If reauth is successful, the view switches to the
// details view and displays the details of `password_form`. Otherwise, it
// remains on the list view.
void AuthenticateUserAndDisplayDetailsOf(
password_manager::PasswordForm password_form);
// Holds the favicon of the page when it is asynchronously loaded.
gfx::Image favicon_;
raw_ptr<ManagePasswordsDetailsView> password_details_view_ = nullptr;
ManagePasswordsBubbleController controller_;
raw_ptr<PageSwitcherView> page_container_ = nullptr;
// Used to keep track of the time once the user passed the auth challenge to
// navigate to the details view. Once it runs out, SwitchToListView() will be
// run.
base::OneShotTimer auth_timer_;
};
#endif // CHROME_BROWSER_UI_VIEWS_PASSWORDS_MANAGE_PASSWORDS_VIEW_H_
|