| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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_HARMONY_LAYOUT_DELEGATE_H_ | 5 #ifndef CHROME_BROWSER_UI_VIEWS_HARMONY_LAYOUT_DELEGATE_H_ |
| 6 #define CHROME_BROWSER_UI_VIEWS_HARMONY_LAYOUT_DELEGATE_H_ | 6 #define CHROME_BROWSER_UI_VIEWS_HARMONY_LAYOUT_DELEGATE_H_ |
| 7 | 7 |
| 8 #include "ui/views/layout/grid_layout.h" | 8 #include "ui/views/layout/grid_layout.h" |
| 9 | 9 |
| 10 class LayoutDelegate { | 10 class LayoutDelegate { |
| 11 public: | 11 public: |
| 12 enum class LayoutDistanceType { | 12 enum class LayoutDistanceType { |
| 13 // Left or right margin. | 13 // Horizontal or vertical margin between the edge of a dialog and a |
| 14 PANEL_HORIZ_MARGIN, | 14 // contained button. |
| 15 // Top or bottom margin. | 15 DIALOG_BUTTON_MARGIN, |
| 16 PANEL_VERT_MARGIN, | 16 // Horizontal or vertical margin between the edge of a panel and the |
| 17 // Horizontal spacing between controls that are logically related. | 17 // contained content. |
| 18 PANEL_CONTENT_MARGIN, |
| 19 // Horizontal spacing between buttons that are logically related, e.g. |
| 20 // for a button set. |
| 21 RELATED_BUTTON_HORIZONTAL_SPACING, |
| 22 // Horizontal spacing between other controls that are logically related. |
| 18 RELATED_CONTROL_HORIZONTAL_SPACING, | 23 RELATED_CONTROL_HORIZONTAL_SPACING, |
| 19 // Vertical spacing between controls that are logically related. | 24 // Vertical spacing between controls that are logically related. |
| 20 RELATED_CONTROL_VERTICAL_SPACING, | 25 RELATED_CONTROL_VERTICAL_SPACING, |
| 21 // Horizontal spacing between buttons that are logically related. | 26 // Horizontal indent of a subsection relative to related items above, e.g. |
| 22 RELATED_BUTTON_HORIZONTAL_SPACING, | 27 // checkboxes below explanatory text/headings. |
| 28 SUBSECTION_HORIZONTAL_INDENT, |
| 23 // Vertical spacing between controls that are logically unrelated. | 29 // Vertical spacing between controls that are logically unrelated. |
| 24 UNRELATED_CONTROL_VERTICAL_SPACING, | 30 UNRELATED_CONTROL_VERTICAL_SPACING, |
| 25 // Larger vertical spacing between unrelated controls. | 31 // Larger vertical spacing between unrelated controls. |
| 26 UNRELATED_CONTROL_LARGE_VERTICAL_SPACING, | 32 UNRELATED_CONTROL_VERTICAL_SPACING_LARGE, |
| 27 // Vertical spacing between the edge of the window and the | |
| 28 // top or bottom of a button. | |
| 29 BUTTON_HEDGE_MARGIN_NEW, | |
| 30 // Horizontal spacing between the edge of the window and the | |
| 31 // left or right of a button. | |
| 32 BUTTON_VEDGE_MARGIN_NEW, | |
| 33 // Indent of checkboxes relative to related text. | |
| 34 CHECKBOX_INDENT, | |
| 35 }; | 33 }; |
| 36 | 34 |
| 37 enum class DialogWidthType { | 35 enum class DialogWidthType { |
| 38 SMALL, | 36 SMALL, |
| 39 MEDIUM, | 37 MEDIUM, |
| 40 LARGE, | 38 LARGE, |
| 41 }; | 39 }; |
| 42 | 40 |
| 43 LayoutDelegate() {} | 41 LayoutDelegate() {} |
| 44 virtual ~LayoutDelegate() {} | 42 virtual ~LayoutDelegate() {} |
| 45 | 43 |
| 46 // Returns the active LayoutDelegate singleton, depending on UI configuration. | 44 // Returns the active LayoutDelegate singleton, depending on UI configuration. |
| 47 // By default, this is the same instance returned by Get(), but if Harmony | 45 // This may be an instance of this class or a subclass, e.g. a |
| 48 // or another UI style is enabled, this may be an instance of a LayoutDelegate | 46 // HarmonyLayoutDelegate. |
| 49 // subclass instead. | |
| 50 static LayoutDelegate* Get(); | 47 static LayoutDelegate* Get(); |
| 51 | 48 |
| 52 // Returns a layout distance, indexed by |type|. These distances are in | 49 // Returns the requested distance in DIPs. |
| 53 // device-independent units. | |
| 54 virtual int GetLayoutDistance(LayoutDistanceType type) const; | 50 virtual int GetLayoutDistance(LayoutDistanceType type) const; |
| 55 | 51 |
| 56 // Returns the alignment used for control labels in a GridLayout; for example, | 52 // Returns the alignment used for control labels in a GridLayout; for example, |
| 57 // in this GridLayout: | 53 // in this GridLayout: |
| 58 // --------------------------- | 54 // --------------------------- |
| 59 // | Label 1 Checkbox 1 | | 55 // | Label 1 Checkbox 1 | |
| 60 // | Label 2 Checkbox 2 | | 56 // | Label 2 Checkbox 2 | |
| 61 // --------------------------- | 57 // --------------------------- |
| 62 // This value controls the alignment used for "Label 1" and "Label 2". | 58 // This value controls the alignment used for "Label 1" and "Label 2". |
| 63 virtual views::GridLayout::Alignment GetControlLabelGridAlignment() const; | 59 virtual views::GridLayout::Alignment GetControlLabelGridAlignment() const; |
| 64 | 60 |
| 65 // Returns whether to use extra padding on dialogs. If this is false, content | 61 // Returns whether to use extra padding on dialogs. If this is false, content |
| 66 // Views for dialogs should not insert extra padding at their own edges. | 62 // Views for dialogs should not insert extra padding at their own edges. |
| 67 virtual bool UseExtraDialogPadding() const; | 63 virtual bool UseExtraDialogPadding() const; |
| 68 | 64 |
| 69 // Returns whether Harmony mode is enabled. This method is deprecated and | 65 // DEPRECATED. Returns whether Harmony mode is enabled. |
| 70 // should only be used in dire circumstances, such as when Harmony specifies a | 66 // |
| 71 // different distance type than was previously used. | 67 // Instead of using this, create a generic solution that works for all UI |
| 68 // types, e.g. by adding a new LayoutDistance value that means what you need. |
| 69 // |
| 70 // TODO(pkasting): Fix callers and remove this. |
| 72 virtual bool IsHarmonyMode() const; | 71 virtual bool IsHarmonyMode() const; |
| 73 | 72 |
| 74 // Returns the preferred width for a dialog of the specified width type. If | 73 // Returns the preferred width in DIPs for a dialog of the specified |type|. |
| 75 // there is no preferred width for |type|, returns 0. | 74 // May return 0 if the dialog has no preferred width. |
| 76 virtual int GetDialogPreferredWidth(DialogWidthType type) const; | 75 virtual int GetDialogPreferredWidth(DialogWidthType type) const; |
| 77 | 76 |
| 78 private: | 77 private: |
| 79 DISALLOW_COPY_AND_ASSIGN(LayoutDelegate); | 78 DISALLOW_COPY_AND_ASSIGN(LayoutDelegate); |
| 80 }; | 79 }; |
| 81 | 80 |
| 82 #endif // CHROME_BROWSER_UI_VIEWS_HARMONY_LAYOUT_DELEGATE_H_ | 81 #endif // CHROME_BROWSER_UI_VIEWS_HARMONY_LAYOUT_DELEGATE_H_ |
| OLD | NEW |