"use strict";(globalThis.blocksyJsonP=globalThis.blocksyJsonP||[]).push([[188],{1188:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{eval("// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"default\": () => (/* binding */ GradientPicker)\n});\n\n// EXTERNAL MODULE: external \"window.wp.i18n\"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n// EXTERNAL MODULE: external \"window.wp.element\"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: external \"window.wp.components\"\nvar external_window_wp_components_ = __webpack_require__(8441);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n// EXTERNAL MODULE: ./node_modules/@wordpress/icons/build-module/icon/index.js\nvar icon = __webpack_require__(1984);\n// EXTERNAL MODULE: ./node_modules/@wordpress/icons/build-module/library/check.js\nvar check = __webpack_require__(8184);\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/circular-option-picker.js\nconst _excluded = [\"className\", \"isSelected\", \"selectedIconProps\", \"tooltipText\"],\n _excluded2 = [\"className\", \"children\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n/**\n * External dependencies\n */\n\n\n/**\n * WordPress dependencies\n */\n\n\n/**\n * Internal dependencies\n */\n\n\n\nfunction Option(_ref) {\n let {\n className,\n isSelected,\n selectedIconProps,\n tooltipText\n } = _ref,\n additionalProps = _objectWithoutProperties(_ref, _excluded);\n\n const optionButton = (0,external_window_wp_element_.createElement)(external_window_wp_components_.Button, _extends({\n isPressed: isSelected,\n className: \"components-circular-option-picker__option\"\n }, additionalProps));\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: classnames_default()(className, 'components-circular-option-picker__option-wrapper')\n }, tooltipText ? (0,external_window_wp_element_.createElement)(external_window_wp_components_.Tooltip, {\n text: tooltipText\n }, optionButton) : optionButton, isSelected && (0,external_window_wp_element_.createElement)(icon/* default */.Z, _extends({\n icon: check/* default */.Z\n }, selectedIconProps ? selectedIconProps : {})));\n}\n\nfunction DropdownLinkAction(_ref2) {\n let {\n buttonProps,\n className,\n dropdownProps,\n linkText\n } = _ref2;\n return (0,external_window_wp_element_.createElement)(external_window_wp_components_.Dropdown, _extends({\n className: classnames_default()('components-circular-option-picker__dropdown-link-action', className),\n renderToggle: _ref3 => {\n let {\n isOpen,\n onToggle\n } = _ref3;\n return (0,external_window_wp_element_.createElement)(external_window_wp_components_.Button, _extends({\n \"aria-expanded\": isOpen,\n \"aria-haspopup\": \"true\",\n onClick: onToggle,\n variant: \"link\"\n }, buttonProps), linkText);\n }\n }, dropdownProps));\n}\n\nfunction ButtonAction(_ref4) {\n let {\n className,\n children\n } = _ref4,\n additionalProps = _objectWithoutProperties(_ref4, _excluded2);\n\n return (0,external_window_wp_element_.createElement)(external_window_wp_components_.Button, _extends({\n className: classnames_default()('components-circular-option-picker__clear', className),\n isSmall: true,\n variant: \"secondary\"\n }, additionalProps), children);\n}\n\nfunction CircularOptionPicker(_ref5) {\n let {\n actions,\n className,\n options,\n children\n } = _ref5;\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: classnames_default()('components-circular-option-picker', className)\n }, (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"components-circular-option-picker__swatches\"\n }, options), children, actions && (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"components-circular-option-picker__custom-clear-wrapper\"\n }, actions));\n}\nCircularOptionPicker.Option = Option;\nCircularOptionPicker.ButtonAction = ButtonAction;\nCircularOptionPicker.DropdownLinkAction = DropdownLinkAction;\n// EXTERNAL MODULE: ./node_modules/lodash/omit.js\nvar omit = __webpack_require__(7557);\nvar omit_default = /*#__PURE__*/__webpack_require__.n(omit);\n// EXTERNAL MODULE: ./node_modules/lodash/get.js\nvar get = __webpack_require__(7361);\nvar get_default = /*#__PURE__*/__webpack_require__.n(get);\n// EXTERNAL MODULE: external \"window.wp.compose\"\nvar external_window_wp_compose_ = __webpack_require__(3356);\n// EXTERNAL MODULE: ./node_modules/lodash/merge.js\nvar merge = __webpack_require__(3857);\nvar merge_default = /*#__PURE__*/__webpack_require__.n(merge);\n// EXTERNAL MODULE: ./node_modules/colord/index.mjs\nvar colord = __webpack_require__(6765);\n// EXTERNAL MODULE: ./node_modules/colord/plugins/names.mjs\nvar names = __webpack_require__(3933);\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/colors.js\n/**\n * External dependencies\n */\n\n\n(0,colord/* extend */.l7)([names/* default */.Z]);\n/**\n * Generating a CSS compliant rgba() color value.\n *\n * @param {string} hexValue The hex value to convert to rgba().\n * @param {number} alpha The alpha value for opacity.\n * @return {string} The converted rgba() color value.\n *\n * @example\n * rgba( '#000000', 0.5 )\n * // rgba(0, 0, 0, 0.5)\n */\n\nfunction rgba() {\n let hexValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n let alpha = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;\n return (0,colord/* colord */.Vi)(hexValue).alpha(alpha).toRgbString();\n}\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/colors-values.js\n\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * Internal dependencies\n */\n\nconst BASE = {\n black: '#000',\n white: '#fff'\n};\n/**\n * TODO: Continue to update values as \"G2\" design evolves.\n *\n * \"G2\" refers to the movement to advance the interface of the block editor.\n * https://github.com/WordPress/gutenberg/issues/18667\n */\n\nconst G2 = {\n blue: {\n medium: {\n focus: '#007cba',\n focusDark: '#fff'\n }\n },\n gray: {\n 900: '#1e1e1e',\n 700: '#757575',\n // Meets 4.6:1 text contrast against white.\n 600: '#949494',\n // Meets 3:1 UI or large text contrast against white.\n 400: '#ccc',\n 200: '#ddd',\n // Used for most borders.\n 100: '#f0f0f0'\n },\n darkGray: {\n primary: '#1e1e1e',\n heading: '#050505'\n },\n mediumGray: {\n text: '#757575'\n },\n lightGray: {\n ui: '#949494',\n secondary: '#ccc',\n tertiary: '#e7e8e9'\n }\n};\nconst DARK_GRAY = {\n 900: '#191e23',\n 800: '#23282d',\n 700: '#32373c',\n 600: '#40464d',\n 500: '#555d66',\n // Use this most of the time for dark items.\n 400: '#606a73',\n 300: '#6c7781',\n // Lightest gray that can be used for AA text contrast.\n 200: '#7e8993',\n 150: '#8d96a0',\n // Lightest gray that can be used for AA non-text contrast.\n 100: '#8f98a1',\n placeholder: rgba(G2.gray[900], 0.62)\n};\nconst DARK_OPACITY = {\n 900: rgba('#000510', 0.9),\n 800: rgba('#00000a', 0.85),\n 700: rgba('#06060b', 0.8),\n 600: rgba('#000913', 0.75),\n 500: rgba('#0a1829', 0.7),\n 400: rgba('#0a1829', 0.65),\n 300: rgba('#0e1c2e', 0.62),\n 200: rgba('#162435', 0.55),\n 100: rgba('#223443', 0.5),\n backgroundFill: rgba(DARK_GRAY[700], 0.7)\n};\nconst DARK_OPACITY_LIGHT = {\n 900: rgba('#304455', 0.45),\n 800: rgba('#425863', 0.4),\n 700: rgba('#667886', 0.35),\n 600: rgba('#7b86a2', 0.3),\n 500: rgba('#9197a2', 0.25),\n 400: rgba('#95959c', 0.2),\n 300: rgba('#829493', 0.15),\n 200: rgba('#8b8b96', 0.1),\n 100: rgba('#747474', 0.05)\n};\nconst LIGHT_GRAY = {\n 900: '#a2aab2',\n 800: '#b5bcc2',\n 700: '#ccd0d4',\n 600: '#d7dade',\n 500: '#e2e4e7',\n // Good for \"grayed\" items and borders.\n 400: '#e8eaeb',\n // Good for \"readonly\" input fields and special text selection.\n 300: '#edeff0',\n 200: '#f3f4f5',\n 100: '#f8f9f9',\n placeholder: rgba(BASE.white, 0.65)\n};\nconst LIGHT_OPACITY_LIGHT = {\n 900: rgba(BASE.white, 0.5),\n 800: rgba(BASE.white, 0.45),\n 700: rgba(BASE.white, 0.4),\n 600: rgba(BASE.white, 0.35),\n 500: rgba(BASE.white, 0.3),\n 400: rgba(BASE.white, 0.25),\n 300: rgba(BASE.white, 0.2),\n 200: rgba(BASE.white, 0.15),\n 100: rgba(BASE.white, 0.1),\n backgroundFill: rgba(LIGHT_GRAY[300], 0.8)\n}; // Additional colors.\n// Some are from https://make.wordpress.org/design/handbook/foundations/colors/.\n\nconst BLUE = {\n wordpress: {\n 700: '#00669b'\n },\n dark: {\n 900: '#0071a1'\n },\n medium: {\n 900: '#006589',\n 800: '#00739c',\n 700: '#007fac',\n 600: '#008dbe',\n 500: '#00a0d2',\n 400: '#33b3db',\n 300: '#66c6e4',\n 200: '#bfe7f3',\n 100: '#e5f5fa',\n highlight: '#b3e7fe',\n focus: '#007cba'\n }\n};\nconst ALERT = {\n yellow: '#f0b849',\n red: '#d94f4f',\n green: '#4ab866'\n};\nconst ADMIN = {\n theme: `var( --wp-admin-theme-color, ${BLUE.wordpress[700]})`,\n themeDark10: `var( --wp-admin-theme-color-darker-10, ${BLUE.medium.focus})`\n}; // Namespaced values for raw colors hex codes\n\nconst UI = {\n theme: ADMIN.theme,\n background: BASE.white,\n backgroundDisabled: LIGHT_GRAY[200],\n border: G2.gray[700],\n borderHover: G2.gray[700],\n borderFocus: ADMIN.themeDark10,\n borderDisabled: G2.gray[400],\n borderLight: G2.gray[200],\n label: DARK_GRAY[500],\n textDisabled: DARK_GRAY[150],\n textDark: BASE.white,\n textLight: BASE.black\n};\nconst COLORS = _objectSpread(_objectSpread({}, BASE), {}, {\n darkGray: merge_default()({}, DARK_GRAY, G2.darkGray),\n darkOpacity: DARK_OPACITY,\n darkOpacityLight: DARK_OPACITY_LIGHT,\n mediumGray: G2.mediumGray,\n gray: G2.gray,\n lightGray: merge_default()({}, LIGHT_GRAY, G2.lightGray),\n lightGrayLight: LIGHT_OPACITY_LIGHT,\n blue: merge_default()({}, BLUE, G2.blue),\n alert: ALERT,\n admin: ADMIN,\n ui: UI\n});\n/* harmony default export */ const colors_values = (COLORS);\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/config-values.js\nfunction config_values_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction config_values_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? config_values_ownKeys(Object(source), !0).forEach(function (key) { config_values_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : config_values_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction config_values_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * Internal dependencies\n */\n\n\nconst space = n => `${n * 4}px`;\n\nconst CONTROL_HEIGHT = '36px';\nconst CONTROL_PADDING_X = '12px';\nconst CONTROL_PROPS = {\n controlSurfaceColor: COLORS.white,\n controlTextActiveColor: COLORS.ui.theme,\n controlPaddingX: CONTROL_PADDING_X,\n controlPaddingXLarge: `calc(${CONTROL_PADDING_X} * 1.3334)`,\n controlPaddingXSmall: `calc(${CONTROL_PADDING_X} / 1.3334)`,\n controlBackgroundColor: COLORS.white,\n controlBorderRadius: '2px',\n controlBorderColor: COLORS.gray[700],\n controlBoxShadow: 'transparent',\n controlBorderColorHover: COLORS.gray[700],\n controlBoxShadowFocus: `0 0 0 0.5px ${COLORS.admin.theme}`,\n controlDestructiveBorderColor: COLORS.alert.red,\n controlHeight: CONTROL_HEIGHT,\n controlHeightXSmall: `calc( ${CONTROL_HEIGHT} * 0.6 )`,\n controlHeightSmall: `calc( ${CONTROL_HEIGHT} * 0.8 )`,\n controlHeightLarge: `calc( ${CONTROL_HEIGHT} * 1.2 )`,\n controlHeightXLarge: `calc( ${CONTROL_HEIGHT} * 1.4 )`\n};\nconst TOGGLE_GROUP_CONTROL_PROPS = {\n toggleGroupControlBackgroundColor: CONTROL_PROPS.controlBackgroundColor,\n toggleGroupControlBorderColor: COLORS.ui.border,\n toggleGroupControlBackdropBackgroundColor: CONTROL_PROPS.controlSurfaceColor,\n toggleGroupControlBackdropBorderColor: COLORS.ui.border,\n toggleGroupControlBackdropBoxShadow: 'transparent',\n toggleGroupControlButtonColorActive: CONTROL_PROPS.controlBackgroundColor\n};\n/* harmony default export */ const config_values = (config_values_objectSpread(config_values_objectSpread(config_values_objectSpread({}, CONTROL_PROPS), TOGGLE_GROUP_CONTROL_PROPS), {}, {\n colorDivider: 'rgba(0, 0, 0, 0.1)',\n colorScrollbarThumb: 'rgba(0, 0, 0, 0.2)',\n colorScrollbarThumbHover: 'rgba(0, 0, 0, 0.5)',\n colorScrollbarTrack: 'rgba(0, 0, 0, 0.04)',\n elevationIntensity: 1,\n radiusBlockUi: '2px',\n borderWidth: '1px',\n borderWidthFocus: '1.5px',\n borderWidthTab: '4px',\n spinnerSize: '18px',\n fontSize: '13px',\n fontSizeH1: 'calc(2.44 * 13px)',\n fontSizeH2: 'calc(1.95 * 13px)',\n fontSizeH3: 'calc(1.56 * 13px)',\n fontSizeH4: 'calc(1.25 * 13px)',\n fontSizeH5: '13px',\n fontSizeH6: 'calc(0.8 * 13px)',\n fontSizeInputMobile: '16px',\n fontSizeMobile: '15px',\n fontSizeSmall: 'calc(0.92 * 13px)',\n fontSizeXSmall: 'calc(0.75 * 13px)',\n fontLineHeightBase: '1.2',\n fontWeight: 'normal',\n fontWeightHeading: '600',\n gridBase: '4px',\n cardBorderRadius: '2px',\n cardPaddingXSmall: `${space(2)}`,\n cardPaddingSmall: `${space(4)}`,\n cardPaddingMedium: `${space(4)} ${space(6)}`,\n cardPaddingLarge: `${space(6)} ${space(8)}`,\n surfaceBackgroundColor: COLORS.white,\n surfaceBackgroundSubtleColor: '#F3F3F3',\n surfaceBackgroundTintColor: '#F5F5F5',\n surfaceBorderColor: 'rgba(0, 0, 0, 0.1)',\n surfaceBorderBoldColor: 'rgba(0, 0, 0, 0.15)',\n surfaceBorderSubtleColor: 'rgba(0, 0, 0, 0.05)',\n surfaceBackgroundTertiaryColor: COLORS.white,\n surfaceColor: COLORS.white,\n transitionDuration: '200ms',\n transitionDurationFast: '160ms',\n transitionDurationFaster: '120ms',\n transitionDurationFastest: '100ms',\n transitionTimingFunction: 'cubic-bezier(0.08, 0.52, 0.52, 1)',\n transitionTimingFunctionControl: 'cubic-bezier(0.12, 0.8, 0.32, 1)'\n}));\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/angle-picker-control/angle-circle.js\nconst angle_circle_excluded = [\"value\", \"onChange\"];\n\nfunction angle_circle_extends() { angle_circle_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return angle_circle_extends.apply(this, arguments); }\n\nfunction angle_circle_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction angle_circle_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? angle_circle_ownKeys(Object(source), !0).forEach(function (key) { angle_circle_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : angle_circle_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction angle_circle_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction angle_circle_objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = angle_circle_objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction angle_circle_objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n/**\n * WordPress dependencies\n */\n\n\n\n\n\n\n/**\n * Internal dependencies\n */\n\nconst CIRCLE_SIZE = 32;\nconst INNER_CIRCLE_SIZE = 3;\n\nconst angle_circle_space = n => `${n * 4}px`;\n\nfunction AngleCircle(_ref) {\n let {\n value,\n onChange\n } = _ref,\n props = angle_circle_objectWithoutProperties(_ref, angle_circle_excluded);\n\n const angleCircleRef = (0,external_window_wp_element_.useRef)();\n const angleCircleCenter = (0,external_window_wp_element_.useRef)();\n const previousCursorValue = (0,external_window_wp_element_.useRef)();\n\n const setAngleCircleCenter = () => {\n const rect = angleCircleRef.current.getBoundingClientRect();\n angleCircleCenter.current = {\n x: rect.x + rect.width / 2,\n y: rect.y + rect.height / 2\n };\n };\n\n const changeAngleToPosition = event => {\n const {\n x: centerX,\n y: centerY\n } = angleCircleCenter.current;\n const {\n ownerDocument\n } = angleCircleRef.current; // Prevent (drag) mouse events from selecting and accidentally\n // triggering actions from other elements.\n\n event.preventDefault(); // Ensure the input isn't focused as preventDefault would leave it\n\n ownerDocument.activeElement.blur();\n onChange(getAngle(centerX, centerY, event.clientX, event.clientY));\n };\n\n const {\n startDrag,\n isDragging\n } = (0,external_window_wp_compose_.__experimentalUseDragging)({\n onDragStart: event => {\n setAngleCircleCenter();\n changeAngleToPosition(event);\n },\n onDragMove: changeAngleToPosition,\n onDragEnd: changeAngleToPosition\n });\n (0,external_window_wp_element_.useEffect)(() => {\n if (isDragging) {\n if (previousCursorValue.current === undefined) {\n previousCursorValue.current = document.body.style.cursor;\n }\n\n document.body.style.cursor = 'grabbing';\n } else {\n document.body.style.cursor = previousCursorValue.current || null;\n previousCursorValue.current = undefined;\n }\n }, [isDragging]);\n return (\n /* eslint-disable jsx-a11y/no-static-element-interactions */\n (0,external_window_wp_element_.createElement)(\"div\", angle_circle_extends({\n ref: angleCircleRef,\n onMouseDown: startDrag,\n className: \"components-angle-picker-control__angle-circle\",\n style: angle_circle_objectSpread(angle_circle_objectSpread({}, isDragging ? {\n cursor: 'grabbing'\n } : {}), {}, {\n borderRadius: '50%',\n border: `${config_values.borderWidth} solid ${colors_values.ui.border}`,\n boxSizing: 'border-box',\n cursor: 'grab',\n height: `${CIRCLE_SIZE}px`,\n overflow: `hidden`,\n width: `${CIRCLE_SIZE}px`\n })\n }, props), (0,external_window_wp_element_.createElement)(\"div\", {\n style: angle_circle_objectSpread(angle_circle_objectSpread({}, value ? {\n transform: `rotate(${value}deg)`\n } : {}), {}, {\n boxSizing: 'border-box',\n position: 'relative',\n width: '100%',\n height: '100%'\n }),\n className: \"components-angle-picker-control__angle-circle-indicator-wrapper\"\n }, (0,external_window_wp_element_.createElement)(\"div\", {\n style: {\n background: colors_values.admin.theme,\n borderRadius: '50%',\n border: `${INNER_CIRCLE_SIZE}px solid ${colors_values.admin.theme}`,\n bottom: 0,\n boxSizing: 'border-box',\n display: 'block',\n height: 0,\n left: 0,\n margin: 'auto',\n position: 'absolute',\n right: 0,\n top: `-${CIRCLE_SIZE / 2}px`,\n width: 0\n },\n className: \"components-angle-picker-control__angle-circle-indicator\"\n })))\n /* eslint-enable jsx-a11y/no-static-element-interactions */\n\n );\n}\n\nfunction getAngle(centerX, centerY, pointX, pointY) {\n const y = pointY - centerY;\n const x = pointX - centerX;\n const angleInRadians = Math.atan2(y, x);\n const angleInDeg = Math.round(angleInRadians * (180 / Math.PI)) + 90;\n\n if (angleInDeg < 0) {\n return 360 + angleInDeg;\n }\n\n return angleInDeg;\n}\n\n/* harmony default export */ const angle_circle = (AngleCircle);\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/angle-picker-control/index.js\n\n/**\n * External dependencies\n */\n\n\n/**\n * WordPress dependencies\n */\n\n\n/**\n * Internal dependencies\n */\n\n\nconst {\n Flex,\n FlexBlock,\n FlexItem,\n __experimentalText: Text,\n __experimentalSpacer: Spacer,\n __experimentalInputControl: NumberControl\n} = window.wp.components; // margin-bottom: 8px\n\nconst angle_picker_control_space = n => `${n * 4}px`;\n\nfunction AnglePickerControl(_ref) {\n let {\n className,\n label = (0,external_window_wp_i18n_.__)('Angle'),\n onChange,\n value\n } = _ref;\n\n const handleOnNumberChange = unprocessedValue => {\n const inputValue = unprocessedValue !== '' ? parseInt(unprocessedValue, 10) : 0;\n onChange(inputValue);\n };\n\n const classes = classnames_default()('components-angle-picker-control', className);\n const Root = Flex;\n return (0,external_window_wp_element_.createElement)(Root, {\n className: classes\n }, (0,external_window_wp_element_.createElement)(FlexBlock, null, (0,external_window_wp_element_.createElement)(NumberControl, {\n label: label,\n className: \"components-angle-picker-control__input-field\",\n max: 360,\n min: 0,\n onChange: handleOnNumberChange,\n size: \"__unstable-large\",\n step: \"1\",\n value: value,\n hideHTMLArrows: true,\n suffix: (0,external_window_wp_element_.createElement)(Spacer, {\n as: Text,\n marginBottom: 0,\n marginRight: angle_picker_control_space(3),\n style: {\n color: 'var( --wp-admin-theme-color )'\n }\n }, \"\\xB0\")\n })), (0,external_window_wp_element_.createElement)(FlexItem, {\n style: {\n marginLeft: angle_picker_control_space(4),\n marginBottom: angle_picker_control_space(1),\n marginTop: 'auto'\n }\n }, (0,external_window_wp_element_.createElement)(angle_circle, {\n \"aria-hidden\": \"true\",\n value: value,\n onChange: onChange\n })));\n}\n// EXTERNAL MODULE: ./node_modules/lodash/some.js\nvar some = __webpack_require__(9704);\nvar some_default = /*#__PURE__*/__webpack_require__.n(some);\n// EXTERNAL MODULE: ./node_modules/@wordpress/icons/build-module/library/plus.js\nvar plus = __webpack_require__(5117);\n// EXTERNAL MODULE: external \"window.wp.keycodes\"\nvar external_window_wp_keycodes_ = __webpack_require__(7228);\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/custom-gradient-bar/constants.js\nconst GRADIENT_MARKERS_WIDTH = 16;\nconst INSERT_POINT_WIDTH = 16;\nconst MINIMUM_ABSOLUTE_LEFT_POSITION = 5;\nconst MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_POINT = 10;\nconst MINIMUM_DISTANCE_BETWEEN_POINTS = 0;\nconst MINIMUM_SIGNIFICANT_MOVE = 5;\nconst KEYBOARD_CONTROL_POINT_VARIATION = MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_POINT;\nconst MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_MARKER = (INSERT_POINT_WIDTH + GRADIENT_MARKERS_WIDTH) / 2;\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/custom-gradient-bar/utils.js\nfunction utils_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction utils_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? utils_ownKeys(Object(source), !0).forEach(function (key) { utils_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : utils_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction utils_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * Internal dependencies\n */\n\n/**\n * Control point for the gradient bar.\n *\n * @typedef {Object} ControlPoint\n * @property {string} color Color of the control point.\n * @property {number} position Integer position of the control point as a percentage.\n */\n\n/**\n * Color as parsed from the gradient by gradient-parser.\n *\n * @typedef {Object} Color\n * @property {string} r Red component.\n * @property {string} g Green component.\n * @property {string} b Green component.\n * @property {string} [a] Optional alpha component.\n */\n\n/**\n * Clamps a number between 0 and 100.\n *\n * @param {number} value Value to clamp.\n *\n * @return {number} Value clamped between 0 and 100.\n */\n\nfunction clampPercent(value) {\n return Math.max(0, Math.min(100, value));\n}\n/**\n * Check if a control point is overlapping with another.\n *\n * @param {ControlPoint[]} value Array of control points.\n * @param {number} initialIndex Index of the position to test.\n * @param {number} newPosition New position of the control point.\n * @param {number} minDistance Distance considered to be overlapping.\n *\n * @return {boolean} True if the point is overlapping.\n */\n\nfunction isOverlapping(value, initialIndex, newPosition) {\n let minDistance = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : MINIMUM_DISTANCE_BETWEEN_POINTS;\n const initialPosition = value[initialIndex].position;\n const minPosition = Math.min(initialPosition, newPosition);\n const maxPosition = Math.max(initialPosition, newPosition);\n return value.some((_ref, index) => {\n let {\n position\n } = _ref;\n return index !== initialIndex && (Math.abs(position - newPosition) < minDistance || minPosition < position && position < maxPosition);\n });\n}\n/**\n * Adds a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points Array of control points.\n * @param {number} position Position to insert the new point.\n * @param {Color} color Color to update the control point at index.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nfunction addControlPoint(points, position, color) {\n const nextIndex = points.findIndex(point => point.position > position);\n const newPoint = {\n color,\n position\n };\n const newPoints = points.slice();\n newPoints.splice(nextIndex - 1, 0, newPoint);\n return newPoints;\n}\n/**\n * Removes a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points Array of control points.\n * @param {number} index Index to remove.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nfunction removeControlPoint(points, index) {\n return points.filter((point, pointIndex) => {\n return pointIndex !== index;\n });\n}\n/**\n * Updates a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points Array of control points.\n * @param {number} index Index to update.\n * @param {ControlPoint[]} newPoint New control point to replace the index.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nfunction updateControlPoint(points, index, newPoint) {\n const newValue = points.slice();\n newValue[index] = newPoint;\n return newValue;\n}\n/**\n * Updates the position of a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points Array of control points.\n * @param {number} index Index to update.\n * @param {number} newPosition Position to move the control point at index.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nfunction updateControlPointPosition(points, index, newPosition) {\n if (isOverlapping(points, index, newPosition)) {\n return points;\n }\n\n const newPoint = utils_objectSpread(utils_objectSpread({}, points[index]), {}, {\n position: newPosition\n });\n\n return updateControlPoint(points, index, newPoint);\n}\n/**\n * Updates the position of a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points Array of control points.\n * @param {number} index Index to update.\n * @param {Color} newColor Color to update the control point at index.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nfunction updateControlPointColor(points, index, newColor) {\n const newPoint = utils_objectSpread(utils_objectSpread({}, points[index]), {}, {\n color: newColor\n });\n\n return updateControlPoint(points, index, newPoint);\n}\n/**\n * Updates the position of a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points Array of control points.\n * @param {number} position Position of the color stop.\n * @param {string} newColor Color to update the control point at index.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nfunction updateControlPointColorByPosition(points, position, newColor) {\n const index = points.findIndex(point => point.position === position);\n return updateControlPointColor(points, index, newColor);\n}\n/**\n * Gets the horizontal coordinate when dragging a control point with the mouse.\n *\n * @param {number} mouseXCoordinate Horizontal coordinate of the mouse position.\n * @param {Element} containerElement Container for the gradient picker.\n * @param {number} positionedElementWidth Width of the positioned element.\n *\n * @return {number} Whole number percentage from the left.\n */\n\nfunction getHorizontalRelativeGradientPosition(mouseXCoordinate, containerElement, positionedElementWidth) {\n if (!containerElement) {\n return;\n }\n\n const {\n x,\n width\n } = containerElement.getBoundingClientRect();\n const absolutePositionValue = mouseXCoordinate - x - MINIMUM_ABSOLUTE_LEFT_POSITION - positionedElementWidth / 2;\n const availableWidth = width - MINIMUM_ABSOLUTE_LEFT_POSITION - INSERT_POINT_WIDTH;\n return Math.round(clampPercent(absolutePositionValue * 100 / availableWidth));\n}\n// EXTERNAL MODULE: ./static/js/options/helpers/normalize-color.js\nvar normalize_color = __webpack_require__(9287);\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/custom-gradient-bar/control-points.js\nconst control_points_excluded = [\"isRenderedInSidebar\"],\n control_points_excluded2 = [\"isOpen\", \"position\", \"color\"],\n _excluded3 = [\"isRenderedInSidebar\", \"gradientPickerDomRef\"];\n\nfunction control_points_extends() { control_points_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return control_points_extends.apply(this, arguments); }\n\nfunction control_points_objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = control_points_objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction control_points_objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n/**\n * External dependencies\n */\n\n\n/**\n * WordPress dependencies\n */\n\n\n\n\n\n\n/**\n * Internal dependencies\n */\n\n\n\n\n\nfunction CustomColorPickerDropdown(_ref) {\n let {\n isRenderedInSidebar\n } = _ref,\n props = control_points_objectWithoutProperties(_ref, control_points_excluded);\n\n return (0,external_window_wp_element_.createElement)(external_window_wp_components_.Dropdown, control_points_extends({\n contentClassName: classnames_default()('components-color-palette__custom-color-dropdown-content', {\n 'is-rendered-in-sidebar': isRenderedInSidebar\n })\n }, props));\n}\n\nfunction ControlPointButton(_ref2) {\n let {\n isOpen,\n position,\n color\n } = _ref2,\n additionalProps = control_points_objectWithoutProperties(_ref2, control_points_excluded2);\n\n const instanceId = (0,external_window_wp_compose_.useInstanceId)(ControlPointButton);\n const descriptionId = `components-custom-gradient-picker__control-point-button-description-${instanceId}`;\n return (0,external_window_wp_element_.createElement)(React.Fragment, null, (0,external_window_wp_element_.createElement)(external_window_wp_components_.Button, control_points_extends({\n \"aria-label\": (0,external_window_wp_i18n_.sprintf)( // translators: %1$s: gradient position e.g: 70, %2$s: gradient color code e.g: rgb(52,121,151).\n (0,external_window_wp_i18n_.__)('Gradient control point at position %1$s%% with color code %2$s.'), position, color),\n \"aria-describedby\": descriptionId,\n \"aria-haspopup\": \"true\",\n \"aria-expanded\": isOpen,\n className: classnames_default()('components-custom-gradient-picker__control-point-button', {\n 'is-active': isOpen\n }),\n style: {\n left: `${position}%`\n }\n }, additionalProps)));\n}\n\nfunction GradientColorPickerDropdown(_ref3) {\n let {\n isRenderedInSidebar,\n gradientPickerDomRef\n } = _ref3,\n props = control_points_objectWithoutProperties(_ref3, _excluded3);\n\n const popoverProps = (0,external_window_wp_element_.useMemo)(() => {\n const result = {\n className: 'components-custom-gradient-picker__color-picker-popover',\n position: 'top'\n };\n\n if (isRenderedInSidebar) {\n result.anchorRef = gradientPickerDomRef.current;\n result.position = 'bottom left';\n }\n\n return result;\n }, [gradientPickerDomRef.current, isRenderedInSidebar]);\n return (0,external_window_wp_element_.createElement)(CustomColorPickerDropdown, control_points_extends({\n isRenderedInSidebar: isRenderedInSidebar,\n popoverProps: popoverProps\n }, props));\n}\n\nfunction ControlPoints(_ref4) {\n let {\n disableRemove,\n disableAlpha,\n gradientPickerDomRef,\n ignoreMarkerPosition,\n value: controlPoints,\n onChange,\n onStartControlPointChange,\n onStopControlPointChange,\n __experimentalIsRenderedInSidebar\n } = _ref4;\n const controlPointMoveState = (0,external_window_wp_element_.useRef)();\n\n const onMouseMove = event => {\n const relativePosition = getHorizontalRelativeGradientPosition(event.clientX, gradientPickerDomRef.current, GRADIENT_MARKERS_WIDTH);\n const {\n initialPosition,\n index,\n significantMoveHappened\n } = controlPointMoveState.current;\n\n if (!significantMoveHappened && Math.abs(initialPosition - relativePosition) >= MINIMUM_SIGNIFICANT_MOVE) {\n controlPointMoveState.current.significantMoveHappened = true;\n }\n\n onChange(updateControlPointPosition(controlPoints, index, relativePosition));\n };\n\n const cleanEventListeners = () => {\n if (window && window.removeEventListener && controlPointMoveState.current && controlPointMoveState.current.listenersActivated) {\n window.removeEventListener('mousemove', onMouseMove);\n window.removeEventListener('mouseup', cleanEventListeners);\n onStopControlPointChange();\n controlPointMoveState.current.listenersActivated = false;\n }\n };\n\n (0,external_window_wp_element_.useEffect)(() => {\n return () => {\n cleanEventListeners();\n };\n }, []);\n return controlPoints.map((point, index) => {\n const initialPosition = point === null || point === void 0 ? void 0 : point.position;\n return ignoreMarkerPosition !== initialPosition && (0,external_window_wp_element_.createElement)(GradientColorPickerDropdown, {\n gradientPickerDomRef: gradientPickerDomRef,\n isRenderedInSidebar: __experimentalIsRenderedInSidebar,\n key: index,\n onClose: onStopControlPointChange,\n renderToggle: _ref5 => {\n let {\n isOpen,\n onToggle\n } = _ref5;\n return (0,external_window_wp_element_.createElement)(ControlPointButton, {\n key: index,\n onClick: () => {\n if (controlPointMoveState.current && controlPointMoveState.current.significantMoveHappened) {\n return;\n }\n\n if (isOpen) {\n onStopControlPointChange();\n } else {\n onStartControlPointChange();\n }\n\n onToggle();\n },\n onMouseDown: () => {\n if (window && window.addEventListener) {\n controlPointMoveState.current = {\n initialPosition,\n index,\n significantMoveHappened: false,\n listenersActivated: true\n };\n onStartControlPointChange();\n window.addEventListener('mousemove', onMouseMove);\n window.addEventListener('mouseup', cleanEventListeners);\n }\n },\n onKeyDown: event => {\n if (event.keyCode === external_window_wp_keycodes_.LEFT) {\n // Stop propagation of the key press event to avoid focus moving\n // to another editor area.\n event.stopPropagation();\n onChange(updateControlPointPosition(controlPoints, index, clampPercent(point.position - KEYBOARD_CONTROL_POINT_VARIATION)));\n } else if (event.keyCode === external_window_wp_keycodes_.RIGHT) {\n // Stop propagation of the key press event to avoid focus moving\n // to another editor area.\n event.stopPropagation();\n onChange(updateControlPointPosition(controlPoints, index, clampPercent(point.position + KEYBOARD_CONTROL_POINT_VARIATION)));\n }\n },\n isOpen: isOpen,\n position: point.position,\n color: point.color\n });\n },\n renderContent: _ref6 => {\n let {\n onClose\n } = _ref6;\n return (0,external_window_wp_element_.createElement)(React.Fragment, null, (0,external_window_wp_element_.createElement)(\"div\", {\n className: wp.components.GradientPicker ? 'ct-gutenberg-color-picker-new' : 'ct-gutenberg-color-picker'\n }, (0,external_window_wp_element_.createElement)(external_window_wp_components_.ColorPicker, control_points_extends({\n enableAlpha: !disableAlpha,\n color: point.color\n }, wp.components.GradientPicker ? {\n onChange: color => {\n onChange(updateControlPointColor(controlPoints, index, (0,normalize_color/* normalizeColor */.u)(color)));\n }\n } : {\n onChangeComplete: result => {\n onChange(updateControlPointColor(controlPoints, index, result.rgb.a === 1 ? result.hex : `rgba(${result.rgb.r}, ${result.rgb.g}, ${result.rgb.b}, ${result.rgb.a})`));\n }\n })), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-color-picker-value\"\n }, (0,external_window_wp_element_.createElement)(\"input\", {\n type: \"text\",\n value: (0,normalize_color/* normalizeColor */.u)(point.color),\n onChange: e => {\n onChange(updateControlPointColor(controlPoints, index, (0,normalize_color/* normalizeColor */.u)(e.target.value)));\n }\n }))), !disableRemove && controlPoints.length > 2 && (0,external_window_wp_element_.createElement)(external_window_wp_components_.Button, {\n className: \"components-custom-gradient-picker__remove-control-point\",\n onClick: () => {\n onChange(removeControlPoint(controlPoints, index));\n onClose();\n },\n variant: \"link\"\n }, (0,external_window_wp_i18n_.__)('Remove Control Point')));\n }\n });\n });\n}\n\nfunction InsertPoint(_ref7) {\n let {\n value: controlPoints,\n onChange,\n onOpenInserter,\n onCloseInserter,\n insertPosition,\n disableAlpha,\n __experimentalIsRenderedInSidebar,\n gradientPickerDomRef\n } = _ref7;\n const [alreadyInsertedPoint, setAlreadyInsertedPoint] = (0,external_window_wp_element_.useState)(false);\n const [insertedColor, setInsertedColor] = (0,external_window_wp_element_.useState)('#fff');\n return (0,external_window_wp_element_.createElement)(GradientColorPickerDropdown, {\n gradientPickerDomRef: gradientPickerDomRef,\n isRenderedInSidebar: __experimentalIsRenderedInSidebar,\n className: \"components-custom-gradient-picker__inserter\",\n onClose: () => {\n onCloseInserter();\n },\n renderToggle: _ref8 => {\n let {\n isOpen,\n onToggle\n } = _ref8;\n return (0,external_window_wp_element_.createElement)(external_window_wp_components_.Button, {\n \"aria-expanded\": isOpen,\n \"aria-haspopup\": \"true\",\n onClick: () => {\n if (isOpen) {\n onCloseInserter();\n } else {\n setAlreadyInsertedPoint(false);\n onOpenInserter();\n }\n\n onToggle();\n },\n className: \"components-custom-gradient-picker__insert-point\",\n icon: plus/* default */.Z,\n style: {\n left: insertPosition !== null ? `${insertPosition}%` : undefined\n }\n });\n },\n renderContent: () => (0,external_window_wp_element_.createElement)(\"div\", {\n className: wp.components.GradientPicker ? 'ct-gutenberg-color-picker-new' : 'ct-gutenberg-color-picker'\n }, (0,external_window_wp_element_.createElement)(external_window_wp_components_.ColorPicker, control_points_extends({\n enableAlpha: !disableAlpha,\n color: insertedColor\n }, wp.components.GradientPicker ? {\n onChange: color => {\n if (!alreadyInsertedPoint) {\n onChange(addControlPoint(controlPoints, insertPosition, (0,normalize_color/* normalizeColor */.u)(color)));\n setAlreadyInsertedPoint(true);\n } else {\n onChange(updateControlPointColorByPosition(controlPoints, insertPosition, (0,normalize_color/* normalizeColor */.u)(color)));\n }\n\n setInsertedColor(color);\n }\n } : {\n onChangeComplete: result => {\n if (!alreadyInsertedPoint) {\n onChange(addControlPoint(controlPoints, insertPosition, result.rgb.a === 1 ? result.hex : `rgba(${result.rgb.r}, ${result.rgb.g}, ${result.rgb.b}, ${result.rgb.a})`));\n setAlreadyInsertedPoint(true);\n } else {\n onChange(updateControlPointColorByPosition(controlPoints, insertPosition, result.rgb.a === 1 ? result.hex : `rgba(${result.rgb.r}, ${result.rgb.g}, ${result.rgb.b}, ${result.rgb.a})`));\n }\n\n setInsertedColor(result.rgb.a === 1 ? result.hex : `rgba(${result.rgb.r}, ${result.rgb.g}, ${result.rgb.b}, ${result.rgb.a})`);\n }\n })), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-color-picker-value\"\n }, (0,external_window_wp_element_.createElement)(\"input\", {\n value: (0,normalize_color/* normalizeColor */.u)(insertedColor),\n type: \"text\",\n onChange: _ref9 => {\n let {\n target: {\n value: color\n }\n } = _ref9;\n\n if (!alreadyInsertedPoint) {\n onChange(addControlPoint(controlPoints, insertPosition, (0,normalize_color/* normalizeColor */.u)(color)));\n setAlreadyInsertedPoint(true);\n } else {\n onChange(updateControlPointColorByPosition(controlPoints, insertPosition, (0,normalize_color/* normalizeColor */.u)(color)));\n }\n\n setInsertedColor(color);\n }\n })))\n });\n}\n\nControlPoints.InsertPoint = InsertPoint;\n/* harmony default export */ const control_points = (ControlPoints);\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/custom-gradient-bar/index.js\n\n\n/**\n * External dependencies\n */\n\n\n/**\n * WordPress dependencies\n */\n\n\n/**\n * Internal dependencies\n */\n\n\n\n\n\nfunction customGradientBarReducer(state, action) {\n switch (action.type) {\n case 'MOVE_INSERTER':\n if (state.id === 'IDLE' || state.id === 'MOVING_INSERTER') {\n return {\n id: 'MOVING_INSERTER',\n insertPosition: action.insertPosition\n };\n }\n\n break;\n\n case 'STOP_INSERTER_MOVE':\n if (state.id === 'MOVING_INSERTER') {\n return {\n id: 'IDLE'\n };\n }\n\n break;\n\n case 'OPEN_INSERTER':\n if (state.id === 'MOVING_INSERTER') {\n return {\n id: 'INSERTING_CONTROL_POINT',\n insertPosition: state.insertPosition\n };\n }\n\n break;\n\n case 'CLOSE_INSERTER':\n if (state.id === 'INSERTING_CONTROL_POINT') {\n return {\n id: 'IDLE'\n };\n }\n\n break;\n\n case 'START_CONTROL_CHANGE':\n if (state.id === 'IDLE') {\n return {\n id: 'MOVING_CONTROL_POINT'\n };\n }\n\n break;\n\n case 'STOP_CONTROL_CHANGE':\n if (state.id === 'MOVING_CONTROL_POINT') {\n return {\n id: 'IDLE'\n };\n }\n\n break;\n }\n\n return state;\n}\n\nconst customGradientBarReducerInitialState = {\n id: 'IDLE'\n};\nfunction CustomGradientBar(_ref) {\n let {\n background,\n hasGradient,\n value: controlPoints,\n onChange,\n disableInserter = false,\n disableAlpha = false,\n __experimentalIsRenderedInSidebar\n } = _ref;\n const gradientPickerDomRef = (0,external_window_wp_element_.useRef)();\n const [gradientBarState, gradientBarStateDispatch] = (0,external_window_wp_element_.useReducer)(customGradientBarReducer, customGradientBarReducerInitialState);\n\n const onMouseEnterAndMove = event => {\n const insertPosition = getHorizontalRelativeGradientPosition(event.clientX, gradientPickerDomRef.current, INSERT_POINT_WIDTH); // If the insert point is close to an existing control point don't show it.\n\n if (some_default()(controlPoints, _ref2 => {\n let {\n position\n } = _ref2;\n return Math.abs(insertPosition - position) < MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_POINT;\n })) {\n if (gradientBarState.id === 'MOVING_INSERTER') {\n gradientBarStateDispatch({\n type: 'STOP_INSERTER_MOVE'\n });\n }\n\n return;\n }\n\n gradientBarStateDispatch({\n type: 'MOVE_INSERTER',\n insertPosition\n });\n };\n\n const onMouseLeave = () => {\n gradientBarStateDispatch({\n type: 'STOP_INSERTER_MOVE'\n });\n };\n\n const isMovingInserter = gradientBarState.id === 'MOVING_INSERTER';\n const isInsertingControlPoint = gradientBarState.id === 'INSERTING_CONTROL_POINT';\n return (0,external_window_wp_element_.createElement)(\"div\", {\n ref: gradientPickerDomRef,\n className: classnames_default()('components-custom-gradient-picker__gradient-bar', {\n 'has-gradient': hasGradient\n }),\n onMouseEnter: onMouseEnterAndMove,\n onMouseMove: onMouseEnterAndMove,\n style: {\n background\n },\n onMouseLeave: onMouseLeave\n }, (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"components-custom-gradient-picker__markers-container\"\n }, !disableInserter && (isMovingInserter || isInsertingControlPoint) && (0,external_window_wp_element_.createElement)(control_points.InsertPoint, {\n __experimentalIsRenderedInSidebar: __experimentalIsRenderedInSidebar,\n gradientPickerDomRef: gradientPickerDomRef,\n disableAlpha: disableAlpha,\n insertPosition: gradientBarState.insertPosition,\n value: controlPoints,\n onChange: onChange,\n onOpenInserter: () => {\n gradientBarStateDispatch({\n type: 'OPEN_INSERTER'\n });\n },\n onCloseInserter: () => {\n gradientBarStateDispatch({\n type: 'CLOSE_INSERTER'\n });\n }\n }), (0,external_window_wp_element_.createElement)(control_points, {\n __experimentalIsRenderedInSidebar: __experimentalIsRenderedInSidebar,\n disableAlpha: disableAlpha,\n disableRemove: disableInserter,\n gradientPickerDomRef: gradientPickerDomRef,\n ignoreMarkerPosition: isInsertingControlPoint ? gradientBarState.insertPosition : undefined,\n value: controlPoints,\n onChange: onChange,\n onStartControlPointChange: () => {\n gradientBarStateDispatch({\n type: 'START_CONTROL_CHANGE'\n });\n },\n onStopControlPointChange: () => {\n gradientBarStateDispatch({\n type: 'STOP_CONTROL_CHANGE'\n });\n }\n })));\n}\n// EXTERNAL MODULE: ./node_modules/gradient-parser/build/node.js\nvar node = __webpack_require__(9948);\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/constants.js\n/**\n * WordPress dependencies\n */\n\nconst DEFAULT_GRADIENT = 'linear-gradient(135deg, rgba(6, 147, 227, 1) 0%, rgb(155, 81, 224) 100%)';\nconst DEFAULT_LINEAR_GRADIENT_ANGLE = 180;\nconst HORIZONTAL_GRADIENT_ORIENTATION = {\n type: 'angular',\n value: 90\n};\nconst GRADIENT_OPTIONS = [{\n value: 'linear-gradient',\n label: (0,external_window_wp_i18n_.__)('Linear', 'blocksy')\n}, {\n value: 'radial-gradient',\n label: (0,external_window_wp_i18n_.__)('Radial', 'blocksy')\n}];\nconst DIRECTIONAL_ORIENTATION_ANGLE_MAP = {\n top: 0,\n 'top right': 45,\n 'right top': 45,\n right: 90,\n 'right bottom': 135,\n 'bottom right': 135,\n bottom: 180,\n 'bottom left': 225,\n 'left bottom': 225,\n left: 270,\n 'top left': 315,\n 'left top': 315\n};\n// EXTERNAL MODULE: ./node_modules/lodash/compact.js\nvar compact = __webpack_require__(9693);\nvar compact_default = /*#__PURE__*/__webpack_require__.n(compact);\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/serializer.js\n\n\nfunction serializeGradientColor(_ref) {\n let {\n type,\n value\n } = _ref;\n\n if (type === 'literal') {\n return value;\n }\n\n if (type === 'hex') {\n return `#${value}`;\n }\n\n return `${type}(${value.join(',')})`;\n}\nfunction serializeGradientPosition(position) {\n if (!position) {\n return '';\n }\n\n const {\n value,\n type\n } = position;\n return `${value}${type}`;\n}\nfunction serializeGradientColorStop(_ref2) {\n let {\n type,\n value,\n length\n } = _ref2;\n return `${serializeGradientColor({\n type,\n value\n })} ${serializeGradientPosition(length)}`;\n}\nfunction serializeGradientOrientation(orientation) {\n if (!orientation || orientation.type !== 'angular') {\n return;\n }\n\n return `${orientation.value}deg`;\n}\nfunction serializeGradient(_ref3) {\n let {\n type,\n orientation,\n colorStops\n } = _ref3;\n const serializedOrientation = serializeGradientOrientation(orientation);\n const serializedColorStops = colorStops.sort((colorStop1, colorStop2) => {\n return get_default()(colorStop1, ['length', 'value'], 0) - get_default()(colorStop2, ['length', 'value'], 0);\n }).map(serializeGradientColorStop);\n return `${type}(${compact_default()([serializedOrientation, ...serializedColorStops]).join(',')})`;\n}\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/utils.js\nfunction gradient_utils_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction gradient_utils_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? gradient_utils_ownKeys(Object(source), !0).forEach(function (key) { gradient_utils_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : gradient_utils_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction gradient_utils_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * External dependencies\n */\n\n\n\n/**\n * Internal dependencies\n */\n\n\n\n(0,colord/* extend */.l7)([names/* default */.Z]);\nfunction getLinearGradientRepresentation(gradientAST) {\n return serializeGradient({\n type: 'linear-gradient',\n orientation: HORIZONTAL_GRADIENT_ORIENTATION,\n colorStops: gradientAST.colorStops\n });\n}\n\nfunction hasUnsupportedLength(item) {\n return item.length === undefined || item.length.type !== '%';\n}\n\nfunction getGradientAstWithDefault(value) {\n var _gradientAST$orientat;\n\n // gradientAST will contain the gradient AST as parsed by gradient-parser npm module.\n // More information of its structure available at https://www.npmjs.com/package/gradient-parser#ast.\n let gradientAST;\n let temporaryInvalidValue = value.match(/\\~(.*)\\~/, '');\n value = value.replace(/\\~.*\\~/, 'rgb(500, 500, 500)');\n\n try {\n gradientAST = node.parse(value)[0];\n gradientAST.value = value;\n } catch (error) {\n gradientAST = node.parse(DEFAULT_GRADIENT)[0];\n gradientAST.value = DEFAULT_GRADIENT;\n }\n\n if (((_gradientAST$orientat = gradientAST.orientation) === null || _gradientAST$orientat === void 0 ? void 0 : _gradientAST$orientat.type) === 'directional') {\n gradientAST.orientation.type = 'angular';\n gradientAST.orientation.value = DIRECTIONAL_ORIENTATION_ANGLE_MAP[gradientAST.orientation.value].toString();\n }\n\n if (gradientAST.colorStops.some(hasUnsupportedLength)) {\n const {\n colorStops\n } = gradientAST;\n const step = 100 / (colorStops.length - 1);\n colorStops.forEach((stop, index) => {\n if (stop.value[0] === '500') {\n stop.type = 'literal';\n stop.value = '';\n }\n\n stop.length = {\n value: step * index,\n type: '%'\n };\n });\n gradientAST.value = serializeGradient(gradientAST);\n }\n\n gradientAST.colorStops.forEach((stop, index) => {\n if (stop.value[0] === '500' && temporaryInvalidValue) {\n stop.type = 'literal';\n stop.value = temporaryInvalidValue[1];\n }\n });\n return gradientAST;\n}\nfunction getGradientAstWithControlPoints(gradientAST, newControlPoints) {\n return gradient_utils_objectSpread(gradient_utils_objectSpread({}, gradientAST), {}, {\n colorStops: newControlPoints.map(_ref => {\n let {\n position,\n color\n } = _ref;\n let parsedColor = (0,colord/* colord */.Vi)(color);\n let result = {\n length: {\n type: '%',\n value: position.toString()\n },\n type: 'literal',\n value: `~${color}~`\n };\n\n if (parsedColor.parsed) {\n const {\n r,\n g,\n b,\n a\n } = parsedColor.toRgb();\n result.type = a < 1 ? 'rgba' : 'rgb';\n result.value = a < 1 ? [r, g, b, a] : [r, g, b];\n }\n\n return result;\n })\n });\n}\nfunction getStopCssColor(colorStop) {\n switch (colorStop.type) {\n case 'hex':\n return `#${colorStop.value}`;\n\n case 'literal':\n return colorStop.value;\n\n case 'rgb':\n case 'rgba':\n return `${colorStop.type}(${colorStop.value.join(',')})`;\n\n default:\n // Should be unreachable if passing an AST from gradient-parser.\n // See https://github.com/rafaelcaricio/gradient-parser#ast.\n return 'transparent';\n }\n}\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/custom-gradient-picker.js\n\n\n\nfunction custom_gradient_picker_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction custom_gradient_picker_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? custom_gradient_picker_ownKeys(Object(source), !0).forEach(function (key) { custom_gradient_picker_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : custom_gradient_picker_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction custom_gradient_picker_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n/**\n * External dependencies\n */\n\n/**\n * WordPress dependencies\n */\n\n\n/**\n * Internal dependencies\n */\n\n\n\n\n\n\n\nconst GradientAnglePicker = _ref => {\n let {\n gradientAST,\n hasGradient,\n onChange\n } = _ref;\n\n const angle = get_default()(gradientAST, ['orientation', 'value'], DEFAULT_LINEAR_GRADIENT_ANGLE);\n\n const onAngleChange = newAngle => {\n onChange(serializeGradient(custom_gradient_picker_objectSpread(custom_gradient_picker_objectSpread({}, gradientAST), {}, {\n orientation: {\n type: 'angular',\n value: newAngle\n }\n })));\n };\n\n return (0,external_window_wp_element_.createElement)(AnglePickerControl, {\n onChange: onAngleChange,\n labelPosition: \"top\",\n value: hasGradient ? angle : ''\n });\n};\n\nconst GradientTypePicker = _ref2 => {\n let {\n gradientAST,\n hasGradient,\n onChange\n } = _ref2;\n const {\n type\n } = gradientAST;\n\n const onSetLinearGradient = () => {\n onChange(serializeGradient(custom_gradient_picker_objectSpread(custom_gradient_picker_objectSpread(custom_gradient_picker_objectSpread({}, gradientAST), gradientAST.orientation ? {} : {\n orientation: HORIZONTAL_GRADIENT_ORIENTATION\n }), {}, {\n type: 'linear-gradient'\n })));\n };\n\n const onSetRadialGradient = () => {\n onChange(serializeGradient(custom_gradient_picker_objectSpread(custom_gradient_picker_objectSpread({}, omit_default()(gradientAST, ['orientation'])), {}, {\n type: 'radial-gradient'\n })));\n };\n\n const handleOnChange = next => {\n if (next === 'linear-gradient') {\n onSetLinearGradient();\n }\n\n if (next === 'radial-gradient') {\n onSetRadialGradient();\n }\n };\n\n return (0,external_window_wp_element_.createElement)(external_window_wp_components_.SelectControl, {\n className: \"components-custom-gradient-picker__type-picker\",\n label: (0,external_window_wp_i18n_.__)('Type'),\n labelPosition: \"top\",\n onChange: handleOnChange,\n options: GRADIENT_OPTIONS,\n size: \"__unstable-large\",\n value: hasGradient && type\n });\n};\n\nfunction CustomGradientPicker(_ref3) {\n let {\n value,\n onChange,\n __experimentalIsRenderedInSidebar\n } = _ref3;\n const gradientAST = getGradientAstWithDefault(value); // On radial gradients the bar should display a linear gradient.\n // On radial gradients the bar represents a slice of the gradient from the center until the outside.\n // On liner gradients the bar represents the color stops from left to right independently of the angle.\n\n const background = getLinearGradientRepresentation(gradientAST);\n const hasGradient = gradientAST.value !== DEFAULT_GRADIENT; // Control points color option may be hex from presets, custom colors will be rgb.\n // The position should always be a percentage.\n\n const controlPoints = gradientAST.colorStops.map(colorStop => ({\n color: getStopCssColor(colorStop),\n position: parseInt(colorStop.length.value)\n })); // flex-grow: 5;\n\n const AccessoryWrapper = external_window_wp_components_.FlexBlock;\n const SelectWrapper = external_window_wp_components_.FlexBlock;\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"components-custom-gradient-picker\"\n }, (0,external_window_wp_element_.createElement)(CustomGradientBar, {\n __experimentalIsRenderedInSidebar: __experimentalIsRenderedInSidebar,\n background: background,\n hasGradient: hasGradient,\n value: controlPoints,\n onChange: newControlPoints => {\n onChange(serializeGradient(getGradientAstWithControlPoints(gradientAST, newControlPoints)));\n }\n }), (0,external_window_wp_element_.createElement)(external_window_wp_components_.Flex, {\n gap: 3,\n className: \"components-custom-gradient-picker__ui-line\"\n }, (0,external_window_wp_element_.createElement)(SelectWrapper, null, (0,external_window_wp_element_.createElement)(GradientTypePicker, {\n gradientAST: gradientAST,\n hasGradient: hasGradient,\n onChange: onChange\n })), (0,external_window_wp_element_.createElement)(AccessoryWrapper, null, gradientAST.type === 'linear-gradient' && (0,external_window_wp_element_.createElement)(GradientAnglePicker, {\n gradientAST: gradientAST,\n hasGradient: hasGradient,\n onChange: onChange\n }))));\n}\n;// CONCATENATED MODULE: ./static/js/options/options/background/gradient/index.js\nfunction gradient_extends() { gradient_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return gradient_extends.apply(this, arguments); }\n\n/**\n * External dependencies\n */\n\n/**\n * WordPress dependencies\n */\n\n\n\n/**\n * Internal dependencies\n */\n\n\n\n\nfunction SingleOrigin(_ref) {\n let {\n className,\n clearGradient,\n gradients,\n onChange,\n value,\n actions,\n content\n } = _ref;\n const gradientOptions = (0,external_window_wp_element_.useMemo)(() => {\n return (gradients || []).map(_ref2 => {\n let {\n gradient,\n name\n } = _ref2;\n return (0,external_window_wp_element_.createElement)(CircularOptionPicker.Option, {\n key: gradient,\n value: gradient,\n isSelected: value === gradient,\n tooltipText: name || // translators: %s: gradient code e.g: \"linear-gradient(90deg, rgba(98,16,153,1) 0%, rgba(172,110,22,1) 100%);\".\n (0,external_window_wp_i18n_.sprintf)((0,external_window_wp_i18n_.__)('Gradient code: %s'), gradient),\n style: {\n color: 'rgba( 0,0,0,0 )',\n background: gradient\n },\n onClick: value === gradient ? clearGradient : () => onChange(gradient),\n \"aria-label\": name ? // translators: %s: The name of the gradient e.g: \"Angular red to blue\".\n (0,external_window_wp_i18n_.sprintf)((0,external_window_wp_i18n_.__)('Gradient: %s'), name) : // translators: %s: gradient code e.g: \"linear-gradient(90deg, rgba(98,16,153,1) 0%, rgba(172,110,22,1) 100%);\".\n (0,external_window_wp_i18n_.sprintf)((0,external_window_wp_i18n_.__)('Gradient code: %s'), gradient)\n });\n });\n }, [gradients, value, onChange, clearGradient]);\n return (0,external_window_wp_element_.createElement)(CircularOptionPicker, {\n className: className,\n options: gradientOptions,\n actions: actions\n }, content);\n}\n\nfunction MultipleOrigin(_ref3) {\n let {\n className,\n clearGradient,\n gradients,\n onChange,\n value,\n actions,\n content\n } = _ref3;\n return (0,external_window_wp_element_.createElement)(external_window_wp_components_.__experimentalVStack, {\n spacing: 3,\n className: className\n }, (gradients || []).map((_ref4, index) => {\n let {\n name,\n gradients: gradientSet\n } = _ref4;\n return (0,external_window_wp_element_.createElement)(external_window_wp_components_.__experimentalVStack, {\n spacing: 2,\n key: index\n }, (0,external_window_wp_element_.createElement)(external_window_wp_components_.__experimentalHeading, null, name), (0,external_window_wp_element_.createElement)(SingleOrigin, gradient_extends({\n clearGradient: clearGradient,\n gradients: gradientSet,\n onChange: onChange,\n value: value\n }, gradients.length === index + 1 ? {\n actions,\n content\n } : {})));\n }));\n}\n\nfunction GradientPicker(_ref5) {\n let {\n className,\n gradients,\n onChange,\n value,\n clearable = true,\n disableCustomGradients = false,\n __experimentalHasMultipleOrigins,\n __experimentalIsRenderedInSidebar\n } = _ref5;\n const clearGradient = (0,external_window_wp_element_.useCallback)(() => onChange(undefined), [onChange]);\n const Component = __experimentalHasMultipleOrigins && gradients !== null && gradients !== void 0 && gradients.length ? MultipleOrigin : SingleOrigin;\n return (0,external_window_wp_element_.createElement)(Component, {\n className: className,\n clearable: clearable,\n clearGradient: clearGradient,\n gradients: gradients,\n onChange: onChange,\n value: value,\n actions: clearable && ((gradients === null || gradients === void 0 ? void 0 : gradients.length) || !disableCustomGradients) && (0,external_window_wp_element_.createElement)(CircularOptionPicker.ButtonAction, {\n onClick: clearGradient\n }, (0,external_window_wp_i18n_.__)('Clear')),\n content: !disableCustomGradients && (0,external_window_wp_element_.createElement)(CustomGradientPicker, {\n __experimentalIsRenderedInSidebar: __experimentalIsRenderedInSidebar,\n value: value,\n onChange: onChange\n })\n });\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"1188.js","mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;ACvGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACzEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACzLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7UA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACnLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/background/gradient/circular-option-picker.js?6a5d","webpack://blocksyOptions/./static/js/options/options/background/gradient/colors.js?393f","webpack://blocksyOptions/./static/js/options/options/background/gradient/colors-values.js?fe1d","webpack://blocksyOptions/./static/js/options/options/background/gradient/config-values.js?dbf6","webpack://blocksyOptions/./static/js/options/options/background/gradient/angle-picker-control/angle-circle.js?1650","webpack://blocksyOptions/./static/js/options/options/background/gradient/angle-picker-control/index.js?8b03","webpack://blocksyOptions/./static/js/options/options/background/gradient/custom-gradient-bar/constants.js?1fb7","webpack://blocksyOptions/./static/js/options/options/background/gradient/custom-gradient-bar/utils.js?ec8f","webpack://blocksyOptions/./static/js/options/options/background/gradient/custom-gradient-bar/control-points.js?0651","webpack://blocksyOptions/./static/js/options/options/background/gradient/custom-gradient-bar/index.js?14a9","webpack://blocksyOptions/./static/js/options/options/background/gradient/constants.js?8c9e","webpack://blocksyOptions/./static/js/options/options/background/gradient/serializer.js?d26c","webpack://blocksyOptions/./static/js/options/options/background/gradient/utils.js?3eff","webpack://blocksyOptions/./static/js/options/options/background/gradient/custom-gradient-picker.js?e440","webpack://blocksyOptions/./static/js/options/options/background/gradient/index.js?c72a"],"sourcesContent":["const _excluded = [\"className\", \"isSelected\", \"selectedIconProps\", \"tooltipText\"],\n      _excluded2 = [\"className\", \"children\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport { createElement } from '@wordpress/element';\n/**\n * External dependencies\n */\n\nimport classnames from 'classnames';\n/**\n * WordPress dependencies\n */\n\nimport { Icon, check } from '@wordpress/icons';\n/**\n * Internal dependencies\n */\n\nimport { Button, Dropdown, Tooltip } from '@wordpress/components';\n\nfunction Option(_ref) {\n  let {\n    className,\n    isSelected,\n    selectedIconProps,\n    tooltipText\n  } = _ref,\n      additionalProps = _objectWithoutProperties(_ref, _excluded);\n\n  const optionButton = createElement(Button, _extends({\n    isPressed: isSelected,\n    className: \"components-circular-option-picker__option\"\n  }, additionalProps));\n  return createElement(\"div\", {\n    className: classnames(className, 'components-circular-option-picker__option-wrapper')\n  }, tooltipText ? createElement(Tooltip, {\n    text: tooltipText\n  }, optionButton) : optionButton, isSelected && createElement(Icon, _extends({\n    icon: check\n  }, selectedIconProps ? selectedIconProps : {})));\n}\n\nfunction DropdownLinkAction(_ref2) {\n  let {\n    buttonProps,\n    className,\n    dropdownProps,\n    linkText\n  } = _ref2;\n  return createElement(Dropdown, _extends({\n    className: classnames('components-circular-option-picker__dropdown-link-action', className),\n    renderToggle: _ref3 => {\n      let {\n        isOpen,\n        onToggle\n      } = _ref3;\n      return createElement(Button, _extends({\n        \"aria-expanded\": isOpen,\n        \"aria-haspopup\": \"true\",\n        onClick: onToggle,\n        variant: \"link\"\n      }, buttonProps), linkText);\n    }\n  }, dropdownProps));\n}\n\nfunction ButtonAction(_ref4) {\n  let {\n    className,\n    children\n  } = _ref4,\n      additionalProps = _objectWithoutProperties(_ref4, _excluded2);\n\n  return createElement(Button, _extends({\n    className: classnames('components-circular-option-picker__clear', className),\n    isSmall: true,\n    variant: \"secondary\"\n  }, additionalProps), children);\n}\n\nexport default function CircularOptionPicker(_ref5) {\n  let {\n    actions,\n    className,\n    options,\n    children\n  } = _ref5;\n  return createElement(\"div\", {\n    className: classnames('components-circular-option-picker', className)\n  }, createElement(\"div\", {\n    className: \"components-circular-option-picker__swatches\"\n  }, options), children, actions && createElement(\"div\", {\n    className: \"components-circular-option-picker__custom-clear-wrapper\"\n  }, actions));\n}\nCircularOptionPicker.Option = Option;\nCircularOptionPicker.ButtonAction = ButtonAction;\nCircularOptionPicker.DropdownLinkAction = DropdownLinkAction;","/**\n * External dependencies\n */\nimport { colord, extend } from 'colord';\nimport namesPlugin from 'colord/plugins/names';\nextend([namesPlugin]);\n/**\n * Generating a CSS compliant rgba() color value.\n *\n * @param {string} hexValue The hex value to convert to rgba().\n * @param {number} alpha    The alpha value for opacity.\n * @return {string} The converted rgba() color value.\n *\n * @example\n * rgba( '#000000', 0.5 )\n * // rgba(0, 0, 0, 0.5)\n */\n\nexport function rgba() {\n  let hexValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n  let alpha = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;\n  return colord(hexValue).alpha(alpha).toRgbString();\n}","import _merge from \"lodash/merge\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * Internal dependencies\n */\nimport { rgba } from './colors';\nexport const BASE = {\n  black: '#000',\n  white: '#fff'\n};\n/**\n * TODO: Continue to update values as \"G2\" design evolves.\n *\n * \"G2\" refers to the movement to advance the interface of the block editor.\n * https://github.com/WordPress/gutenberg/issues/18667\n */\n\nexport const G2 = {\n  blue: {\n    medium: {\n      focus: '#007cba',\n      focusDark: '#fff'\n    }\n  },\n  gray: {\n    900: '#1e1e1e',\n    700: '#757575',\n    // Meets 4.6:1 text contrast against white.\n    600: '#949494',\n    // Meets 3:1 UI or large text contrast against white.\n    400: '#ccc',\n    200: '#ddd',\n    // Used for most borders.\n    100: '#f0f0f0'\n  },\n  darkGray: {\n    primary: '#1e1e1e',\n    heading: '#050505'\n  },\n  mediumGray: {\n    text: '#757575'\n  },\n  lightGray: {\n    ui: '#949494',\n    secondary: '#ccc',\n    tertiary: '#e7e8e9'\n  }\n};\nexport const DARK_GRAY = {\n  900: '#191e23',\n  800: '#23282d',\n  700: '#32373c',\n  600: '#40464d',\n  500: '#555d66',\n  // Use this most of the time for dark items.\n  400: '#606a73',\n  300: '#6c7781',\n  // Lightest gray that can be used for AA text contrast.\n  200: '#7e8993',\n  150: '#8d96a0',\n  // Lightest gray that can be used for AA non-text contrast.\n  100: '#8f98a1',\n  placeholder: rgba(G2.gray[900], 0.62)\n};\nexport const DARK_OPACITY = {\n  900: rgba('#000510', 0.9),\n  800: rgba('#00000a', 0.85),\n  700: rgba('#06060b', 0.8),\n  600: rgba('#000913', 0.75),\n  500: rgba('#0a1829', 0.7),\n  400: rgba('#0a1829', 0.65),\n  300: rgba('#0e1c2e', 0.62),\n  200: rgba('#162435', 0.55),\n  100: rgba('#223443', 0.5),\n  backgroundFill: rgba(DARK_GRAY[700], 0.7)\n};\nexport const DARK_OPACITY_LIGHT = {\n  900: rgba('#304455', 0.45),\n  800: rgba('#425863', 0.4),\n  700: rgba('#667886', 0.35),\n  600: rgba('#7b86a2', 0.3),\n  500: rgba('#9197a2', 0.25),\n  400: rgba('#95959c', 0.2),\n  300: rgba('#829493', 0.15),\n  200: rgba('#8b8b96', 0.1),\n  100: rgba('#747474', 0.05)\n};\nexport const LIGHT_GRAY = {\n  900: '#a2aab2',\n  800: '#b5bcc2',\n  700: '#ccd0d4',\n  600: '#d7dade',\n  500: '#e2e4e7',\n  // Good for \"grayed\" items and borders.\n  400: '#e8eaeb',\n  // Good for \"readonly\" input fields and special text selection.\n  300: '#edeff0',\n  200: '#f3f4f5',\n  100: '#f8f9f9',\n  placeholder: rgba(BASE.white, 0.65)\n};\nexport const LIGHT_OPACITY_LIGHT = {\n  900: rgba(BASE.white, 0.5),\n  800: rgba(BASE.white, 0.45),\n  700: rgba(BASE.white, 0.4),\n  600: rgba(BASE.white, 0.35),\n  500: rgba(BASE.white, 0.3),\n  400: rgba(BASE.white, 0.25),\n  300: rgba(BASE.white, 0.2),\n  200: rgba(BASE.white, 0.15),\n  100: rgba(BASE.white, 0.1),\n  backgroundFill: rgba(LIGHT_GRAY[300], 0.8)\n}; // Additional colors.\n// Some are from https://make.wordpress.org/design/handbook/foundations/colors/.\n\nexport const BLUE = {\n  wordpress: {\n    700: '#00669b'\n  },\n  dark: {\n    900: '#0071a1'\n  },\n  medium: {\n    900: '#006589',\n    800: '#00739c',\n    700: '#007fac',\n    600: '#008dbe',\n    500: '#00a0d2',\n    400: '#33b3db',\n    300: '#66c6e4',\n    200: '#bfe7f3',\n    100: '#e5f5fa',\n    highlight: '#b3e7fe',\n    focus: '#007cba'\n  }\n};\nexport const ALERT = {\n  yellow: '#f0b849',\n  red: '#d94f4f',\n  green: '#4ab866'\n};\nexport const ADMIN = {\n  theme: `var( --wp-admin-theme-color, ${BLUE.wordpress[700]})`,\n  themeDark10: `var( --wp-admin-theme-color-darker-10, ${BLUE.medium.focus})`\n}; // Namespaced values for raw colors hex codes\n\nexport const UI = {\n  theme: ADMIN.theme,\n  background: BASE.white,\n  backgroundDisabled: LIGHT_GRAY[200],\n  border: G2.gray[700],\n  borderHover: G2.gray[700],\n  borderFocus: ADMIN.themeDark10,\n  borderDisabled: G2.gray[400],\n  borderLight: G2.gray[200],\n  label: DARK_GRAY[500],\n  textDisabled: DARK_GRAY[150],\n  textDark: BASE.white,\n  textLight: BASE.black\n};\nexport const COLORS = _objectSpread(_objectSpread({}, BASE), {}, {\n  darkGray: _merge({}, DARK_GRAY, G2.darkGray),\n  darkOpacity: DARK_OPACITY,\n  darkOpacityLight: DARK_OPACITY_LIGHT,\n  mediumGray: G2.mediumGray,\n  gray: G2.gray,\n  lightGray: _merge({}, LIGHT_GRAY, G2.lightGray),\n  lightGrayLight: LIGHT_OPACITY_LIGHT,\n  blue: _merge({}, BLUE, G2.blue),\n  alert: ALERT,\n  admin: ADMIN,\n  ui: UI\n});\nexport default COLORS;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * Internal dependencies\n */\nimport { COLORS } from './colors-values';\n\nconst space = n => `${n * 4}px`;\n\nconst CONTROL_HEIGHT = '36px';\nconst CONTROL_PADDING_X = '12px';\nconst CONTROL_PROPS = {\n  controlSurfaceColor: COLORS.white,\n  controlTextActiveColor: COLORS.ui.theme,\n  controlPaddingX: CONTROL_PADDING_X,\n  controlPaddingXLarge: `calc(${CONTROL_PADDING_X} * 1.3334)`,\n  controlPaddingXSmall: `calc(${CONTROL_PADDING_X} / 1.3334)`,\n  controlBackgroundColor: COLORS.white,\n  controlBorderRadius: '2px',\n  controlBorderColor: COLORS.gray[700],\n  controlBoxShadow: 'transparent',\n  controlBorderColorHover: COLORS.gray[700],\n  controlBoxShadowFocus: `0 0 0 0.5px ${COLORS.admin.theme}`,\n  controlDestructiveBorderColor: COLORS.alert.red,\n  controlHeight: CONTROL_HEIGHT,\n  controlHeightXSmall: `calc( ${CONTROL_HEIGHT} * 0.6 )`,\n  controlHeightSmall: `calc( ${CONTROL_HEIGHT} * 0.8 )`,\n  controlHeightLarge: `calc( ${CONTROL_HEIGHT} * 1.2 )`,\n  controlHeightXLarge: `calc( ${CONTROL_HEIGHT} * 1.4 )`\n};\nconst TOGGLE_GROUP_CONTROL_PROPS = {\n  toggleGroupControlBackgroundColor: CONTROL_PROPS.controlBackgroundColor,\n  toggleGroupControlBorderColor: COLORS.ui.border,\n  toggleGroupControlBackdropBackgroundColor: CONTROL_PROPS.controlSurfaceColor,\n  toggleGroupControlBackdropBorderColor: COLORS.ui.border,\n  toggleGroupControlBackdropBoxShadow: 'transparent',\n  toggleGroupControlButtonColorActive: CONTROL_PROPS.controlBackgroundColor\n};\nexport default _objectSpread(_objectSpread(_objectSpread({}, CONTROL_PROPS), TOGGLE_GROUP_CONTROL_PROPS), {}, {\n  colorDivider: 'rgba(0, 0, 0, 0.1)',\n  colorScrollbarThumb: 'rgba(0, 0, 0, 0.2)',\n  colorScrollbarThumbHover: 'rgba(0, 0, 0, 0.5)',\n  colorScrollbarTrack: 'rgba(0, 0, 0, 0.04)',\n  elevationIntensity: 1,\n  radiusBlockUi: '2px',\n  borderWidth: '1px',\n  borderWidthFocus: '1.5px',\n  borderWidthTab: '4px',\n  spinnerSize: '18px',\n  fontSize: '13px',\n  fontSizeH1: 'calc(2.44 * 13px)',\n  fontSizeH2: 'calc(1.95 * 13px)',\n  fontSizeH3: 'calc(1.56 * 13px)',\n  fontSizeH4: 'calc(1.25 * 13px)',\n  fontSizeH5: '13px',\n  fontSizeH6: 'calc(0.8 * 13px)',\n  fontSizeInputMobile: '16px',\n  fontSizeMobile: '15px',\n  fontSizeSmall: 'calc(0.92 * 13px)',\n  fontSizeXSmall: 'calc(0.75 * 13px)',\n  fontLineHeightBase: '1.2',\n  fontWeight: 'normal',\n  fontWeightHeading: '600',\n  gridBase: '4px',\n  cardBorderRadius: '2px',\n  cardPaddingXSmall: `${space(2)}`,\n  cardPaddingSmall: `${space(4)}`,\n  cardPaddingMedium: `${space(4)} ${space(6)}`,\n  cardPaddingLarge: `${space(6)} ${space(8)}`,\n  surfaceBackgroundColor: COLORS.white,\n  surfaceBackgroundSubtleColor: '#F3F3F3',\n  surfaceBackgroundTintColor: '#F5F5F5',\n  surfaceBorderColor: 'rgba(0, 0, 0, 0.1)',\n  surfaceBorderBoldColor: 'rgba(0, 0, 0, 0.15)',\n  surfaceBorderSubtleColor: 'rgba(0, 0, 0, 0.05)',\n  surfaceBackgroundTertiaryColor: COLORS.white,\n  surfaceColor: COLORS.white,\n  transitionDuration: '200ms',\n  transitionDurationFast: '160ms',\n  transitionDurationFaster: '120ms',\n  transitionDurationFastest: '100ms',\n  transitionTimingFunction: 'cubic-bezier(0.08, 0.52, 0.52, 1)',\n  transitionTimingFunctionControl: 'cubic-bezier(0.12, 0.8, 0.32, 1)'\n});","const _excluded = [\"value\", \"onChange\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport { createElement } from '@wordpress/element';\n/**\n * WordPress dependencies\n */\n\nimport { useEffect, useRef } from '@wordpress/element';\nimport { Flex } from '@wordpress/components';\nimport { __experimentalUseDragging as useDragging } from '@wordpress/compose';\nimport COLORS from '../colors-values';\nimport CONFIG from '../config-values';\n/**\n * Internal dependencies\n */\n\nconst CIRCLE_SIZE = 32;\nconst INNER_CIRCLE_SIZE = 3;\n\nconst space = n => `${n * 4}px`;\n\nfunction AngleCircle(_ref) {\n  let {\n    value,\n    onChange\n  } = _ref,\n      props = _objectWithoutProperties(_ref, _excluded);\n\n  const angleCircleRef = useRef();\n  const angleCircleCenter = useRef();\n  const previousCursorValue = useRef();\n\n  const setAngleCircleCenter = () => {\n    const rect = angleCircleRef.current.getBoundingClientRect();\n    angleCircleCenter.current = {\n      x: rect.x + rect.width / 2,\n      y: rect.y + rect.height / 2\n    };\n  };\n\n  const changeAngleToPosition = event => {\n    const {\n      x: centerX,\n      y: centerY\n    } = angleCircleCenter.current;\n    const {\n      ownerDocument\n    } = angleCircleRef.current; // Prevent (drag) mouse events from selecting and accidentally\n    // triggering actions from other elements.\n\n    event.preventDefault(); // Ensure the input isn't focused as preventDefault would leave it\n\n    ownerDocument.activeElement.blur();\n    onChange(getAngle(centerX, centerY, event.clientX, event.clientY));\n  };\n\n  const {\n    startDrag,\n    isDragging\n  } = useDragging({\n    onDragStart: event => {\n      setAngleCircleCenter();\n      changeAngleToPosition(event);\n    },\n    onDragMove: changeAngleToPosition,\n    onDragEnd: changeAngleToPosition\n  });\n  useEffect(() => {\n    if (isDragging) {\n      if (previousCursorValue.current === undefined) {\n        previousCursorValue.current = document.body.style.cursor;\n      }\n\n      document.body.style.cursor = 'grabbing';\n    } else {\n      document.body.style.cursor = previousCursorValue.current || null;\n      previousCursorValue.current = undefined;\n    }\n  }, [isDragging]);\n  return (\n    /* eslint-disable jsx-a11y/no-static-element-interactions */\n    createElement(\"div\", _extends({\n      ref: angleCircleRef,\n      onMouseDown: startDrag,\n      className: \"components-angle-picker-control__angle-circle\",\n      style: _objectSpread(_objectSpread({}, isDragging ? {\n        cursor: 'grabbing'\n      } : {}), {}, {\n        borderRadius: '50%',\n        border: `${CONFIG.borderWidth} solid ${COLORS.ui.border}`,\n        boxSizing: 'border-box',\n        cursor: 'grab',\n        height: `${CIRCLE_SIZE}px`,\n        overflow: `hidden`,\n        width: `${CIRCLE_SIZE}px`\n      })\n    }, props), createElement(\"div\", {\n      style: _objectSpread(_objectSpread({}, value ? {\n        transform: `rotate(${value}deg)`\n      } : {}), {}, {\n        boxSizing: 'border-box',\n        position: 'relative',\n        width: '100%',\n        height: '100%'\n      }),\n      className: \"components-angle-picker-control__angle-circle-indicator-wrapper\"\n    }, createElement(\"div\", {\n      style: {\n        background: COLORS.admin.theme,\n        borderRadius: '50%',\n        border: `${INNER_CIRCLE_SIZE}px solid ${COLORS.admin.theme}`,\n        bottom: 0,\n        boxSizing: 'border-box',\n        display: 'block',\n        height: 0,\n        left: 0,\n        margin: 'auto',\n        position: 'absolute',\n        right: 0,\n        top: `-${CIRCLE_SIZE / 2}px`,\n        width: 0\n      },\n      className: \"components-angle-picker-control__angle-circle-indicator\"\n    })))\n    /* eslint-enable jsx-a11y/no-static-element-interactions */\n\n  );\n}\n\nfunction getAngle(centerX, centerY, pointX, pointY) {\n  const y = pointY - centerY;\n  const x = pointX - centerX;\n  const angleInRadians = Math.atan2(y, x);\n  const angleInDeg = Math.round(angleInRadians * (180 / Math.PI)) + 90;\n\n  if (angleInDeg < 0) {\n    return 360 + angleInDeg;\n  }\n\n  return angleInDeg;\n}\n\nexport default AngleCircle;","import { createElement } from '@wordpress/element';\n/**\n * External dependencies\n */\n\nimport classnames from 'classnames';\n/**\n * WordPress dependencies\n */\n\nimport { __ } from 'ct-i18n';\n/**\n * Internal dependencies\n */\n\nimport AngleCircle from './angle-circle';\nconst {\n  Flex,\n  FlexBlock,\n  FlexItem,\n  __experimentalText: Text,\n  __experimentalSpacer: Spacer,\n  __experimentalInputControl: NumberControl\n} = window.wp.components; // margin-bottom: 8px\n\nconst space = n => `${n * 4}px`;\n\nexport default function AnglePickerControl(_ref) {\n  let {\n    className,\n    label = __('Angle'),\n    onChange,\n    value\n  } = _ref;\n\n  const handleOnNumberChange = unprocessedValue => {\n    const inputValue = unprocessedValue !== '' ? parseInt(unprocessedValue, 10) : 0;\n    onChange(inputValue);\n  };\n\n  const classes = classnames('components-angle-picker-control', className);\n  const Root = Flex;\n  return createElement(Root, {\n    className: classes\n  }, createElement(FlexBlock, null, createElement(NumberControl, {\n    label: label,\n    className: \"components-angle-picker-control__input-field\",\n    max: 360,\n    min: 0,\n    onChange: handleOnNumberChange,\n    size: \"__unstable-large\",\n    step: \"1\",\n    value: value,\n    hideHTMLArrows: true,\n    suffix: createElement(Spacer, {\n      as: Text,\n      marginBottom: 0,\n      marginRight: space(3),\n      style: {\n        color: 'var( --wp-admin-theme-color )'\n      }\n    }, \"\\xB0\")\n  })), createElement(FlexItem, {\n    style: {\n      marginLeft: space(4),\n      marginBottom: space(1),\n      marginTop: 'auto'\n    }\n  }, createElement(AngleCircle, {\n    \"aria-hidden\": \"true\",\n    value: value,\n    onChange: onChange\n  })));\n}","export const GRADIENT_MARKERS_WIDTH = 16;\nexport const INSERT_POINT_WIDTH = 16;\nexport const MINIMUM_ABSOLUTE_LEFT_POSITION = 5;\nexport const MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_POINT = 10;\nexport const MINIMUM_DISTANCE_BETWEEN_POINTS = 0;\nexport const MINIMUM_SIGNIFICANT_MOVE = 5;\nexport const KEYBOARD_CONTROL_POINT_VARIATION = MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_POINT;\nexport const MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_MARKER = (INSERT_POINT_WIDTH + GRADIENT_MARKERS_WIDTH) / 2;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * Internal dependencies\n */\nimport { MINIMUM_DISTANCE_BETWEEN_POINTS, MINIMUM_ABSOLUTE_LEFT_POSITION, INSERT_POINT_WIDTH } from './constants';\n/**\n * Control point for the gradient bar.\n *\n * @typedef {Object} ControlPoint\n * @property {string} color    Color of the control point.\n * @property {number} position Integer position of the control point as a percentage.\n */\n\n/**\n * Color as parsed from the gradient by gradient-parser.\n *\n * @typedef {Object} Color\n * @property {string} r   Red component.\n * @property {string} g   Green component.\n * @property {string} b   Green component.\n * @property {string} [a] Optional alpha component.\n */\n\n/**\n * Clamps a number between 0 and 100.\n *\n * @param {number} value Value to clamp.\n *\n * @return {number} Value clamped between 0 and 100.\n */\n\nexport function clampPercent(value) {\n  return Math.max(0, Math.min(100, value));\n}\n/**\n * Check if a control point is overlapping with another.\n *\n * @param {ControlPoint[]} value        Array of control points.\n * @param {number}         initialIndex Index of the position to test.\n * @param {number}         newPosition  New position of the control point.\n * @param {number}         minDistance  Distance considered to be overlapping.\n *\n * @return {boolean} True if the point is overlapping.\n */\n\nexport function isOverlapping(value, initialIndex, newPosition) {\n  let minDistance = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : MINIMUM_DISTANCE_BETWEEN_POINTS;\n  const initialPosition = value[initialIndex].position;\n  const minPosition = Math.min(initialPosition, newPosition);\n  const maxPosition = Math.max(initialPosition, newPosition);\n  return value.some((_ref, index) => {\n    let {\n      position\n    } = _ref;\n    return index !== initialIndex && (Math.abs(position - newPosition) < minDistance || minPosition < position && position < maxPosition);\n  });\n}\n/**\n * Adds a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points   Array of control points.\n * @param {number}         position Position to insert the new point.\n * @param {Color}          color    Color to update the control point at index.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nexport function addControlPoint(points, position, color) {\n  const nextIndex = points.findIndex(point => point.position > position);\n  const newPoint = {\n    color,\n    position\n  };\n  const newPoints = points.slice();\n  newPoints.splice(nextIndex - 1, 0, newPoint);\n  return newPoints;\n}\n/**\n * Removes a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points Array of control points.\n * @param {number}         index  Index to remove.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nexport function removeControlPoint(points, index) {\n  return points.filter((point, pointIndex) => {\n    return pointIndex !== index;\n  });\n}\n/**\n * Updates a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points   Array of control points.\n * @param {number}         index    Index to update.\n * @param {ControlPoint[]} newPoint New control point to replace the index.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nexport function updateControlPoint(points, index, newPoint) {\n  const newValue = points.slice();\n  newValue[index] = newPoint;\n  return newValue;\n}\n/**\n * Updates the position of a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points      Array of control points.\n * @param {number}         index       Index to update.\n * @param {number}         newPosition Position to move the control point at index.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nexport function updateControlPointPosition(points, index, newPosition) {\n  if (isOverlapping(points, index, newPosition)) {\n    return points;\n  }\n\n  const newPoint = _objectSpread(_objectSpread({}, points[index]), {}, {\n    position: newPosition\n  });\n\n  return updateControlPoint(points, index, newPoint);\n}\n/**\n * Updates the position of a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points   Array of control points.\n * @param {number}         index    Index to update.\n * @param {Color}          newColor Color to update the control point at index.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nexport function updateControlPointColor(points, index, newColor) {\n  const newPoint = _objectSpread(_objectSpread({}, points[index]), {}, {\n    color: newColor\n  });\n\n  return updateControlPoint(points, index, newPoint);\n}\n/**\n * Updates the position of a control point from an array and returns the new array.\n *\n * @param {ControlPoint[]} points   Array of control points.\n * @param {number}         position Position of the color stop.\n * @param {string}         newColor Color to update the control point at index.\n *\n * @return {ControlPoint[]} New array of control points.\n */\n\nexport function updateControlPointColorByPosition(points, position, newColor) {\n  const index = points.findIndex(point => point.position === position);\n  return updateControlPointColor(points, index, newColor);\n}\n/**\n * Gets the horizontal coordinate when dragging a control point with the mouse.\n *\n * @param {number}  mouseXCoordinate       Horizontal coordinate of the mouse position.\n * @param {Element} containerElement       Container for the gradient picker.\n * @param {number}  positionedElementWidth Width of the positioned element.\n *\n * @return {number} Whole number percentage from the left.\n */\n\nexport function getHorizontalRelativeGradientPosition(mouseXCoordinate, containerElement, positionedElementWidth) {\n  if (!containerElement) {\n    return;\n  }\n\n  const {\n    x,\n    width\n  } = containerElement.getBoundingClientRect();\n  const absolutePositionValue = mouseXCoordinate - x - MINIMUM_ABSOLUTE_LEFT_POSITION - positionedElementWidth / 2;\n  const availableWidth = width - MINIMUM_ABSOLUTE_LEFT_POSITION - INSERT_POINT_WIDTH;\n  return Math.round(clampPercent(absolutePositionValue * 100 / availableWidth));\n}","const _excluded = [\"isRenderedInSidebar\"],\n      _excluded2 = [\"isOpen\", \"position\", \"color\"],\n      _excluded3 = [\"isRenderedInSidebar\", \"gradientPickerDomRef\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n/**\n * External dependencies\n */\nimport classnames from 'classnames';\nimport { colord } from 'colord';\n/**\n * WordPress dependencies\n */\n\nimport { useInstanceId } from '@wordpress/compose';\nimport { useEffect, useRef, useState, useMemo, createElement } from '@wordpress/element';\nimport { plus } from '@wordpress/icons';\nimport { LEFT, RIGHT } from '@wordpress/keycodes';\nimport { Dropdown, Button, ColorPicker } from '@wordpress/components';\n/**\n * Internal dependencies\n */\n\nimport { __, sprintf } from 'ct-i18n';\nimport { addControlPoint, clampPercent, removeControlPoint, updateControlPointColor, updateControlPointColorByPosition, updateControlPointPosition, getHorizontalRelativeGradientPosition } from './utils';\nimport { GRADIENT_MARKERS_WIDTH, MINIMUM_SIGNIFICANT_MOVE, KEYBOARD_CONTROL_POINT_VARIATION } from './constants';\nimport { normalizeColor } from '../../../../helpers/normalize-color';\nexport function CustomColorPickerDropdown(_ref) {\n  let {\n    isRenderedInSidebar\n  } = _ref,\n      props = _objectWithoutProperties(_ref, _excluded);\n\n  return createElement(Dropdown, _extends({\n    contentClassName: classnames('components-color-palette__custom-color-dropdown-content', {\n      'is-rendered-in-sidebar': isRenderedInSidebar\n    })\n  }, props));\n}\n\nfunction ControlPointButton(_ref2) {\n  let {\n    isOpen,\n    position,\n    color\n  } = _ref2,\n      additionalProps = _objectWithoutProperties(_ref2, _excluded2);\n\n  const instanceId = useInstanceId(ControlPointButton);\n  const descriptionId = `components-custom-gradient-picker__control-point-button-description-${instanceId}`;\n  return createElement(React.Fragment, null, createElement(Button, _extends({\n    \"aria-label\": sprintf( // translators: %1$s: gradient position e.g: 70, %2$s: gradient color code e.g: rgb(52,121,151).\n    __('Gradient control point at position %1$s%% with color code %2$s.'), position, color),\n    \"aria-describedby\": descriptionId,\n    \"aria-haspopup\": \"true\",\n    \"aria-expanded\": isOpen,\n    className: classnames('components-custom-gradient-picker__control-point-button', {\n      'is-active': isOpen\n    }),\n    style: {\n      left: `${position}%`\n    }\n  }, additionalProps)));\n}\n\nfunction GradientColorPickerDropdown(_ref3) {\n  let {\n    isRenderedInSidebar,\n    gradientPickerDomRef\n  } = _ref3,\n      props = _objectWithoutProperties(_ref3, _excluded3);\n\n  const popoverProps = useMemo(() => {\n    const result = {\n      className: 'components-custom-gradient-picker__color-picker-popover',\n      position: 'top'\n    };\n\n    if (isRenderedInSidebar) {\n      result.anchorRef = gradientPickerDomRef.current;\n      result.position = 'bottom left';\n    }\n\n    return result;\n  }, [gradientPickerDomRef.current, isRenderedInSidebar]);\n  return createElement(CustomColorPickerDropdown, _extends({\n    isRenderedInSidebar: isRenderedInSidebar,\n    popoverProps: popoverProps\n  }, props));\n}\n\nfunction ControlPoints(_ref4) {\n  let {\n    disableRemove,\n    disableAlpha,\n    gradientPickerDomRef,\n    ignoreMarkerPosition,\n    value: controlPoints,\n    onChange,\n    onStartControlPointChange,\n    onStopControlPointChange,\n    __experimentalIsRenderedInSidebar\n  } = _ref4;\n  const controlPointMoveState = useRef();\n\n  const onMouseMove = event => {\n    const relativePosition = getHorizontalRelativeGradientPosition(event.clientX, gradientPickerDomRef.current, GRADIENT_MARKERS_WIDTH);\n    const {\n      initialPosition,\n      index,\n      significantMoveHappened\n    } = controlPointMoveState.current;\n\n    if (!significantMoveHappened && Math.abs(initialPosition - relativePosition) >= MINIMUM_SIGNIFICANT_MOVE) {\n      controlPointMoveState.current.significantMoveHappened = true;\n    }\n\n    onChange(updateControlPointPosition(controlPoints, index, relativePosition));\n  };\n\n  const cleanEventListeners = () => {\n    if (window && window.removeEventListener && controlPointMoveState.current && controlPointMoveState.current.listenersActivated) {\n      window.removeEventListener('mousemove', onMouseMove);\n      window.removeEventListener('mouseup', cleanEventListeners);\n      onStopControlPointChange();\n      controlPointMoveState.current.listenersActivated = false;\n    }\n  };\n\n  useEffect(() => {\n    return () => {\n      cleanEventListeners();\n    };\n  }, []);\n  return controlPoints.map((point, index) => {\n    const initialPosition = point === null || point === void 0 ? void 0 : point.position;\n    return ignoreMarkerPosition !== initialPosition && createElement(GradientColorPickerDropdown, {\n      gradientPickerDomRef: gradientPickerDomRef,\n      isRenderedInSidebar: __experimentalIsRenderedInSidebar,\n      key: index,\n      onClose: onStopControlPointChange,\n      renderToggle: _ref5 => {\n        let {\n          isOpen,\n          onToggle\n        } = _ref5;\n        return createElement(ControlPointButton, {\n          key: index,\n          onClick: () => {\n            if (controlPointMoveState.current && controlPointMoveState.current.significantMoveHappened) {\n              return;\n            }\n\n            if (isOpen) {\n              onStopControlPointChange();\n            } else {\n              onStartControlPointChange();\n            }\n\n            onToggle();\n          },\n          onMouseDown: () => {\n            if (window && window.addEventListener) {\n              controlPointMoveState.current = {\n                initialPosition,\n                index,\n                significantMoveHappened: false,\n                listenersActivated: true\n              };\n              onStartControlPointChange();\n              window.addEventListener('mousemove', onMouseMove);\n              window.addEventListener('mouseup', cleanEventListeners);\n            }\n          },\n          onKeyDown: event => {\n            if (event.keyCode === LEFT) {\n              // Stop propagation of the key press event to avoid focus moving\n              // to another editor area.\n              event.stopPropagation();\n              onChange(updateControlPointPosition(controlPoints, index, clampPercent(point.position - KEYBOARD_CONTROL_POINT_VARIATION)));\n            } else if (event.keyCode === RIGHT) {\n              // Stop propagation of the key press event to avoid focus moving\n              // to another editor area.\n              event.stopPropagation();\n              onChange(updateControlPointPosition(controlPoints, index, clampPercent(point.position + KEYBOARD_CONTROL_POINT_VARIATION)));\n            }\n          },\n          isOpen: isOpen,\n          position: point.position,\n          color: point.color\n        });\n      },\n      renderContent: _ref6 => {\n        let {\n          onClose\n        } = _ref6;\n        return createElement(React.Fragment, null, createElement(\"div\", {\n          className: wp.components.GradientPicker ? 'ct-gutenberg-color-picker-new' : 'ct-gutenberg-color-picker'\n        }, createElement(ColorPicker, _extends({\n          enableAlpha: !disableAlpha,\n          color: point.color\n        }, wp.components.GradientPicker ? {\n          onChange: color => {\n            onChange(updateControlPointColor(controlPoints, index, normalizeColor(color)));\n          }\n        } : {\n          onChangeComplete: result => {\n            onChange(updateControlPointColor(controlPoints, index, result.rgb.a === 1 ? result.hex : `rgba(${result.rgb.r}, ${result.rgb.g}, ${result.rgb.b}, ${result.rgb.a})`));\n          }\n        })), createElement(\"div\", {\n          className: \"ct-color-picker-value\"\n        }, createElement(\"input\", {\n          type: \"text\",\n          value: normalizeColor(point.color),\n          onChange: e => {\n            onChange(updateControlPointColor(controlPoints, index, normalizeColor(e.target.value)));\n          }\n        }))), !disableRemove && controlPoints.length > 2 && createElement(Button, {\n          className: \"components-custom-gradient-picker__remove-control-point\",\n          onClick: () => {\n            onChange(removeControlPoint(controlPoints, index));\n            onClose();\n          },\n          variant: \"link\"\n        }, __('Remove Control Point')));\n      }\n    });\n  });\n}\n\nfunction InsertPoint(_ref7) {\n  let {\n    value: controlPoints,\n    onChange,\n    onOpenInserter,\n    onCloseInserter,\n    insertPosition,\n    disableAlpha,\n    __experimentalIsRenderedInSidebar,\n    gradientPickerDomRef\n  } = _ref7;\n  const [alreadyInsertedPoint, setAlreadyInsertedPoint] = useState(false);\n  const [insertedColor, setInsertedColor] = useState('#fff');\n  return createElement(GradientColorPickerDropdown, {\n    gradientPickerDomRef: gradientPickerDomRef,\n    isRenderedInSidebar: __experimentalIsRenderedInSidebar,\n    className: \"components-custom-gradient-picker__inserter\",\n    onClose: () => {\n      onCloseInserter();\n    },\n    renderToggle: _ref8 => {\n      let {\n        isOpen,\n        onToggle\n      } = _ref8;\n      return createElement(Button, {\n        \"aria-expanded\": isOpen,\n        \"aria-haspopup\": \"true\",\n        onClick: () => {\n          if (isOpen) {\n            onCloseInserter();\n          } else {\n            setAlreadyInsertedPoint(false);\n            onOpenInserter();\n          }\n\n          onToggle();\n        },\n        className: \"components-custom-gradient-picker__insert-point\",\n        icon: plus,\n        style: {\n          left: insertPosition !== null ? `${insertPosition}%` : undefined\n        }\n      });\n    },\n    renderContent: () => createElement(\"div\", {\n      className: wp.components.GradientPicker ? 'ct-gutenberg-color-picker-new' : 'ct-gutenberg-color-picker'\n    }, createElement(ColorPicker, _extends({\n      enableAlpha: !disableAlpha,\n      color: insertedColor\n    }, wp.components.GradientPicker ? {\n      onChange: color => {\n        if (!alreadyInsertedPoint) {\n          onChange(addControlPoint(controlPoints, insertPosition, normalizeColor(color)));\n          setAlreadyInsertedPoint(true);\n        } else {\n          onChange(updateControlPointColorByPosition(controlPoints, insertPosition, normalizeColor(color)));\n        }\n\n        setInsertedColor(color);\n      }\n    } : {\n      onChangeComplete: result => {\n        if (!alreadyInsertedPoint) {\n          onChange(addControlPoint(controlPoints, insertPosition, result.rgb.a === 1 ? result.hex : `rgba(${result.rgb.r}, ${result.rgb.g}, ${result.rgb.b}, ${result.rgb.a})`));\n          setAlreadyInsertedPoint(true);\n        } else {\n          onChange(updateControlPointColorByPosition(controlPoints, insertPosition, result.rgb.a === 1 ? result.hex : `rgba(${result.rgb.r}, ${result.rgb.g}, ${result.rgb.b}, ${result.rgb.a})`));\n        }\n\n        setInsertedColor(result.rgb.a === 1 ? result.hex : `rgba(${result.rgb.r}, ${result.rgb.g}, ${result.rgb.b}, ${result.rgb.a})`);\n      }\n    })), createElement(\"div\", {\n      className: \"ct-color-picker-value\"\n    }, createElement(\"input\", {\n      value: normalizeColor(insertedColor),\n      type: \"text\",\n      onChange: _ref9 => {\n        let {\n          target: {\n            value: color\n          }\n        } = _ref9;\n\n        if (!alreadyInsertedPoint) {\n          onChange(addControlPoint(controlPoints, insertPosition, normalizeColor(color)));\n          setAlreadyInsertedPoint(true);\n        } else {\n          onChange(updateControlPointColorByPosition(controlPoints, insertPosition, normalizeColor(color)));\n        }\n\n        setInsertedColor(color);\n      }\n    })))\n  });\n}\n\nControlPoints.InsertPoint = InsertPoint;\nexport default ControlPoints;","import _some from \"lodash/some\";\nimport { createElement } from '@wordpress/element';\n/**\n * External dependencies\n */\n\nimport classnames from 'classnames';\n/**\n * WordPress dependencies\n */\n\nimport { useRef, useReducer } from '@wordpress/element';\n/**\n * Internal dependencies\n */\n\nimport ControlPoints from './control-points';\nimport { getHorizontalRelativeGradientPosition } from './utils';\nimport { INSERT_POINT_WIDTH, MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_POINT } from './constants';\n\nfunction customGradientBarReducer(state, action) {\n  switch (action.type) {\n    case 'MOVE_INSERTER':\n      if (state.id === 'IDLE' || state.id === 'MOVING_INSERTER') {\n        return {\n          id: 'MOVING_INSERTER',\n          insertPosition: action.insertPosition\n        };\n      }\n\n      break;\n\n    case 'STOP_INSERTER_MOVE':\n      if (state.id === 'MOVING_INSERTER') {\n        return {\n          id: 'IDLE'\n        };\n      }\n\n      break;\n\n    case 'OPEN_INSERTER':\n      if (state.id === 'MOVING_INSERTER') {\n        return {\n          id: 'INSERTING_CONTROL_POINT',\n          insertPosition: state.insertPosition\n        };\n      }\n\n      break;\n\n    case 'CLOSE_INSERTER':\n      if (state.id === 'INSERTING_CONTROL_POINT') {\n        return {\n          id: 'IDLE'\n        };\n      }\n\n      break;\n\n    case 'START_CONTROL_CHANGE':\n      if (state.id === 'IDLE') {\n        return {\n          id: 'MOVING_CONTROL_POINT'\n        };\n      }\n\n      break;\n\n    case 'STOP_CONTROL_CHANGE':\n      if (state.id === 'MOVING_CONTROL_POINT') {\n        return {\n          id: 'IDLE'\n        };\n      }\n\n      break;\n  }\n\n  return state;\n}\n\nconst customGradientBarReducerInitialState = {\n  id: 'IDLE'\n};\nexport default function CustomGradientBar(_ref) {\n  let {\n    background,\n    hasGradient,\n    value: controlPoints,\n    onChange,\n    disableInserter = false,\n    disableAlpha = false,\n    __experimentalIsRenderedInSidebar\n  } = _ref;\n  const gradientPickerDomRef = useRef();\n  const [gradientBarState, gradientBarStateDispatch] = useReducer(customGradientBarReducer, customGradientBarReducerInitialState);\n\n  const onMouseEnterAndMove = event => {\n    const insertPosition = getHorizontalRelativeGradientPosition(event.clientX, gradientPickerDomRef.current, INSERT_POINT_WIDTH); // If the insert point is close to an existing control point don't show it.\n\n    if (_some(controlPoints, _ref2 => {\n      let {\n        position\n      } = _ref2;\n      return Math.abs(insertPosition - position) < MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_POINT;\n    })) {\n      if (gradientBarState.id === 'MOVING_INSERTER') {\n        gradientBarStateDispatch({\n          type: 'STOP_INSERTER_MOVE'\n        });\n      }\n\n      return;\n    }\n\n    gradientBarStateDispatch({\n      type: 'MOVE_INSERTER',\n      insertPosition\n    });\n  };\n\n  const onMouseLeave = () => {\n    gradientBarStateDispatch({\n      type: 'STOP_INSERTER_MOVE'\n    });\n  };\n\n  const isMovingInserter = gradientBarState.id === 'MOVING_INSERTER';\n  const isInsertingControlPoint = gradientBarState.id === 'INSERTING_CONTROL_POINT';\n  return createElement(\"div\", {\n    ref: gradientPickerDomRef,\n    className: classnames('components-custom-gradient-picker__gradient-bar', {\n      'has-gradient': hasGradient\n    }),\n    onMouseEnter: onMouseEnterAndMove,\n    onMouseMove: onMouseEnterAndMove,\n    style: {\n      background\n    },\n    onMouseLeave: onMouseLeave\n  }, createElement(\"div\", {\n    className: \"components-custom-gradient-picker__markers-container\"\n  }, !disableInserter && (isMovingInserter || isInsertingControlPoint) && createElement(ControlPoints.InsertPoint, {\n    __experimentalIsRenderedInSidebar: __experimentalIsRenderedInSidebar,\n    gradientPickerDomRef: gradientPickerDomRef,\n    disableAlpha: disableAlpha,\n    insertPosition: gradientBarState.insertPosition,\n    value: controlPoints,\n    onChange: onChange,\n    onOpenInserter: () => {\n      gradientBarStateDispatch({\n        type: 'OPEN_INSERTER'\n      });\n    },\n    onCloseInserter: () => {\n      gradientBarStateDispatch({\n        type: 'CLOSE_INSERTER'\n      });\n    }\n  }), createElement(ControlPoints, {\n    __experimentalIsRenderedInSidebar: __experimentalIsRenderedInSidebar,\n    disableAlpha: disableAlpha,\n    disableRemove: disableInserter,\n    gradientPickerDomRef: gradientPickerDomRef,\n    ignoreMarkerPosition: isInsertingControlPoint ? gradientBarState.insertPosition : undefined,\n    value: controlPoints,\n    onChange: onChange,\n    onStartControlPointChange: () => {\n      gradientBarStateDispatch({\n        type: 'START_CONTROL_CHANGE'\n      });\n    },\n    onStopControlPointChange: () => {\n      gradientBarStateDispatch({\n        type: 'STOP_CONTROL_CHANGE'\n      });\n    }\n  })));\n}","/**\n * WordPress dependencies\n */\nimport { __ } from 'ct-i18n';\nexport const DEFAULT_GRADIENT = 'linear-gradient(135deg, rgba(6, 147, 227, 1) 0%, rgb(155, 81, 224) 100%)';\nexport const DEFAULT_LINEAR_GRADIENT_ANGLE = 180;\nexport const HORIZONTAL_GRADIENT_ORIENTATION = {\n  type: 'angular',\n  value: 90\n};\nexport const GRADIENT_OPTIONS = [{\n  value: 'linear-gradient',\n  label: __('Linear', 'blocksy')\n}, {\n  value: 'radial-gradient',\n  label: __('Radial', 'blocksy')\n}];\nexport const DIRECTIONAL_ORIENTATION_ANGLE_MAP = {\n  top: 0,\n  'top right': 45,\n  'right top': 45,\n  right: 90,\n  'right bottom': 135,\n  'bottom right': 135,\n  bottom: 180,\n  'bottom left': 225,\n  'left bottom': 225,\n  left: 270,\n  'top left': 315,\n  'left top': 315\n};","import _get from \"lodash/get\";\nimport _compact from \"lodash/compact\";\nexport function serializeGradientColor(_ref) {\n  let {\n    type,\n    value\n  } = _ref;\n\n  if (type === 'literal') {\n    return value;\n  }\n\n  if (type === 'hex') {\n    return `#${value}`;\n  }\n\n  return `${type}(${value.join(',')})`;\n}\nexport function serializeGradientPosition(position) {\n  if (!position) {\n    return '';\n  }\n\n  const {\n    value,\n    type\n  } = position;\n  return `${value}${type}`;\n}\nexport function serializeGradientColorStop(_ref2) {\n  let {\n    type,\n    value,\n    length\n  } = _ref2;\n  return `${serializeGradientColor({\n    type,\n    value\n  })} ${serializeGradientPosition(length)}`;\n}\nexport function serializeGradientOrientation(orientation) {\n  if (!orientation || orientation.type !== 'angular') {\n    return;\n  }\n\n  return `${orientation.value}deg`;\n}\nexport function serializeGradient(_ref3) {\n  let {\n    type,\n    orientation,\n    colorStops\n  } = _ref3;\n  const serializedOrientation = serializeGradientOrientation(orientation);\n  const serializedColorStops = colorStops.sort((colorStop1, colorStop2) => {\n    return _get(colorStop1, ['length', 'value'], 0) - _get(colorStop2, ['length', 'value'], 0);\n  }).map(serializeGradientColorStop);\n  return `${type}(${_compact([serializedOrientation, ...serializedColorStops]).join(',')})`;\n}","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * External dependencies\n */\nimport gradientParser from 'gradient-parser';\nimport { colord, extend } from 'colord';\nimport namesPlugin from 'colord/plugins/names';\n/**\n * Internal dependencies\n */\n\nimport { DEFAULT_GRADIENT, HORIZONTAL_GRADIENT_ORIENTATION, DIRECTIONAL_ORIENTATION_ANGLE_MAP } from './constants';\nimport { serializeGradient } from './serializer';\nextend([namesPlugin]);\nexport function getLinearGradientRepresentation(gradientAST) {\n  return serializeGradient({\n    type: 'linear-gradient',\n    orientation: HORIZONTAL_GRADIENT_ORIENTATION,\n    colorStops: gradientAST.colorStops\n  });\n}\n\nfunction hasUnsupportedLength(item) {\n  return item.length === undefined || item.length.type !== '%';\n}\n\nexport function getGradientAstWithDefault(value) {\n  var _gradientAST$orientat;\n\n  // gradientAST will contain the gradient AST as parsed by gradient-parser npm module.\n  // More information of its structure available at https://www.npmjs.com/package/gradient-parser#ast.\n  let gradientAST;\n  let temporaryInvalidValue = value.match(/\\~(.*)\\~/, '');\n  value = value.replace(/\\~.*\\~/, 'rgb(500, 500, 500)');\n\n  try {\n    gradientAST = gradientParser.parse(value)[0];\n    gradientAST.value = value;\n  } catch (error) {\n    gradientAST = gradientParser.parse(DEFAULT_GRADIENT)[0];\n    gradientAST.value = DEFAULT_GRADIENT;\n  }\n\n  if (((_gradientAST$orientat = gradientAST.orientation) === null || _gradientAST$orientat === void 0 ? void 0 : _gradientAST$orientat.type) === 'directional') {\n    gradientAST.orientation.type = 'angular';\n    gradientAST.orientation.value = DIRECTIONAL_ORIENTATION_ANGLE_MAP[gradientAST.orientation.value].toString();\n  }\n\n  if (gradientAST.colorStops.some(hasUnsupportedLength)) {\n    const {\n      colorStops\n    } = gradientAST;\n    const step = 100 / (colorStops.length - 1);\n    colorStops.forEach((stop, index) => {\n      if (stop.value[0] === '500') {\n        stop.type = 'literal';\n        stop.value = '';\n      }\n\n      stop.length = {\n        value: step * index,\n        type: '%'\n      };\n    });\n    gradientAST.value = serializeGradient(gradientAST);\n  }\n\n  gradientAST.colorStops.forEach((stop, index) => {\n    if (stop.value[0] === '500' && temporaryInvalidValue) {\n      stop.type = 'literal';\n      stop.value = temporaryInvalidValue[1];\n    }\n  });\n  return gradientAST;\n}\nexport function getGradientAstWithControlPoints(gradientAST, newControlPoints) {\n  return _objectSpread(_objectSpread({}, gradientAST), {}, {\n    colorStops: newControlPoints.map(_ref => {\n      let {\n        position,\n        color\n      } = _ref;\n      let parsedColor = colord(color);\n      let result = {\n        length: {\n          type: '%',\n          value: position.toString()\n        },\n        type: 'literal',\n        value: `~${color}~`\n      };\n\n      if (parsedColor.parsed) {\n        const {\n          r,\n          g,\n          b,\n          a\n        } = parsedColor.toRgb();\n        result.type = a < 1 ? 'rgba' : 'rgb';\n        result.value = a < 1 ? [r, g, b, a] : [r, g, b];\n      }\n\n      return result;\n    })\n  });\n}\nexport function getStopCssColor(colorStop) {\n  switch (colorStop.type) {\n    case 'hex':\n      return `#${colorStop.value}`;\n\n    case 'literal':\n      return colorStop.value;\n\n    case 'rgb':\n    case 'rgba':\n      return `${colorStop.type}(${colorStop.value.join(',')})`;\n\n    default:\n      // Should be unreachable if passing an AST from gradient-parser.\n      // See https://github.com/rafaelcaricio/gradient-parser#ast.\n      return 'transparent';\n  }\n}","import _omit from \"lodash/omit\";\nimport _get from \"lodash/get\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement } from '@wordpress/element';\n/**\n * External dependencies\n */\n\n/**\n * WordPress dependencies\n */\nimport { __ } from 'ct-i18n';\nimport { SelectControl, Flex, FlexBlock } from '@wordpress/components';\n/**\n * Internal dependencies\n */\n\nimport AnglePickerControl from './angle-picker-control';\nimport CustomGradientBar from './custom-gradient-bar';\nimport { getGradientAstWithDefault, getLinearGradientRepresentation, getGradientAstWithControlPoints, getStopCssColor } from './utils';\nimport { serializeGradient } from './serializer';\nimport { DEFAULT_LINEAR_GRADIENT_ANGLE, HORIZONTAL_GRADIENT_ORIENTATION, GRADIENT_OPTIONS, DEFAULT_GRADIENT } from './constants';\n\nconst GradientAnglePicker = _ref => {\n  let {\n    gradientAST,\n    hasGradient,\n    onChange\n  } = _ref;\n\n  const angle = _get(gradientAST, ['orientation', 'value'], DEFAULT_LINEAR_GRADIENT_ANGLE);\n\n  const onAngleChange = newAngle => {\n    onChange(serializeGradient(_objectSpread(_objectSpread({}, gradientAST), {}, {\n      orientation: {\n        type: 'angular',\n        value: newAngle\n      }\n    })));\n  };\n\n  return createElement(AnglePickerControl, {\n    onChange: onAngleChange,\n    labelPosition: \"top\",\n    value: hasGradient ? angle : ''\n  });\n};\n\nconst GradientTypePicker = _ref2 => {\n  let {\n    gradientAST,\n    hasGradient,\n    onChange\n  } = _ref2;\n  const {\n    type\n  } = gradientAST;\n\n  const onSetLinearGradient = () => {\n    onChange(serializeGradient(_objectSpread(_objectSpread(_objectSpread({}, gradientAST), gradientAST.orientation ? {} : {\n      orientation: HORIZONTAL_GRADIENT_ORIENTATION\n    }), {}, {\n      type: 'linear-gradient'\n    })));\n  };\n\n  const onSetRadialGradient = () => {\n    onChange(serializeGradient(_objectSpread(_objectSpread({}, _omit(gradientAST, ['orientation'])), {}, {\n      type: 'radial-gradient'\n    })));\n  };\n\n  const handleOnChange = next => {\n    if (next === 'linear-gradient') {\n      onSetLinearGradient();\n    }\n\n    if (next === 'radial-gradient') {\n      onSetRadialGradient();\n    }\n  };\n\n  return createElement(SelectControl, {\n    className: \"components-custom-gradient-picker__type-picker\",\n    label: __('Type'),\n    labelPosition: \"top\",\n    onChange: handleOnChange,\n    options: GRADIENT_OPTIONS,\n    size: \"__unstable-large\",\n    value: hasGradient && type\n  });\n};\n\nexport default function CustomGradientPicker(_ref3) {\n  let {\n    value,\n    onChange,\n    __experimentalIsRenderedInSidebar\n  } = _ref3;\n  const gradientAST = getGradientAstWithDefault(value); // On radial gradients the bar should display a linear gradient.\n  // On radial gradients the bar represents a slice of the gradient from the center until the outside.\n  // On liner gradients the bar represents the color stops from left to right independently of the angle.\n\n  const background = getLinearGradientRepresentation(gradientAST);\n  const hasGradient = gradientAST.value !== DEFAULT_GRADIENT; // Control points color option may be hex from presets, custom colors will be rgb.\n  // The position should always be a percentage.\n\n  const controlPoints = gradientAST.colorStops.map(colorStop => ({\n    color: getStopCssColor(colorStop),\n    position: parseInt(colorStop.length.value)\n  })); // flex-grow: 5;\n\n  const AccessoryWrapper = FlexBlock;\n  const SelectWrapper = FlexBlock;\n  return createElement(\"div\", {\n    className: \"components-custom-gradient-picker\"\n  }, createElement(CustomGradientBar, {\n    __experimentalIsRenderedInSidebar: __experimentalIsRenderedInSidebar,\n    background: background,\n    hasGradient: hasGradient,\n    value: controlPoints,\n    onChange: newControlPoints => {\n      onChange(serializeGradient(getGradientAstWithControlPoints(gradientAST, newControlPoints)));\n    }\n  }), createElement(Flex, {\n    gap: 3,\n    className: \"components-custom-gradient-picker__ui-line\"\n  }, createElement(SelectWrapper, null, createElement(GradientTypePicker, {\n    gradientAST: gradientAST,\n    hasGradient: hasGradient,\n    onChange: onChange\n  })), createElement(AccessoryWrapper, null, gradientAST.type === 'linear-gradient' && createElement(GradientAnglePicker, {\n    gradientAST: gradientAST,\n    hasGradient: hasGradient,\n    onChange: onChange\n  }))));\n}","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n/**\n * External dependencies\n */\n\n/**\n * WordPress dependencies\n */\nimport { __, sprintf } from 'ct-i18n';\nimport { createElement, useCallback, useMemo } from '@wordpress/element';\nimport { __experimentalHeading as Heading, __experimentalVStack as VStack } from '@wordpress/components';\n/**\n * Internal dependencies\n */\n\nimport CircularOptionPicker from './circular-option-picker';\nimport CustomGradientPicker from './custom-gradient-picker';\n\nfunction SingleOrigin(_ref) {\n  let {\n    className,\n    clearGradient,\n    gradients,\n    onChange,\n    value,\n    actions,\n    content\n  } = _ref;\n  const gradientOptions = useMemo(() => {\n    return (gradients || []).map(_ref2 => {\n      let {\n        gradient,\n        name\n      } = _ref2;\n      return createElement(CircularOptionPicker.Option, {\n        key: gradient,\n        value: gradient,\n        isSelected: value === gradient,\n        tooltipText: name || // translators: %s: gradient code e.g: \"linear-gradient(90deg, rgba(98,16,153,1) 0%, rgba(172,110,22,1) 100%);\".\n        sprintf(__('Gradient code: %s'), gradient),\n        style: {\n          color: 'rgba( 0,0,0,0 )',\n          background: gradient\n        },\n        onClick: value === gradient ? clearGradient : () => onChange(gradient),\n        \"aria-label\": name ? // translators: %s: The name of the gradient e.g: \"Angular red to blue\".\n        sprintf(__('Gradient: %s'), name) : // translators: %s: gradient code e.g: \"linear-gradient(90deg, rgba(98,16,153,1) 0%, rgba(172,110,22,1) 100%);\".\n        sprintf(__('Gradient code: %s'), gradient)\n      });\n    });\n  }, [gradients, value, onChange, clearGradient]);\n  return createElement(CircularOptionPicker, {\n    className: className,\n    options: gradientOptions,\n    actions: actions\n  }, content);\n}\n\nfunction MultipleOrigin(_ref3) {\n  let {\n    className,\n    clearGradient,\n    gradients,\n    onChange,\n    value,\n    actions,\n    content\n  } = _ref3;\n  return createElement(VStack, {\n    spacing: 3,\n    className: className\n  }, (gradients || []).map((_ref4, index) => {\n    let {\n      name,\n      gradients: gradientSet\n    } = _ref4;\n    return createElement(VStack, {\n      spacing: 2,\n      key: index\n    }, createElement(Heading, null, name), createElement(SingleOrigin, _extends({\n      clearGradient: clearGradient,\n      gradients: gradientSet,\n      onChange: onChange,\n      value: value\n    }, gradients.length === index + 1 ? {\n      actions,\n      content\n    } : {})));\n  }));\n}\n\nexport default function GradientPicker(_ref5) {\n  let {\n    className,\n    gradients,\n    onChange,\n    value,\n    clearable = true,\n    disableCustomGradients = false,\n    __experimentalHasMultipleOrigins,\n    __experimentalIsRenderedInSidebar\n  } = _ref5;\n  const clearGradient = useCallback(() => onChange(undefined), [onChange]);\n  const Component = __experimentalHasMultipleOrigins && gradients !== null && gradients !== void 0 && gradients.length ? MultipleOrigin : SingleOrigin;\n  return createElement(Component, {\n    className: className,\n    clearable: clearable,\n    clearGradient: clearGradient,\n    gradients: gradients,\n    onChange: onChange,\n    value: value,\n    actions: clearable && ((gradients === null || gradients === void 0 ? void 0 : gradients.length) || !disableCustomGradients) && createElement(CircularOptionPicker.ButtonAction, {\n      onClick: clearGradient\n    }, __('Clear')),\n    content: !disableCustomGradients && createElement(CustomGradientPicker, {\n      __experimentalIsRenderedInSidebar: __experimentalIsRenderedInSidebar,\n      value: value,\n      onChange: onChange\n    })\n  });\n}"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///1188\n")}}]);