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

Side by Side Diff: chrome/browser/ui/views/webshare/webshare_target_picker_view.h

Issue 2667803002: Picker takes a vector of pairs, and passes back the user chosen target. (Closed)
Patch Set: Enable share button, only if target selected Created 3 years, 10 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 unified diff | Download patch
OLDNEW
1 // Copyright 2017 The Chromium Authors. All rights reserved. 1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_UI_VIEWS_WEBSHARE_WEBSHARE_TARGET_PICKER_VIEW_H_ 5 #ifndef CHROME_BROWSER_UI_VIEWS_WEBSHARE_WEBSHARE_TARGET_PICKER_VIEW_H_
6 #define CHROME_BROWSER_UI_VIEWS_WEBSHARE_WEBSHARE_TARGET_PICKER_VIEW_H_ 6 #define CHROME_BROWSER_UI_VIEWS_WEBSHARE_WEBSHARE_TARGET_PICKER_VIEW_H_
7 7
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/callback.h" 10 #include "base/callback.h"
11 #include "base/macros.h" 11 #include "base/macros.h"
12 #include "base/strings/string16.h" 12 #include "base/strings/string16.h"
13 #include "chrome/browser/ui/browser_dialogs.h" 13 #include "chrome/browser/ui/browser_dialogs.h"
14 #include "ui/base/models/table_model.h" 14 #include "ui/base/models/table_model.h"
15 #include "ui/base/ui_base_types.h" 15 #include "ui/base/ui_base_types.h"
16 #include "ui/views/controls/table/table_view.h"
16 #include "ui/views/window/dialog_delegate.h" 17 #include "ui/views/window/dialog_delegate.h"
17 18
18 // Dialog that presents the user with a list of share target apps. Allows the 19 // Dialog that presents the user with a list of share target apps. Allows the
19 // user to pick one target to be opened and have data passed to it. 20 // user to pick one target to be opened and have data passed to it.
20 // 21 //
21 // NOTE: This dialog has *not* been UI-reviewed, and is being used by an 22 // NOTE: This dialog has *not* been UI-reviewed, and is being used by an
22 // in-development feature (Web Share) behind a runtime flag. It should not be 23 // in-development feature (Web Share) behind a runtime flag. It should not be
23 // used by any released code until going through UI review. 24 // used by any released code until going through UI review.
24 class WebShareTargetPickerView : public views::DialogDelegateView, 25 class WebShareTargetPickerView : public views::DialogDelegateView,
25 public ui::TableModel { 26 public ui::TableModel {
26 public: 27 public:
27 // |targets| is a list of app titles that will be shown in a list. Calls 28 // |targets| is a list of app titles that will be shown in a list. If the user
28 // |close_callback| with SHARE if an app was chosen, or CANCEL if the dialog 29 // picks a target, this calls |callback| with the manifest URL of the chosen
29 // was cancelled. 30 // target, and returns null if the user cancelled the share.
Matt Giuca 2017/02/01 07:04:33 s/and/or
constantina 2017/02/01 23:24:21 Done.
30 WebShareTargetPickerView( 31 WebShareTargetPickerView(
31 const std::vector<base::string16>& targets, 32 const std::vector<base::string16>& targets,
32 const base::Callback<void(SharePickerResult)>& close_callback); 33 const base::Callback<void(base::Optional<base::string16>)>&
34 close_callback);
33 ~WebShareTargetPickerView() override; 35 ~WebShareTargetPickerView() override;
34 36
35 // views::View overrides: 37 // views::View overrides:
36 gfx::Size GetPreferredSize() const override; 38 gfx::Size GetPreferredSize() const override;
37 39
38 // views::WidgetDelegate overrides: 40 // views::WidgetDelegate overrides:
39 ui::ModalType GetModalType() const override; 41 ui::ModalType GetModalType() const override;
40 base::string16 GetWindowTitle() const override; 42 base::string16 GetWindowTitle() const override;
41 43
42 // views::DialogDelegate overrides: 44 // views::DialogDelegate overrides:
43 bool Cancel() override; 45 bool Cancel() override;
44 bool Accept() override; 46 bool Accept() override;
45 base::string16 GetDialogButtonLabel(ui::DialogButton button) const override; 47 base::string16 GetDialogButtonLabel(ui::DialogButton button) const override;
48 bool IsDialogButtonEnabled(ui::DialogButton button) const override;
46 49
47 // ui::TableModel overrides: 50 // ui::TableModel overrides:
48 int RowCount() override; 51 int RowCount() override;
49 base::string16 GetText(int row, int column_id) override; 52 base::string16 GetText(int row, int column_id) override;
50 void SetObserver(ui::TableModelObserver* observer) override; 53 void SetObserver(ui::TableModelObserver* observer) override;
51 54
52 private: 55 private:
56 views::TableView* table_;
57
53 const std::vector<base::string16> targets_; 58 const std::vector<base::string16> targets_;
54 59
55 base::Callback<void(SharePickerResult)> close_callback_; 60 base::Callback<void(base::Optional<base::string16>)> close_callback_;
56 61
57 DISALLOW_COPY_AND_ASSIGN(WebShareTargetPickerView); 62 DISALLOW_COPY_AND_ASSIGN(WebShareTargetPickerView);
58 }; 63 };
59 64
60 #endif // CHROME_BROWSER_UI_VIEWS_WEBSHARE_WEBSHARE_TARGET_PICKER_VIEW_H_ 65 #endif // CHROME_BROWSER_UI_VIEWS_WEBSHARE_WEBSHARE_TARGET_PICKER_VIEW_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698