@webiny/lexical-editor-actions 5.43.2 → 6.0.0-alpha.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.
- package/LexicalEditorActions.js +10 -15
- package/LexicalEditorActions.js.map +1 -1
- package/components/LexicalColorPicker/LexicalColorPicker.js +72 -89
- package/components/LexicalColorPicker/LexicalColorPicker.js.map +1 -1
- package/components/LexicalColorPickerDropdown.js +12 -18
- package/components/LexicalColorPickerDropdown.js.map +1 -1
- package/components/TextAlignmentDropdown.js +39 -44
- package/components/TextAlignmentDropdown.js.map +1 -1
- package/index.js +1 -12
- package/index.js.map +1 -1
- package/package.json +6 -6
package/LexicalEditorActions.js
CHANGED
|
@@ -1,22 +1,17 @@
|
|
|
1
|
-
|
|
1
|
+
import { TextAlignmentAction } from "@webiny/lexical-editor";
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { LexicalColorPickerDropdown } from "./components/LexicalColorPickerDropdown";
|
|
4
|
+
import { FontColorAction } from "@webiny/lexical-editor";
|
|
5
|
+
import { TextAlignmentDropdown } from "./components/TextAlignmentDropdown";
|
|
2
6
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
Object.defineProperty(exports, "__esModule", {
|
|
5
|
-
value: true
|
|
6
|
-
});
|
|
7
|
-
exports.LexicalEditorActions = void 0;
|
|
8
|
-
var _lexicalEditor = require("@webiny/lexical-editor");
|
|
9
|
-
var _react = _interopRequireDefault(require("react"));
|
|
10
|
-
var _LexicalColorPickerDropdown = require("./components/LexicalColorPickerDropdown");
|
|
11
|
-
var _TextAlignmentDropdown = require("./components/TextAlignmentDropdown");
|
|
12
7
|
/*
|
|
13
8
|
* Lexical editor configuration and components with global composition scope
|
|
14
9
|
*/
|
|
15
|
-
|
|
16
|
-
return /*#__PURE__*/
|
|
17
|
-
element: /*#__PURE__*/
|
|
18
|
-
}), /*#__PURE__*/
|
|
19
|
-
element: /*#__PURE__*/
|
|
10
|
+
export const LexicalEditorActions = () => {
|
|
11
|
+
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(FontColorAction.ColorPicker, {
|
|
12
|
+
element: /*#__PURE__*/React.createElement(LexicalColorPickerDropdown, null)
|
|
13
|
+
}), /*#__PURE__*/React.createElement(TextAlignmentAction.TextAlignmentDropDown, {
|
|
14
|
+
element: /*#__PURE__*/React.createElement(TextAlignmentDropdown, null)
|
|
20
15
|
}));
|
|
21
16
|
};
|
|
22
17
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["TextAlignmentAction","React","LexicalColorPickerDropdown","FontColorAction","TextAlignmentDropdown","LexicalEditorActions","createElement","Fragment","ColorPicker","element","TextAlignmentDropDown"],"sources":["LexicalEditorActions.tsx"],"sourcesContent":["import { TextAlignmentAction } from \"@webiny/lexical-editor\";\nimport React from \"react\";\nimport { LexicalColorPickerDropdown } from \"~/components/LexicalColorPickerDropdown\";\nimport { FontColorAction } from \"@webiny/lexical-editor\";\nimport { TextAlignmentDropdown } from \"~/components/TextAlignmentDropdown\";\n\n/*\n * Lexical editor configuration and components with global composition scope\n */\nexport const LexicalEditorActions = () => {\n return (\n <>\n <FontColorAction.ColorPicker element={<LexicalColorPickerDropdown />} />\n <TextAlignmentAction.TextAlignmentDropDown element={<TextAlignmentDropdown />} />\n </>\n );\n};\n"],"mappings":"AAAA,SAASA,mBAAmB,QAAQ,wBAAwB;AAC5D,OAAOC,KAAK,MAAM,OAAO;AACzB,SAASC,0BAA0B;AACnC,SAASC,eAAe,QAAQ,wBAAwB;AACxD,SAASC,qBAAqB;;AAE9B;AACA;AACA;AACA,OAAO,MAAMC,oBAAoB,GAAGA,CAAA,KAAM;EACtC,oBACIJ,KAAA,CAAAK,aAAA,CAAAL,KAAA,CAAAM,QAAA,qBACIN,KAAA,CAAAK,aAAA,CAACH,eAAe,CAACK,WAAW;IAACC,OAAO,eAAER,KAAA,CAAAK,aAAA,CAACJ,0BAA0B,MAAE;EAAE,CAAE,CAAC,eACxED,KAAA,CAAAK,aAAA,CAACN,mBAAmB,CAACU,qBAAqB;IAACD,OAAO,eAAER,KAAA,CAAAK,aAAA,CAACF,qBAAqB,MAAE;EAAE,CAAE,CAClF,CAAC;AAEX,CAAC","ignoreList":[]}
|
|
@@ -1,23 +1,14 @@
|
|
|
1
|
-
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
2
|
+
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)."; }
|
|
3
|
+
import React, { useCallback, useState, useEffect, useMemo } from "react";
|
|
4
|
+
import { css } from "emotion";
|
|
5
|
+
import { usePageElements } from "@webiny/app-page-builder-elements/hooks/usePageElements";
|
|
6
|
+
import { ChromePicker } from "react-color";
|
|
7
|
+
import { Tooltip } from "@webiny/ui/Tooltip";
|
|
2
8
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
value: true
|
|
7
|
-
});
|
|
8
|
-
exports.LexicalColorPicker = void 0;
|
|
9
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
10
|
-
var _objectSpread3 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
11
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
12
|
-
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
13
|
-
var _react = _interopRequireWildcard(require("react"));
|
|
14
|
-
var _emotion = require("emotion");
|
|
15
|
-
var _usePageElements = require("@webiny/app-page-builder-elements/hooks/usePageElements");
|
|
16
|
-
var _reactColor = require("react-color");
|
|
17
|
-
var _Tooltip = require("@webiny/ui/Tooltip");
|
|
18
|
-
var _roundColor_lens24px = require("./round-color_lens-24px.svg");
|
|
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
|
|
20
|
-
var ColorPickerStyle = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV === "production" ? {
|
|
9
|
+
// Icons
|
|
10
|
+
import { ReactComponent as IconPalette } from "./round-color_lens-24px.svg";
|
|
11
|
+
const ColorPickerStyle = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
21
12
|
target: "ewrv11k2"
|
|
22
13
|
} : {
|
|
23
14
|
target: "ewrv11k2",
|
|
@@ -28,24 +19,24 @@ var ColorPickerStyle = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_E
|
|
|
28
19
|
} : {
|
|
29
20
|
name: "1tb6adp",
|
|
30
21
|
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"]} */",
|
|
22
|
+
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    boxSizing: \"content-box\"\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"]} */",
|
|
32
23
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
33
24
|
});
|
|
34
|
-
|
|
25
|
+
const ColorBox = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
35
26
|
target: "ewrv11k1"
|
|
36
27
|
} : {
|
|
37
28
|
target: "ewrv11k1",
|
|
38
29
|
label: "ColorBox"
|
|
39
30
|
})(process.env.NODE_ENV === "production" ? {
|
|
40
|
-
name: "
|
|
41
|
-
styles: "cursor:pointer;width:40px;height:40px;border-radius:50%;margin:5px;border:1px solid var(--mdc-theme-on-background);padding:3px"
|
|
31
|
+
name: "tujbiz",
|
|
32
|
+
styles: "cursor:pointer;width:40px;height:40px;border-radius:50%;margin:5px;border:1px solid var(--mdc-theme-on-background);padding:3px;box-sizing:content-box"
|
|
42
33
|
} : {
|
|
43
|
-
name: "
|
|
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"]} */",
|
|
34
|
+
name: "tujbiz",
|
|
35
|
+
styles: "cursor:pointer;width:40px;height:40px;border-radius:50%;margin:5px;border:1px solid var(--mdc-theme-on-background);padding:3px;box-sizing:content-box",
|
|
36
|
+
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    boxSizing: \"content-box\"\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"]} */",
|
|
46
37
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
47
38
|
});
|
|
48
|
-
|
|
39
|
+
const Color = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "production" ? {
|
|
49
40
|
target: "ewrv11k0"
|
|
50
41
|
} : {
|
|
51
42
|
target: "ewrv11k0",
|
|
@@ -77,28 +68,28 @@ var Color = /*#__PURE__*/(0, _base.default)("button", process.env.NODE_ENV === "
|
|
|
77
68
|
opacity: 1
|
|
78
69
|
}
|
|
79
70
|
}
|
|
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"]} */");
|
|
81
|
-
|
|
71
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LexicalColorPicker.tsx"],"names":[],"mappings":"AAgCc","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    boxSizing: \"content-box\"\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"]} */");
|
|
72
|
+
const iconPaletteStyle = css({
|
|
82
73
|
height: 20,
|
|
83
74
|
width: "100%",
|
|
84
75
|
marginTop: 1,
|
|
85
76
|
color: "var(--mdc-theme-secondary)"
|
|
86
77
|
});
|
|
87
|
-
|
|
78
|
+
const COLORS = {
|
|
88
79
|
lightGray: "hsla(0, 0%, 97%, 1)",
|
|
89
80
|
gray: "hsla(300, 2%, 92%, 1)",
|
|
90
81
|
darkGray: "hsla(0, 0%, 70%, 1)",
|
|
91
82
|
darkestGray: "hsla(0, 0%, 20%, 1)",
|
|
92
83
|
black: "hsla(208, 100%, 5%, 1)"
|
|
93
84
|
};
|
|
94
|
-
|
|
95
|
-
selectedColor:
|
|
85
|
+
const styles = {
|
|
86
|
+
selectedColor: css({
|
|
96
87
|
boxShadow: "inset 0px 0px 0px 10px var(--mdc-theme-secondary)",
|
|
97
88
|
button: {
|
|
98
89
|
border: "5px solid var(--mdc-theme-surface)"
|
|
99
90
|
}
|
|
100
91
|
}),
|
|
101
|
-
button:
|
|
92
|
+
button: css({
|
|
102
93
|
cursor: "pointer",
|
|
103
94
|
height: 30,
|
|
104
95
|
boxSizing: "border-box",
|
|
@@ -117,115 +108,107 @@ var styles = {
|
|
|
117
108
|
height: 16
|
|
118
109
|
}
|
|
119
110
|
}),
|
|
120
|
-
color:
|
|
111
|
+
color: css({
|
|
121
112
|
width: "40px",
|
|
122
113
|
height: "100%"
|
|
123
114
|
})
|
|
124
115
|
};
|
|
125
|
-
|
|
116
|
+
const chromePickerStyle = css({
|
|
126
117
|
width: "270px !important",
|
|
127
118
|
margin: "15px -15px -15px -15px"
|
|
128
119
|
});
|
|
129
|
-
|
|
120
|
+
const showPickerStyle = {
|
|
130
121
|
display: "block"
|
|
131
122
|
};
|
|
132
|
-
|
|
123
|
+
const hidePickerStyle = {
|
|
133
124
|
display: "none"
|
|
134
125
|
};
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
showPicker = _useState2[0],
|
|
142
|
-
setShowPicker = _useState2[1];
|
|
126
|
+
export const LexicalColorPicker = ({
|
|
127
|
+
value,
|
|
128
|
+
onChange,
|
|
129
|
+
onChangeComplete
|
|
130
|
+
}) => {
|
|
131
|
+
const [showPicker, setShowPicker] = useState(false);
|
|
143
132
|
// Either a custom color or a color coming from the theme object.
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
setActualSelectedColor = _useState4[1];
|
|
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 () {
|
|
133
|
+
const [actualSelectedColor, setActualSelectedColor] = useState(value || "#fff");
|
|
134
|
+
const [isThemeColor, setIsThemeColor] = useState(false);
|
|
135
|
+
useEffect(() => {
|
|
153
136
|
if (value) {
|
|
154
137
|
setActualSelectedColor(value);
|
|
155
138
|
}
|
|
156
139
|
}, [value]);
|
|
157
|
-
|
|
158
|
-
return
|
|
140
|
+
const getColorValue = useCallback((rgb, alpha) => {
|
|
141
|
+
return `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${alpha ?? rgb.a})`;
|
|
159
142
|
}, []);
|
|
160
|
-
|
|
143
|
+
const onColorChange = useCallback((color, event) => {
|
|
161
144
|
event.preventDefault();
|
|
162
145
|
// controls of the picker are updated as user moves the mouse
|
|
163
|
-
|
|
146
|
+
const customColor = getColorValue(color.rgb, color.rgb.a === 0 ? 1 : color.rgb.a);
|
|
164
147
|
setActualSelectedColor(customColor);
|
|
165
148
|
if (typeof onChange === "function") {
|
|
166
149
|
onChange(customColor);
|
|
167
150
|
}
|
|
168
151
|
}, [onChange]);
|
|
169
|
-
|
|
170
|
-
|
|
152
|
+
const onColorChangeComplete = useCallback(({
|
|
153
|
+
rgb
|
|
154
|
+
}, event) => {
|
|
171
155
|
event.preventDefault();
|
|
172
|
-
|
|
156
|
+
const color = getColorValue(rgb, rgb.a === 0 ? 1 : rgb.a);
|
|
173
157
|
setActualSelectedColor(color);
|
|
174
158
|
onChangeComplete(color);
|
|
175
159
|
}, [onChangeComplete]);
|
|
176
|
-
|
|
160
|
+
const togglePicker = useCallback(e => {
|
|
177
161
|
e.stopPropagation();
|
|
178
|
-
setShowPicker(
|
|
179
|
-
return !state;
|
|
180
|
-
});
|
|
162
|
+
setShowPicker(state => !state);
|
|
181
163
|
}, []);
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
return Object.keys(colors).reduce(
|
|
186
|
-
return
|
|
164
|
+
const pageElements = usePageElements();
|
|
165
|
+
const themeColors = useMemo(() => {
|
|
166
|
+
const colors = pageElements.theme?.styles?.colors ?? {};
|
|
167
|
+
return Object.keys(colors).reduce((acc, key) => {
|
|
168
|
+
return {
|
|
169
|
+
...acc,
|
|
170
|
+
[key]: colors[key]
|
|
171
|
+
};
|
|
187
172
|
}, {});
|
|
188
173
|
}, [pageElements.theme?.styles?.colors]);
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
return themeColors[key] === value;
|
|
192
|
-
});
|
|
174
|
+
useEffect(() => {
|
|
175
|
+
const isThemeColor = Object.keys(themeColors).some(key => themeColors[key] === value);
|
|
193
176
|
setIsThemeColor(isThemeColor);
|
|
194
177
|
}, [themeColors, value]);
|
|
195
|
-
return /*#__PURE__*/
|
|
196
|
-
|
|
197
|
-
return /*#__PURE__*/
|
|
178
|
+
return /*#__PURE__*/React.createElement(ColorPickerStyle, null, Object.keys(themeColors).map((key, index) => {
|
|
179
|
+
const color = themeColors[key];
|
|
180
|
+
return /*#__PURE__*/React.createElement(ColorBox, {
|
|
198
181
|
key: index,
|
|
199
182
|
className: color === value ? styles.selectedColor : ""
|
|
200
|
-
}, /*#__PURE__*/
|
|
201
|
-
content: /*#__PURE__*/
|
|
183
|
+
}, /*#__PURE__*/React.createElement(Tooltip, {
|
|
184
|
+
content: /*#__PURE__*/React.createElement("span", null, color),
|
|
202
185
|
placement: "bottom"
|
|
203
|
-
}, /*#__PURE__*/
|
|
186
|
+
}, /*#__PURE__*/React.createElement(Color, {
|
|
204
187
|
style: {
|
|
205
188
|
backgroundColor: color
|
|
206
189
|
},
|
|
207
|
-
onClick:
|
|
190
|
+
onClick: () => {
|
|
208
191
|
// With page elements implementation, we want to store the color key and
|
|
209
192
|
// then the actual color will be retrieved from the theme object.
|
|
210
|
-
|
|
193
|
+
const colors = pageElements.theme?.styles?.colors;
|
|
211
194
|
onChangeComplete(colors[key], key);
|
|
212
195
|
}
|
|
213
196
|
})));
|
|
214
|
-
}), /*#__PURE__*/
|
|
197
|
+
}), /*#__PURE__*/React.createElement(ColorBox, {
|
|
215
198
|
className: value && !isThemeColor ? styles.selectedColor : ""
|
|
216
|
-
}, /*#__PURE__*/
|
|
217
|
-
content: /*#__PURE__*/
|
|
199
|
+
}, /*#__PURE__*/React.createElement(Tooltip, {
|
|
200
|
+
content: /*#__PURE__*/React.createElement("span", null, "Color picker"),
|
|
218
201
|
placement: "bottom"
|
|
219
|
-
}, /*#__PURE__*/
|
|
202
|
+
}, /*#__PURE__*/React.createElement(Color, {
|
|
220
203
|
style: {
|
|
221
204
|
backgroundColor: isThemeColor ? "#fff" : value
|
|
222
205
|
},
|
|
223
206
|
onClick: togglePicker
|
|
224
|
-
}, /*#__PURE__*/
|
|
207
|
+
}, /*#__PURE__*/React.createElement(IconPalette, {
|
|
225
208
|
className: iconPaletteStyle
|
|
226
|
-
})))), /*#__PURE__*/
|
|
209
|
+
})))), /*#__PURE__*/React.createElement("div", {
|
|
227
210
|
style: showPicker ? showPickerStyle : hidePickerStyle
|
|
228
|
-
}, /*#__PURE__*/
|
|
211
|
+
}, /*#__PURE__*/React.createElement(ChromePicker, {
|
|
229
212
|
className: chromePickerStyle,
|
|
230
213
|
color: actualSelectedColor,
|
|
231
214
|
disableAlpha: true,
|
|
@@ -1 +1 @@
|
|
|
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":[]}
|
|
1
|
+
{"version":3,"names":["React","useCallback","useState","useEffect","useMemo","css","usePageElements","ChromePicker","Tooltip","ReactComponent","IconPalette","ColorPickerStyle","_styled","process","env","NODE_ENV","target","label","name","styles","map","toString","_EMOTION_STRINGIFIED_CSS_ERROR__","ColorBox","Color","cursor","width","height","transition","borderColor","display","alignItems","borderRadius","content","position","top","left","zIndex","opacity","transform","boxShadow","iconPaletteStyle","marginTop","color","COLORS","lightGray","gray","darkGray","darkestGray","black","selectedColor","button","border","boxSizing","backgroundColor","outline","chromePickerStyle","margin","showPickerStyle","hidePickerStyle","LexicalColorPicker","value","onChange","onChangeComplete","showPicker","setShowPicker","actualSelectedColor","setActualSelectedColor","isThemeColor","setIsThemeColor","getColorValue","rgb","alpha","r","g","b","a","onColorChange","event","preventDefault","customColor","onColorChangeComplete","togglePicker","e","stopPropagation","state","pageElements","themeColors","colors","theme","Object","keys","reduce","acc","key","some","createElement","index","className","placement","style","onClick","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 boxSizing: \"content-box\"\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":[]}
|
|
@@ -1,29 +1,23 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
var _emotion = require("emotion");
|
|
12
|
-
var LexicalColorPickerDropdown = exports.LexicalColorPickerDropdown = function LexicalColorPickerDropdown() {
|
|
13
|
-
var _useFontColorPicker = (0, _lexicalEditor.useFontColorPicker)(),
|
|
14
|
-
value = _useFontColorPicker.value,
|
|
15
|
-
applyColor = _useFontColorPicker.applyColor;
|
|
16
|
-
var buttonColorSelection = (0, _emotion.css)({
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { useFontColorPicker, DropDown } from "@webiny/lexical-editor";
|
|
3
|
+
import { LexicalColorPicker } from "./LexicalColorPicker/LexicalColorPicker";
|
|
4
|
+
import { css } from "emotion";
|
|
5
|
+
export const LexicalColorPickerDropdown = () => {
|
|
6
|
+
const {
|
|
7
|
+
value,
|
|
8
|
+
applyColor
|
|
9
|
+
} = useFontColorPicker();
|
|
10
|
+
const buttonColorSelection = css({
|
|
17
11
|
borderBottom: "3px solid " + value
|
|
18
12
|
});
|
|
19
|
-
return /*#__PURE__*/
|
|
13
|
+
return /*#__PURE__*/React.createElement(DropDown, {
|
|
20
14
|
buttonClassName: "toolbar-item color-picker",
|
|
21
15
|
buttonAriaLabel: "Formatting options for text color",
|
|
22
16
|
buttonIconClassName: "icon font-color " + buttonColorSelection,
|
|
23
17
|
stopCloseOnClickSelf: true,
|
|
24
18
|
disabled: false,
|
|
25
19
|
showScroll: false
|
|
26
|
-
}, /*#__PURE__*/
|
|
20
|
+
}, /*#__PURE__*/React.createElement(LexicalColorPicker, {
|
|
27
21
|
value: value,
|
|
28
22
|
onChangeComplete: applyColor
|
|
29
23
|
}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["React","useFontColorPicker","DropDown","LexicalColorPicker","css","LexicalColorPickerDropdown","value","applyColor","buttonColorSelection","borderBottom","createElement","buttonClassName","buttonAriaLabel","buttonIconClassName","stopCloseOnClickSelf","disabled","showScroll","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,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,kBAAkB,EAAEC,QAAQ,QAAQ,wBAAwB;AACrE,SAASC,kBAAkB;AAC3B,SAASC,GAAG,QAAQ,SAAS;AAE7B,OAAO,MAAMC,0BAA0B,GAAGA,CAAA,KAAM;EAC5C,MAAM;IAAEC,KAAK;IAAEC;EAAW,CAAC,GAAGN,kBAAkB,CAAC,CAAC;EAElD,MAAMO,oBAAoB,GAAGJ,GAAG,CAAC;IAC7BK,YAAY,EAAE,YAAY,GAAGH;EACjC,CAAC,CAAC;EAEF,oBACIN,KAAA,CAAAU,aAAA,CAACR,QAAQ;IACLS,eAAe,EAAC,2BAA2B;IAC3CC,eAAe,EAAE,mCAAoC;IACrDC,mBAAmB,EAAE,kBAAkB,GAAGL,oBAAqB;IAC/DM,oBAAoB,EAAE,IAAK;IAC3BC,QAAQ,EAAE,KAAM;IAChBC,UAAU,EAAE;EAAM,gBAElBhB,KAAA,CAAAU,aAAA,CAACP,kBAAkB;IAACG,KAAK,EAAEA,KAAM;IAACW,gBAAgB,EAAEV;EAAW,CAAE,CAC3D,CAAC;AAEnB,CAAC","ignoreList":[]}
|
|
@@ -1,81 +1,76 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
outdentText = _useTextAlignmentActi.outdentText,
|
|
16
|
-
indentText = _useTextAlignmentActi.indentText;
|
|
17
|
-
var isRTL = (0, _useCurrentSelection.useDeriveValueFromSelection)(function (_ref) {
|
|
18
|
-
var rangeSelection = _ref.rangeSelection;
|
|
19
|
-
return rangeSelection ? (0, _selection.$isParentElementRTL)(rangeSelection) : false;
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { $isParentElementRTL } from "@lexical/selection";
|
|
3
|
+
import { Divider, DropDown, DropDownItem, useTextAlignmentAction } from "@webiny/lexical-editor";
|
|
4
|
+
import { useDeriveValueFromSelection } from "@webiny/lexical-editor/hooks/useCurrentSelection";
|
|
5
|
+
export const TextAlignmentDropdown = () => {
|
|
6
|
+
const {
|
|
7
|
+
applyTextAlignment,
|
|
8
|
+
outdentText,
|
|
9
|
+
indentText
|
|
10
|
+
} = useTextAlignmentAction();
|
|
11
|
+
const isRTL = useDeriveValueFromSelection(({
|
|
12
|
+
rangeSelection
|
|
13
|
+
}) => {
|
|
14
|
+
return rangeSelection ? $isParentElementRTL(rangeSelection) : false;
|
|
20
15
|
});
|
|
21
|
-
return /*#__PURE__*/
|
|
16
|
+
return /*#__PURE__*/React.createElement(DropDown, {
|
|
22
17
|
buttonLabel: "Align",
|
|
23
18
|
buttonIconClassName: "icon left-align",
|
|
24
19
|
buttonClassName: "toolbar-item spaced alignment",
|
|
25
20
|
buttonAriaLabel: "Formatting options for text alignment"
|
|
26
|
-
}, /*#__PURE__*/
|
|
27
|
-
onClick:
|
|
21
|
+
}, /*#__PURE__*/React.createElement(DropDownItem, {
|
|
22
|
+
onClick: () => {
|
|
28
23
|
applyTextAlignment("left");
|
|
29
24
|
},
|
|
30
25
|
className: "item"
|
|
31
|
-
}, /*#__PURE__*/
|
|
26
|
+
}, /*#__PURE__*/React.createElement("i", {
|
|
32
27
|
className: "icon left-align"
|
|
33
|
-
}), /*#__PURE__*/
|
|
28
|
+
}), /*#__PURE__*/React.createElement("span", {
|
|
34
29
|
className: "text"
|
|
35
|
-
}, "Left Align")), /*#__PURE__*/
|
|
36
|
-
onClick:
|
|
30
|
+
}, "Left Align")), /*#__PURE__*/React.createElement(DropDownItem, {
|
|
31
|
+
onClick: () => {
|
|
37
32
|
applyTextAlignment("center");
|
|
38
33
|
},
|
|
39
34
|
className: "item"
|
|
40
|
-
}, /*#__PURE__*/
|
|
35
|
+
}, /*#__PURE__*/React.createElement("i", {
|
|
41
36
|
className: "icon center-align"
|
|
42
|
-
}), /*#__PURE__*/
|
|
37
|
+
}), /*#__PURE__*/React.createElement("span", {
|
|
43
38
|
className: "text"
|
|
44
|
-
}, "Center Align")), /*#__PURE__*/
|
|
45
|
-
onClick:
|
|
39
|
+
}, "Center Align")), /*#__PURE__*/React.createElement(DropDownItem, {
|
|
40
|
+
onClick: () => {
|
|
46
41
|
applyTextAlignment("right");
|
|
47
42
|
},
|
|
48
43
|
className: "item"
|
|
49
|
-
}, /*#__PURE__*/
|
|
44
|
+
}, /*#__PURE__*/React.createElement("i", {
|
|
50
45
|
className: "icon right-align"
|
|
51
|
-
}), /*#__PURE__*/
|
|
46
|
+
}), /*#__PURE__*/React.createElement("span", {
|
|
52
47
|
className: "text"
|
|
53
|
-
}, "Right Align")), /*#__PURE__*/
|
|
54
|
-
onClick:
|
|
48
|
+
}, "Right Align")), /*#__PURE__*/React.createElement(DropDownItem, {
|
|
49
|
+
onClick: () => {
|
|
55
50
|
applyTextAlignment("justify");
|
|
56
51
|
},
|
|
57
52
|
className: "item"
|
|
58
|
-
}, /*#__PURE__*/
|
|
53
|
+
}, /*#__PURE__*/React.createElement("i", {
|
|
59
54
|
className: "icon justify-align"
|
|
60
|
-
}), /*#__PURE__*/
|
|
55
|
+
}), /*#__PURE__*/React.createElement("span", {
|
|
61
56
|
className: "text"
|
|
62
|
-
}, "Justify Align")), /*#__PURE__*/
|
|
63
|
-
onClick:
|
|
57
|
+
}, "Justify Align")), /*#__PURE__*/React.createElement(Divider, null), /*#__PURE__*/React.createElement(DropDownItem, {
|
|
58
|
+
onClick: () => {
|
|
64
59
|
outdentText();
|
|
65
60
|
},
|
|
66
61
|
className: "item"
|
|
67
|
-
}, /*#__PURE__*/
|
|
62
|
+
}, /*#__PURE__*/React.createElement("i", {
|
|
68
63
|
className: "icon " + (isRTL ? "indent" : "outdent")
|
|
69
|
-
}), /*#__PURE__*/
|
|
64
|
+
}), /*#__PURE__*/React.createElement("span", {
|
|
70
65
|
className: "text"
|
|
71
|
-
}, "Outdent")), /*#__PURE__*/
|
|
72
|
-
onClick:
|
|
66
|
+
}, "Outdent")), /*#__PURE__*/React.createElement(DropDownItem, {
|
|
67
|
+
onClick: () => {
|
|
73
68
|
indentText();
|
|
74
69
|
},
|
|
75
70
|
className: "item"
|
|
76
|
-
}, /*#__PURE__*/
|
|
71
|
+
}, /*#__PURE__*/React.createElement("i", {
|
|
77
72
|
className: "icon " + (isRTL ? "outdent" : "indent")
|
|
78
|
-
}), /*#__PURE__*/
|
|
73
|
+
}), /*#__PURE__*/React.createElement("span", {
|
|
79
74
|
className: "text"
|
|
80
75
|
}, "Indent")));
|
|
81
76
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["React","$isParentElementRTL","Divider","DropDown","DropDownItem","useTextAlignmentAction","useDeriveValueFromSelection","TextAlignmentDropdown","applyTextAlignment","outdentText","indentText","isRTL","rangeSelection","createElement","buttonLabel","buttonIconClassName","buttonClassName","buttonAriaLabel","onClick","className"],"sources":["TextAlignmentDropdown.tsx"],"sourcesContent":["import React from \"react\";\nimport { $isParentElementRTL } from \"@lexical/selection\";\nimport { Divider, DropDown, DropDownItem, useTextAlignmentAction } from \"@webiny/lexical-editor\";\nimport { useDeriveValueFromSelection } from \"@webiny/lexical-editor/hooks/useCurrentSelection\";\n\nexport const TextAlignmentDropdown = () => {\n const { applyTextAlignment, outdentText, indentText } = useTextAlignmentAction();\n\n const isRTL = useDeriveValueFromSelection(({ rangeSelection }) => {\n return rangeSelection ? $isParentElementRTL(rangeSelection) : false;\n });\n\n return (\n <DropDown\n buttonLabel=\"Align\"\n buttonIconClassName=\"icon left-align\"\n buttonClassName=\"toolbar-item spaced alignment\"\n buttonAriaLabel=\"Formatting options for text alignment\"\n >\n <DropDownItem\n onClick={() => {\n applyTextAlignment(\"left\");\n }}\n className=\"item\"\n >\n <i className=\"icon left-align\" />\n <span className=\"text\">Left Align</span>\n </DropDownItem>\n <DropDownItem\n onClick={() => {\n applyTextAlignment(\"center\");\n }}\n className=\"item\"\n >\n <i className=\"icon center-align\" />\n <span className=\"text\">Center Align</span>\n </DropDownItem>\n <DropDownItem\n onClick={() => {\n applyTextAlignment(\"right\");\n }}\n className=\"item\"\n >\n <i className=\"icon right-align\" />\n <span className=\"text\">Right Align</span>\n </DropDownItem>\n <DropDownItem\n onClick={() => {\n applyTextAlignment(\"justify\");\n }}\n className=\"item\"\n >\n <i className=\"icon justify-align\" />\n <span className=\"text\">Justify Align</span>\n </DropDownItem>\n <Divider />\n <DropDownItem\n onClick={() => {\n outdentText();\n }}\n className=\"item\"\n >\n <i className={\"icon \" + (isRTL ? \"indent\" : \"outdent\")} />\n <span className=\"text\">Outdent</span>\n </DropDownItem>\n <DropDownItem\n onClick={() => {\n indentText();\n }}\n className=\"item\"\n >\n <i className={\"icon \" + (isRTL ? \"outdent\" : \"indent\")} />\n <span className=\"text\">Indent</span>\n </DropDownItem>\n </DropDown>\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,mBAAmB,QAAQ,oBAAoB;AACxD,SAASC,OAAO,EAAEC,QAAQ,EAAEC,YAAY,EAAEC,sBAAsB,QAAQ,wBAAwB;AAChG,SAASC,2BAA2B,QAAQ,kDAAkD;AAE9F,OAAO,MAAMC,qBAAqB,GAAGA,CAAA,KAAM;EACvC,MAAM;IAAEC,kBAAkB;IAAEC,WAAW;IAAEC;EAAW,CAAC,GAAGL,sBAAsB,CAAC,CAAC;EAEhF,MAAMM,KAAK,GAAGL,2BAA2B,CAAC,CAAC;IAAEM;EAAe,CAAC,KAAK;IAC9D,OAAOA,cAAc,GAAGX,mBAAmB,CAACW,cAAc,CAAC,GAAG,KAAK;EACvE,CAAC,CAAC;EAEF,oBACIZ,KAAA,CAAAa,aAAA,CAACV,QAAQ;IACLW,WAAW,EAAC,OAAO;IACnBC,mBAAmB,EAAC,iBAAiB;IACrCC,eAAe,EAAC,+BAA+B;IAC/CC,eAAe,EAAC;EAAuC,gBAEvDjB,KAAA,CAAAa,aAAA,CAACT,YAAY;IACTc,OAAO,EAAEA,CAAA,KAAM;MACXV,kBAAkB,CAAC,MAAM,CAAC;IAC9B,CAAE;IACFW,SAAS,EAAC;EAAM,gBAEhBnB,KAAA,CAAAa,aAAA;IAAGM,SAAS,EAAC;EAAiB,CAAE,CAAC,eACjCnB,KAAA,CAAAa,aAAA;IAAMM,SAAS,EAAC;EAAM,GAAC,YAAgB,CAC7B,CAAC,eACfnB,KAAA,CAAAa,aAAA,CAACT,YAAY;IACTc,OAAO,EAAEA,CAAA,KAAM;MACXV,kBAAkB,CAAC,QAAQ,CAAC;IAChC,CAAE;IACFW,SAAS,EAAC;EAAM,gBAEhBnB,KAAA,CAAAa,aAAA;IAAGM,SAAS,EAAC;EAAmB,CAAE,CAAC,eACnCnB,KAAA,CAAAa,aAAA;IAAMM,SAAS,EAAC;EAAM,GAAC,cAAkB,CAC/B,CAAC,eACfnB,KAAA,CAAAa,aAAA,CAACT,YAAY;IACTc,OAAO,EAAEA,CAAA,KAAM;MACXV,kBAAkB,CAAC,OAAO,CAAC;IAC/B,CAAE;IACFW,SAAS,EAAC;EAAM,gBAEhBnB,KAAA,CAAAa,aAAA;IAAGM,SAAS,EAAC;EAAkB,CAAE,CAAC,eAClCnB,KAAA,CAAAa,aAAA;IAAMM,SAAS,EAAC;EAAM,GAAC,aAAiB,CAC9B,CAAC,eACfnB,KAAA,CAAAa,aAAA,CAACT,YAAY;IACTc,OAAO,EAAEA,CAAA,KAAM;MACXV,kBAAkB,CAAC,SAAS,CAAC;IACjC,CAAE;IACFW,SAAS,EAAC;EAAM,gBAEhBnB,KAAA,CAAAa,aAAA;IAAGM,SAAS,EAAC;EAAoB,CAAE,CAAC,eACpCnB,KAAA,CAAAa,aAAA;IAAMM,SAAS,EAAC;EAAM,GAAC,eAAmB,CAChC,CAAC,eACfnB,KAAA,CAAAa,aAAA,CAACX,OAAO,MAAE,CAAC,eACXF,KAAA,CAAAa,aAAA,CAACT,YAAY;IACTc,OAAO,EAAEA,CAAA,KAAM;MACXT,WAAW,CAAC,CAAC;IACjB,CAAE;IACFU,SAAS,EAAC;EAAM,gBAEhBnB,KAAA,CAAAa,aAAA;IAAGM,SAAS,EAAE,OAAO,IAAIR,KAAK,GAAG,QAAQ,GAAG,SAAS;EAAE,CAAE,CAAC,eAC1DX,KAAA,CAAAa,aAAA;IAAMM,SAAS,EAAC;EAAM,GAAC,SAAa,CAC1B,CAAC,eACfnB,KAAA,CAAAa,aAAA,CAACT,YAAY;IACTc,OAAO,EAAEA,CAAA,KAAM;MACXR,UAAU,CAAC,CAAC;IAChB,CAAE;IACFS,SAAS,EAAC;EAAM,gBAEhBnB,KAAA,CAAAa,aAAA;IAAGM,SAAS,EAAE,OAAO,IAAIR,KAAK,GAAG,SAAS,GAAG,QAAQ;EAAE,CAAE,CAAC,eAC1DX,KAAA,CAAAa,aAAA;IAAMM,SAAS,EAAC;EAAM,GAAC,QAAY,CACzB,CACR,CAAC;AAEnB,CAAC","ignoreList":[]}
|
package/index.js
CHANGED
|
@@ -1,14 +1,3 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
Object.defineProperty(exports, "LexicalEditorActions", {
|
|
7
|
-
enumerable: true,
|
|
8
|
-
get: function get() {
|
|
9
|
-
return _LexicalEditorActions.LexicalEditorActions;
|
|
10
|
-
}
|
|
11
|
-
});
|
|
12
|
-
var _LexicalEditorActions = require("./LexicalEditorActions");
|
|
1
|
+
export { LexicalEditorActions } from "./LexicalEditorActions";
|
|
13
2
|
|
|
14
3
|
//# sourceMappingURL=index.js.map
|
package/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["LexicalEditorActions"],"sources":["index.ts"],"sourcesContent":["export { LexicalEditorActions } from \"~/LexicalEditorActions\";\n"],"mappings":"AAAA,SAASA,oBAAoB","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webiny/lexical-editor-actions",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "6.0.0-alpha.0",
|
|
4
4
|
"dependencies": {
|
|
5
5
|
"@emotion/styled": "11.10.6",
|
|
6
6
|
"@lexical/selection": "0.23.1",
|
|
7
|
-
"@webiny/app-page-builder-elements": "
|
|
8
|
-
"@webiny/lexical-editor": "
|
|
9
|
-
"@webiny/ui": "
|
|
7
|
+
"@webiny/app-page-builder-elements": "6.0.0-alpha.0",
|
|
8
|
+
"@webiny/lexical-editor": "6.0.0-alpha.0",
|
|
9
|
+
"@webiny/ui": "6.0.0-alpha.0",
|
|
10
10
|
"emotion": "10.0.27",
|
|
11
11
|
"react": "18.2.0",
|
|
12
12
|
"react-color": "2.19.3",
|
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
},
|
|
15
15
|
"devDependencies": {
|
|
16
16
|
"@types/react-color": "2.17.11",
|
|
17
|
-
"@webiny/project-utils": "
|
|
17
|
+
"@webiny/project-utils": "6.0.0-alpha.0"
|
|
18
18
|
},
|
|
19
19
|
"publishConfig": {
|
|
20
20
|
"access": "public",
|
|
@@ -24,5 +24,5 @@
|
|
|
24
24
|
"build": "node ../cli/bin.js run build",
|
|
25
25
|
"watch": "node ../cli/bin.js run watch"
|
|
26
26
|
},
|
|
27
|
-
"gitHead": "
|
|
27
|
+
"gitHead": "a5b28fed7a242d8f56712197a8ea83aa6d2ed101"
|
|
28
28
|
}
|