@wordpress/components 19.0.0 → 19.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (213) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/CONTRIBUTING.md +12 -12
  3. package/build/angle-picker-control/index.js +3 -1
  4. package/build/angle-picker-control/index.js.map +1 -1
  5. package/build/angle-picker-control/styles/angle-picker-control-styles.js +4 -4
  6. package/build/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  7. package/build/base-control/index.js +1 -1
  8. package/build/base-control/index.js.map +1 -1
  9. package/build/color-edit/index.js +180 -199
  10. package/build/color-edit/index.js.map +1 -1
  11. package/build/color-edit/styles.js +112 -0
  12. package/build/color-edit/styles.js.map +1 -0
  13. package/build/color-list-picker/index.js +6 -1
  14. package/build/color-list-picker/index.js.map +1 -1
  15. package/build/color-palette/index.js +86 -21
  16. package/build/color-palette/index.js.map +1 -1
  17. package/build/color-palette/styles.js +31 -0
  18. package/build/color-palette/styles.js.map +1 -0
  19. package/build/color-picker/component.js +7 -18
  20. package/build/color-picker/component.js.map +1 -1
  21. package/build/color-picker/picker.js +3 -3
  22. package/build/color-picker/picker.js.map +1 -1
  23. package/build/duotone-picker/custom-duotone-bar.js +0 -1
  24. package/build/duotone-picker/custom-duotone-bar.js.map +1 -1
  25. package/build/duotone-picker/duotone-picker.js +1 -0
  26. package/build/duotone-picker/duotone-picker.js.map +1 -1
  27. package/build/gradient-picker/index.js +69 -9
  28. package/build/gradient-picker/index.js.map +1 -1
  29. package/build/index.native.js +9 -0
  30. package/build/index.native.js.map +1 -1
  31. package/build/mobile/bottom-sheet/cell.native.js +4 -2
  32. package/build/mobile/bottom-sheet/cell.native.js.map +1 -1
  33. package/build/mobile/bottom-sheet/link-cell.native.js +3 -2
  34. package/build/mobile/bottom-sheet/link-cell.native.js.map +1 -1
  35. package/build/mobile/link-settings/image-link-destinations-screen.native.js +140 -0
  36. package/build/mobile/link-settings/image-link-destinations-screen.native.js.map +1 -0
  37. package/build/mobile/link-settings/index.native.js +3 -2
  38. package/build/mobile/link-settings/index.native.js.map +1 -1
  39. package/build/mobile/link-settings/link-settings-navigation.native.js +1 -0
  40. package/build/mobile/link-settings/link-settings-navigation.native.js.map +1 -1
  41. package/build/mobile/link-settings/link-settings-screen.native.js +11 -5
  42. package/build/mobile/link-settings/link-settings-screen.native.js.map +1 -1
  43. package/build/mobile/picker/index.android.js +4 -2
  44. package/build/mobile/picker/index.android.js.map +1 -1
  45. package/build/modal/index.js +10 -3
  46. package/build/modal/index.js.map +1 -1
  47. package/build/navigation/group/index.js +1 -2
  48. package/build/navigation/group/index.js.map +1 -1
  49. package/build/navigation/menu/menu-title-search.js +8 -27
  50. package/build/navigation/menu/menu-title-search.js.map +1 -1
  51. package/build/navigation/menu/menu-title.js +2 -2
  52. package/build/navigation/menu/menu-title.js.map +1 -1
  53. package/build/navigation/styles/navigation-styles.js +34 -29
  54. package/build/navigation/styles/navigation-styles.js.map +1 -1
  55. package/build/popover/index.js +4 -2
  56. package/build/popover/index.js.map +1 -1
  57. package/build/range-control/styles/range-control-styles.js +33 -29
  58. package/build/range-control/styles/range-control-styles.js.map +1 -1
  59. package/build/search-control/index.js +37 -14
  60. package/build/search-control/index.js.map +1 -1
  61. package/build/text/styles.js +7 -7
  62. package/build/text/styles.js.map +1 -1
  63. package/build/tools-panel/styles.js +18 -23
  64. package/build/tools-panel/styles.js.map +1 -1
  65. package/build/tools-panel/tools-panel/component.js +10 -7
  66. package/build/tools-panel/tools-panel/component.js.map +1 -1
  67. package/build/tools-panel/tools-panel/hook.js +3 -1
  68. package/build/tools-panel/tools-panel/hook.js.map +1 -1
  69. package/build/tools-panel/tools-panel-header/component.js +3 -0
  70. package/build/tools-panel/tools-panel-header/component.js.map +1 -1
  71. package/build/utils/hooks/index.js +8 -0
  72. package/build/utils/hooks/index.js.map +1 -1
  73. package/build/utils/hooks/use-combined-ref.js +28 -0
  74. package/build/utils/hooks/use-combined-ref.js.map +1 -0
  75. package/build-module/angle-picker-control/index.js +3 -1
  76. package/build-module/angle-picker-control/index.js.map +1 -1
  77. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js +4 -4
  78. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  79. package/build-module/base-control/index.js +1 -1
  80. package/build-module/base-control/index.js.map +1 -1
  81. package/build-module/color-edit/index.js +175 -201
  82. package/build-module/color-edit/index.js.map +1 -1
  83. package/build-module/color-edit/styles.js +90 -0
  84. package/build-module/color-edit/styles.js.map +1 -0
  85. package/build-module/color-list-picker/index.js +6 -1
  86. package/build-module/color-list-picker/index.js.map +1 -1
  87. package/build-module/color-palette/index.js +85 -22
  88. package/build-module/color-palette/index.js.map +1 -1
  89. package/build-module/color-palette/styles.js +27 -0
  90. package/build-module/color-palette/styles.js.map +1 -0
  91. package/build-module/color-picker/component.js +7 -16
  92. package/build-module/color-picker/component.js.map +1 -1
  93. package/build-module/color-picker/picker.js +4 -4
  94. package/build-module/color-picker/picker.js.map +1 -1
  95. package/build-module/duotone-picker/custom-duotone-bar.js +0 -1
  96. package/build-module/duotone-picker/custom-duotone-bar.js.map +1 -1
  97. package/build-module/duotone-picker/duotone-picker.js +1 -0
  98. package/build-module/duotone-picker/duotone-picker.js.map +1 -1
  99. package/build-module/gradient-picker/index.js +67 -9
  100. package/build-module/gradient-picker/index.js.map +1 -1
  101. package/build-module/index.native.js +1 -0
  102. package/build-module/index.native.js.map +1 -1
  103. package/build-module/mobile/bottom-sheet/cell.native.js +4 -2
  104. package/build-module/mobile/bottom-sheet/cell.native.js.map +1 -1
  105. package/build-module/mobile/bottom-sheet/link-cell.native.js +3 -2
  106. package/build-module/mobile/bottom-sheet/link-cell.native.js.map +1 -1
  107. package/build-module/mobile/link-settings/image-link-destinations-screen.native.js +121 -0
  108. package/build-module/mobile/link-settings/image-link-destinations-screen.native.js.map +1 -0
  109. package/build-module/mobile/link-settings/index.native.js +3 -2
  110. package/build-module/mobile/link-settings/index.native.js.map +1 -1
  111. package/build-module/mobile/link-settings/link-settings-navigation.native.js +1 -0
  112. package/build-module/mobile/link-settings/link-settings-navigation.native.js.map +1 -1
  113. package/build-module/mobile/link-settings/link-settings-screen.native.js +11 -5
  114. package/build-module/mobile/link-settings/link-settings-screen.native.js.map +1 -1
  115. package/build-module/mobile/picker/index.android.js +4 -2
  116. package/build-module/mobile/picker/index.android.js.map +1 -1
  117. package/build-module/modal/index.js +10 -4
  118. package/build-module/modal/index.js.map +1 -1
  119. package/build-module/navigation/group/index.js +1 -2
  120. package/build-module/navigation/group/index.js.map +1 -1
  121. package/build-module/navigation/menu/menu-title-search.js +8 -24
  122. package/build-module/navigation/menu/menu-title-search.js.map +1 -1
  123. package/build-module/navigation/menu/menu-title.js +3 -3
  124. package/build-module/navigation/menu/menu-title.js.map +1 -1
  125. package/build-module/navigation/styles/navigation-styles.js +31 -27
  126. package/build-module/navigation/styles/navigation-styles.js.map +1 -1
  127. package/build-module/popover/index.js +4 -2
  128. package/build-module/popover/index.js.map +1 -1
  129. package/build-module/range-control/styles/range-control-styles.js +33 -29
  130. package/build-module/range-control/styles/range-control-styles.js.map +1 -1
  131. package/build-module/search-control/index.js +36 -15
  132. package/build-module/search-control/index.js.map +1 -1
  133. package/build-module/text/styles.js +7 -7
  134. package/build-module/text/styles.js.map +1 -1
  135. package/build-module/tools-panel/styles.js +16 -23
  136. package/build-module/tools-panel/styles.js.map +1 -1
  137. package/build-module/tools-panel/tools-panel/component.js +10 -6
  138. package/build-module/tools-panel/tools-panel/component.js.map +1 -1
  139. package/build-module/tools-panel/tools-panel/hook.js +2 -1
  140. package/build-module/tools-panel/tools-panel/hook.js.map +1 -1
  141. package/build-module/tools-panel/tools-panel-header/component.js +3 -0
  142. package/build-module/tools-panel/tools-panel-header/component.js.map +1 -1
  143. package/build-module/utils/hooks/index.js +1 -0
  144. package/build-module/utils/hooks/index.js.map +1 -1
  145. package/build-module/utils/hooks/use-combined-ref.js +25 -0
  146. package/build-module/utils/hooks/use-combined-ref.js.map +1 -0
  147. package/build-style/style-rtl.css +39 -51
  148. package/build-style/style.css +39 -51
  149. package/build-types/range-control/styles/range-control-styles.d.ts.map +1 -1
  150. package/build-types/tools-panel/styles.d.ts +1 -1
  151. package/build-types/tools-panel/styles.d.ts.map +1 -1
  152. package/build-types/tools-panel/tools-panel/component.d.ts.map +1 -1
  153. package/build-types/tools-panel/tools-panel/hook.d.ts.map +1 -1
  154. package/build-types/tools-panel/tools-panel-header/component.d.ts.map +1 -1
  155. package/build-types/utils/hooks/index.d.ts +1 -0
  156. package/build-types/utils/hooks/use-combined-ref.d.ts +8 -0
  157. package/build-types/utils/hooks/use-combined-ref.d.ts.map +1 -0
  158. package/package.json +6 -6
  159. package/src/angle-picker-control/index.js +3 -1
  160. package/src/angle-picker-control/styles/angle-picker-control-styles.js +2 -2
  161. package/src/base-control/index.js +1 -1
  162. package/src/circular-option-picker/style.scss +3 -5
  163. package/src/color-edit/index.js +248 -274
  164. package/src/color-edit/style.scss +4 -45
  165. package/src/color-edit/styles.js +97 -0
  166. package/src/color-list-picker/index.js +5 -0
  167. package/src/color-list-picker/style.scss +4 -0
  168. package/src/color-palette/index.js +90 -26
  169. package/src/color-palette/style.scss +18 -0
  170. package/src/color-palette/styles.js +19 -0
  171. package/src/color-palette/test/__snapshots__/index.js.snap +448 -414
  172. package/src/color-picker/component.tsx +6 -17
  173. package/src/color-picker/picker.tsx +6 -4
  174. package/src/color-picker/test/index.js +0 -15
  175. package/src/duotone-picker/custom-duotone-bar.js +0 -1
  176. package/src/duotone-picker/duotone-picker.js +1 -0
  177. package/src/gradient-picker/index.js +79 -11
  178. package/src/heading/test/__snapshots__/index.js.snap +1 -1
  179. package/src/index.native.js +1 -0
  180. package/src/mobile/bottom-sheet/cell.native.js +7 -2
  181. package/src/mobile/bottom-sheet/cellStyles.android.scss +5 -1
  182. package/src/mobile/bottom-sheet/cellStyles.ios.scss +5 -1
  183. package/src/mobile/bottom-sheet/link-cell.native.js +10 -3
  184. package/src/mobile/link-settings/image-link-destinations-screen.native.js +148 -0
  185. package/src/mobile/link-settings/index.native.js +3 -2
  186. package/src/mobile/link-settings/link-settings-navigation.native.js +1 -0
  187. package/src/mobile/link-settings/link-settings-screen.native.js +6 -2
  188. package/src/mobile/link-settings/style.native.scss +17 -0
  189. package/src/mobile/picker/index.android.js +2 -1
  190. package/src/modal/README.md +8 -0
  191. package/src/modal/index.js +60 -45
  192. package/src/modal/style.scss +5 -0
  193. package/src/navigation/group/index.js +1 -2
  194. package/src/navigation/menu/menu-title-search.js +11 -26
  195. package/src/navigation/menu/menu-title.js +4 -4
  196. package/src/navigation/styles/navigation-styles.js +29 -52
  197. package/src/popover/index.js +2 -2
  198. package/src/range-control/styles/range-control-styles.js +4 -1
  199. package/src/resizable-box/style.scss +5 -0
  200. package/src/search-control/index.js +47 -23
  201. package/src/style.scss +1 -0
  202. package/src/text/styles.js +1 -1
  203. package/src/text/test/__snapshots__/index.js.snap +2 -2
  204. package/src/tools-panel/stories/index.js +21 -19
  205. package/src/tools-panel/styles.ts +18 -26
  206. package/src/tools-panel/tools-panel/component.tsx +7 -4
  207. package/src/tools-panel/tools-panel/hook.ts +4 -1
  208. package/src/tools-panel/tools-panel-header/component.tsx +1 -0
  209. package/src/ui/control-label/test/__snapshots__/index.js.snap +3 -3
  210. package/src/ui/form-group/test/__snapshots__/index.js.snap +2 -2
  211. package/src/utils/hooks/index.js +1 -0
  212. package/src/utils/hooks/use-combined-ref.ts +29 -0
  213. package/tsconfig.tsbuildinfo +1 -1
