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
ash / wm / desks / templates / saved_desk_dialog_controller.h [blame]
// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef ASH_WM_DESKS_TEMPLATES_SAVED_DESK_DIALOG_CONTROLLER_H_
#define ASH_WM_DESKS_TEMPLATES_SAVED_DESK_DIALOG_CONTROLLER_H_
#include <memory>
#include "ash/ash_export.h"
#include "ash/public/cpp/desk_template.h"
#include "ash/style/system_dialog_delegate_view.h"
#include "ash/wm/desks/desks_controller.h"
#include "base/functional/callback.h"
#include "base/memory/raw_ptr.h"
#include "base/memory/weak_ptr.h"
#include "base/scoped_observation.h"
#include "ui/views/widget/widget.h"
#include "ui/views/widget/widget_observer.h"
namespace aura {
class Window;
}
namespace ash {
// SavedDeskDialogController controls when to show the various confirmation
// dialogs for modifying saved desks.
class ASH_EXPORT SavedDeskDialogController : public views::WidgetObserver {
public:
SavedDeskDialogController();
SavedDeskDialogController(const SavedDeskDialogController&) = delete;
SavedDeskDialogController& operator=(const SavedDeskDialogController&) =
delete;
~SavedDeskDialogController() override;
const views::Widget* dialog_widget() const { return dialog_widget_; }
// Shows the dialog. The dialog will look slightly different depending on the
// type. The `template_name` is used for the replace and delete dialogs, which
// show the name of the template which will be replaced and deleted in the
// dialog description.
void ShowUnsupportedAppsDialog(
aura::Window* root_window,
const std::vector<raw_ptr<aura::Window, VectorExperimental>>&
unsupported_apps,
size_t incognito_window_count,
DesksController::GetDeskTemplateCallback callback,
std::unique_ptr<DeskTemplate> desk_template);
void ShowReplaceDialog(aura::Window* root_window,
const std::u16string& template_name,
DeskTemplateType template_type,
base::OnceClosure on_accept_callback,
base::OnceClosure on_cancel_callback);
// Show the delete template dialog when user press the delete button.
// The `template_name` shows the name of the template which will be deleted in
// the dialog description.
void ShowDeleteDialog(aura::Window* root_window,
const std::u16string& template_name,
DeskTemplateType template_type,
base::OnceClosure on_accept_callback);
// views::WidgetObserver:
void OnWidgetDestroying(views::Widget* widget) override;
// Helper function to get the system dialog view.
const SystemDialogDelegateView* GetSystemDialogViewForTesting() const;
private:
// Creates and shows the dialog on `root_window`.
void CreateDialogWidget(std::unique_ptr<views::WidgetDelegate> dialog,
aura::Window* root_window);
// Returns true if a dialog can be shown.
bool CanShowDialog() const;
// Callbacks for when a user has either accepted the unsupported apps dialog
// or not.
void OnUserAcceptedUnsupportedAppsDialog();
void OnUserCanceledUnsupportedAppsDialog();
// Pointer to the widget (if any) that contains the current dialog.
raw_ptr<views::Widget> dialog_widget_ = nullptr;
// When a caller creates an unsupported apps dialog, they provide a callback
// for the result. Since we can only bind the callback once, we have to store
// the callback and DeskTemplate until we know what the user's choice is.
DesksController::GetDeskTemplateCallback unsupported_apps_callback_;
std::unique_ptr<DeskTemplate> unsupported_apps_template_;
base::ScopedObservation<views::Widget, views::WidgetObserver>
dialog_widget_observation_{this};
base::WeakPtrFactory<SavedDeskDialogController> weak_ptr_factory_{this};
};
} // namespace ash
#endif // ASH_WM_DESKS_TEMPLATES_SAVED_DESK_DIALOG_CONTROLLER_H_