@webiny/lexical-editor-actions 5.40.0 → 5.40.1-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -7,13 +7,14 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
});
|
|
8
8
|
exports.LexicalColorPicker = void 0;
|
|
9
9
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
10
|
+
var _objectSpread3 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
10
11
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
11
12
|
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
12
13
|
var _react = _interopRequireWildcard(require("react"));
|
|
13
14
|
var _emotion = require("emotion");
|
|
14
15
|
var _usePageElements = require("@webiny/app-page-builder-elements/hooks/usePageElements");
|
|
15
|
-
var _classnames2 = _interopRequireDefault(require("classnames"));
|
|
16
16
|
var _reactColor = require("react-color");
|
|
17
|
+
var _Tooltip = require("@webiny/ui/Tooltip");
|
|
17
18
|
var _roundColor_lens24px = require("./round-color_lens-24px.svg");
|
|
18
19
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; } // Icons
|
|
19
20
|
var ColorPickerStyle = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV === "production" ? {
|
|
@@ -22,12 +23,12 @@ var ColorPickerStyle = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_E
|
|
|
22
23
|
target: "ewrv11k2",
|
|
23
24
|
label: "ColorPickerStyle"
|
|
24
25
|
})(process.env.NODE_ENV === "production" ? {
|
|
25
|
-
name: "
|
|
26
|
-
styles: "position:relative;display:flex;flex-wrap:wrap;justify-content:
|
|
26
|
+
name: "1tb6adp",
|
|
27
|
+
styles: "position:relative;display:flex;flex-wrap:wrap;justify-content:flex-start;width:240px;padding:15px;background-color:#fff"
|
|
27
28
|
} : {
|
|
28
|
-
name: "
|
|
29
|
-
styles: "position:relative;display:flex;flex-wrap:wrap;justify-content:
|
|
30
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LexicalColorPicker.tsx"],"names":[],"mappings":"AAWyB","file":"LexicalColorPicker.tsx","sourcesContent":["import React, { useCallback, useState, SyntheticEvent } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { css } from \"emotion\";\nimport { usePageElements } from \"@webiny/app-page-builder-elements/hooks/usePageElements\";\nimport classnames from \"classnames\";\nimport { ChromePicker, ColorState, RGBColor } from \"react-color\";\nimport { OnChangeHandler } from \"react-color/lib/components/common/ColorWrap\";\n\n// Icons\nimport { ReactComponent as IconPalette } from \"./round-color_lens-24px.svg\";\n\nconst ColorPickerStyle = styled(\"div\")({\n    position: \"relative\",\n    display: \"flex\",\n    flexWrap: \"wrap\",\n    justifyContent: \"space-between\",\n    width: 225,\n    padding: 0,\n    backgroundColor: \"#fff\"\n});\n\nconst ColorBox = styled(\"div\")({\n    cursor: \"pointer\",\n    width: 50,\n    height: 40,\n    margin: 10,\n    borderRadius: 2\n});\n\nconst Color = styled(\"button\")({\n    cursor: \"pointer\",\n    width: 40,\n    height: 30,\n    border: \"1px solid var(--mdc-theme-on-background)\",\n    transition: \"transform 0.2s, scale 0.2s\",\n    display: \"flex\",\n    alignItems: \"center\",\n    \"&::after\": {\n        boxShadow: \"0 0.25rem 0.125rem 0 rgba(0,0,0,0.05)\",\n        transition: \"opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1)\",\n        content: '\"\"',\n        position: \"absolute\",\n        top: 0,\n        left: 0,\n        width: \"100%\",\n        height: \"100%\",\n        zIndex: -1,\n        opacity: 0\n    },\n    \"&:hover\": {\n        transform: \"scale(1.25)\",\n        \"&::after\": {\n            opacity: 1\n        }\n    }\n});\n\nconst transparent = css({\n    backgroundSize: \"10px 10px\",\n    backgroundImage:\n        \"linear-gradient( 45deg, #555 25%, transparent 25%, transparent),\" +\n        \"linear-gradient(-45deg, #555 25%, transparent 25%, transparent),\" +\n        \"linear-gradient( 45deg, transparent 75%, #555 75%),\" +\n        \"linear-gradient(-45deg, transparent 75%, #555 75%)\"\n});\n\nconst iconPaletteStyle = css({\n    height: 20,\n    width: \"100%\",\n    marginTop: 1,\n    color: \"var(--mdc-theme-secondary)\"\n});\n\nconst COLORS = {\n    lightGray: \"hsla(0, 0%, 97%, 1)\",\n    gray: \"hsla(300, 2%, 92%, 1)\",\n    darkGray: \"hsla(0, 0%, 70%, 1)\",\n    darkestGray: \"hsla(0, 0%, 20%, 1)\",\n    black: \"hsla(208, 100%, 5%, 1)\"\n};\n\nconst styles = {\n    selectedColor: css({\n        boxShadow: \"0px 0px 0px 2px var(--mdc-theme-secondary)\"\n    }),\n    button: css({\n        cursor: \"pointer\",\n        height: 30,\n        boxSizing: \"border-box\",\n        \"&:hover:not(:disabled)\": { backgroundColor: COLORS.gray },\n        \"&:focus:not(:disabled)\": {\n            outline: \"none\"\n        },\n        \"&:disabled\": {\n            opacity: 0.5,\n            cursor: \"not-allowed\"\n        },\n        \"& svg\": {\n            width: 16,\n            height: 16\n        }\n    }),\n    color: css({\n        width: \"40px\",\n        height: \"100%\"\n    })\n};\n\ninterface LexicalColorPickerProps {\n    value: string;\n    onChange?: (color: string) => void;\n    onChangeComplete: (color: string, name?: string) => void;\n    handlerClassName?: string;\n}\n\nexport const LexicalColorPicker = ({\n    value,\n    onChange,\n    onChangeComplete\n}: LexicalColorPickerProps) => {\n    const [showPicker, setShowPicker] = useState(false);\n    // Either a custom color or a color coming from the theme object.\n    const [actualSelectedColor, setActualSelectedColor] = useState(value || \"#fff\");\n    let themeColor = false;\n\n    const getColorValue = useCallback((rgb: RGBColor) => {\n        return `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${rgb.a})`;\n    }, []);\n\n    const onColorChange = useCallback(\n        (color: ColorState, event: React.SyntheticEvent) => {\n            event.preventDefault();\n            // controls of the picker are updated as user moves the mouse\n            const customColor = getColorValue(color.rgb);\n            setActualSelectedColor(customColor);\n            if (typeof onChange === \"function\") {\n                onChange(customColor);\n            }\n        },\n        [onChange]\n    );\n\n    const onColorChangeComplete = useCallback(\n        ({ rgb }: ColorState, event: React.SyntheticEvent) => {\n            setActualSelectedColor(value);\n            onChangeComplete(getColorValue(rgb));\n            event.preventDefault();\n        },\n        [onChangeComplete]\n    );\n\n    const togglePicker = useCallback((e: SyntheticEvent) => {\n        e.stopPropagation();\n        setShowPicker(!showPicker);\n    }, []);\n\n    const pageElements = usePageElements();\n\n    const themeColors: Record<string, any> = {};\n    const colors = pageElements.theme?.styles?.colors;\n    if (colors) {\n        for (const key in colors) {\n            if (colors[key]) {\n                themeColors[key] = colors[key];\n            }\n        }\n    }\n\n    return (\n        <ColorPickerStyle>\n            {Object.keys(themeColors).map((key, index) => {\n                const color = themeColors[key];\n\n                if (color === value || value === \"transparent\") {\n                    themeColor = true;\n                }\n                return (\n                    <ColorBox key={index}>\n                        <Color\n                            className={key === value ? styles.selectedColor : \"\"}\n                            style={{ backgroundColor: color }}\n                            onClick={() => {\n                                // With page elements implementation, we want to store the color key and\n                                // then the actual color will be retrieved from the theme object.\n                                const colors = pageElements.theme?.styles?.colors;\n                                onChangeComplete(colors[key], key);\n                            }}\n                        />\n                    </ColorBox>\n                );\n            })}\n\n            <ColorBox>\n                <Color\n                    className={classnames(transparent, {\n                        [styles.selectedColor]: value === \"transparent\"\n                    })}\n                    onClick={() => {\n                        onChangeComplete(\"transparent\");\n                    }}\n                />\n            </ColorBox>\n\n            <ColorBox>\n                <Color\n                    className={value && !themeColor ? styles.selectedColor : \"\"}\n                    style={{ backgroundColor: themeColor ? \"#fff\" : value }}\n                    onClick={togglePicker}\n                >\n                    <IconPalette className={iconPaletteStyle} />\n                </Color>\n            </ColorBox>\n\n            {showPicker && (\n                <ChromePicker\n                    color={actualSelectedColor}\n                    // TODO figure out types for the props\n                    onChange={onColorChange as OnChangeHandler}\n                    onChangeComplete={onColorChangeComplete as OnChangeHandler}\n                />\n            )}\n        </ColorPickerStyle>\n    );\n};\n"]} */",
|
|
29
|
+
name: "1tb6adp",
|
|
30
|
+
styles: "position:relative;display:flex;flex-wrap:wrap;justify-content:flex-start;width:240px;padding:15px;background-color:#fff",
|
|
31
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LexicalColorPicker.tsx"],"names":[],"mappings":"AAWyB","file":"LexicalColorPicker.tsx","sourcesContent":["import React, { useCallback, useState, SyntheticEvent, useEffect, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { css } from \"emotion\";\nimport { usePageElements } from \"@webiny/app-page-builder-elements/hooks/usePageElements\";\nimport { ChromePicker, ColorState, RGBColor } from \"react-color\";\nimport { OnChangeHandler } from \"react-color/lib/components/common/ColorWrap\";\nimport { Tooltip } from \"@webiny/ui/Tooltip\";\n\n// Icons\nimport { ReactComponent as IconPalette } from \"./round-color_lens-24px.svg\";\n\nconst ColorPickerStyle = styled(\"div\")({\n    position: \"relative\",\n    display: \"flex\",\n    flexWrap: \"wrap\",\n    justifyContent: \"flex-start\",\n    width: 240,\n    padding: 15,\n    backgroundColor: \"#fff\"\n});\n\nconst ColorBox = styled(\"div\")({\n    cursor: \"pointer\",\n    width: 40,\n    height: 40,\n    borderRadius: \"50%\",\n    margin: 5,\n    border: \"1px solid var(--mdc-theme-on-background)\",\n    padding: 3\n});\n\nconst Color = styled(\"button\")({\n    cursor: \"pointer\",\n    width: 40,\n    height: 40,\n    transition: \"transform 0.1s, border 0.2s\",\n    borderColor: \"transparent\",\n    display: \"flex\",\n    alignItems: \"center\",\n    borderRadius: \"50%\",\n    \"&::after\": {\n        transition: \"opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1)\",\n        content: '\"\"',\n        position: \"absolute\",\n        top: 0,\n        left: 0,\n        width: \"100%\",\n        height: \"100%\",\n        zIndex: -1,\n        opacity: 0\n    },\n    \"&:hover\": {\n        transform: \"scale(1.1)\",\n        boxShadow: \"0 0.25rem 0.125rem 0 rgba(0,0,0,0.05)\",\n        \"&::after\": {\n            opacity: 1\n        }\n    }\n});\n\nconst iconPaletteStyle = css({\n    height: 20,\n    width: \"100%\",\n    marginTop: 1,\n    color: \"var(--mdc-theme-secondary)\"\n});\n\nconst COLORS = {\n    lightGray: \"hsla(0, 0%, 97%, 1)\",\n    gray: \"hsla(300, 2%, 92%, 1)\",\n    darkGray: \"hsla(0, 0%, 70%, 1)\",\n    darkestGray: \"hsla(0, 0%, 20%, 1)\",\n    black: \"hsla(208, 100%, 5%, 1)\"\n};\n\nconst styles = {\n    selectedColor: css({\n        boxShadow: \"inset 0px 0px 0px 10px var(--mdc-theme-secondary)\",\n        button: {\n            border: \"5px solid var(--mdc-theme-surface)\"\n        }\n    }),\n    button: css({\n        cursor: \"pointer\",\n        height: 30,\n        boxSizing: \"border-box\",\n        \"&:hover:not(:disabled)\": { backgroundColor: COLORS.gray },\n        \"&:focus:not(:disabled)\": {\n            outline: \"none\"\n        },\n        \"&:disabled\": {\n            opacity: 0.5,\n            cursor: \"not-allowed\"\n        },\n        \"& svg\": {\n            width: 16,\n            height: 16\n        }\n    }),\n    color: css({\n        width: \"40px\",\n        height: \"100%\"\n    })\n};\n\nconst chromePickerStyle = css({\n    width: \"270px !important\",\n    margin: \"15px -15px -15px -15px\"\n});\n\ninterface LexicalColorPickerProps {\n    value: string;\n    onChange?: (color: string) => void;\n    onChangeComplete: (color: string, name?: string) => void;\n    handlerClassName?: string;\n}\n\nconst showPickerStyle = { display: \"block\" };\nconst hidePickerStyle = { display: \"none\" };\n\nexport const LexicalColorPicker = ({\n    value,\n    onChange,\n    onChangeComplete\n}: LexicalColorPickerProps) => {\n    const [showPicker, setShowPicker] = useState(false);\n    // Either a custom color or a color coming from the theme object.\n    const [actualSelectedColor, setActualSelectedColor] = useState(value || \"#fff\");\n    const [isThemeColor, setIsThemeColor] = useState(false);\n\n    useEffect(() => {\n        if (value) {\n            setActualSelectedColor(value);\n        }\n    }, [value]);\n\n    const getColorValue = useCallback((rgb: RGBColor, alpha?: number) => {\n        return `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${alpha ?? rgb.a})`;\n    }, []);\n\n    const onColorChange = useCallback(\n        (color: ColorState, event: React.SyntheticEvent) => {\n            event.preventDefault();\n            // controls of the picker are updated as user moves the mouse\n            const customColor = getColorValue(color.rgb, color.rgb.a === 0 ? 1 : color.rgb.a);\n            setActualSelectedColor(customColor);\n            if (typeof onChange === \"function\") {\n                onChange(customColor);\n            }\n        },\n        [onChange]\n    );\n\n    const onColorChangeComplete = useCallback(\n        ({ rgb }: ColorState, event: React.SyntheticEvent) => {\n            event.preventDefault();\n            const color = getColorValue(rgb, rgb.a === 0 ? 1 : rgb.a);\n            setActualSelectedColor(color);\n            onChangeComplete(color);\n        },\n        [onChangeComplete]\n    );\n\n    const togglePicker = useCallback((e: SyntheticEvent) => {\n        e.stopPropagation();\n        setShowPicker(state => !state);\n    }, []);\n\n    const pageElements = usePageElements();\n\n    const themeColors: Record<string, any> = useMemo(() => {\n        const colors = pageElements.theme?.styles?.colors ?? {};\n\n        return Object.keys(colors).reduce((acc, key) => {\n            return { ...acc, [key]: colors[key] };\n        }, {});\n    }, [pageElements.theme?.styles?.colors]);\n\n    useEffect(() => {\n        const isThemeColor = Object.keys(themeColors).some(key => themeColors[key] === value);\n        setIsThemeColor(isThemeColor);\n    }, [themeColors, value]);\n\n    return (\n        <ColorPickerStyle>\n            {Object.keys(themeColors).map((key, index) => {\n                const color = themeColors[key];\n\n                return (\n                    <ColorBox key={index} className={color === value ? styles.selectedColor : \"\"}>\n                        <Tooltip content={<span>{color}</span>} placement=\"bottom\">\n                            <Color\n                                style={{ backgroundColor: color }}\n                                onClick={() => {\n                                    // With page elements implementation, we want to store the color key and\n                                    // then the actual color will be retrieved from the theme object.\n                                    const colors = pageElements.theme?.styles?.colors;\n                                    onChangeComplete(colors[key], key);\n                                }}\n                            />\n                        </Tooltip>\n                    </ColorBox>\n                );\n            })}\n\n            <ColorBox className={value && !isThemeColor ? styles.selectedColor : \"\"}>\n                <Tooltip content={<span>Color picker</span>} placement=\"bottom\">\n                    <Color\n                        style={{ backgroundColor: isThemeColor ? \"#fff\" : value }}\n                        onClick={togglePicker}\n                    >\n                        <IconPalette className={iconPaletteStyle} />\n                    </Color>\n                </Tooltip>\n            </ColorBox>\n\n            <div style={showPicker ? showPickerStyle : hidePickerStyle}>\n                <ChromePicker\n                    className={chromePickerStyle}\n                    color={actualSelectedColor}\n                    disableAlpha={true}\n                    onChange={onColorChange as OnChangeHandler}\n                    onChangeComplete={onColorChangeComplete as OnChangeHandler}\n                />\n            </div>\n        </ColorPickerStyle>\n    );\n};\n"]} */",
|
|
31
32
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
32
33
|
});
|
|
33
34
|
var ColorBox = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV === "production" ? {
|
|
@@ -36,12 +37,12 @@ var ColorBox = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV === "
|
|
|
36
37
|
target: "ewrv11k1",
|
|
37
38
|
label: "ColorBox"
|
|
38
39
|
})(process.env.NODE_ENV === "production" ? {
|
|
39
|
-
name: "
|
|
40
|
-
styles: "cursor:pointer;width:
|
|
40
|
+
name: "ycm87k",
|
|
41
|
+
styles: "cursor:pointer;width:40px;height:40px;border-radius:50%;margin:5px;border:1px solid var(--mdc-theme-on-background);padding:3px"
|
|
41
42
|
} : {
|
|
42
|
-
name: "
|
|
43
|
-
styles: "cursor:pointer;width:
|
|
44
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LexicalColorPicker.tsx"],"names":[],"mappings":"AAqBiB","file":"LexicalColorPicker.tsx","sourcesContent":["import React, { useCallback, useState, SyntheticEvent } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { css } from \"emotion\";\nimport { usePageElements } from \"@webiny/app-page-builder-elements/hooks/usePageElements\";\nimport classnames from \"classnames\";\nimport { ChromePicker, ColorState, RGBColor } from \"react-color\";\nimport { OnChangeHandler } from \"react-color/lib/components/common/ColorWrap\";\n\n// Icons\nimport { ReactComponent as IconPalette } from \"./round-color_lens-24px.svg\";\n\nconst ColorPickerStyle = styled(\"div\")({\n    position: \"relative\",\n    display: \"flex\",\n    flexWrap: \"wrap\",\n    justifyContent: \"space-between\",\n    width: 225,\n    padding: 0,\n    backgroundColor: \"#fff\"\n});\n\nconst ColorBox = styled(\"div\")({\n    cursor: \"pointer\",\n    width: 50,\n    height: 40,\n    margin: 10,\n    borderRadius: 2\n});\n\nconst Color = styled(\"button\")({\n    cursor: \"pointer\",\n    width: 40,\n    height: 30,\n    border: \"1px solid var(--mdc-theme-on-background)\",\n    transition: \"transform 0.2s, scale 0.2s\",\n    display: \"flex\",\n    alignItems: \"center\",\n    \"&::after\": {\n        boxShadow: \"0 0.25rem 0.125rem 0 rgba(0,0,0,0.05)\",\n        transition: \"opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1)\",\n        content: '\"\"',\n        position: \"absolute\",\n        top: 0,\n        left: 0,\n        width: \"100%\",\n        height: \"100%\",\n        zIndex: -1,\n        opacity: 0\n    },\n    \"&:hover\": {\n        transform: \"scale(1.25)\",\n        \"&::after\": {\n            opacity: 1\n        }\n    }\n});\n\nconst transparent = css({\n    backgroundSize: \"10px 10px\",\n    backgroundImage:\n        \"linear-gradient( 45deg, #555 25%, transparent 25%, transparent),\" +\n        \"linear-gradient(-45deg, #555 25%, transparent 25%, transparent),\" +\n        \"linear-gradient( 45deg, transparent 75%, #555 75%),\" +\n        \"linear-gradient(-45deg, transparent 75%, #555 75%)\"\n});\n\nconst iconPaletteStyle = css({\n    height: 20,\n    width: \"100%\",\n    marginTop: 1,\n    color: \"var(--mdc-theme-secondary)\"\n});\n\nconst COLORS = {\n    lightGray: \"hsla(0, 0%, 97%, 1)\",\n    gray: \"hsla(300, 2%, 92%, 1)\",\n    darkGray: \"hsla(0, 0%, 70%, 1)\",\n    darkestGray: \"hsla(0, 0%, 20%, 1)\",\n    black: \"hsla(208, 100%, 5%, 1)\"\n};\n\nconst styles = {\n    selectedColor: css({\n        boxShadow: \"0px 0px 0px 2px var(--mdc-theme-secondary)\"\n    }),\n    button: css({\n        cursor: \"pointer\",\n        height: 30,\n        boxSizing: \"border-box\",\n        \"&:hover:not(:disabled)\": { backgroundColor: COLORS.gray },\n        \"&:focus:not(:disabled)\": {\n            outline: \"none\"\n        },\n        \"&:disabled\": {\n            opacity: 0.5,\n            cursor: \"not-allowed\"\n        },\n        \"& svg\": {\n            width: 16,\n            height: 16\n        }\n    }),\n    color: css({\n        width: \"40px\",\n        height: \"100%\"\n    })\n};\n\ninterface LexicalColorPickerProps {\n    value: string;\n    onChange?: (color: string) => void;\n    onChangeComplete: (color: string, name?: string) => void;\n    handlerClassName?: string;\n}\n\nexport const LexicalColorPicker = ({\n    value,\n    onChange,\n    onChangeComplete\n}: LexicalColorPickerProps) => {\n    const [showPicker, setShowPicker] = useState(false);\n    // Either a custom color or a color coming from the theme object.\n    const [actualSelectedColor, setActualSelectedColor] = useState(value || \"#fff\");\n    let themeColor = false;\n\n    const getColorValue = useCallback((rgb: RGBColor) => {\n        return `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${rgb.a})`;\n    }, []);\n\n    const onColorChange = useCallback(\n        (color: ColorState, event: React.SyntheticEvent) => {\n            event.preventDefault();\n            // controls of the picker are updated as user moves the mouse\n            const customColor = getColorValue(color.rgb);\n            setActualSelectedColor(customColor);\n            if (typeof onChange === \"function\") {\n                onChange(customColor);\n            }\n        },\n        [onChange]\n    );\n\n    const onColorChangeComplete = useCallback(\n        ({ rgb }: ColorState, event: React.SyntheticEvent) => {\n            setActualSelectedColor(value);\n            onChangeComplete(getColorValue(rgb));\n            event.preventDefault();\n        },\n        [onChangeComplete]\n    );\n\n    const togglePicker = useCallback((e: SyntheticEvent) => {\n        e.stopPropagation();\n        setShowPicker(!showPicker);\n    }, []);\n\n    const pageElements = usePageElements();\n\n    const themeColors: Record<string, any> = {};\n    const colors = pageElements.theme?.styles?.colors;\n    if (colors) {\n        for (const key in colors) {\n            if (colors[key]) {\n                themeColors[key] = colors[key];\n            }\n        }\n    }\n\n    return (\n        <ColorPickerStyle>\n            {Object.keys(themeColors).map((key, index) => {\n                const color = themeColors[key];\n\n                if (color === value || value === \"transparent\") {\n                    themeColor = true;\n                }\n                return (\n                    <ColorBox key={index}>\n                        <Color\n                            className={key === value ? styles.selectedColor : \"\"}\n                            style={{ backgroundColor: color }}\n                            onClick={() => {\n                                // With page elements implementation, we want to store the color key and\n                                // then the actual color will be retrieved from the theme object.\n                                const colors = pageElements.theme?.styles?.colors;\n                                onChangeComplete(colors[key], key);\n                            }}\n                        />\n                    </ColorBox>\n                );\n            })}\n\n            <ColorBox>\n                <Color\n                    className={classnames(transparent, {\n                        [styles.selectedColor]: value === \"transparent\"\n                    })}\n                    onClick={() => {\n                        onChangeComplete(\"transparent\");\n                    }}\n                />\n            </ColorBox>\n\n            <ColorBox>\n                <Color\n                    className={value && !themeColor ? styles.selectedColor : \"\"}\n                    style={{ backgroundColor: themeColor ? \"#fff\" : value }}\n                    onClick={togglePicker}\n                >\n                    <IconPalette className={iconPaletteStyle} />\n                </Color>\n            </ColorBox>\n\n            {showPicker && (\n                <ChromePicker\n                    color={actualSelectedColor}\n                    // TODO figure out types for the props\n                    onChange={onColorChange as OnChangeHandler}\n                    onChangeComplete={onColorChangeComplete as OnChangeHandler}\n                />\n            )}\n        </ColorPickerStyle>\n    );\n};\n"]} */",
|
|
43
|
+
name: "ycm87k",
|
|
44
|
+
styles: "cursor:pointer;width:40px;height:40px;border-radius:50%;margin:5px;border:1px solid var(--mdc-theme-on-background);padding:3px",
|
|
45
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LexicalColorPicker.tsx"],"names":[],"mappings":"AAqBiB","file":"LexicalColorPicker.tsx","sourcesContent":["import React, { useCallback, useState, SyntheticEvent, useEffect, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { css } from \"emotion\";\nimport { usePageElements } from \"@webiny/app-page-builder-elements/hooks/usePageElements\";\nimport { ChromePicker, ColorState, RGBColor } from \"react-color\";\nimport { OnChangeHandler } from \"react-color/lib/components/common/ColorWrap\";\nimport { Tooltip } from \"@webiny/ui/Tooltip\";\n\n// Icons\nimport { ReactComponent as IconPalette } from \"./round-color_lens-24px.svg\";\n\nconst ColorPickerStyle = styled(\"div\")({\n    position: \"relative\",\n    display: \"flex\",\n    flexWrap: \"wrap\",\n    justifyContent: \"flex-start\",\n    width: 240,\n    padding: 15,\n    backgroundColor: \"#fff\"\n});\n\nconst ColorBox = styled(\"div\")({\n    cursor: \"pointer\",\n    width: 40,\n    height: 40,\n    borderRadius: \"50%\",\n    margin: 5,\n    border: \"1px solid var(--mdc-theme-on-background)\",\n    padding: 3\n});\n\nconst Color = styled(\"button\")({\n    cursor: \"pointer\",\n    width: 40,\n    height: 40,\n    transition: \"transform 0.1s, border 0.2s\",\n    borderColor: \"transparent\",\n    display: \"flex\",\n    alignItems: \"center\",\n    borderRadius: \"50%\",\n    \"&::after\": {\n        transition: \"opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1)\",\n        content: '\"\"',\n        position: \"absolute\",\n        top: 0,\n        left: 0,\n        width: \"100%\",\n        height: \"100%\",\n        zIndex: -1,\n        opacity: 0\n    },\n    \"&:hover\": {\n        transform: \"scale(1.1)\",\n        boxShadow: \"0 0.25rem 0.125rem 0 rgba(0,0,0,0.05)\",\n        \"&::after\": {\n            opacity: 1\n        }\n    }\n});\n\nconst iconPaletteStyle = css({\n    height: 20,\n    width: \"100%\",\n    marginTop: 1,\n    color: \"var(--mdc-theme-secondary)\"\n});\n\nconst COLORS = {\n    lightGray: \"hsla(0, 0%, 97%, 1)\",\n    gray: \"hsla(300, 2%, 92%, 1)\",\n    darkGray: \"hsla(0, 0%, 70%, 1)\",\n    darkestGray: \"hsla(0, 0%, 20%, 1)\",\n    black: \"hsla(208, 100%, 5%, 1)\"\n};\n\nconst styles = {\n    selectedColor: css({\n        boxShadow: \"inset 0px 0px 0px 10px var(--mdc-theme-secondary)\",\n        button: {\n            border: \"5px solid var(--mdc-theme-surface)\"\n        }\n    }),\n    button: css({\n        cursor: \"pointer\",\n        height: 30,\n        boxSizing: \"border-box\",\n        \"&:hover:not(:disabled)\": { backgroundColor: COLORS.gray },\n        \"&:focus:not(:disabled)\": {\n            outline: \"none\"\n        },\n        \"&:disabled\": {\n            opacity: 0.5,\n            cursor: \"not-allowed\"\n        },\n        \"& svg\": {\n            width: 16,\n            height: 16\n        }\n    }),\n    color: css({\n        width: \"40px\",\n        height: \"100%\"\n    })\n};\n\nconst chromePickerStyle = css({\n    width: \"270px !important\",\n    margin: \"15px -15px -15px -15px\"\n});\n\ninterface LexicalColorPickerProps {\n    value: string;\n    onChange?: (color: string) => void;\n    onChangeComplete: (color: string, name?: string) => void;\n    handlerClassName?: string;\n}\n\nconst showPickerStyle = { display: \"block\" };\nconst hidePickerStyle = { display: \"none\" };\n\nexport const LexicalColorPicker = ({\n    value,\n    onChange,\n    onChangeComplete\n}: LexicalColorPickerProps) => {\n    const [showPicker, setShowPicker] = useState(false);\n    // Either a custom color or a color coming from the theme object.\n    const [actualSelectedColor, setActualSelectedColor] = useState(value || \"#fff\");\n    const [isThemeColor, setIsThemeColor] = useState(false);\n\n    useEffect(() => {\n        if (value) {\n            setActualSelectedColor(value);\n        }\n    }, [value]);\n\n    const getColorValue = useCallback((rgb: RGBColor, alpha?: number) => {\n        return `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${alpha ?? rgb.a})`;\n    }, []);\n\n    const onColorChange = useCallback(\n        (color: ColorState, event: React.SyntheticEvent) => {\n            event.preventDefault();\n            // controls of the picker are updated as user moves the mouse\n            const customColor = getColorValue(color.rgb, color.rgb.a === 0 ? 1 : color.rgb.a);\n            setActualSelectedColor(customColor);\n            if (typeof onChange === \"function\") {\n                onChange(customColor);\n            }\n        },\n        [onChange]\n    );\n\n    const onColorChangeComplete = useCallback(\n        ({ rgb }: ColorState, event: React.SyntheticEvent) => {\n            event.preventDefault();\n            const color = getColorValue(rgb, rgb.a === 0 ? 1 : rgb.a);\n            setActualSelectedColor(color);\n            onChangeComplete(color);\n        },\n        [onChangeComplete]\n    );\n\n    const togglePicker = useCallback((e: SyntheticEvent) => {\n        e.stopPropagation();\n        setShowPicker(state => !state);\n    }, []);\n\n    const pageElements = usePageElements();\n\n    const themeColors: Record<string, any> = useMemo(() => {\n        const colors = pageElements.theme?.styles?.colors ?? {};\n\n        return Object.keys(colors).reduce((acc, key) => {\n            return { ...acc, [key]: colors[key] };\n        }, {});\n    }, [pageElements.theme?.styles?.colors]);\n\n    useEffect(() => {\n        const isThemeColor = Object.keys(themeColors).some(key => themeColors[key] === value);\n        setIsThemeColor(isThemeColor);\n    }, [themeColors, value]);\n\n    return (\n        <ColorPickerStyle>\n            {Object.keys(themeColors).map((key, index) => {\n                const color = themeColors[key];\n\n                return (\n                    <ColorBox key={index} className={color === value ? styles.selectedColor : \"\"}>\n                        <Tooltip content={<span>{color}</span>} placement=\"bottom\">\n                            <Color\n                                style={{ backgroundColor: color }}\n                                onClick={() => {\n                                    // With page elements implementation, we want to store the color key and\n                                    // then the actual color will be retrieved from the theme object.\n                                    const colors = pageElements.theme?.styles?.colors;\n                                    onChangeComplete(colors[key], key);\n                                }}\n                            />\n                        </Tooltip>\n                    </ColorBox>\n                );\n            })}\n\n            <ColorBox className={value && !isThemeColor ? styles.selectedColor : \"\"}>\n                <Tooltip content={<span>Color picker</span>} placement=\"bottom\">\n                    <Color\n                        style={{ backgroundColor: isThemeColor ? \"#fff\" : value }}\n                        onClick={togglePicker}\n                    >\n                        <IconPalette className={iconPaletteStyle} />\n                    </Color>\n                </Tooltip>\n            </ColorBox>\n\n            <div style={showPicker ? showPickerStyle : hidePickerStyle}>\n                <ChromePicker\n                    className={chromePickerStyle}\n                    color={actualSelectedColor}\n                    disableAlpha={true}\n                    onChange={onColorChange as OnChangeHandler}\n                    onChangeComplete={onColorChangeComplete as OnChangeHandler}\n                />\n            </div>\n        </ColorPickerStyle>\n    );\n};\n"]} */",
|
|
45
46
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
46
47
|
});
|
|
47
48
|
var Color = /*#__PURE__*/(0, _base.default)("button", process.env.NODE_ENV === "production" ? {
|
|
@@ -52,13 +53,13 @@ var Color = /*#__PURE__*/(0, _base.default)("button", process.env.NODE_ENV === "
|
|
|
52
53
|
})({
|
|
53
54
|
cursor: "pointer",
|
|
54
55
|
width: 40,
|
|
55
|
-
height:
|
|
56
|
-
|
|
57
|
-
|
|
56
|
+
height: 40,
|
|
57
|
+
transition: "transform 0.1s, border 0.2s",
|
|
58
|
+
borderColor: "transparent",
|
|
58
59
|
display: "flex",
|
|
59
60
|
alignItems: "center",
|
|
61
|
+
borderRadius: "50%",
|
|
60
62
|
"&::after": {
|
|
61
|
-
boxShadow: "0 0.25rem 0.125rem 0 rgba(0,0,0,0.05)",
|
|
62
63
|
transition: "opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1)",
|
|
63
64
|
content: '""',
|
|
64
65
|
position: "absolute",
|
|
@@ -70,16 +71,13 @@ var Color = /*#__PURE__*/(0, _base.default)("button", process.env.NODE_ENV === "
|
|
|
70
71
|
opacity: 0
|
|
71
72
|
},
|
|
72
73
|
"&:hover": {
|
|
73
|
-
transform: "scale(1.
|
|
74
|
+
transform: "scale(1.1)",
|
|
75
|
+
boxShadow: "0 0.25rem 0.125rem 0 rgba(0,0,0,0.05)",
|
|
74
76
|
"&::after": {
|
|
75
77
|
opacity: 1
|
|
76
78
|
}
|
|
77
79
|
}
|
|
78
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LexicalColorPicker.tsx"],"names":[],"mappings":"AA6Bc","file":"LexicalColorPicker.tsx","sourcesContent":["import React, { useCallback, useState, SyntheticEvent } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { css } from \"emotion\";\nimport { usePageElements } from \"@webiny/app-page-builder-elements/hooks/usePageElements\";\nimport classnames from \"classnames\";\nimport { ChromePicker, ColorState, RGBColor } from \"react-color\";\nimport { OnChangeHandler } from \"react-color/lib/components/common/ColorWrap\";\n\n// Icons\nimport { ReactComponent as IconPalette } from \"./round-color_lens-24px.svg\";\n\nconst ColorPickerStyle = styled(\"div\")({\n    position: \"relative\",\n    display: \"flex\",\n    flexWrap: \"wrap\",\n    justifyContent: \"space-between\",\n    width: 225,\n    padding: 0,\n    backgroundColor: \"#fff\"\n});\n\nconst ColorBox = styled(\"div\")({\n    cursor: \"pointer\",\n    width: 50,\n    height: 40,\n    margin: 10,\n    borderRadius: 2\n});\n\nconst Color = styled(\"button\")({\n    cursor: \"pointer\",\n    width: 40,\n    height: 30,\n    border: \"1px solid var(--mdc-theme-on-background)\",\n    transition: \"transform 0.2s, scale 0.2s\",\n    display: \"flex\",\n    alignItems: \"center\",\n    \"&::after\": {\n        boxShadow: \"0 0.25rem 0.125rem 0 rgba(0,0,0,0.05)\",\n        transition: \"opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1)\",\n        content: '\"\"',\n        position: \"absolute\",\n        top: 0,\n        left: 0,\n        width: \"100%\",\n        height: \"100%\",\n        zIndex: -1,\n        opacity: 0\n    },\n    \"&:hover\": {\n        transform: \"scale(1.25)\",\n        \"&::after\": {\n            opacity: 1\n        }\n    }\n});\n\nconst transparent = css({\n    backgroundSize: \"10px 10px\",\n    backgroundImage:\n        \"linear-gradient( 45deg, #555 25%, transparent 25%, transparent),\" +\n        \"linear-gradient(-45deg, #555 25%, transparent 25%, transparent),\" +\n        \"linear-gradient( 45deg, transparent 75%, #555 75%),\" +\n        \"linear-gradient(-45deg, transparent 75%, #555 75%)\"\n});\n\nconst iconPaletteStyle = css({\n    height: 20,\n    width: \"100%\",\n    marginTop: 1,\n    color: \"var(--mdc-theme-secondary)\"\n});\n\nconst COLORS = {\n    lightGray: \"hsla(0, 0%, 97%, 1)\",\n    gray: \"hsla(300, 2%, 92%, 1)\",\n    darkGray: \"hsla(0, 0%, 70%, 1)\",\n    darkestGray: \"hsla(0, 0%, 20%, 1)\",\n    black: \"hsla(208, 100%, 5%, 1)\"\n};\n\nconst styles = {\n    selectedColor: css({\n        boxShadow: \"0px 0px 0px 2px var(--mdc-theme-secondary)\"\n    }),\n    button: css({\n        cursor: \"pointer\",\n        height: 30,\n        boxSizing: \"border-box\",\n        \"&:hover:not(:disabled)\": { backgroundColor: COLORS.gray },\n        \"&:focus:not(:disabled)\": {\n            outline: \"none\"\n        },\n        \"&:disabled\": {\n            opacity: 0.5,\n            cursor: \"not-allowed\"\n        },\n        \"& svg\": {\n            width: 16,\n            height: 16\n        }\n    }),\n    color: css({\n        width: \"40px\",\n        height: \"100%\"\n    })\n};\n\ninterface LexicalColorPickerProps {\n    value: string;\n    onChange?: (color: string) => void;\n    onChangeComplete: (color: string, name?: string) => void;\n    handlerClassName?: string;\n}\n\nexport const LexicalColorPicker = ({\n    value,\n    onChange,\n    onChangeComplete\n}: LexicalColorPickerProps) => {\n    const [showPicker, setShowPicker] = useState(false);\n    // Either a custom color or a color coming from the theme object.\n    const [actualSelectedColor, setActualSelectedColor] = useState(value || \"#fff\");\n    let themeColor = false;\n\n    const getColorValue = useCallback((rgb: RGBColor) => {\n        return `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${rgb.a})`;\n    }, []);\n\n    const onColorChange = useCallback(\n        (color: ColorState, event: React.SyntheticEvent) => {\n            event.preventDefault();\n            // controls of the picker are updated as user moves the mouse\n            const customColor = getColorValue(color.rgb);\n            setActualSelectedColor(customColor);\n            if (typeof onChange === \"function\") {\n                onChange(customColor);\n            }\n        },\n        [onChange]\n    );\n\n    const onColorChangeComplete = useCallback(\n        ({ rgb }: ColorState, event: React.SyntheticEvent) => {\n            setActualSelectedColor(value);\n            onChangeComplete(getColorValue(rgb));\n            event.preventDefault();\n        },\n        [onChangeComplete]\n    );\n\n    const togglePicker = useCallback((e: SyntheticEvent) => {\n        e.stopPropagation();\n        setShowPicker(!showPicker);\n    }, []);\n\n    const pageElements = usePageElements();\n\n    const themeColors: Record<string, any> = {};\n    const colors = pageElements.theme?.styles?.colors;\n    if (colors) {\n        for (const key in colors) {\n            if (colors[key]) {\n                themeColors[key] = colors[key];\n            }\n        }\n    }\n\n    return (\n        <ColorPickerStyle>\n            {Object.keys(themeColors).map((key, index) => {\n                const color = themeColors[key];\n\n                if (color === value || value === \"transparent\") {\n                    themeColor = true;\n                }\n                return (\n                    <ColorBox key={index}>\n                        <Color\n                            className={key === value ? styles.selectedColor : \"\"}\n                            style={{ backgroundColor: color }}\n                            onClick={() => {\n                                // With page elements implementation, we want to store the color key and\n                                // then the actual color will be retrieved from the theme object.\n                                const colors = pageElements.theme?.styles?.colors;\n                                onChangeComplete(colors[key], key);\n                            }}\n                        />\n                    </ColorBox>\n                );\n            })}\n\n            <ColorBox>\n                <Color\n                    className={classnames(transparent, {\n                        [styles.selectedColor]: value === \"transparent\"\n                    })}\n                    onClick={() => {\n                        onChangeComplete(\"transparent\");\n                    }}\n                />\n            </ColorBox>\n\n            <ColorBox>\n                <Color\n                    className={value && !themeColor ? styles.selectedColor : \"\"}\n                    style={{ backgroundColor: themeColor ? \"#fff\" : value }}\n                    onClick={togglePicker}\n                >\n                    <IconPalette className={iconPaletteStyle} />\n                </Color>\n            </ColorBox>\n\n            {showPicker && (\n                <ChromePicker\n                    color={actualSelectedColor}\n                    // TODO figure out types for the props\n                    onChange={onColorChange as OnChangeHandler}\n                    onChangeComplete={onColorChangeComplete as OnChangeHandler}\n                />\n            )}\n        </ColorPickerStyle>\n    );\n};\n"]} */");
|
|
79
|
-
var transparent = (0, _emotion.css)({
|
|
80
|
-
backgroundSize: "10px 10px",
|
|
81
|
-
backgroundImage: "linear-gradient( 45deg, #555 25%, transparent 25%, transparent)," + "linear-gradient(-45deg, #555 25%, transparent 25%, transparent)," + "linear-gradient( 45deg, transparent 75%, #555 75%)," + "linear-gradient(-45deg, transparent 75%, #555 75%)"
|
|
82
|
-
});
|
|
80
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LexicalColorPicker.tsx"],"names":[],"mappings":"AA+Bc","file":"LexicalColorPicker.tsx","sourcesContent":["import React, { useCallback, useState, SyntheticEvent, useEffect, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { css } from \"emotion\";\nimport { usePageElements } from \"@webiny/app-page-builder-elements/hooks/usePageElements\";\nimport { ChromePicker, ColorState, RGBColor } from \"react-color\";\nimport { OnChangeHandler } from \"react-color/lib/components/common/ColorWrap\";\nimport { Tooltip } from \"@webiny/ui/Tooltip\";\n\n// Icons\nimport { ReactComponent as IconPalette } from \"./round-color_lens-24px.svg\";\n\nconst ColorPickerStyle = styled(\"div\")({\n    position: \"relative\",\n    display: \"flex\",\n    flexWrap: \"wrap\",\n    justifyContent: \"flex-start\",\n    width: 240,\n    padding: 15,\n    backgroundColor: \"#fff\"\n});\n\nconst ColorBox = styled(\"div\")({\n    cursor: \"pointer\",\n    width: 40,\n    height: 40,\n    borderRadius: \"50%\",\n    margin: 5,\n    border: \"1px solid var(--mdc-theme-on-background)\",\n    padding: 3\n});\n\nconst Color = styled(\"button\")({\n    cursor: \"pointer\",\n    width: 40,\n    height: 40,\n    transition: \"transform 0.1s, border 0.2s\",\n    borderColor: \"transparent\",\n    display: \"flex\",\n    alignItems: \"center\",\n    borderRadius: \"50%\",\n    \"&::after\": {\n        transition: \"opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1)\",\n        content: '\"\"',\n        position: \"absolute\",\n        top: 0,\n        left: 0,\n        width: \"100%\",\n        height: \"100%\",\n        zIndex: -1,\n        opacity: 0\n    },\n    \"&:hover\": {\n        transform: \"scale(1.1)\",\n        boxShadow: \"0 0.25rem 0.125rem 0 rgba(0,0,0,0.05)\",\n        \"&::after\": {\n            opacity: 1\n        }\n    }\n});\n\nconst iconPaletteStyle = css({\n    height: 20,\n    width: \"100%\",\n    marginTop: 1,\n    color: \"var(--mdc-theme-secondary)\"\n});\n\nconst COLORS = {\n    lightGray: \"hsla(0, 0%, 97%, 1)\",\n    gray: \"hsla(300, 2%, 92%, 1)\",\n    darkGray: \"hsla(0, 0%, 70%, 1)\",\n    darkestGray: \"hsla(0, 0%, 20%, 1)\",\n    black: \"hsla(208, 100%, 5%, 1)\"\n};\n\nconst styles = {\n    selectedColor: css({\n        boxShadow: \"inset 0px 0px 0px 10px var(--mdc-theme-secondary)\",\n        button: {\n            border: \"5px solid var(--mdc-theme-surface)\"\n        }\n    }),\n    button: css({\n        cursor: \"pointer\",\n        height: 30,\n        boxSizing: \"border-box\",\n        \"&:hover:not(:disabled)\": { backgroundColor: COLORS.gray },\n        \"&:focus:not(:disabled)\": {\n            outline: \"none\"\n        },\n        \"&:disabled\": {\n            opacity: 0.5,\n            cursor: \"not-allowed\"\n        },\n        \"& svg\": {\n            width: 16,\n            height: 16\n        }\n    }),\n    color: css({\n        width: \"40px\",\n        height: \"100%\"\n    })\n};\n\nconst chromePickerStyle = css({\n    width: \"270px !important\",\n    margin: \"15px -15px -15px -15px\"\n});\n\ninterface LexicalColorPickerProps {\n    value: string;\n    onChange?: (color: string) => void;\n    onChangeComplete: (color: string, name?: string) => void;\n    handlerClassName?: string;\n}\n\nconst showPickerStyle = { display: \"block\" };\nconst hidePickerStyle = { display: \"none\" };\n\nexport const LexicalColorPicker = ({\n    value,\n    onChange,\n    onChangeComplete\n}: LexicalColorPickerProps) => {\n    const [showPicker, setShowPicker] = useState(false);\n    // Either a custom color or a color coming from the theme object.\n    const [actualSelectedColor, setActualSelectedColor] = useState(value || \"#fff\");\n    const [isThemeColor, setIsThemeColor] = useState(false);\n\n    useEffect(() => {\n        if (value) {\n            setActualSelectedColor(value);\n        }\n    }, [value]);\n\n    const getColorValue = useCallback((rgb: RGBColor, alpha?: number) => {\n        return `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${alpha ?? rgb.a})`;\n    }, []);\n\n    const onColorChange = useCallback(\n        (color: ColorState, event: React.SyntheticEvent) => {\n            event.preventDefault();\n            // controls of the picker are updated as user moves the mouse\n            const customColor = getColorValue(color.rgb, color.rgb.a === 0 ? 1 : color.rgb.a);\n            setActualSelectedColor(customColor);\n            if (typeof onChange === \"function\") {\n                onChange(customColor);\n            }\n        },\n        [onChange]\n    );\n\n    const onColorChangeComplete = useCallback(\n        ({ rgb }: ColorState, event: React.SyntheticEvent) => {\n            event.preventDefault();\n            const color = getColorValue(rgb, rgb.a === 0 ? 1 : rgb.a);\n            setActualSelectedColor(color);\n            onChangeComplete(color);\n        },\n        [onChangeComplete]\n    );\n\n    const togglePicker = useCallback((e: SyntheticEvent) => {\n        e.stopPropagation();\n        setShowPicker(state => !state);\n    }, []);\n\n    const pageElements = usePageElements();\n\n    const themeColors: Record<string, any> = useMemo(() => {\n        const colors = pageElements.theme?.styles?.colors ?? {};\n\n        return Object.keys(colors).reduce((acc, key) => {\n            return { ...acc, [key]: colors[key] };\n        }, {});\n    }, [pageElements.theme?.styles?.colors]);\n\n    useEffect(() => {\n        const isThemeColor = Object.keys(themeColors).some(key => themeColors[key] === value);\n        setIsThemeColor(isThemeColor);\n    }, [themeColors, value]);\n\n    return (\n        <ColorPickerStyle>\n            {Object.keys(themeColors).map((key, index) => {\n                const color = themeColors[key];\n\n                return (\n                    <ColorBox key={index} className={color === value ? styles.selectedColor : \"\"}>\n                        <Tooltip content={<span>{color}</span>} placement=\"bottom\">\n                            <Color\n                                style={{ backgroundColor: color }}\n                                onClick={() => {\n                                    // With page elements implementation, we want to store the color key and\n                                    // then the actual color will be retrieved from the theme object.\n                                    const colors = pageElements.theme?.styles?.colors;\n                                    onChangeComplete(colors[key], key);\n                                }}\n                            />\n                        </Tooltip>\n                    </ColorBox>\n                );\n            })}\n\n            <ColorBox className={value && !isThemeColor ? styles.selectedColor : \"\"}>\n                <Tooltip content={<span>Color picker</span>} placement=\"bottom\">\n                    <Color\n                        style={{ backgroundColor: isThemeColor ? \"#fff\" : value }}\n                        onClick={togglePicker}\n                    >\n                        <IconPalette className={iconPaletteStyle} />\n                    </Color>\n                </Tooltip>\n            </ColorBox>\n\n            <div style={showPicker ? showPickerStyle : hidePickerStyle}>\n                <ChromePicker\n                    className={chromePickerStyle}\n                    color={actualSelectedColor}\n                    disableAlpha={true}\n                    onChange={onColorChange as OnChangeHandler}\n                    onChangeComplete={onColorChangeComplete as OnChangeHandler}\n                />\n            </div>\n        </ColorPickerStyle>\n    );\n};\n"]} */");
|
|
83
81
|
var iconPaletteStyle = (0, _emotion.css)({
|
|
84
82
|
height: 20,
|
|
85
83
|
width: "100%",
|
|
@@ -95,7 +93,10 @@ var COLORS = {
|
|
|
95
93
|
};
|
|
96
94
|
var styles = {
|
|
97
95
|
selectedColor: (0, _emotion.css)({
|
|
98
|
-
boxShadow: "0px 0px 0px
|
|
96
|
+
boxShadow: "inset 0px 0px 0px 10px var(--mdc-theme-secondary)",
|
|
97
|
+
button: {
|
|
98
|
+
border: "5px solid var(--mdc-theme-surface)"
|
|
99
|
+
}
|
|
99
100
|
}),
|
|
100
101
|
button: (0, _emotion.css)({
|
|
101
102
|
cursor: "pointer",
|
|
@@ -121,6 +122,16 @@ var styles = {
|
|
|
121
122
|
height: "100%"
|
|
122
123
|
})
|
|
123
124
|
};
|
|
125
|
+
var chromePickerStyle = (0, _emotion.css)({
|
|
126
|
+
width: "270px !important",
|
|
127
|
+
margin: "15px -15px -15px -15px"
|
|
128
|
+
});
|
|
129
|
+
var showPickerStyle = {
|
|
130
|
+
display: "block"
|
|
131
|
+
};
|
|
132
|
+
var hidePickerStyle = {
|
|
133
|
+
display: "none"
|
|
134
|
+
};
|
|
124
135
|
var LexicalColorPicker = exports.LexicalColorPicker = function LexicalColorPicker(_ref) {
|
|
125
136
|
var value = _ref.value,
|
|
126
137
|
onChange = _ref.onChange,
|
|
@@ -134,14 +145,22 @@ var LexicalColorPicker = exports.LexicalColorPicker = function LexicalColorPicke
|
|
|
134
145
|
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
135
146
|
actualSelectedColor = _useState4[0],
|
|
136
147
|
setActualSelectedColor = _useState4[1];
|
|
137
|
-
var
|
|
138
|
-
|
|
139
|
-
|
|
148
|
+
var _useState5 = (0, _react.useState)(false),
|
|
149
|
+
_useState6 = (0, _slicedToArray2.default)(_useState5, 2),
|
|
150
|
+
isThemeColor = _useState6[0],
|
|
151
|
+
setIsThemeColor = _useState6[1];
|
|
152
|
+
(0, _react.useEffect)(function () {
|
|
153
|
+
if (value) {
|
|
154
|
+
setActualSelectedColor(value);
|
|
155
|
+
}
|
|
156
|
+
}, [value]);
|
|
157
|
+
var getColorValue = (0, _react.useCallback)(function (rgb, alpha) {
|
|
158
|
+
return "rgba(".concat(rgb.r, ", ").concat(rgb.g, ", ").concat(rgb.b, ", ").concat(alpha ?? rgb.a, ")");
|
|
140
159
|
}, []);
|
|
141
160
|
var onColorChange = (0, _react.useCallback)(function (color, event) {
|
|
142
161
|
event.preventDefault();
|
|
143
162
|
// controls of the picker are updated as user moves the mouse
|
|
144
|
-
var customColor = getColorValue(color.rgb);
|
|
163
|
+
var customColor = getColorValue(color.rgb, color.rgb.a === 0 ? 1 : color.rgb.a);
|
|
145
164
|
setActualSelectedColor(customColor);
|
|
146
165
|
if (typeof onChange === "function") {
|
|
147
166
|
onChange(customColor);
|
|
@@ -149,33 +168,39 @@ var LexicalColorPicker = exports.LexicalColorPicker = function LexicalColorPicke
|
|
|
149
168
|
}, [onChange]);
|
|
150
169
|
var onColorChangeComplete = (0, _react.useCallback)(function (_ref2, event) {
|
|
151
170
|
var rgb = _ref2.rgb;
|
|
152
|
-
setActualSelectedColor(value);
|
|
153
|
-
onChangeComplete(getColorValue(rgb));
|
|
154
171
|
event.preventDefault();
|
|
172
|
+
var color = getColorValue(rgb, rgb.a === 0 ? 1 : rgb.a);
|
|
173
|
+
setActualSelectedColor(color);
|
|
174
|
+
onChangeComplete(color);
|
|
155
175
|
}, [onChangeComplete]);
|
|
156
176
|
var togglePicker = (0, _react.useCallback)(function (e) {
|
|
157
177
|
e.stopPropagation();
|
|
158
|
-
setShowPicker(
|
|
178
|
+
setShowPicker(function (state) {
|
|
179
|
+
return !state;
|
|
180
|
+
});
|
|
159
181
|
}, []);
|
|
160
182
|
var pageElements = (0, _usePageElements.usePageElements)();
|
|
161
|
-
var themeColors = {
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
183
|
+
var themeColors = (0, _react.useMemo)(function () {
|
|
184
|
+
var colors = pageElements.theme?.styles?.colors ?? {};
|
|
185
|
+
return Object.keys(colors).reduce(function (acc, key) {
|
|
186
|
+
return (0, _objectSpread3.default)((0, _objectSpread3.default)({}, acc), {}, (0, _defineProperty2.default)({}, key, colors[key]));
|
|
187
|
+
}, {});
|
|
188
|
+
}, [pageElements.theme?.styles?.colors]);
|
|
189
|
+
(0, _react.useEffect)(function () {
|
|
190
|
+
var isThemeColor = Object.keys(themeColors).some(function (key) {
|
|
191
|
+
return themeColors[key] === value;
|
|
192
|
+
});
|
|
193
|
+
setIsThemeColor(isThemeColor);
|
|
194
|
+
}, [themeColors, value]);
|
|
170
195
|
return /*#__PURE__*/_react.default.createElement(ColorPickerStyle, null, Object.keys(themeColors).map(function (key, index) {
|
|
171
196
|
var color = themeColors[key];
|
|
172
|
-
if (color === value || value === "transparent") {
|
|
173
|
-
themeColor = true;
|
|
174
|
-
}
|
|
175
197
|
return /*#__PURE__*/_react.default.createElement(ColorBox, {
|
|
176
|
-
key: index
|
|
198
|
+
key: index,
|
|
199
|
+
className: color === value ? styles.selectedColor : ""
|
|
200
|
+
}, /*#__PURE__*/_react.default.createElement(_Tooltip.Tooltip, {
|
|
201
|
+
content: /*#__PURE__*/_react.default.createElement("span", null, color),
|
|
202
|
+
placement: "bottom"
|
|
177
203
|
}, /*#__PURE__*/_react.default.createElement(Color, {
|
|
178
|
-
className: key === value ? styles.selectedColor : "",
|
|
179
204
|
style: {
|
|
180
205
|
backgroundColor: color
|
|
181
206
|
},
|
|
@@ -185,27 +210,28 @@ var LexicalColorPicker = exports.LexicalColorPicker = function LexicalColorPicke
|
|
|
185
210
|
var colors = pageElements.theme?.styles?.colors;
|
|
186
211
|
onChangeComplete(colors[key], key);
|
|
187
212
|
}
|
|
188
|
-
}));
|
|
189
|
-
}), /*#__PURE__*/_react.default.createElement(ColorBox,
|
|
190
|
-
className:
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
}
|
|
195
|
-
className: value && !themeColor ? styles.selectedColor : "",
|
|
213
|
+
})));
|
|
214
|
+
}), /*#__PURE__*/_react.default.createElement(ColorBox, {
|
|
215
|
+
className: value && !isThemeColor ? styles.selectedColor : ""
|
|
216
|
+
}, /*#__PURE__*/_react.default.createElement(_Tooltip.Tooltip, {
|
|
217
|
+
content: /*#__PURE__*/_react.default.createElement("span", null, "Color picker"),
|
|
218
|
+
placement: "bottom"
|
|
219
|
+
}, /*#__PURE__*/_react.default.createElement(Color, {
|
|
196
220
|
style: {
|
|
197
|
-
backgroundColor:
|
|
221
|
+
backgroundColor: isThemeColor ? "#fff" : value
|
|
198
222
|
},
|
|
199
223
|
onClick: togglePicker
|
|
200
224
|
}, /*#__PURE__*/_react.default.createElement(_roundColor_lens24px.ReactComponent, {
|
|
201
225
|
className: iconPaletteStyle
|
|
202
|
-
}))),
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
,
|
|
226
|
+
})))), /*#__PURE__*/_react.default.createElement("div", {
|
|
227
|
+
style: showPicker ? showPickerStyle : hidePickerStyle
|
|
228
|
+
}, /*#__PURE__*/_react.default.createElement(_reactColor.ChromePicker, {
|
|
229
|
+
className: chromePickerStyle,
|
|
230
|
+
color: actualSelectedColor,
|
|
231
|
+
disableAlpha: true,
|
|
206
232
|
onChange: onColorChange,
|
|
207
233
|
onChangeComplete: onColorChangeComplete
|
|
208
|
-
}));
|
|
234
|
+
})));
|
|
209
235
|
};
|
|
210
236
|
|
|
211
237
|
//# sourceMappingURL=LexicalColorPicker.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireWildcard","require","_emotion","_usePageElements","_classnames2","_interopRequireDefault","_reactColor","_roundColor_lens24px","_EMOTION_STRINGIFIED_CSS_ERROR__","ColorPickerStyle","_base","default","process","env","NODE_ENV","target","label","name","styles","map","toString","ColorBox","Color","cursor","width","height","border","transition","display","alignItems","boxShadow","content","position","top","left","zIndex","opacity","transform","transparent","css","backgroundSize","backgroundImage","iconPaletteStyle","marginTop","color","COLORS","lightGray","gray","darkGray","darkestGray","black","selectedColor","button","boxSizing","backgroundColor","outline","LexicalColorPicker","exports","_ref","value","onChange","onChangeComplete","_useState","useState","_useState2","_slicedToArray2","showPicker","setShowPicker","_useState3","_useState4","actualSelectedColor","setActualSelectedColor","themeColor","getColorValue","useCallback","rgb","concat","r","g","b","a","onColorChange","event","preventDefault","customColor","onColorChangeComplete","_ref2","togglePicker","e","stopPropagation","pageElements","usePageElements","themeColors","colors","theme","key","createElement","Object","keys","index","className","style","onClick","classnames","_defineProperty2","ReactComponent","ChromePicker"],"sources":["LexicalColorPicker.tsx"],"sourcesContent":["import React, { useCallback, useState, SyntheticEvent } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { css } from \"emotion\";\nimport { usePageElements } from \"@webiny/app-page-builder-elements/hooks/usePageElements\";\nimport classnames from \"classnames\";\nimport { ChromePicker, ColorState, RGBColor } from \"react-color\";\nimport { OnChangeHandler } from \"react-color/lib/components/common/ColorWrap\";\n\n// Icons\nimport { ReactComponent as IconPalette } from \"./round-color_lens-24px.svg\";\n\nconst ColorPickerStyle = styled(\"div\")({\n position: \"relative\",\n display: \"flex\",\n flexWrap: \"wrap\",\n justifyContent: \"space-between\",\n width: 225,\n padding: 0,\n backgroundColor: \"#fff\"\n});\n\nconst ColorBox = styled(\"div\")({\n cursor: \"pointer\",\n width: 50,\n height: 40,\n margin: 10,\n borderRadius: 2\n});\n\nconst Color = styled(\"button\")({\n cursor: \"pointer\",\n width: 40,\n height: 30,\n border: \"1px solid var(--mdc-theme-on-background)\",\n transition: \"transform 0.2s, scale 0.2s\",\n display: \"flex\",\n alignItems: \"center\",\n \"&::after\": {\n boxShadow: \"0 0.25rem 0.125rem 0 rgba(0,0,0,0.05)\",\n transition: \"opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1)\",\n content: '\"\"',\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n height: \"100%\",\n zIndex: -1,\n opacity: 0\n },\n \"&:hover\": {\n transform: \"scale(1.25)\",\n \"&::after\": {\n opacity: 1\n }\n }\n});\n\nconst transparent = css({\n backgroundSize: \"10px 10px\",\n backgroundImage:\n \"linear-gradient( 45deg, #555 25%, transparent 25%, transparent),\" +\n \"linear-gradient(-45deg, #555 25%, transparent 25%, transparent),\" +\n \"linear-gradient( 45deg, transparent 75%, #555 75%),\" +\n \"linear-gradient(-45deg, transparent 75%, #555 75%)\"\n});\n\nconst iconPaletteStyle = css({\n height: 20,\n width: \"100%\",\n marginTop: 1,\n color: \"var(--mdc-theme-secondary)\"\n});\n\nconst COLORS = {\n lightGray: \"hsla(0, 0%, 97%, 1)\",\n gray: \"hsla(300, 2%, 92%, 1)\",\n darkGray: \"hsla(0, 0%, 70%, 1)\",\n darkestGray: \"hsla(0, 0%, 20%, 1)\",\n black: \"hsla(208, 100%, 5%, 1)\"\n};\n\nconst styles = {\n selectedColor: css({\n boxShadow: \"0px 0px 0px 2px var(--mdc-theme-secondary)\"\n }),\n button: css({\n cursor: \"pointer\",\n height: 30,\n boxSizing: \"border-box\",\n \"&:hover:not(:disabled)\": { backgroundColor: COLORS.gray },\n \"&:focus:not(:disabled)\": {\n outline: \"none\"\n },\n \"&:disabled\": {\n opacity: 0.5,\n cursor: \"not-allowed\"\n },\n \"& svg\": {\n width: 16,\n height: 16\n }\n }),\n color: css({\n width: \"40px\",\n height: \"100%\"\n })\n};\n\ninterface LexicalColorPickerProps {\n value: string;\n onChange?: (color: string) => void;\n onChangeComplete: (color: string, name?: string) => void;\n handlerClassName?: string;\n}\n\nexport const LexicalColorPicker = ({\n value,\n onChange,\n onChangeComplete\n}: LexicalColorPickerProps) => {\n const [showPicker, setShowPicker] = useState(false);\n // Either a custom color or a color coming from the theme object.\n const [actualSelectedColor, setActualSelectedColor] = useState(value || \"#fff\");\n let themeColor = false;\n\n const getColorValue = useCallback((rgb: RGBColor) => {\n return `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${rgb.a})`;\n }, []);\n\n const onColorChange = useCallback(\n (color: ColorState, event: React.SyntheticEvent) => {\n event.preventDefault();\n // controls of the picker are updated as user moves the mouse\n const customColor = getColorValue(color.rgb);\n setActualSelectedColor(customColor);\n if (typeof onChange === \"function\") {\n onChange(customColor);\n }\n },\n [onChange]\n );\n\n const onColorChangeComplete = useCallback(\n ({ rgb }: ColorState, event: React.SyntheticEvent) => {\n setActualSelectedColor(value);\n onChangeComplete(getColorValue(rgb));\n event.preventDefault();\n },\n [onChangeComplete]\n );\n\n const togglePicker = useCallback((e: SyntheticEvent) => {\n e.stopPropagation();\n setShowPicker(!showPicker);\n }, []);\n\n const pageElements = usePageElements();\n\n const themeColors: Record<string, any> = {};\n const colors = pageElements.theme?.styles?.colors;\n if (colors) {\n for (const key in colors) {\n if (colors[key]) {\n themeColors[key] = colors[key];\n }\n }\n }\n\n return (\n <ColorPickerStyle>\n {Object.keys(themeColors).map((key, index) => {\n const color = themeColors[key];\n\n if (color === value || value === \"transparent\") {\n themeColor = true;\n }\n return (\n <ColorBox key={index}>\n <Color\n className={key === value ? styles.selectedColor : \"\"}\n style={{ backgroundColor: color }}\n onClick={() => {\n // With page elements implementation, we want to store the color key and\n // then the actual color will be retrieved from the theme object.\n const colors = pageElements.theme?.styles?.colors;\n onChangeComplete(colors[key], key);\n }}\n />\n </ColorBox>\n );\n })}\n\n <ColorBox>\n <Color\n className={classnames(transparent, {\n [styles.selectedColor]: value === \"transparent\"\n })}\n onClick={() => {\n onChangeComplete(\"transparent\");\n }}\n />\n </ColorBox>\n\n <ColorBox>\n <Color\n className={value && !themeColor ? styles.selectedColor : \"\"}\n style={{ backgroundColor: themeColor ? \"#fff\" : value }}\n onClick={togglePicker}\n >\n <IconPalette className={iconPaletteStyle} />\n </Color>\n </ColorBox>\n\n {showPicker && (\n <ChromePicker\n color={actualSelectedColor}\n // TODO figure out types for the props\n onChange={onColorChange as OnChangeHandler}\n onChangeComplete={onColorChangeComplete as OnChangeHandler}\n />\n )}\n </ColorPickerStyle>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_emotion","_usePageElements","_reactColor","_Tooltip","_roundColor_lens24px","_EMOTION_STRINGIFIED_CSS_ERROR__","ColorPickerStyle","_base","default","process","env","NODE_ENV","target","label","name","styles","map","toString","ColorBox","Color","cursor","width","height","transition","borderColor","display","alignItems","borderRadius","content","position","top","left","zIndex","opacity","transform","boxShadow","iconPaletteStyle","css","marginTop","color","COLORS","lightGray","gray","darkGray","darkestGray","black","selectedColor","button","border","boxSizing","backgroundColor","outline","chromePickerStyle","margin","showPickerStyle","hidePickerStyle","LexicalColorPicker","exports","_ref","value","onChange","onChangeComplete","_useState","useState","_useState2","_slicedToArray2","showPicker","setShowPicker","_useState3","_useState4","actualSelectedColor","setActualSelectedColor","_useState5","_useState6","isThemeColor","setIsThemeColor","useEffect","getColorValue","useCallback","rgb","alpha","concat","r","g","b","a","onColorChange","event","preventDefault","customColor","onColorChangeComplete","_ref2","togglePicker","e","stopPropagation","state","pageElements","usePageElements","themeColors","useMemo","colors","theme","Object","keys","reduce","acc","key","_objectSpread3","_defineProperty2","some","createElement","index","className","Tooltip","placement","style","onClick","ReactComponent","ChromePicker","disableAlpha"],"sources":["LexicalColorPicker.tsx"],"sourcesContent":["import React, { useCallback, useState, SyntheticEvent, useEffect, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { css } from \"emotion\";\nimport { usePageElements } from \"@webiny/app-page-builder-elements/hooks/usePageElements\";\nimport { ChromePicker, ColorState, RGBColor } from \"react-color\";\nimport { OnChangeHandler } from \"react-color/lib/components/common/ColorWrap\";\nimport { Tooltip } from \"@webiny/ui/Tooltip\";\n\n// Icons\nimport { ReactComponent as IconPalette } from \"./round-color_lens-24px.svg\";\n\nconst ColorPickerStyle = styled(\"div\")({\n position: \"relative\",\n display: \"flex\",\n flexWrap: \"wrap\",\n justifyContent: \"flex-start\",\n width: 240,\n padding: 15,\n backgroundColor: \"#fff\"\n});\n\nconst ColorBox = styled(\"div\")({\n cursor: \"pointer\",\n width: 40,\n height: 40,\n borderRadius: \"50%\",\n margin: 5,\n border: \"1px solid var(--mdc-theme-on-background)\",\n padding: 3\n});\n\nconst Color = styled(\"button\")({\n cursor: \"pointer\",\n width: 40,\n height: 40,\n transition: \"transform 0.1s, border 0.2s\",\n borderColor: \"transparent\",\n display: \"flex\",\n alignItems: \"center\",\n borderRadius: \"50%\",\n \"&::after\": {\n transition: \"opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1)\",\n content: '\"\"',\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n height: \"100%\",\n zIndex: -1,\n opacity: 0\n },\n \"&:hover\": {\n transform: \"scale(1.1)\",\n boxShadow: \"0 0.25rem 0.125rem 0 rgba(0,0,0,0.05)\",\n \"&::after\": {\n opacity: 1\n }\n }\n});\n\nconst iconPaletteStyle = css({\n height: 20,\n width: \"100%\",\n marginTop: 1,\n color: \"var(--mdc-theme-secondary)\"\n});\n\nconst COLORS = {\n lightGray: \"hsla(0, 0%, 97%, 1)\",\n gray: \"hsla(300, 2%, 92%, 1)\",\n darkGray: \"hsla(0, 0%, 70%, 1)\",\n darkestGray: \"hsla(0, 0%, 20%, 1)\",\n black: \"hsla(208, 100%, 5%, 1)\"\n};\n\nconst styles = {\n selectedColor: css({\n boxShadow: \"inset 0px 0px 0px 10px var(--mdc-theme-secondary)\",\n button: {\n border: \"5px solid var(--mdc-theme-surface)\"\n }\n }),\n button: css({\n cursor: \"pointer\",\n height: 30,\n boxSizing: \"border-box\",\n \"&:hover:not(:disabled)\": { backgroundColor: COLORS.gray },\n \"&:focus:not(:disabled)\": {\n outline: \"none\"\n },\n \"&:disabled\": {\n opacity: 0.5,\n cursor: \"not-allowed\"\n },\n \"& svg\": {\n width: 16,\n height: 16\n }\n }),\n color: css({\n width: \"40px\",\n height: \"100%\"\n })\n};\n\nconst chromePickerStyle = css({\n width: \"270px !important\",\n margin: \"15px -15px -15px -15px\"\n});\n\ninterface LexicalColorPickerProps {\n value: string;\n onChange?: (color: string) => void;\n onChangeComplete: (color: string, name?: string) => void;\n handlerClassName?: string;\n}\n\nconst showPickerStyle = { display: \"block\" };\nconst hidePickerStyle = { display: \"none\" };\n\nexport const LexicalColorPicker = ({\n value,\n onChange,\n onChangeComplete\n}: LexicalColorPickerProps) => {\n const [showPicker, setShowPicker] = useState(false);\n // Either a custom color or a color coming from the theme object.\n const [actualSelectedColor, setActualSelectedColor] = useState(value || \"#fff\");\n const [isThemeColor, setIsThemeColor] = useState(false);\n\n useEffect(() => {\n if (value) {\n setActualSelectedColor(value);\n }\n }, [value]);\n\n const getColorValue = useCallback((rgb: RGBColor, alpha?: number) => {\n return `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${alpha ?? rgb.a})`;\n }, []);\n\n const onColorChange = useCallback(\n (color: ColorState, event: React.SyntheticEvent) => {\n event.preventDefault();\n // controls of the picker are updated as user moves the mouse\n const customColor = getColorValue(color.rgb, color.rgb.a === 0 ? 1 : color.rgb.a);\n setActualSelectedColor(customColor);\n if (typeof onChange === \"function\") {\n onChange(customColor);\n }\n },\n [onChange]\n );\n\n const onColorChangeComplete = useCallback(\n ({ rgb }: ColorState, event: React.SyntheticEvent) => {\n event.preventDefault();\n const color = getColorValue(rgb, rgb.a === 0 ? 1 : rgb.a);\n setActualSelectedColor(color);\n onChangeComplete(color);\n },\n [onChangeComplete]\n );\n\n const togglePicker = useCallback((e: SyntheticEvent) => {\n e.stopPropagation();\n setShowPicker(state => !state);\n }, []);\n\n const pageElements = usePageElements();\n\n const themeColors: Record<string, any> = useMemo(() => {\n const colors = pageElements.theme?.styles?.colors ?? {};\n\n return Object.keys(colors).reduce((acc, key) => {\n return { ...acc, [key]: colors[key] };\n }, {});\n }, [pageElements.theme?.styles?.colors]);\n\n useEffect(() => {\n const isThemeColor = Object.keys(themeColors).some(key => themeColors[key] === value);\n setIsThemeColor(isThemeColor);\n }, [themeColors, value]);\n\n return (\n <ColorPickerStyle>\n {Object.keys(themeColors).map((key, index) => {\n const color = themeColors[key];\n\n return (\n <ColorBox key={index} className={color === value ? styles.selectedColor : \"\"}>\n <Tooltip content={<span>{color}</span>} placement=\"bottom\">\n <Color\n style={{ backgroundColor: color }}\n onClick={() => {\n // With page elements implementation, we want to store the color key and\n // then the actual color will be retrieved from the theme object.\n const colors = pageElements.theme?.styles?.colors;\n onChangeComplete(colors[key], key);\n }}\n />\n </Tooltip>\n </ColorBox>\n );\n })}\n\n <ColorBox className={value && !isThemeColor ? styles.selectedColor : \"\"}>\n <Tooltip content={<span>Color picker</span>} placement=\"bottom\">\n <Color\n style={{ backgroundColor: isThemeColor ? \"#fff\" : value }}\n onClick={togglePicker}\n >\n <IconPalette className={iconPaletteStyle} />\n </Color>\n </Tooltip>\n </ColorBox>\n\n <div style={showPicker ? showPickerStyle : hidePickerStyle}>\n <ChromePicker\n className={chromePickerStyle}\n color={actualSelectedColor}\n disableAlpha={true}\n onChange={onColorChange as OnChangeHandler}\n onChangeComplete={onColorChangeComplete as OnChangeHandler}\n />\n </div>\n </ColorPickerStyle>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -8,14 +8,18 @@ exports.LexicalColorPickerDropdown = void 0;
|
|
|
8
8
|
var _react = _interopRequireDefault(require("react"));
|
|
9
9
|
var _lexicalEditor = require("@webiny/lexical-editor");
|
|
10
10
|
var _LexicalColorPicker = require("./LexicalColorPicker/LexicalColorPicker");
|
|
11
|
+
var _emotion = require("emotion");
|
|
11
12
|
var LexicalColorPickerDropdown = exports.LexicalColorPickerDropdown = function LexicalColorPickerDropdown() {
|
|
12
13
|
var _useFontColorPicker = (0, _lexicalEditor.useFontColorPicker)(),
|
|
13
14
|
value = _useFontColorPicker.value,
|
|
14
15
|
applyColor = _useFontColorPicker.applyColor;
|
|
16
|
+
var buttonColorSelection = (0, _emotion.css)({
|
|
17
|
+
borderBottom: "3px solid " + value
|
|
18
|
+
});
|
|
15
19
|
return /*#__PURE__*/_react.default.createElement(_lexicalEditor.DropDown, {
|
|
16
20
|
buttonClassName: "toolbar-item color-picker",
|
|
17
21
|
buttonAriaLabel: "Formatting options for text color",
|
|
18
|
-
buttonIconClassName: "icon font-color",
|
|
22
|
+
buttonIconClassName: "icon font-color " + buttonColorSelection,
|
|
19
23
|
stopCloseOnClickSelf: true,
|
|
20
24
|
disabled: false,
|
|
21
25
|
showScroll: false
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireDefault","require","_lexicalEditor","_LexicalColorPicker","LexicalColorPickerDropdown","exports","_useFontColorPicker","useFontColorPicker","value","applyColor","default","createElement","DropDown","buttonClassName","buttonAriaLabel","buttonIconClassName","stopCloseOnClickSelf","disabled","showScroll","LexicalColorPicker","onChangeComplete"],"sources":["LexicalColorPickerDropdown.tsx"],"sourcesContent":["import React from \"react\";\nimport { useFontColorPicker, DropDown } from \"@webiny/lexical-editor\";\nimport { LexicalColorPicker } from \"~/components/LexicalColorPicker/LexicalColorPicker\";\n\nexport const LexicalColorPickerDropdown = () => {\n const { value, applyColor } = useFontColorPicker();\n\n return (\n <DropDown\n buttonClassName=\"toolbar-item color-picker\"\n buttonAriaLabel={\"Formatting options for text color\"}\n buttonIconClassName
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_lexicalEditor","_LexicalColorPicker","_emotion","LexicalColorPickerDropdown","exports","_useFontColorPicker","useFontColorPicker","value","applyColor","buttonColorSelection","css","borderBottom","default","createElement","DropDown","buttonClassName","buttonAriaLabel","buttonIconClassName","stopCloseOnClickSelf","disabled","showScroll","LexicalColorPicker","onChangeComplete"],"sources":["LexicalColorPickerDropdown.tsx"],"sourcesContent":["import React from \"react\";\nimport { useFontColorPicker, DropDown } from \"@webiny/lexical-editor\";\nimport { LexicalColorPicker } from \"~/components/LexicalColorPicker/LexicalColorPicker\";\nimport { css } from \"emotion\";\n\nexport const LexicalColorPickerDropdown = () => {\n const { value, applyColor } = useFontColorPicker();\n\n const buttonColorSelection = css({\n borderBottom: \"3px solid \" + value\n });\n\n return (\n <DropDown\n buttonClassName=\"toolbar-item color-picker\"\n buttonAriaLabel={\"Formatting options for text color\"}\n buttonIconClassName={\"icon font-color \" + buttonColorSelection}\n stopCloseOnClickSelf={true}\n disabled={false}\n showScroll={false}\n >\n <LexicalColorPicker value={value} onChangeComplete={applyColor} />\n </DropDown>\n );\n};\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,cAAA,GAAAD,OAAA;AACA,IAAAE,mBAAA,GAAAF,OAAA;AACA,IAAAG,QAAA,GAAAH,OAAA;AAEO,IAAMI,0BAA0B,GAAAC,OAAA,CAAAD,0BAAA,GAAG,SAA7BA,0BAA0BA,CAAA,EAAS;EAC5C,IAAAE,mBAAA,GAA8B,IAAAC,iCAAkB,EAAC,CAAC;IAA1CC,KAAK,GAAAF,mBAAA,CAALE,KAAK;IAAEC,UAAU,GAAAH,mBAAA,CAAVG,UAAU;EAEzB,IAAMC,oBAAoB,GAAG,IAAAC,YAAG,EAAC;IAC7BC,YAAY,EAAE,YAAY,GAAGJ;EACjC,CAAC,CAAC;EAEF,oBACIV,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACb,cAAA,CAAAc,QAAQ;IACLC,eAAe,EAAC,2BAA2B;IAC3CC,eAAe,EAAE,mCAAoC;IACrDC,mBAAmB,EAAE,kBAAkB,GAAGR,oBAAqB;IAC/DS,oBAAoB,EAAE,IAAK;IAC3BC,QAAQ,EAAE,KAAM;IAChBC,UAAU,EAAE;EAAM,gBAElBvB,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACZ,mBAAA,CAAAoB,kBAAkB;IAACd,KAAK,EAAEA,KAAM;IAACe,gBAAgB,EAAEd;EAAW,CAAE,CAC3D,CAAC;AAEnB,CAAC","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webiny/lexical-editor-actions",
|
|
3
|
-
"version": "5.40.0",
|
|
3
|
+
"version": "5.40.1-beta.0",
|
|
4
4
|
"dependencies": {
|
|
5
5
|
"@emotion/styled": "11.10.6",
|
|
6
|
-
"@lexical/selection": "0.
|
|
7
|
-
"@webiny/app-page-builder-elements": "5.40.0",
|
|
8
|
-
"@webiny/lexical-editor": "5.40.0",
|
|
9
|
-
"
|
|
6
|
+
"@lexical/selection": "0.16.0",
|
|
7
|
+
"@webiny/app-page-builder-elements": "5.40.1-beta.0",
|
|
8
|
+
"@webiny/lexical-editor": "5.40.1-beta.0",
|
|
9
|
+
"@webiny/ui": "5.40.1-beta.0",
|
|
10
10
|
"emotion": "10.0.27",
|
|
11
11
|
"react": "18.2.0",
|
|
12
12
|
"react-color": "2.19.3",
|
|
@@ -14,8 +14,8 @@
|
|
|
14
14
|
},
|
|
15
15
|
"devDependencies": {
|
|
16
16
|
"@types/react-color": "2.17.11",
|
|
17
|
-
"@webiny/cli": "5.40.0",
|
|
18
|
-
"@webiny/project-utils": "5.40.0"
|
|
17
|
+
"@webiny/cli": "5.40.1-beta.0",
|
|
18
|
+
"@webiny/project-utils": "5.40.1-beta.0"
|
|
19
19
|
},
|
|
20
20
|
"publishConfig": {
|
|
21
21
|
"access": "public",
|
|
@@ -25,5 +25,5 @@
|
|
|
25
25
|
"build": "yarn webiny run build",
|
|
26
26
|
"watch": "yarn webiny run watch"
|
|
27
27
|
},
|
|
28
|
-
"gitHead": "
|
|
28
|
+
"gitHead": "a20d2b69a4fbc681a3dad6469e09ef6eb314505e"
|
|
29
29
|
}
|