@@ -1,240 +1,214 @@
1
+ import _extends from "@babel/runtime/helpers/esm/extends";
1
2
  import { createElement, Fragment } from "@wordpress/element";
2
3
 
3
4
  /**
4
5
  * External dependencies
5
6
  */
6
- import classnames from 'classnames';
7
- import { isEmpty, kebabCase } from 'lodash';
7
+ import kebabCase from 'lodash';
8
8
  /**
9
9
  * WordPress dependencies
10
10
  */
11
11
 
12
- import { __, sprintf } from '@wordpress/i18n';
13
- import { useEffect, useState } from '@wordpress/element';
14
- import { edit, close, chevronDown, chevronUp, plus } from '@wordpress/icons';
12
+ import { useState, useRef, useEffect } from '@wordpress/element';
13
+ import { __ } from '@wordpress/i18n';
14
+ import { lineSolid, moreVertical, plus } from '@wordpress/icons';
15
+ import { __experimentalUseFocusOutside as useFocusOutside } from '@wordpress/compose';
15
16
  /**
16
17
  * Internal dependencies
17
18
  */
18
19
 
19
- import Dropdown from '../dropdown';
20
- import CircularOptionPicker from '../circular-option-picker';
21
- import { ColorPicker } from '../color-picker';
22
20
  import Button from '../button';
