@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.
- package/CHANGELOG.md +6 -0
- package/CONTRIBUTING.md +12 -12
- package/build/angle-picker-control/index.js +3 -1
- package/build/angle-picker-control/index.js.map +1 -1
- package/build/angle-picker-control/styles/angle-picker-control-styles.js +4 -4
- package/build/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
- package/build/base-control/index.js +1 -1
- package/build/base-control/index.js.map +1 -1
- package/build/color-edit/index.js +180 -199
- package/build/color-edit/index.js.map +1 -1
- package/build/color-edit/styles.js +112 -0
- package/build/color-edit/styles.js.map +1 -0
- package/build/color-list-picker/index.js +6 -1
- package/build/color-list-picker/index.js.map +1 -1
- package/build/color-palette/index.js +86 -21
- package/build/color-palette/index.js.map +1 -1
- package/build/color-palette/styles.js +31 -0
- package/build/color-palette/styles.js.map +1 -0
- package/build/color-picker/component.js +7 -18
- package/build/color-picker/component.js.map +1 -1
- package/build/color-picker/picker.js +3 -3
- package/build/color-picker/picker.js.map +1 -1
- package/build/duotone-picker/custom-duotone-bar.js +0 -1
- package/build/duotone-picker/custom-duotone-bar.js.map +1 -1
- package/build/duotone-picker/duotone-picker.js +1 -0
- package/build/duotone-picker/duotone-picker.js.map +1 -1
- package/build/gradient-picker/index.js +69 -9
- package/build/gradient-picker/index.js.map +1 -1
- package/build/index.native.js +9 -0
- package/build/index.native.js.map +1 -1
- package/build/mobile/bottom-sheet/cell.native.js +4 -2
- package/build/mobile/bottom-sheet/cell.native.js.map +1 -1
- package/build/mobile/bottom-sheet/link-cell.native.js +3 -2
- package/build/mobile/bottom-sheet/link-cell.native.js.map +1 -1
- package/build/mobile/link-settings/image-link-destinations-screen.native.js +140 -0
- package/build/mobile/link-settings/image-link-destinations-screen.native.js.map +1 -0
- package/build/mobile/link-settings/index.native.js +3 -2
- package/build/mobile/link-settings/index.native.js.map +1 -1
- package/build/mobile/link-settings/link-settings-navigation.native.js +1 -0
- package/build/mobile/link-settings/link-settings-navigation.native.js.map +1 -1
- package/build/mobile/link-settings/link-settings-screen.native.js +11 -5
- package/build/mobile/link-settings/link-settings-screen.native.js.map +1 -1
- package/build/mobile/picker/index.android.js +4 -2
- package/build/mobile/picker/index.android.js.map +1 -1
- package/build/modal/index.js +10 -3
- package/build/modal/index.js.map +1 -1
- package/build/navigation/group/index.js +1 -2
- package/build/navigation/group/index.js.map +1 -1
- package/build/navigation/menu/menu-title-search.js +8 -27
- package/build/navigation/menu/menu-title-search.js.map +1 -1
- package/build/navigation/menu/menu-title.js +2 -2
- package/build/navigation/menu/menu-title.js.map +1 -1
- package/build/navigation/styles/navigation-styles.js +34 -29
- package/build/navigation/styles/navigation-styles.js.map +1 -1
- package/build/popover/index.js +4 -2
- package/build/popover/index.js.map +1 -1
- package/build/range-control/styles/range-control-styles.js +33 -29
- package/build/range-control/styles/range-control-styles.js.map +1 -1
- package/build/search-control/index.js +37 -14
- package/build/search-control/index.js.map +1 -1
- package/build/text/styles.js +7 -7
- package/build/text/styles.js.map +1 -1
- package/build/tools-panel/styles.js +18 -23
- package/build/tools-panel/styles.js.map +1 -1
- package/build/tools-panel/tools-panel/component.js +10 -7
- package/build/tools-panel/tools-panel/component.js.map +1 -1
- package/build/tools-panel/tools-panel/hook.js +3 -1
- package/build/tools-panel/tools-panel/hook.js.map +1 -1
- package/build/tools-panel/tools-panel-header/component.js +3 -0
- package/build/tools-panel/tools-panel-header/component.js.map +1 -1
- package/build/utils/hooks/index.js +8 -0
- package/build/utils/hooks/index.js.map +1 -1
- package/build/utils/hooks/use-combined-ref.js +28 -0
- package/build/utils/hooks/use-combined-ref.js.map +1 -0
- package/build-module/angle-picker-control/index.js +3 -1
- package/build-module/angle-picker-control/index.js.map +1 -1
- package/build-module/angle-picker-control/styles/angle-picker-control-styles.js +4 -4
- package/build-module/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
- package/build-module/base-control/index.js +1 -1
- package/build-module/base-control/index.js.map +1 -1
- package/build-module/color-edit/index.js +175 -201
- package/build-module/color-edit/index.js.map +1 -1
- package/build-module/color-edit/styles.js +90 -0
- package/build-module/color-edit/styles.js.map +1 -0
- package/build-module/color-list-picker/index.js +6 -1
- package/build-module/color-list-picker/index.js.map +1 -1
- package/build-module/color-palette/index.js +85 -22
- package/build-module/color-palette/index.js.map +1 -1
- package/build-module/color-palette/styles.js +27 -0
- package/build-module/color-palette/styles.js.map +1 -0
- package/build-module/color-picker/component.js +7 -16
- package/build-module/color-picker/component.js.map +1 -1
- package/build-module/color-picker/picker.js +4 -4
- package/build-module/color-picker/picker.js.map +1 -1
- package/build-module/duotone-picker/custom-duotone-bar.js +0 -1
- package/build-module/duotone-picker/custom-duotone-bar.js.map +1 -1
- package/build-module/duotone-picker/duotone-picker.js +1 -0
- package/build-module/duotone-picker/duotone-picker.js.map +1 -1
- package/build-module/gradient-picker/index.js +67 -9
- package/build-module/gradient-picker/index.js.map +1 -1
- package/build-module/index.native.js +1 -0
- package/build-module/index.native.js.map +1 -1
- package/build-module/mobile/bottom-sheet/cell.native.js +4 -2
- package/build-module/mobile/bottom-sheet/cell.native.js.map +1 -1
- package/build-module/mobile/bottom-sheet/link-cell.native.js +3 -2
- package/build-module/mobile/bottom-sheet/link-cell.native.js.map +1 -1
- package/build-module/mobile/link-settings/image-link-destinations-screen.native.js +121 -0
- package/build-module/mobile/link-settings/image-link-destinations-screen.native.js.map +1 -0
- package/build-module/mobile/link-settings/index.native.js +3 -2
- package/build-module/mobile/link-settings/index.native.js.map +1 -1
- package/build-module/mobile/link-settings/link-settings-navigation.native.js +1 -0
- package/build-module/mobile/link-settings/link-settings-navigation.native.js.map +1 -1
- package/build-module/mobile/link-settings/link-settings-screen.native.js +11 -5
- package/build-module/mobile/link-settings/link-settings-screen.native.js.map +1 -1
- package/build-module/mobile/picker/index.android.js +4 -2
- package/build-module/mobile/picker/index.android.js.map +1 -1
- package/build-module/modal/index.js +10 -4
- package/build-module/modal/index.js.map +1 -1
- package/build-module/navigation/group/index.js +1 -2
- package/build-module/navigation/group/index.js.map +1 -1
- package/build-module/navigation/menu/menu-title-search.js +8 -24
- package/build-module/navigation/menu/menu-title-search.js.map +1 -1
- package/build-module/navigation/menu/menu-title.js +3 -3
- package/build-module/navigation/menu/menu-title.js.map +1 -1
- package/build-module/navigation/styles/navigation-styles.js +31 -27
- package/build-module/navigation/styles/navigation-styles.js.map +1 -1
- package/build-module/popover/index.js +4 -2
- package/build-module/popover/index.js.map +1 -1
- package/build-module/range-control/styles/range-control-styles.js +33 -29
- package/build-module/range-control/styles/range-control-styles.js.map +1 -1
- package/build-module/search-control/index.js +36 -15
- package/build-module/search-control/index.js.map +1 -1
- package/build-module/text/styles.js +7 -7
- package/build-module/text/styles.js.map +1 -1
- package/build-module/tools-panel/styles.js +16 -23
- package/build-module/tools-panel/styles.js.map +1 -1
- package/build-module/tools-panel/tools-panel/component.js +10 -6
- package/build-module/tools-panel/tools-panel/component.js.map +1 -1
- package/build-module/tools-panel/tools-panel/hook.js +2 -1
- package/build-module/tools-panel/tools-panel/hook.js.map +1 -1
- package/build-module/tools-panel/tools-panel-header/component.js +3 -0
- package/build-module/tools-panel/tools-panel-header/component.js.map +1 -1
- package/build-module/utils/hooks/index.js +1 -0
- package/build-module/utils/hooks/index.js.map +1 -1
- package/build-module/utils/hooks/use-combined-ref.js +25 -0
- package/build-module/utils/hooks/use-combined-ref.js.map +1 -0
- package/build-style/style-rtl.css +39 -51
- package/build-style/style.css +39 -51
- package/build-types/range-control/styles/range-control-styles.d.ts.map +1 -1
- package/build-types/tools-panel/styles.d.ts +1 -1
- package/build-types/tools-panel/styles.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel/component.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel/hook.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel-header/component.d.ts.map +1 -1
- package/build-types/utils/hooks/index.d.ts +1 -0
- package/build-types/utils/hooks/use-combined-ref.d.ts +8 -0
- package/build-types/utils/hooks/use-combined-ref.d.ts.map +1 -0
- package/package.json +6 -6
- package/src/angle-picker-control/index.js +3 -1
- package/src/angle-picker-control/styles/angle-picker-control-styles.js +2 -2
- package/src/base-control/index.js +1 -1
- package/src/circular-option-picker/style.scss +3 -5
- package/src/color-edit/index.js +248 -274
- package/src/color-edit/style.scss +4 -45
- package/src/color-edit/styles.js +97 -0
- package/src/color-list-picker/index.js +5 -0
- package/src/color-list-picker/style.scss +4 -0
- package/src/color-palette/index.js +90 -26
- package/src/color-palette/style.scss +18 -0
- package/src/color-palette/styles.js +19 -0
- package/src/color-palette/test/__snapshots__/index.js.snap +448 -414
- package/src/color-picker/component.tsx +6 -17
- package/src/color-picker/picker.tsx +6 -4
- package/src/color-picker/test/index.js +0 -15
- package/src/duotone-picker/custom-duotone-bar.js +0 -1
- package/src/duotone-picker/duotone-picker.js +1 -0
- package/src/gradient-picker/index.js +79 -11
- package/src/heading/test/__snapshots__/index.js.snap +1 -1
- package/src/index.native.js +1 -0
- package/src/mobile/bottom-sheet/cell.native.js +7 -2
- package/src/mobile/bottom-sheet/cellStyles.android.scss +5 -1
- package/src/mobile/bottom-sheet/cellStyles.ios.scss +5 -1
- package/src/mobile/bottom-sheet/link-cell.native.js +10 -3
- package/src/mobile/link-settings/image-link-destinations-screen.native.js +148 -0
- package/src/mobile/link-settings/index.native.js +3 -2
- package/src/mobile/link-settings/link-settings-navigation.native.js +1 -0
- package/src/mobile/link-settings/link-settings-screen.native.js +6 -2
- package/src/mobile/link-settings/style.native.scss +17 -0
- package/src/mobile/picker/index.android.js +2 -1
- package/src/modal/README.md +8 -0
- package/src/modal/index.js +60 -45
- package/src/modal/style.scss +5 -0
- package/src/navigation/group/index.js +1 -2
- package/src/navigation/menu/menu-title-search.js +11 -26
- package/src/navigation/menu/menu-title.js +4 -4
- package/src/navigation/styles/navigation-styles.js +29 -52
- package/src/popover/index.js +2 -2
- package/src/range-control/styles/range-control-styles.js +4 -1
- package/src/resizable-box/style.scss +5 -0
- package/src/search-control/index.js +47 -23
- package/src/style.scss +1 -0
- package/src/text/styles.js +1 -1
- package/src/text/test/__snapshots__/index.js.snap +2 -2
- package/src/tools-panel/stories/index.js +21 -19
- package/src/tools-panel/styles.ts +18 -26
- package/src/tools-panel/tools-panel/component.tsx +7 -4
- package/src/tools-panel/tools-panel/hook.ts +4 -1
- package/src/tools-panel/tools-panel-header/component.tsx +1 -0
- package/src/ui/control-label/test/__snapshots__/index.js.snap +3 -3
- package/src/ui/form-group/test/__snapshots__/index.js.snap +2 -2
- package/src/utils/hooks/index.js +1 -0
- package/src/utils/hooks/use-combined-ref.ts +29 -0
- 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
|
|
7
|
-
import { isEmpty, kebabCase } from 'lodash';
|
|
7
|
+
import kebabCase from 'lodash';
|
|
8
8
|
/**
|
|
9
9
|
* WordPress dependencies
|
|
10
10
|
*/
|
|
11
11
|
|
|
12
|
-
import {
|
|
13
|
-
import {
|
|
14
|
-
import {
|
|
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
|
|
24
|
-
import
|
|
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
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
onToggle
|
|
32
|
+
function ColorNameInput({
|
|
33
|
+
value,
|
|
34
|
+
onChange
|
|
30
35
|
}) {
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
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
|
-
|
|
46
|
-
confirmLabel = __('OK'),
|
|
47
|
-
isEditingNameOnMount = false,
|
|
48
|
-
isEditingColorOnMount = false,
|
|
49
|
-
onCancel,
|
|
50
|
-
immutableColorSlugs = []
|
|
50
|
+
onStopEditing
|
|
51
51
|
}) {
|
|
52
|
-
const
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
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
|
-
}),
|
|
98
|
-
|
|
99
|
-
|
|
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(
|
|
135
|
-
|
|
136
|
-
|
|
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
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
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
|
-
|
|
82
|
+
function ColorPaletteEditListView({
|
|
186
83
|
colors,
|
|
187
84
|
onChange,
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
canReset = true
|
|
85
|
+
editingColor,
|
|
86
|
+
setEditingColor
|
|
191
87
|
}) {
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
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
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
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
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
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
|
-
|
|
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
|
-
|
|
233
|
-
|
|
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
|
-
|
|
236
|
-
|
|
237
|
-
onClick: () =>
|
|
238
|
-
|
|
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"]}
|