23
- import TextControl from '../text-control';
24
- import BaseControl from '../base-control';
21
+ import { ColorPicker } from '../color-picker';
22
+ import { FlexItem } from '../flex';
23
+ import { HStack } from '../h-stack';
24
+ import { ItemGroup } from '../item-group';
25
+ import { VStack } from '../v-stack';
26
+ import ColorPalette from '../color-palette';
27
+ import DropdownMenu from '../dropdown-menu';
28
+ import Popover from '../popover';
29
+ import { ColorActionsContainer, ColorEditStyles, ColorHeading, ColorHStackHeader, ColorIndicatorStyled, ColorItem, ColorNameContainer, ColorNameInputControl, DoneButton, RemoveButton } from './styles';
30
+ import { NavigableMenu } from '../navigable-container';
25
31
 
26
- function DropdownOpenOnMount({
27
- shouldOpen,
28
- isOpen,
29
- onToggle
32
+ function ColorNameInput({
33
+ value,
34
+ onChange
30
35
  }) {
31
- useEffect(() => {
32
- if (shouldOpen && !isOpen) {
33
- onToggle();
34
- }
35
- }, []);
36
- return null;
36
+ return createElement(ColorNameInputControl, {
37
+ label: __('Color name'),
38
+ hideLabelFromVision: true,
39
+ value: value,
40
+ onChange: onChange
41
+ });
37
42
  }
38
43
 
39
44
  function ColorOption({
40
45
  color,
41
- name,
42
- slug,
43
46
  onChange,
47
+ isEditing,
48
+ onStartEditing,
44
49
  onRemove,
45
- onConfirm,
46
- confirmLabel = __('OK'),
47
- isEditingNameOnMount = false,
48
- isEditingColorOnMount = false,
49
- onCancel,
50
- immutableColorSlugs = []
50
+ onStopEditing
51
51
  }) {
52
- const [isHover, setIsHover] = useState(false);
53
- const [isFocused, setIsFocused] = useState(false);
54
- const [isEditingName, setIsEditingName] = useState(isEditingNameOnMount);
55
- const [isShowingAdvancedPanel, setIsShowingAdvancedPanel] = useState(false);
56
- const isShowingControls = (isHover || isFocused || isEditingName || isShowingAdvancedPanel) && !immutableColorSlugs.includes(slug);
57
- return createElement("div", {
58
- tabIndex: 0,
59
- className: classnames('components-color-edit__color-option', {
60
- 'is-hover': isHover && !isEditingName && !isShowingAdvancedPanel
61
- }),
62
- onMouseEnter: () => setIsHover(true),
63
- onMouseLeave: () => setIsHover(false),
64
- onFocus: () => setIsFocused(true),
65
- onBlur: () => setIsFocused(false),
66
- "aria-label": name ? // translators: %s: The name of the color e.g: "vivid red".
67
- sprintf(__('Color: %s'), name) : // translators: %s: color hex code e.g: "#f00".
68
- sprintf(__('Color code: %s'), color)
69
- }, createElement("div", {
70
- className: "components-color-edit__color-option-main-area"
71
- }, createElement(Dropdown, {
72
- renderToggle: ({
73
- isOpen,
74
- onToggle
75
- }) => createElement(Fragment, null, createElement(DropdownOpenOnMount, {
76
- shouldOpen: isEditingColorOnMount,
77
- isOpen: isOpen,
78
- onToggle: onToggle
79
- }), createElement(CircularOptionPicker.Option, {
80
- style: {
81
- backgroundColor: color,
82
- color
83
- },
84
- "aria-expanded": isOpen,
85
- "aria-haspopup": "true",
86
- onClick: onToggle,
87
- "aria-label": __('Edit color value')
88
- })),
89
- renderContent: () => createElement(ColorPicker, {
90
- color: color,
91
- onChange: newColor => onChange({
92
- color: newColor,
93
- slug,
94
- name
95
- })
52
+ const focusOutsideProps = useFocusOutside(onStopEditing);
53
+ return createElement(ColorItem, _extends({
54
+ as: "div",
55
+ onClick: onStartEditing
56
+ }, isEditing ? focusOutsideProps : {}), createElement(HStack, {
57
+ justify: "flex-start"
58
+ }, createElement(FlexItem, null, createElement(ColorIndicatorStyled, {
59
+ colorValue: color.color
60
+ })), createElement(FlexItem, null, isEditing ? createElement(ColorNameInput, {
61
+ value: color.name,
62
+ onChange: nextName => onChange({ ...color,
63
+ name: nextName,
64
+ slug: kebabCase(nextName)
96
65
  })
97
- }), !isEditingName && createElement("div", {
98
- className: "components-color-edit__color-option-color-name"
99
- }, name), isEditingName && createElement(Fragment, null, createElement(TextControl, {
100
- className: "components-color-edit__color-option-color-name-input",
101
- hideLabelFromVision: true,
102
- onChange: newColorName => onChange({
103
- color,
104
- slug: kebabCase(newColorName),
105
- name: newColorName
106
- }),
107
- label: __('Color name'),
108
- placeholder: __('Name'),
109
- value: name
110
- }), createElement(Button, {
111
- onClick: () => {
112
- setIsEditingName(false);
113
- setIsFocused(false);
114
-
115
- if (onConfirm) {
116
- onConfirm();
117
- }
118
- },
119
- variant: "primary"
120
- }, confirmLabel)), !isEditingName && createElement(Fragment, null, createElement(Button, {
121
- className: classnames({
122
- 'components-color-edit__hidden-control': !isShowingControls
123
- }),
124
- icon: edit,
125
- label: __('Edit color name'),
126
- onClick: () => setIsEditingName(true)
127
- }), createElement(Button, {
128
- className: classnames({
129
- 'components-color-edit__hidden-control': !isShowingControls
130
- }),
131
- icon: close,
66
+ }) : createElement(ColorNameContainer, null, color.name)), isEditing && createElement(FlexItem, null, createElement(RemoveButton, {
67
+ isSmall: true,
68
+ icon: lineSolid,
132
69
  label: __('Remove color'),
133
70
  onClick: onRemove
134
- })), createElement(Button, {
135
- className: classnames({
136
- 'components-color-edit__hidden-control': !isShowingControls
137
- }),
138
- icon: isShowingAdvancedPanel ? chevronUp : chevronDown,
139
- label: __('Additional color settings'),
140
- onClick: () => {
141
- if (isShowingAdvancedPanel) {
142
- setIsFocused(false);
143
- }
144
-
145
- setIsShowingAdvancedPanel(!isShowingAdvancedPanel);
146
- },
147
- "aria-expanded": isShowingAdvancedPanel
148
- })), onCancel && createElement(Button, {
149
- className: "components-color-edit__cancel-button",
150
- onClick: onCancel
151
- }, __('Cancel')), isShowingAdvancedPanel && createElement(TextControl, {
152
- className: "components-color-edit__slug-input",
153
- onChange: newSlug => onChange({
154
- color,
155
- slug: newSlug,
156
- name
157
- }),
158
- label: __('Slug'),
159
- value: slug
160
- }));
161
- }
162
-
163
- function ColorInserter({
164
- onInsert,
165
- onCancel
166
- }) {
167
- const [color, setColor] = useState({
168
- color: '#fff',
169
- name: '',
170
- slug: ''
171
- });
172
- return createElement(ColorOption, {
71
+ }))), isEditing && createElement(Popover, {
72
+ position: "bottom left",
73
+ className: "components-color-edit__color-popover"
74
+ }, createElement(ColorPicker, {
173
75
  color: color.color,
174
- name: color.name,
175
- slug: color.slug,
176
- onChange: setColor,
177
- confirmLabel: __('Save'),
178
- onConfirm: () => onInsert(color),
179
- isEditingNameOnMount: true,
180
- isEditingColorOnMount: true,
181
- onCancel: onCancel
182
- });
76
+ onChange: newColor => onChange({ ...color,
77
+ color: newColor
78
+ })
79
+ })));
183
80
  }
184
81
 
185
- export default function ColorEdit({
82
+ function ColorPaletteEditListView({
186
83
  colors,
187
84
  onChange,
188
- emptyUI,
189
- immutableColorSlugs,
190
- canReset = true
85
+ editingColor,
86
+ setEditingColor
191
87
  }) {
192
- const [isInsertingColor, setIsInsertingColor] = useState(false);
193
- return createElement(BaseControl, null, createElement("fieldset", null, createElement("div", {
194
- className: "components-color-edit__label-and-insert-container"
195
- }, createElement("legend", null, createElement("div", null, createElement(BaseControl.VisualLabel, null, __('Color palette')))), !isInsertingColor && createElement(Button, {
196
- onClick: () => {
197
- setIsInsertingColor(true);
88
+ // When unmounting the component if there are empty colors (the user did not complete the insertion) clean them.
89
+ const colorReference = useRef();
90
+ useEffect(() => {
91
+ colorReference.current = colors;
92
+ }, [colors]);
93
+ useEffect(() => {
94
+ return () => {
95
+ if (colorReference.current.some(({
96
+ slug
97
+ }) => !slug)) {
98
+ const newColors = colorReference.current.filter(({
99
+ slug
100
+ }) => slug);
101
+ onChange(newColors.length ? newColors : undefined);
102
+ }
103
+ };
104
+ }, []);
105
+ return createElement(VStack, {
106
+ spacing: 3
107
+ }, createElement(ItemGroup, {
108
+ isBordered: true,
109
+ isSeparated: true
110
+ }, colors.map((color, index) => createElement(ColorOption, {
111
+ key: index,
112
+ color: color,
113
+ onStartEditing: () => {
114
+ if (editingColor !== index) {
115
+ setEditingColor(index);
116
+ }
198
117
  },
199
- className: "components-color-edit__insert-button",
200
- icon: plus
201
- })), createElement("div", null, !isEmpty(colors) && colors.map((color, index) => {
202
- return createElement(ColorOption, {
203
- key: index,
204
- color: color.color,
205
- name: color.name,
206
- slug: color.slug,
207
- immutableColorSlugs: immutableColorSlugs,
208
- onChange: newColor => {
209
- onChange(colors.map((currentColor, currentIndex) => {
210
- if (currentIndex === index) {
211
- return newColor;
212
- }
118
+ onChange: newColor => {
119
+ onChange(colors.map((currentColor, currentIndex) => {
120
+ if (currentIndex === index) {
121
+ return newColor;
122
+ }
213
123
 
214
- return currentColor;
215
- }));
216
- },
217
- onRemove: () => {
218
- onChange(colors.filter((_currentColor, currentIndex) => {
219
- if (currentIndex === index) {
220
- return false;
221
- }
124
+ return currentColor;
125
+ }));
126
+ },
127
+ onRemove: () => {
128
+ setEditingColor(null);
129
+ const newColors = colors.filter((_currentColor, currentIndex) => {
130
+ if (currentIndex === index) {
131
+ return false;
132
+ }
222
133
 
223
- return true;
224
- }));
225
- }
226
- });
227
- }), isInsertingColor && createElement(ColorInserter, {
228
- onInsert: newColor => {
229
- setIsInsertingColor(false);
230
- onChange([...(colors || []), newColor]);
134
+ return true;
135
+ });
136
+ onChange(newColors.length ? newColors : undefined);
231
137
  },
232
- onCancel: () => setIsInsertingColor(false)
233
- }), !isInsertingColor && isEmpty(colors) && emptyUI), !!canReset && createElement(Button, {
138
+ isEditing: index === editingColor,
139
+ onStopEditing: () => {
140
+ if (index === editingColor) {
141
+ setEditingColor(null);
142
+ }
143
+ }
144
+ }))));
145
+ }
146
+
147
+ const EMPTY_ARRAY = [];
148
+ export default function ColorEdit({
149
+ colors = EMPTY_ARRAY,
150
+ onChange
151
+ }) {
152
+ const [isEditing, setIsEditing] = useState(false);
153
+ const [editingColor, setEditingColor] = useState(null);
154
+ const isAdding = isEditing && editingColor && colors[editingColor] && !colors[editingColor].slug;
155
+ const hasColors = colors.length > 0;
156
+ return createElement(ColorEditStyles, null, createElement(ColorHStackHeader, null, createElement(ColorHeading, null, __('Custom')), createElement(ColorActionsContainer, null, isEditing && createElement(DoneButton, {
157
+ isSmall: true,
158
+ onClick: () => {
159
+ setIsEditing(false);
160
+ setEditingColor(null);
161
+ }
162
+ }, __('Done')), createElement(Button, {
163
+ isSmall: true,
164
+ isPressed: isAdding,
165
+ icon: plus,
166
+ label: __('Add custom color'),
167
+ onClick: () => {
168
+ onChange([...colors, {
169
+ color: '#000',
170
+ name: '',
171
+ slug: ''
172
+ }]);
173
+ setIsEditing(true);
174
+ setEditingColor(colors.length);
175
+ }
176
+ }), !isEditing && createElement(Button, {
177
+ disabled: !hasColors,
234
178
  isSmall: true,
235
- variant: "secondary",
236
- className: "components-color-edit__reset-button",
237
- onClick: () => onChange()
238
- }, __('Reset'))));
179
+ icon: moreVertical,
180
+ label: __('Edit colors'),
181
+ onClick: () => {
182
+ setIsEditing(true);
183
+ }
184
+ }), isEditing && createElement(DropdownMenu, {
185
+ icon: moreVertical,
186
+ label: __('Custom color options'),
187
+ toggleProps: {
188
+ isSmall: true
189
+ }
190
+ }, ({
191
+ onClose
192
+ }) => createElement(Fragment, null, createElement(NavigableMenu, {
193
+ role: "menu"
194
+ }, createElement(Button, {
195
+ variant: "tertiary",
196
+ onClick: () => {
197
+ setEditingColor(null);
198
+ setIsEditing(false);
199
+ onChange();
200
+ onClose();
201
+ }
202
+ }, __('Remove all custom colors'))))))), hasColors && createElement(Fragment, null, isEditing && createElement(ColorPaletteEditListView, {
203
+ colors: colors,
204
+ onChange: onChange,
205
+ editingColor: editingColor,
206
+ setEditingColor: setEditingColor
207
+ }), !isEditing && createElement(ColorPalette, {
208
+ colors: colors,
209
+ onChange: () => {},
210
+ clearable: false,
211
+ disableCustomColors: true
212
+ })), !hasColors && __('Custom colors are empty! Add some colors to create your own color palette.'));
239
213
  }
240
214
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/color-edit/index.js"],"names":["classnames","isEmpty","kebabCase","__","sprintf","useEffect","useState","edit","close","chevronDown","chevronUp","plus","Dropdown","CircularOptionPicker","ColorPicker","Button","TextControl","BaseControl","DropdownOpenOnMount","shouldOpen","isOpen","onToggle","ColorOption","color","name","slug","onChange","onRemove","onConfirm","confirmLabel","isEditingNameOnMount","isEditingColorOnMount","onCancel","immutableColorSlugs","isHover","setIsHover","isFocused","setIsFocused","isEditingName","setIsEditingName","isShowingAdvancedPanel","setIsShowingAdvancedPanel","isShowingControls","includes","backgroundColor","newColor","newColorName","newSlug","ColorInserter","onInsert","setColor","ColorEdit","colors","emptyUI","canReset","isInsertingColor","setIsInsertingColor","map","index","currentColor","currentIndex","filter","_currentColor"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport classnames from 'classnames';\nimport { isEmpty, kebabCase } from 'lodash';\n\n/**\n * WordPress dependencies\n */\nimport { __, sprintf } from '@wordpress/i18n';\nimport { useEffect, useState } from '@wordpress/element';\nimport { edit, close, chevronDown, chevronUp, plus } from '@wordpress/icons';\n\n/**\n * Internal dependencies\n */\nimport Dropdown from '../dropdown';\nimport CircularOptionPicker from '../circular-option-picker';\nimport { ColorPicker } from '../color-picker';\nimport Button from '../button';\nimport TextControl from '../text-control';\nimport BaseControl from '../base-control';\n\nfunction DropdownOpenOnMount( { shouldOpen, isOpen, onToggle } ) {\n\tuseEffect( () => {\n\t\tif ( shouldOpen && ! isOpen ) {\n\t\t\tonToggle();\n\t\t}\n\t}, [] );\n\treturn null;\n}\n\nfunction ColorOption( {\n\tcolor,\n\tname,\n\tslug,\n\tonChange,\n\tonRemove,\n\tonConfirm,\n\tconfirmLabel = __( 'OK' ),\n\tisEditingNameOnMount = false,\n\tisEditingColorOnMount = false,\n\tonCancel,\n\timmutableColorSlugs = [],\n} ) {\n\tconst [ isHover, setIsHover ] = useState( false );\n\tconst [ isFocused, setIsFocused ] = useState( false );\n\tconst [ isEditingName, setIsEditingName ] = useState(\n\t\tisEditingNameOnMount\n\t);\n\tconst [ isShowingAdvancedPanel, setIsShowingAdvancedPanel ] = useState(\n\t\tfalse\n\t);\n\n\tconst isShowingControls =\n\t\t( isHover || isFocused || isEditingName || isShowingAdvancedPanel ) &&\n\t\t! immutableColorSlugs.includes( slug );\n\n\treturn (\n\t\t<div\n\t\t\ttabIndex={ 0 }\n\t\t\tclassName={ classnames( 'components-color-edit__color-option', {\n\t\t\t\t'is-hover':\n\t\t\t\t\tisHover && ! isEditingName && ! isShowingAdvancedPanel,\n\t\t\t} ) }\n\t\t\tonMouseEnter={ () => setIsHover( true ) }\n\t\t\tonMouseLeave={ () => setIsHover( false ) }\n\t\t\tonFocus={ () => setIsFocused( true ) }\n\t\t\tonBlur={ () => setIsFocused( false ) }\n\t\t\taria-label={\n\t\t\t\tname\n\t\t\t\t\t? // translators: %s: The name of the color e.g: \"vivid red\".\n\t\t\t\t\t sprintf( __( 'Color: %s' ), name )\n\t\t\t\t\t: // translators: %s: color hex code e.g: \"#f00\".\n\t\t\t\t\t sprintf( __( 'Color code: %s' ), color )\n\t\t\t}\n\t\t>\n\t\t\t<div className=\"components-color-edit__color-option-main-area\">\n\t\t\t\t<Dropdown\n\t\t\t\t\trenderToggle={ ( { isOpen, onToggle } ) => (\n\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t<DropdownOpenOnMount\n\t\t\t\t\t\t\t\tshouldOpen={ isEditingColorOnMount }\n\t\t\t\t\t\t\t\tisOpen={ isOpen }\n\t\t\t\t\t\t\t\tonToggle={ onToggle }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t<CircularOptionPicker.Option\n\t\t\t\t\t\t\t\tstyle={ { backgroundColor: color, color } }\n\t\t\t\t\t\t\t\taria-expanded={ isOpen }\n\t\t\t\t\t\t\t\taria-haspopup=\"true\"\n\t\t\t\t\t\t\t\tonClick={ onToggle }\n\t\t\t\t\t\t\t\taria-label={ __( 'Edit color value' ) }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</>\n\t\t\t\t\t) }\n\t\t\t\t\trenderContent={ () => (\n\t\t\t\t\t\t<ColorPicker\n\t\t\t\t\t\t\tcolor={ color }\n\t\t\t\t\t\t\tonChange={ ( newColor ) =>\n\t\t\t\t\t\t\t\tonChange( {\n\t\t\t\t\t\t\t\t\tcolor: newColor,\n\t\t\t\t\t\t\t\t\tslug,\n\t\t\t\t\t\t\t\t\tname,\n\t\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t/>\n\t\t\t\t{ ! isEditingName && (\n\t\t\t\t\t<div className=\"components-color-edit__color-option-color-name\">\n\t\t\t\t\t\t{ name }\n\t\t\t\t\t</div>\n\t\t\t\t) }\n\t\t\t\t{ isEditingName && (\n\t\t\t\t\t<>\n\t\t\t\t\t\t<TextControl\n\t\t\t\t\t\t\tclassName=\"components-color-edit__color-option-color-name-input\"\n\t\t\t\t\t\t\thideLabelFromVision\n\t\t\t\t\t\t\tonChange={ ( newColorName ) =>\n\t\t\t\t\t\t\t\tonChange( {\n\t\t\t\t\t\t\t\t\tcolor,\n\t\t\t\t\t\t\t\t\tslug: kebabCase( newColorName ),\n\t\t\t\t\t\t\t\t\tname: newColorName,\n\t\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tlabel={ __( 'Color name' ) }\n\t\t\t\t\t\t\tplaceholder={ __( 'Name' ) }\n\t\t\t\t\t\t\tvalue={ name }\n\t\t\t\t\t\t/>\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\tsetIsEditingName( false );\n\t\t\t\t\t\t\t\tsetIsFocused( false );\n\t\t\t\t\t\t\t\tif ( onConfirm ) {\n\t\t\t\t\t\t\t\t\tonConfirm();\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\tvariant=\"primary\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{ confirmLabel }\n\t\t\t\t\t\t</Button>\n\t\t\t\t\t</>\n\t\t\t\t) }\n\t\t\t\t{ ! isEditingName && (\n\t\t\t\t\t<>\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tclassName={ classnames( {\n\t\t\t\t\t\t\t\t'components-color-edit__hidden-control': ! isShowingControls,\n\t\t\t\t\t\t\t} ) }\n\t\t\t\t\t\t\ticon={ edit }\n\t\t\t\t\t\t\tlabel={ __( 'Edit color name' ) }\n\t\t\t\t\t\t\tonClick={ () => setIsEditingName( true ) }\n\t\t\t\t\t\t/>\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tclassName={ classnames( {\n\t\t\t\t\t\t\t\t'components-color-edit__hidden-control': ! isShowingControls,\n\t\t\t\t\t\t\t} ) }\n\t\t\t\t\t\t\ticon={ close }\n\t\t\t\t\t\t\tlabel={ __( 'Remove color' ) }\n\t\t\t\t\t\t\tonClick={ onRemove }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</>\n\t\t\t\t) }\n\t\t\t\t<Button\n\t\t\t\t\tclassName={ classnames( {\n\t\t\t\t\t\t'components-color-edit__hidden-control': ! isShowingControls,\n\t\t\t\t\t} ) }\n\t\t\t\t\ticon={ isShowingAdvancedPanel ? chevronUp : chevronDown }\n\t\t\t\t\tlabel={ __( 'Additional color settings' ) }\n\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\tif ( isShowingAdvancedPanel ) {\n\t\t\t\t\t\t\tsetIsFocused( false );\n\t\t\t\t\t\t}\n\t\t\t\t\t\tsetIsShowingAdvancedPanel( ! isShowingAdvancedPanel );\n\t\t\t\t\t} }\n\t\t\t\t\taria-expanded={ isShowingAdvancedPanel }\n\t\t\t\t/>\n\t\t\t</div>\n\t\t\t{ onCancel && (\n\t\t\t\t<Button\n\t\t\t\t\tclassName=\"components-color-edit__cancel-button\"\n\t\t\t\t\tonClick={ onCancel }\n\t\t\t\t>\n\t\t\t\t\t{ __( 'Cancel' ) }\n\t\t\t\t</Button>\n\t\t\t) }\n\t\t\t{ isShowingAdvancedPanel && (\n\t\t\t\t<TextControl\n\t\t\t\t\tclassName=\"components-color-edit__slug-input\"\n\t\t\t\t\tonChange={ ( newSlug ) =>\n\t\t\t\t\t\tonChange( {\n\t\t\t\t\t\t\tcolor,\n\t\t\t\t\t\t\tslug: newSlug,\n\t\t\t\t\t\t\tname,\n\t\t\t\t\t\t} )\n\t\t\t\t\t}\n\t\t\t\t\tlabel={ __( 'Slug' ) }\n\t\t\t\t\tvalue={ slug }\n\t\t\t\t/>\n\t\t\t) }\n\t\t</div>\n\t);\n}\n\nfunction ColorInserter( { onInsert, onCancel } ) {\n\tconst [ color, setColor ] = useState( {\n\t\tcolor: '#fff',\n\t\tname: '',\n\t\tslug: '',\n\t} );\n\treturn (\n\t\t<ColorOption\n\t\t\tcolor={ color.color }\n\t\t\tname={ color.name }\n\t\t\tslug={ color.slug }\n\t\t\tonChange={ setColor }\n\t\t\tconfirmLabel={ __( 'Save' ) }\n\t\t\tonConfirm={ () => onInsert( color ) }\n\t\t\tisEditingNameOnMount\n\t\t\tisEditingColorOnMount\n\t\t\tonCancel={ onCancel }\n\t\t/>\n\t);\n}\n\nexport default function ColorEdit( {\n\tcolors,\n\tonChange,\n\temptyUI,\n\timmutableColorSlugs,\n\tcanReset = true,\n} ) {\n\tconst [ isInsertingColor, setIsInsertingColor ] = useState( false );\n\treturn (\n\t\t<BaseControl>\n\t\t\t<fieldset>\n\t\t\t\t<div className=\"components-color-edit__label-and-insert-container\">\n\t\t\t\t\t<legend>\n\t\t\t\t\t\t<div>\n\t\t\t\t\t\t\t<BaseControl.VisualLabel>\n\t\t\t\t\t\t\t\t{ __( 'Color palette' ) }\n\t\t\t\t\t\t\t</BaseControl.VisualLabel>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</legend>\n\t\t\t\t\t{ ! isInsertingColor && (\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\tsetIsInsertingColor( true );\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\tclassName=\"components-color-edit__insert-button\"\n\t\t\t\t\t\t\ticon={ plus }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t</div>\n\t\t\t\t<div>\n\t\t\t\t\t{ ! isEmpty( colors ) &&\n\t\t\t\t\t\tcolors.map( ( color, index ) => {\n\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t<ColorOption\n\t\t\t\t\t\t\t\t\tkey={ index }\n\t\t\t\t\t\t\t\t\tcolor={ color.color }\n\t\t\t\t\t\t\t\t\tname={ color.name }\n\t\t\t\t\t\t\t\t\tslug={ color.slug }\n\t\t\t\t\t\t\t\t\timmutableColorSlugs={ immutableColorSlugs }\n\t\t\t\t\t\t\t\t\tonChange={ ( newColor ) => {\n\t\t\t\t\t\t\t\t\t\tonChange(\n\t\t\t\t\t\t\t\t\t\t\tcolors.map(\n\t\t\t\t\t\t\t\t\t\t\t\t(\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentColor,\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentIndex\n\t\t\t\t\t\t\t\t\t\t\t\t) => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentIndex === index\n\t\t\t\t\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\treturn newColor;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\treturn currentColor;\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\t\tonRemove={ () => {\n\t\t\t\t\t\t\t\t\t\tonChange(\n\t\t\t\t\t\t\t\t\t\t\tcolors.filter(\n\t\t\t\t\t\t\t\t\t\t\t\t(\n\t\t\t\t\t\t\t\t\t\t\t\t\t_currentColor,\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentIndex\n\t\t\t\t\t\t\t\t\t\t\t\t) => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentIndex === index\n\t\t\t\t\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t} ) }\n\t\t\t\t\t{ isInsertingColor && (\n\t\t\t\t\t\t<ColorInserter\n\t\t\t\t\t\t\tonInsert={ ( newColor ) => {\n\t\t\t\t\t\t\t\tsetIsInsertingColor( false );\n\t\t\t\t\t\t\t\tonChange( [ ...( colors || [] ), newColor ] );\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\tonCancel={ () => setIsInsertingColor( false ) }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t\t{ ! isInsertingColor && isEmpty( colors ) && emptyUI }\n\t\t\t\t</div>\n\t\t\t\t{ !! canReset && (\n\t\t\t\t\t<Button\n\t\t\t\t\t\tisSmall\n\t\t\t\t\t\tvariant=\"secondary\"\n\t\t\t\t\t\tclassName=\"components-color-edit__reset-button\"\n\t\t\t\t\t\tonClick={ () => onChange() }\n\t\t\t\t\t>\n\t\t\t\t\t\t{ __( 'Reset' ) }\n\t\t\t\t\t</Button>\n\t\t\t\t) }\n\t\t\t</fieldset>\n\t\t</BaseControl>\n\t);\n}\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/color-edit/index.js"],"names":["kebabCase","useState","useRef","useEffect","__","lineSolid","moreVertical","plus","__experimentalUseFocusOutside","useFocusOutside","Button","ColorPicker","FlexItem","HStack","ItemGroup","VStack","ColorPalette","DropdownMenu","Popover","ColorActionsContainer","ColorEditStyles","ColorHeading","ColorHStackHeader","ColorIndicatorStyled","ColorItem","ColorNameContainer","ColorNameInputControl","DoneButton","RemoveButton","NavigableMenu","ColorNameInput","value","onChange","ColorOption","color","isEditing","onStartEditing","onRemove","onStopEditing","focusOutsideProps","name","nextName","slug","newColor","ColorPaletteEditListView","colors","editingColor","setEditingColor","colorReference","current","some","newColors","filter","length","undefined","map","index","currentColor","currentIndex","_currentColor","EMPTY_ARRAY","ColorEdit","setIsEditing","isAdding","hasColors","isSmall","onClose"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport kebabCase from 'lodash';\n\n/**\n * WordPress dependencies\n */\nimport { useState, useRef, useEffect } from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { lineSolid, moreVertical, plus } from '@wordpress/icons';\nimport { __experimentalUseFocusOutside as useFocusOutside } from '@wordpress/compose';\n\n/**\n * Internal dependencies\n */\nimport Button from '../button';\nimport { ColorPicker } from '../color-picker';\nimport { FlexItem } from '../flex';\nimport { HStack } from '../h-stack';\nimport { ItemGroup } from '../item-group';\nimport { VStack } from '../v-stack';\nimport ColorPalette from '../color-palette';\nimport DropdownMenu from '../dropdown-menu';\nimport Popover from '../popover';\nimport {\n\tColorActionsContainer,\n\tColorEditStyles,\n\tColorHeading,\n\tColorHStackHeader,\n\tColorIndicatorStyled,\n\tColorItem,\n\tColorNameContainer,\n\tColorNameInputControl,\n\tDoneButton,\n\tRemoveButton,\n} from './styles';\nimport { NavigableMenu } from '../navigable-container';\n\nfunction ColorNameInput( { value, onChange } ) {\n\treturn (\n\t\t<ColorNameInputControl\n\t\t\tlabel={ __( 'Color name' ) }\n\t\t\thideLabelFromVision\n\t\t\tvalue={ value }\n\t\t\tonChange={ onChange }\n\t\t/>\n\t);\n}\n\nfunction ColorOption( {\n\tcolor,\n\tonChange,\n\tisEditing,\n\tonStartEditing,\n\tonRemove,\n\tonStopEditing,\n} ) {\n\tconst focusOutsideProps = useFocusOutside( onStopEditing );\n\treturn (\n\t\t<ColorItem\n\t\t\tas=\"div\"\n\t\t\tonClick={ onStartEditing }\n\t\t\t{ ...( isEditing ? focusOutsideProps : {} ) }\n\t\t>\n\t\t\t<HStack justify=\"flex-start\">\n\t\t\t\t<FlexItem>\n\t\t\t\t\t<ColorIndicatorStyled colorValue={ color.color } />\n\t\t\t\t</FlexItem>\n\t\t\t\t<FlexItem>\n\t\t\t\t\t{ isEditing ? (\n\t\t\t\t\t\t<ColorNameInput\n\t\t\t\t\t\t\tvalue={ color.name }\n\t\t\t\t\t\t\tonChange={ ( nextName ) =>\n\t\t\t\t\t\t\t\tonChange( {\n\t\t\t\t\t\t\t\t\t...color,\n\t\t\t\t\t\t\t\t\tname: nextName,\n\t\t\t\t\t\t\t\t\tslug: kebabCase( nextName ),\n\t\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t/>\n\t\t\t\t\t) : (\n\t\t\t\t\t\t<ColorNameContainer>{ color.name }</ColorNameContainer>\n\t\t\t\t\t) }\n\t\t\t\t</FlexItem>\n\t\t\t\t{ isEditing && (\n\t\t\t\t\t<FlexItem>\n\t\t\t\t\t\t<RemoveButton\n\t\t\t\t\t\t\tisSmall\n\t\t\t\t\t\t\ticon={ lineSolid }\n\t\t\t\t\t\t\tlabel={ __( 'Remove color' ) }\n\t\t\t\t\t\t\tonClick={ onRemove }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</FlexItem>\n\t\t\t\t) }\n\t\t\t</HStack>\n\t\t\t{ isEditing && (\n\t\t\t\t<Popover\n\t\t\t\t\tposition=\"bottom left\"\n\t\t\t\t\tclassName=\"components-color-edit__color-popover\"\n\t\t\t\t>\n\t\t\t\t\t<ColorPicker\n\t\t\t\t\t\tcolor={ color.color }\n\t\t\t\t\t\tonChange={ ( newColor ) =>\n\t\t\t\t\t\t\tonChange( {\n\t\t\t\t\t\t\t\t...color,\n\t\t\t\t\t\t\t\tcolor: newColor,\n\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t}\n\t\t\t\t\t/>\n\t\t\t\t</Popover>\n\t\t\t) }\n\t\t</ColorItem>\n\t);\n}\n\nfunction ColorPaletteEditListView( {\n\tcolors,\n\tonChange,\n\teditingColor,\n\tsetEditingColor,\n} ) {\n\t// When unmounting the component if there are empty colors (the user did not complete the insertion) clean them.\n\tconst colorReference = useRef();\n\tuseEffect( () => {\n\t\tcolorReference.current = colors;\n\t}, [ colors ] );\n\tuseEffect( () => {\n\t\treturn () => {\n\t\t\tif ( colorReference.current.some( ( { slug } ) => ! slug ) ) {\n\t\t\t\tconst newColors = colorReference.current.filter(\n\t\t\t\t\t( { slug } ) => slug\n\t\t\t\t);\n\t\t\t\tonChange( newColors.length ? newColors : undefined );\n\t\t\t}\n\t\t};\n\t}, [] );\n\treturn (\n\t\t<VStack spacing={ 3 }>\n\t\t\t<ItemGroup isBordered isSeparated>\n\t\t\t\t{ colors.map( ( color, index ) => (\n\t\t\t\t\t<ColorOption\n\t\t\t\t\t\tkey={ index }\n\t\t\t\t\t\tcolor={ color }\n\t\t\t\t\t\tonStartEditing={ () => {\n\t\t\t\t\t\t\tif ( editingColor !== index ) {\n\t\t\t\t\t\t\t\tsetEditingColor( index );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} }\n\t\t\t\t\t\tonChange={ ( newColor ) => {\n\t\t\t\t\t\t\tonChange(\n\t\t\t\t\t\t\t\tcolors.map( ( currentColor, currentIndex ) => {\n\t\t\t\t\t\t\t\t\tif ( currentIndex === index ) {\n\t\t\t\t\t\t\t\t\t\treturn newColor;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\treturn currentColor;\n\t\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t} }\n\t\t\t\t\t\tonRemove={ () => {\n\t\t\t\t\t\t\tsetEditingColor( null );\n\t\t\t\t\t\t\tconst newColors = colors.filter(\n\t\t\t\t\t\t\t\t( _currentColor, currentIndex ) => {\n\t\t\t\t\t\t\t\t\tif ( currentIndex === index ) {\n\t\t\t\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\tonChange(\n\t\t\t\t\t\t\t\tnewColors.length ? newColors : undefined\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t} }\n\t\t\t\t\t\tisEditing={ index === editingColor }\n\t\t\t\t\t\tonStopEditing={ () => {\n\t\t\t\t\t\t\tif ( index === editingColor ) {\n\t\t\t\t\t\t\t\tsetEditingColor( null );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} }\n\t\t\t\t\t/>\n\t\t\t\t) ) }\n\t\t\t</ItemGroup>\n\t\t</VStack>\n\t);\n}\n\nconst EMPTY_ARRAY = [];\n\nexport default function ColorEdit( { colors = EMPTY_ARRAY, onChange } ) {\n\tconst [ isEditing, setIsEditing ] = useState( false );\n\tconst [ editingColor, setEditingColor ] = useState( null );\n\tconst isAdding =\n\t\tisEditing &&\n\t\teditingColor &&\n\t\tcolors[ editingColor ] &&\n\t\t! colors[ editingColor ].slug;\n\n\tconst hasColors = colors.length > 0;\n\n\treturn (\n\t\t<ColorEditStyles>\n\t\t\t<ColorHStackHeader>\n\t\t\t\t<ColorHeading>{ __( 'Custom' ) }</ColorHeading>\n\t\t\t\t<ColorActionsContainer>\n\t\t\t\t\t{ isEditing && (\n\t\t\t\t\t\t<DoneButton\n\t\t\t\t\t\t\tisSmall\n\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\tsetIsEditing( false );\n\t\t\t\t\t\t\t\tsetEditingColor( null );\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{ __( 'Done' ) }\n\t\t\t\t\t\t</DoneButton>\n\t\t\t\t\t) }\n\t\t\t\t\t<Button\n\t\t\t\t\t\tisSmall\n\t\t\t\t\t\tisPressed={ isAdding }\n\t\t\t\t\t\ticon={ plus }\n\t\t\t\t\t\tlabel={ __( 'Add custom color' ) }\n\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\tonChange( [\n\t\t\t\t\t\t\t\t...colors,\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tcolor: '#000',\n\t\t\t\t\t\t\t\t\tname: '',\n\t\t\t\t\t\t\t\t\tslug: '',\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t] );\n\t\t\t\t\t\t\tsetIsEditing( true );\n\t\t\t\t\t\t\tsetEditingColor( colors.length );\n\t\t\t\t\t\t} }\n\t\t\t\t\t/>\n\t\t\t\t\t{ ! isEditing && (\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tdisabled={ ! hasColors }\n\t\t\t\t\t\t\tisSmall\n\t\t\t\t\t\t\ticon={ moreVertical }\n\t\t\t\t\t\t\tlabel={ __( 'Edit colors' ) }\n\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\tsetIsEditing( true );\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t\t{ isEditing && (\n\t\t\t\t\t\t<DropdownMenu\n\t\t\t\t\t\t\ticon={ moreVertical }\n\t\t\t\t\t\t\tlabel={ __( 'Custom color options' ) }\n\t\t\t\t\t\t\ttoggleProps={ {\n\t\t\t\t\t\t\t\tisSmall: true,\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{ ( { onClose } ) => (\n\t\t\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t\t\t<NavigableMenu role=\"menu\">\n\t\t\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t\t\tvariant=\"tertiary\"\n\t\t\t\t\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\t\t\t\t\tsetEditingColor( null );\n\t\t\t\t\t\t\t\t\t\t\t\tsetIsEditing( false );\n\t\t\t\t\t\t\t\t\t\t\t\tonChange();\n\t\t\t\t\t\t\t\t\t\t\t\tonClose();\n\t\t\t\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t{ __( 'Remove all custom colors' ) }\n\t\t\t\t\t\t\t\t\t\t</Button>\n\t\t\t\t\t\t\t\t\t</NavigableMenu>\n\t\t\t\t\t\t\t\t</>\n\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t</DropdownMenu>\n\t\t\t\t\t) }\n\t\t\t\t</ColorActionsContainer>\n\t\t\t</ColorHStackHeader>\n\t\t\t{ hasColors && (\n\t\t\t\t<>\n\t\t\t\t\t{ isEditing && (\n\t\t\t\t\t\t<ColorPaletteEditListView\n\t\t\t\t\t\t\tcolors={ colors }\n\t\t\t\t\t\t\tonChange={ onChange }\n\t\t\t\t\t\t\teditingColor={ editingColor }\n\t\t\t\t\t\t\tsetEditingColor={ setEditingColor }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t\t{ ! isEditing && (\n\t\t\t\t\t\t<ColorPalette\n\t\t\t\t\t\t\tcolors={ colors }\n\t\t\t\t\t\t\tonChange={ () => {} }\n\t\t\t\t\t\t\tclearable={ false }\n\t\t\t\t\t\t\tdisableCustomColors={ true }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t</>\n\t\t\t) }\n\t\t\t{ ! hasColors &&\n\t\t\t\t__(\n\t\t\t\t\t'Custom colors are empty! Add some colors to create your own color palette.'\n\t\t\t\t) }\n\t\t</ColorEditStyles>\n\t);\n}\n"]}