@strapi/plugin-color-picker 0.0.0-next.f8af92b375dc730ba47ed2117f25df893aae696c → 0.0.0-next.f93d6eabe52aa7681655cfa08eedbc3708dbb90d
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/LICENSE +34 -12
- package/dist/admin/components/ColorPickerIcon.js +31 -0
- package/dist/admin/components/ColorPickerIcon.js.map +1 -0
- package/dist/admin/components/ColorPickerIcon.mjs +29 -0
- package/dist/admin/components/ColorPickerIcon.mjs.map +1 -0
- package/dist/admin/components/ColorPickerInput.js +199 -0
- package/dist/admin/components/ColorPickerInput.js.map +1 -0
- package/dist/admin/components/ColorPickerInput.mjs +178 -0
- package/dist/admin/components/ColorPickerInput.mjs.map +1 -0
- package/dist/admin/index.js +107 -8
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/index.mjs +102 -8
- package/dist/admin/index.mjs.map +1 -1
- package/dist/admin/pluginId.js +6 -0
- package/dist/admin/pluginId.js.map +1 -0
- package/dist/admin/pluginId.mjs +4 -0
- package/dist/admin/pluginId.mjs.map +1 -0
- package/dist/admin/src/components/ColorPickerInput.d.ts +3 -28
- package/dist/admin/src/components/tests/ColorPickerInput.test.d.ts +1 -0
- package/dist/admin/src/utils/prefixPluginTranslations.d.ts +3 -0
- package/dist/admin/translations/cs.json.js +17 -0
- package/dist/admin/translations/cs.json.js.map +1 -0
- package/dist/admin/translations/cs.json.mjs +15 -0
- package/dist/admin/translations/cs.json.mjs.map +1 -0
- package/dist/admin/translations/en.json.js +20 -0
- package/dist/admin/translations/en.json.js.map +1 -0
- package/dist/admin/translations/en.json.mjs +18 -0
- package/dist/admin/translations/en.json.mjs.map +1 -0
- package/dist/admin/translations/ru.json.js +20 -0
- package/dist/admin/translations/ru.json.js.map +1 -0
- package/dist/admin/translations/ru.json.mjs +18 -0
- package/dist/admin/translations/ru.json.mjs.map +1 -0
- package/dist/admin/translations/sv.json.js +17 -0
- package/dist/admin/translations/sv.json.js.map +1 -0
- package/dist/admin/translations/sv.json.mjs +15 -0
- package/dist/admin/translations/sv.json.mjs.map +1 -0
- package/dist/admin/translations/tr.json.js +17 -0
- package/dist/admin/translations/tr.json.js.map +1 -0
- package/dist/admin/translations/tr.json.mjs +15 -0
- package/dist/admin/translations/tr.json.mjs.map +1 -0
- package/dist/admin/translations/uk.json.js +20 -0
- package/dist/admin/translations/uk.json.js.map +1 -0
- package/dist/admin/translations/uk.json.mjs +18 -0
- package/dist/admin/translations/uk.json.mjs.map +1 -0
- package/dist/admin/translations/zh.json.js +17 -0
- package/dist/admin/translations/zh.json.js.map +1 -0
- package/dist/admin/translations/zh.json.mjs +15 -0
- package/dist/admin/translations/zh.json.mjs.map +1 -0
- package/dist/admin/utils/getTrad.js +8 -0
- package/dist/admin/utils/getTrad.js.map +1 -0
- package/dist/admin/utils/getTrad.mjs +6 -0
- package/dist/admin/utils/getTrad.mjs.map +1 -0
- package/dist/admin/utils/prefixPluginTranslations.js +11 -0
- package/dist/admin/utils/prefixPluginTranslations.js.map +1 -0
- package/dist/admin/utils/prefixPluginTranslations.mjs +9 -0
- package/dist/admin/utils/prefixPluginTranslations.mjs.map +1 -0
- package/dist/server/index.js +7 -10
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +6 -12
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/register.js +12 -0
- package/dist/server/register.js.map +1 -0
- package/dist/server/register.mjs +10 -0
- package/dist/server/register.mjs.map +1 -0
- package/package.json +24 -24
- package/dist/_chunks/ColorPickerInput-0lOoTrf0.js +0 -206
- package/dist/_chunks/ColorPickerInput-0lOoTrf0.js.map +0 -1
- package/dist/_chunks/ColorPickerInput-fKB6YXW8.mjs +0 -185
- package/dist/_chunks/ColorPickerInput-fKB6YXW8.mjs.map +0 -1
- package/dist/_chunks/cs-4GdZY0p6.js +0 -16
- package/dist/_chunks/cs-4GdZY0p6.js.map +0 -1
- package/dist/_chunks/cs-A2xRj-2-.mjs +0 -16
- package/dist/_chunks/cs-A2xRj-2-.mjs.map +0 -1
- package/dist/_chunks/en-L6ZZWDJv.mjs +0 -19
- package/dist/_chunks/en-L6ZZWDJv.mjs.map +0 -1
- package/dist/_chunks/en-WeRHjVEB.js +0 -19
- package/dist/_chunks/en-WeRHjVEB.js.map +0 -1
- package/dist/_chunks/index-OJYEuoCq.js +0 -117
- package/dist/_chunks/index-OJYEuoCq.js.map +0 -1
- package/dist/_chunks/index-uOrtnJpz.mjs +0 -116
- package/dist/_chunks/index-uOrtnJpz.mjs.map +0 -1
- package/dist/_chunks/ru-LLXYEOwl.mjs +0 -19
- package/dist/_chunks/ru-LLXYEOwl.mjs.map +0 -1
- package/dist/_chunks/ru-UXN_ByI9.js +0 -19
- package/dist/_chunks/ru-UXN_ByI9.js.map +0 -1
- package/dist/_chunks/sv-3-Yk9bKb.js +0 -16
- package/dist/_chunks/sv-3-Yk9bKb.js.map +0 -1
- package/dist/_chunks/sv-QqRPNQLw.mjs +0 -16
- package/dist/_chunks/sv-QqRPNQLw.mjs.map +0 -1
- package/dist/_chunks/tr-AbD-f8F0.js +0 -16
- package/dist/_chunks/tr-AbD-f8F0.js.map +0 -1
- package/dist/_chunks/tr-qYGSw8gH.mjs +0 -16
- package/dist/_chunks/tr-qYGSw8gH.mjs.map +0 -1
- package/dist/_chunks/zh-c23gv_oM.js +0 -16
- package/dist/_chunks/zh-c23gv_oM.js.map +0 -1
- package/dist/_chunks/zh-fPTOIT6s.mjs +0 -16
- package/dist/_chunks/zh-fPTOIT6s.mjs.map +0 -1
- package/dist/admin/src/hooks/useComposeRefs.d.ts +0 -29
- package/strapi-server.js +0 -3
|
@@ -1,185 +0,0 @@
|
|
|
1
|
-
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
-
import * as React from "react";
|
|
3
|
-
import { BaseButton, Popover, Field, Flex, FieldLabel, Typography, FocusTrap, Box, FieldInput, FieldHint, FieldError } from "@strapi/design-system";
|
|
4
|
-
import { CarretDown } from "@strapi/icons";
|
|
5
|
-
import { HexColorPicker } from "react-colorful";
|
|
6
|
-
import { useIntl } from "react-intl";
|
|
7
|
-
import styled from "styled-components";
|
|
8
|
-
import { g as getTrad } from "./index-uOrtnJpz.mjs";
|
|
9
|
-
import "@strapi/helper-plugin";
|
|
10
|
-
function setRef(ref, value) {
|
|
11
|
-
if (typeof ref === "function") {
|
|
12
|
-
ref(value);
|
|
13
|
-
} else if (ref !== null && ref !== void 0) {
|
|
14
|
-
ref.current = value;
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
function composeRefs(...refs) {
|
|
18
|
-
return (node) => refs.forEach((ref) => setRef(ref, node));
|
|
19
|
-
}
|
|
20
|
-
function useComposedRefs(...refs) {
|
|
21
|
-
return React.useCallback(composeRefs(...refs), refs);
|
|
22
|
-
}
|
|
23
|
-
const ColorPreview = styled.div`
|
|
24
|
-
border-radius: 50%;
|
|
25
|
-
width: 20px;
|
|
26
|
-
height: 20px;
|
|
27
|
-
margin-right: 10px;
|
|
28
|
-
background-color: ${(props) => props.color};
|
|
29
|
-
border: 1px solid rgba(0, 0, 0, 0.1);
|
|
30
|
-
`;
|
|
31
|
-
const ColorPicker = styled(HexColorPicker)`
|
|
32
|
-
&& {
|
|
33
|
-
width: 100%;
|
|
34
|
-
aspect-ratio: 1.5;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
.react-colorful__pointer {
|
|
38
|
-
width: ${({ theme }) => theme.spaces[3]};
|
|
39
|
-
height: ${({ theme }) => theme.spaces[3]};
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
.react-colorful__saturation {
|
|
43
|
-
border-radius: ${({ theme }) => theme.spaces[1]};
|
|
44
|
-
border-bottom: none;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
.react-colorful__hue {
|
|
48
|
-
border-radius: 10px;
|
|
49
|
-
height: ${({ theme }) => theme.spaces[3]};
|
|
50
|
-
margin-top: ${({ theme }) => theme.spaces[2]};
|
|
51
|
-
}
|
|
52
|
-
`;
|
|
53
|
-
const ColorPickerToggle = styled(BaseButton)`
|
|
54
|
-
display: flex;
|
|
55
|
-
justify-content: space-between;
|
|
56
|
-
align-items: center;
|
|
57
|
-
|
|
58
|
-
svg {
|
|
59
|
-
width: ${({ theme }) => theme.spaces[2]};
|
|
60
|
-
height: ${({ theme }) => theme.spaces[2]};
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
svg > path {
|
|
64
|
-
fill: ${({ theme }) => theme.colors.neutral500};
|
|
65
|
-
justify-self: flex-end;
|
|
66
|
-
}
|
|
67
|
-
`;
|
|
68
|
-
const ColorPickerPopover = styled(Popover)`
|
|
69
|
-
padding: ${({ theme }) => theme.spaces[2]};
|
|
70
|
-
min-height: 270px;
|
|
71
|
-
`;
|
|
72
|
-
const ColorPickerInput = React.forwardRef(
|
|
73
|
-
({
|
|
74
|
-
attribute,
|
|
75
|
-
description,
|
|
76
|
-
disabled = false,
|
|
77
|
-
error,
|
|
78
|
-
intlLabel,
|
|
79
|
-
labelAction,
|
|
80
|
-
name,
|
|
81
|
-
onChange,
|
|
82
|
-
required = false,
|
|
83
|
-
value = ""
|
|
84
|
-
}, forwardedRef) => {
|
|
85
|
-
const [showColorPicker, setShowColorPicker] = React.useState(false);
|
|
86
|
-
const colorPickerButtonRef = React.useRef(null);
|
|
87
|
-
const { formatMessage } = useIntl();
|
|
88
|
-
const color = value || "#000000";
|
|
89
|
-
const handleBlur = (e) => {
|
|
90
|
-
e.preventDefault();
|
|
91
|
-
if (!e.currentTarget.contains(e.relatedTarget)) {
|
|
92
|
-
setShowColorPicker(false);
|
|
93
|
-
}
|
|
94
|
-
};
|
|
95
|
-
const composedRefs = useComposedRefs(forwardedRef, colorPickerButtonRef);
|
|
96
|
-
return /* @__PURE__ */ jsx(
|
|
97
|
-
Field,
|
|
98
|
-
{
|
|
99
|
-
name,
|
|
100
|
-
id: name,
|
|
101
|
-
error,
|
|
102
|
-
hint: description && formatMessage(description),
|
|
103
|
-
required,
|
|
104
|
-
children: /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "stretch", gap: 1, children: [
|
|
105
|
-
/* @__PURE__ */ jsx(FieldLabel, { action: labelAction, children: formatMessage(intlLabel) }),
|
|
106
|
-
/* @__PURE__ */ jsxs(
|
|
107
|
-
ColorPickerToggle,
|
|
108
|
-
{
|
|
109
|
-
ref: composedRefs,
|
|
110
|
-
"aria-label": formatMessage({
|
|
111
|
-
id: getTrad("color-picker.toggle.aria-label"),
|
|
112
|
-
defaultMessage: "Color picker toggle"
|
|
113
|
-
}),
|
|
114
|
-
"aria-controls": "color-picker-value",
|
|
115
|
-
"aria-haspopup": "dialog",
|
|
116
|
-
"aria-expanded": showColorPicker,
|
|
117
|
-
"aria-disabled": disabled,
|
|
118
|
-
disabled,
|
|
119
|
-
onClick: () => setShowColorPicker(!showColorPicker),
|
|
120
|
-
children: [
|
|
121
|
-
/* @__PURE__ */ jsxs(Flex, { children: [
|
|
122
|
-
/* @__PURE__ */ jsx(ColorPreview, { color }),
|
|
123
|
-
/* @__PURE__ */ jsx(
|
|
124
|
-
Typography,
|
|
125
|
-
{
|
|
126
|
-
style: { textTransform: "uppercase" },
|
|
127
|
-
textColor: value ? void 0 : "neutral600",
|
|
128
|
-
variant: "omega",
|
|
129
|
-
children: color
|
|
130
|
-
}
|
|
131
|
-
)
|
|
132
|
-
] }),
|
|
133
|
-
/* @__PURE__ */ jsx(CarretDown, { "aria-hidden": true })
|
|
134
|
-
]
|
|
135
|
-
}
|
|
136
|
-
),
|
|
137
|
-
showColorPicker && /* @__PURE__ */ jsx(
|
|
138
|
-
ColorPickerPopover,
|
|
139
|
-
{
|
|
140
|
-
onBlur: handleBlur,
|
|
141
|
-
role: "dialog",
|
|
142
|
-
source: colorPickerButtonRef,
|
|
143
|
-
spacing: 4,
|
|
144
|
-
children: /* @__PURE__ */ jsxs(FocusTrap, { onEscape: () => setShowColorPicker(false), children: [
|
|
145
|
-
/* @__PURE__ */ jsx(
|
|
146
|
-
ColorPicker,
|
|
147
|
-
{
|
|
148
|
-
color,
|
|
149
|
-
onChange: (hexValue) => onChange({ target: { name, value: hexValue, type: attribute.type } })
|
|
150
|
-
}
|
|
151
|
-
),
|
|
152
|
-
/* @__PURE__ */ jsxs(Flex, { paddingTop: 3, paddingLeft: 4, justifyContent: "flex-end", children: [
|
|
153
|
-
/* @__PURE__ */ jsx(Box, { paddingRight: 2, children: /* @__PURE__ */ jsx(Typography, { variant: "omega", as: "label", textColor: "neutral600", children: formatMessage({
|
|
154
|
-
id: getTrad("color-picker.input.format"),
|
|
155
|
-
defaultMessage: "HEX"
|
|
156
|
-
}) }) }),
|
|
157
|
-
/* @__PURE__ */ jsx(
|
|
158
|
-
FieldInput,
|
|
159
|
-
{
|
|
160
|
-
id: "color-picker-value",
|
|
161
|
-
"aria-label": formatMessage({
|
|
162
|
-
id: getTrad("color-picker.input.aria-label"),
|
|
163
|
-
defaultMessage: "Color picker input"
|
|
164
|
-
}),
|
|
165
|
-
style: { textTransform: "uppercase" },
|
|
166
|
-
value,
|
|
167
|
-
placeholder: "#000000",
|
|
168
|
-
onChange
|
|
169
|
-
}
|
|
170
|
-
)
|
|
171
|
-
] })
|
|
172
|
-
] })
|
|
173
|
-
}
|
|
174
|
-
),
|
|
175
|
-
/* @__PURE__ */ jsx(FieldHint, {}),
|
|
176
|
-
/* @__PURE__ */ jsx(FieldError, {})
|
|
177
|
-
] })
|
|
178
|
-
}
|
|
179
|
-
);
|
|
180
|
-
}
|
|
181
|
-
);
|
|
182
|
-
export {
|
|
183
|
-
ColorPickerInput
|
|
184
|
-
};
|
|
185
|
-
//# sourceMappingURL=ColorPickerInput-fKB6YXW8.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ColorPickerInput-fKB6YXW8.mjs","sources":["../../admin/src/hooks/useComposeRefs.ts","../../admin/src/components/ColorPickerInput.tsx"],"sourcesContent":["import * as React from 'react';\n\ntype PossibleRef<T> = React.Ref<T> | undefined;\n\n/**\n * Set a given ref to a given value\n * This utility takes care of different types of refs: callback refs and RefObject(s)\n */\nfunction setRef<T>(ref: PossibleRef<T>, value: T) {\n if (typeof ref === 'function') {\n ref(value);\n } else if (ref !== null && ref !== undefined) {\n (ref as React.MutableRefObject<T>).current = value;\n }\n}\n\n/**\n * A utility to compose multiple refs together\n * Accepts callback refs and RefObject(s)\n */\nfunction composeRefs<T>(...refs: PossibleRef<T>[]) {\n return (node: T) => refs.forEach((ref) => setRef(ref, node));\n}\n\n/**\n * Takes multiple React like refs either React.Ref or a callback:\n * (node: T) => void and returns a single function that can be\n * passed to a React component as a ref.\n *\n * Example:\n * ```tsx\n * import { useComposedRefs } from '../hooks/useComposedRefs';\n *\n * const Component = React.forwardRef<HTMLInputElement, ComponentProps>((props, forwardedRef) => {\n * const ref = useComposedRefs(internalRef, forwardedRef);\n *\n * React.useEffect(() => {\n * ref.current.focus();\n * }, [ref]);\n *\n * return <input ref={ref} />\n * }\n * ```\n */\nfunction useComposedRefs<T>(...refs: PossibleRef<T>[]) {\n // eslint-disable-next-line react-hooks/exhaustive-deps\n return React.useCallback(composeRefs(...refs), refs);\n}\n\nexport { composeRefs, useComposedRefs };\n","import * as React from 'react';\n\nimport {\n BaseButton,\n Box,\n Field,\n FieldError,\n FieldHint,\n FieldInput,\n FieldLabel,\n Flex,\n FocusTrap,\n Popover,\n Typography,\n} from '@strapi/design-system';\nimport { CarretDown } from '@strapi/icons';\nimport { HexColorPicker } from 'react-colorful';\nimport { useIntl, MessageDescriptor } from 'react-intl';\nimport styled from 'styled-components';\n\nimport { useComposedRefs } from '../hooks/useComposeRefs';\nimport { getTrad } from '../utils/getTrad';\n\nconst ColorPreview = styled.div`\n border-radius: 50%;\n width: 20px;\n height: 20px;\n margin-right: 10px;\n background-color: ${(props) => props.color};\n border: 1px solid rgba(0, 0, 0, 0.1);\n`;\n\nconst ColorPicker = styled(HexColorPicker)`\n && {\n width: 100%;\n aspect-ratio: 1.5;\n }\n\n .react-colorful__pointer {\n width: ${({ theme }) => theme.spaces[3]};\n height: ${({ theme }) => theme.spaces[3]};\n }\n\n .react-colorful__saturation {\n border-radius: ${({ theme }) => theme.spaces[1]};\n border-bottom: none;\n }\n\n .react-colorful__hue {\n border-radius: 10px;\n height: ${({ theme }) => theme.spaces[3]};\n margin-top: ${({ theme }) => theme.spaces[2]};\n }\n`;\n\nconst ColorPickerToggle = styled(BaseButton)`\n display: flex;\n justify-content: space-between;\n align-items: center;\n\n svg {\n width: ${({ theme }) => theme.spaces[2]};\n height: ${({ theme }) => theme.spaces[2]};\n }\n\n svg > path {\n fill: ${({ theme }) => theme.colors.neutral500};\n justify-self: flex-end;\n }\n`;\n\nconst ColorPickerPopover = styled(Popover)`\n padding: ${({ theme }) => theme.spaces[2]};\n min-height: 270px;\n`;\n\n/**\n * TODO: A lot of these props should extend `FieldProps`\n */\ninterface ColorPickerInputProps {\n intlLabel: MessageDescriptor;\n /**\n * TODO: this should be extended from `FieldInputProps['onChange']\n * but that conflicts with it's secondary usage in `HexColorPicker`\n */\n onChange: (event: { target: { name: string; value: string; type: string } }) => void;\n attribute: { type: string; [key: string]: unknown };\n name: string;\n description?: MessageDescriptor;\n disabled?: boolean;\n error?: string;\n labelAction?: React.ReactNode;\n required?: boolean;\n value?: string;\n}\n\nexport const ColorPickerInput = React.forwardRef<HTMLButtonElement, ColorPickerInputProps>(\n (\n {\n attribute,\n description,\n disabled = false,\n error,\n intlLabel,\n labelAction,\n name,\n onChange,\n required = false,\n value = '',\n },\n forwardedRef\n ) => {\n const [showColorPicker, setShowColorPicker] = React.useState(false);\n const colorPickerButtonRef = React.useRef<HTMLButtonElement>(null!);\n const { formatMessage } = useIntl();\n const color = value || '#000000';\n\n const handleBlur: React.FocusEventHandler<HTMLDivElement> = (e) => {\n e.preventDefault();\n\n if (!e.currentTarget.contains(e.relatedTarget)) {\n setShowColorPicker(false);\n }\n };\n\n const composedRefs = useComposedRefs(forwardedRef, colorPickerButtonRef);\n\n return (\n <Field\n name={name}\n id={name}\n // GenericInput calls formatMessage and returns a string for the error\n error={error}\n hint={description && formatMessage(description)}\n required={required}\n >\n <Flex direction=\"column\" alignItems=\"stretch\" gap={1}>\n <FieldLabel action={labelAction}>{formatMessage(intlLabel)}</FieldLabel>\n <ColorPickerToggle\n ref={composedRefs}\n aria-label={formatMessage({\n id: getTrad('color-picker.toggle.aria-label'),\n defaultMessage: 'Color picker toggle',\n })}\n aria-controls=\"color-picker-value\"\n aria-haspopup=\"dialog\"\n aria-expanded={showColorPicker}\n aria-disabled={disabled}\n disabled={disabled}\n onClick={() => setShowColorPicker(!showColorPicker)}\n >\n <Flex>\n <ColorPreview color={color} />\n <Typography\n style={{ textTransform: 'uppercase' }}\n textColor={value ? undefined : 'neutral600'}\n variant=\"omega\"\n >\n {color}\n </Typography>\n </Flex>\n <CarretDown aria-hidden />\n </ColorPickerToggle>\n {showColorPicker && (\n <ColorPickerPopover\n onBlur={handleBlur}\n role=\"dialog\"\n source={colorPickerButtonRef}\n spacing={4}\n >\n <FocusTrap onEscape={() => setShowColorPicker(false)}>\n <ColorPicker\n color={color}\n onChange={(hexValue) =>\n onChange({ target: { name, value: hexValue, type: attribute.type } })\n }\n />\n <Flex paddingTop={3} paddingLeft={4} justifyContent=\"flex-end\">\n <Box paddingRight={2}>\n <Typography variant=\"omega\" as=\"label\" textColor=\"neutral600\">\n {formatMessage({\n id: getTrad('color-picker.input.format'),\n defaultMessage: 'HEX',\n })}\n </Typography>\n </Box>\n <FieldInput\n id=\"color-picker-value\"\n aria-label={formatMessage({\n id: getTrad('color-picker.input.aria-label'),\n defaultMessage: 'Color picker input',\n })}\n style={{ textTransform: 'uppercase' }}\n value={value}\n placeholder=\"#000000\"\n onChange={onChange}\n />\n </Flex>\n </FocusTrap>\n </ColorPickerPopover>\n )}\n <FieldHint />\n <FieldError />\n </Flex>\n </Field>\n );\n }\n);\n"],"names":[],"mappings":"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"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const cs = {
|
|
4
|
-
"color-picker.description": "Vyberte libovolnou barvu",
|
|
5
|
-
"color-picker.input.aria-label": "Vstup pro výběr barvy",
|
|
6
|
-
"color-picker.input.format": "HEX",
|
|
7
|
-
"color-picker.label": "Barva",
|
|
8
|
-
"color-picker.options.advanced.regex": "RegExp vzor",
|
|
9
|
-
"color-picker.options.advanced.regex.description": "Zadejte regulární výraz pro ověření hodnoty HEX",
|
|
10
|
-
"color-picker.options.advanced.requiredField": "Povinné pole",
|
|
11
|
-
"color-picker.options.advanced.requiredField.description": "Pokud je toto pole prázdné, nebudete moci vytvořit záznam",
|
|
12
|
-
"color-picker.settings": "Nastavení",
|
|
13
|
-
"color-picker.toggle.aria-label": "Přepínač výběru barvy"
|
|
14
|
-
};
|
|
15
|
-
exports.default = cs;
|
|
16
|
-
//# sourceMappingURL=cs-4GdZY0p6.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cs-4GdZY0p6.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
const cs = {
|
|
2
|
-
"color-picker.description": "Vyberte libovolnou barvu",
|
|
3
|
-
"color-picker.input.aria-label": "Vstup pro výběr barvy",
|
|
4
|
-
"color-picker.input.format": "HEX",
|
|
5
|
-
"color-picker.label": "Barva",
|
|
6
|
-
"color-picker.options.advanced.regex": "RegExp vzor",
|
|
7
|
-
"color-picker.options.advanced.regex.description": "Zadejte regulární výraz pro ověření hodnoty HEX",
|
|
8
|
-
"color-picker.options.advanced.requiredField": "Povinné pole",
|
|
9
|
-
"color-picker.options.advanced.requiredField.description": "Pokud je toto pole prázdné, nebudete moci vytvořit záznam",
|
|
10
|
-
"color-picker.settings": "Nastavení",
|
|
11
|
-
"color-picker.toggle.aria-label": "Přepínač výběru barvy"
|
|
12
|
-
};
|
|
13
|
-
export {
|
|
14
|
-
cs as default
|
|
15
|
-
};
|
|
16
|
-
//# sourceMappingURL=cs-A2xRj-2-.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cs-A2xRj-2-.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
const en = {
|
|
2
|
-
"color-picker.description": "Select any color",
|
|
3
|
-
"color-picker.input.aria-label": "Color picker input",
|
|
4
|
-
"color-picker.input.format": "HEX",
|
|
5
|
-
"color-picker.label": "Color",
|
|
6
|
-
"color-picker.options.advanced.regex": "RegExp pattern",
|
|
7
|
-
"color-picker.options.advanced.regex.description": "Provide a regular expression to validate the HEX value",
|
|
8
|
-
"color-picker.options.advanced.requiredField": "Required field",
|
|
9
|
-
"color-picker.options.advanced.requiredField.description": "You won't be able to create an entry if this field is empty",
|
|
10
|
-
"color-picker.settings": "Settings",
|
|
11
|
-
"color-picker.toggle.aria-label": "Color picker toggle",
|
|
12
|
-
"plugin.description.long": "A Strapi-maintained color picker custom field. Use saturation and hue sliders to select a color and save the value as a HEX string.",
|
|
13
|
-
"plugin.description.short": "A Strapi-maintained color picker custom field.",
|
|
14
|
-
"plugin.name": "Color picker"
|
|
15
|
-
};
|
|
16
|
-
export {
|
|
17
|
-
en as default
|
|
18
|
-
};
|
|
19
|
-
//# sourceMappingURL=en-L6ZZWDJv.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"en-L6ZZWDJv.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const en = {
|
|
4
|
-
"color-picker.description": "Select any color",
|
|
5
|
-
"color-picker.input.aria-label": "Color picker input",
|
|
6
|
-
"color-picker.input.format": "HEX",
|
|
7
|
-
"color-picker.label": "Color",
|
|
8
|
-
"color-picker.options.advanced.regex": "RegExp pattern",
|
|
9
|
-
"color-picker.options.advanced.regex.description": "Provide a regular expression to validate the HEX value",
|
|
10
|
-
"color-picker.options.advanced.requiredField": "Required field",
|
|
11
|
-
"color-picker.options.advanced.requiredField.description": "You won't be able to create an entry if this field is empty",
|
|
12
|
-
"color-picker.settings": "Settings",
|
|
13
|
-
"color-picker.toggle.aria-label": "Color picker toggle",
|
|
14
|
-
"plugin.description.long": "A Strapi-maintained color picker custom field. Use saturation and hue sliders to select a color and save the value as a HEX string.",
|
|
15
|
-
"plugin.description.short": "A Strapi-maintained color picker custom field.",
|
|
16
|
-
"plugin.name": "Color picker"
|
|
17
|
-
};
|
|
18
|
-
exports.default = en;
|
|
19
|
-
//# sourceMappingURL=en-WeRHjVEB.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"en-WeRHjVEB.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;"}
|
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const helperPlugin = require("@strapi/helper-plugin");
|
|
3
|
-
const jsxRuntime = require("react/jsx-runtime");
|
|
4
|
-
const designSystem = require("@strapi/design-system");
|
|
5
|
-
const icons = require("@strapi/icons");
|
|
6
|
-
const styled = require("styled-components");
|
|
7
|
-
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
|
8
|
-
const styled__default = /* @__PURE__ */ _interopDefault(styled);
|
|
9
|
-
const __variableDynamicImportRuntimeHelper = (glob, path) => {
|
|
10
|
-
const v = glob[path];
|
|
11
|
-
if (v) {
|
|
12
|
-
return typeof v === "function" ? v() : Promise.resolve(v);
|
|
13
|
-
}
|
|
14
|
-
return new Promise((_, reject) => {
|
|
15
|
-
(typeof queueMicrotask === "function" ? queueMicrotask : setTimeout)(reject.bind(null, new Error("Unknown variable dynamic import: " + path)));
|
|
16
|
-
});
|
|
17
|
-
};
|
|
18
|
-
const IconBox = styled__default.default(designSystem.Flex)`
|
|
19
|
-
/* Hard code color values */
|
|
20
|
-
/* to stay consistent between themes */
|
|
21
|
-
background-color: #f0f0ff; /* primary100 */
|
|
22
|
-
border: 1px solid #d9d8ff; /* primary200 */
|
|
23
|
-
|
|
24
|
-
svg > path {
|
|
25
|
-
fill: #4945ff; /* primary600 */
|
|
26
|
-
}
|
|
27
|
-
`;
|
|
28
|
-
const ColorPickerIcon = () => {
|
|
29
|
-
return /* @__PURE__ */ jsxRuntime.jsx(IconBox, { justifyContent: "center", alignItems: "center", width: 7, height: 6, hasRadius: true, "aria-hidden": true, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Icon, { as: icons.Paint }) });
|
|
30
|
-
};
|
|
31
|
-
const pluginId = "color-picker";
|
|
32
|
-
const getTrad = (id) => `${pluginId}.${id}`;
|
|
33
|
-
const index = {
|
|
34
|
-
/**
|
|
35
|
-
* TODO: we need to have the type for StrapiApp done from `@strapi/admin` package.
|
|
36
|
-
*/
|
|
37
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
38
|
-
register(app) {
|
|
39
|
-
app.customFields.register({
|
|
40
|
-
name: "color",
|
|
41
|
-
pluginId: "color-picker",
|
|
42
|
-
type: "string",
|
|
43
|
-
icon: ColorPickerIcon,
|
|
44
|
-
intlLabel: {
|
|
45
|
-
id: getTrad("color-picker.label"),
|
|
46
|
-
defaultMessage: "Color"
|
|
47
|
-
},
|
|
48
|
-
intlDescription: {
|
|
49
|
-
id: getTrad("color-picker.description"),
|
|
50
|
-
defaultMessage: "Select any color"
|
|
51
|
-
},
|
|
52
|
-
components: {
|
|
53
|
-
Input: async () => Promise.resolve().then(() => require("./ColorPickerInput-0lOoTrf0.js")).then((module2) => ({
|
|
54
|
-
default: module2.ColorPickerInput
|
|
55
|
-
}))
|
|
56
|
-
},
|
|
57
|
-
options: {
|
|
58
|
-
advanced: [
|
|
59
|
-
{
|
|
60
|
-
intlLabel: {
|
|
61
|
-
id: getTrad("color-picker.options.advanced.regex"),
|
|
62
|
-
defaultMessage: "RegExp pattern"
|
|
63
|
-
},
|
|
64
|
-
name: "regex",
|
|
65
|
-
type: "text",
|
|
66
|
-
defaultValue: "^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$",
|
|
67
|
-
description: {
|
|
68
|
-
id: getTrad("color-picker.options.advanced.regex.description"),
|
|
69
|
-
defaultMessage: "The text of the regular expression"
|
|
70
|
-
}
|
|
71
|
-
},
|
|
72
|
-
{
|
|
73
|
-
sectionTitle: {
|
|
74
|
-
id: "global.settings",
|
|
75
|
-
defaultMessage: "Settings"
|
|
76
|
-
},
|
|
77
|
-
items: [
|
|
78
|
-
{
|
|
79
|
-
name: "required",
|
|
80
|
-
type: "checkbox",
|
|
81
|
-
intlLabel: {
|
|
82
|
-
id: getTrad("color-picker.options.advanced.requiredField"),
|
|
83
|
-
defaultMessage: "Required field"
|
|
84
|
-
},
|
|
85
|
-
description: {
|
|
86
|
-
id: getTrad("color-picker.options.advanced.requiredField.description"),
|
|
87
|
-
defaultMessage: "You won't be able to create an entry if this field is empty"
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
]
|
|
91
|
-
}
|
|
92
|
-
]
|
|
93
|
-
}
|
|
94
|
-
});
|
|
95
|
-
},
|
|
96
|
-
async registerTrads({ locales }) {
|
|
97
|
-
const importedTrads = await Promise.all(
|
|
98
|
-
locales.map((locale) => {
|
|
99
|
-
return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/cs.json": () => Promise.resolve().then(() => require("./cs-4GdZY0p6.js")), "./translations/en.json": () => Promise.resolve().then(() => require("./en-WeRHjVEB.js")), "./translations/ru.json": () => Promise.resolve().then(() => require("./ru-UXN_ByI9.js")), "./translations/sv.json": () => Promise.resolve().then(() => require("./sv-3-Yk9bKb.js")), "./translations/tr.json": () => Promise.resolve().then(() => require("./tr-AbD-f8F0.js")), "./translations/zh.json": () => Promise.resolve().then(() => require("./zh-c23gv_oM.js")) }), `./translations/${locale}.json`).then(({ default: data }) => {
|
|
100
|
-
return {
|
|
101
|
-
data: helperPlugin.prefixPluginTranslations(data, pluginId),
|
|
102
|
-
locale
|
|
103
|
-
};
|
|
104
|
-
}).catch(() => {
|
|
105
|
-
return {
|
|
106
|
-
data: {},
|
|
107
|
-
locale
|
|
108
|
-
};
|
|
109
|
-
});
|
|
110
|
-
})
|
|
111
|
-
);
|
|
112
|
-
return Promise.resolve(importedTrads);
|
|
113
|
-
}
|
|
114
|
-
};
|
|
115
|
-
exports.getTrad = getTrad;
|
|
116
|
-
exports.index = index;
|
|
117
|
-
//# sourceMappingURL=index-OJYEuoCq.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-OJYEuoCq.js","sources":["../../admin/src/components/ColorPickerIcon.tsx","../../admin/src/pluginId.ts","../../admin/src/utils/getTrad.ts","../../admin/src/index.ts"],"sourcesContent":["import { Flex, Icon } from '@strapi/design-system';\nimport { Paint } from '@strapi/icons';\nimport styled from 'styled-components';\n\nconst IconBox = styled(Flex)`\n /* Hard code color values */\n /* to stay consistent between themes */\n background-color: #f0f0ff; /* primary100 */\n border: 1px solid #d9d8ff; /* primary200 */\n\n svg > path {\n fill: #4945ff; /* primary600 */\n }\n`;\n\nexport const ColorPickerIcon = () => {\n return (\n <IconBox justifyContent=\"center\" alignItems=\"center\" width={7} height={6} hasRadius aria-hidden>\n <Icon as={Paint} />\n </IconBox>\n );\n};\n","export const pluginId = 'color-picker';\n","import { pluginId } from '../pluginId';\n\nexport const getTrad = (id: string) => `${pluginId}.${id}`;\n","import { prefixPluginTranslations } from '@strapi/helper-plugin';\n\nimport { ColorPickerIcon } from './components/ColorPickerIcon';\nimport { pluginId } from './pluginId';\nimport { getTrad } from './utils/getTrad';\n\n// eslint-disable-next-line import/no-default-export\nexport default {\n /**\n * TODO: we need to have the type for StrapiApp done from `@strapi/admin` package.\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n register(app: any) {\n app.customFields.register({\n name: 'color',\n pluginId: 'color-picker',\n type: 'string',\n icon: ColorPickerIcon,\n intlLabel: {\n id: getTrad('color-picker.label'),\n defaultMessage: 'Color',\n },\n intlDescription: {\n id: getTrad('color-picker.description'),\n defaultMessage: 'Select any color',\n },\n components: {\n Input: async () =>\n import('./components/ColorPickerInput').then((module) => ({\n default: module.ColorPickerInput,\n })),\n },\n options: {\n advanced: [\n {\n intlLabel: {\n id: getTrad('color-picker.options.advanced.regex'),\n defaultMessage: 'RegExp pattern',\n },\n name: 'regex',\n type: 'text',\n defaultValue: '^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$',\n description: {\n id: getTrad('color-picker.options.advanced.regex.description'),\n defaultMessage: 'The text of the regular expression',\n },\n },\n {\n sectionTitle: {\n id: 'global.settings',\n defaultMessage: 'Settings',\n },\n items: [\n {\n name: 'required',\n type: 'checkbox',\n intlLabel: {\n id: getTrad('color-picker.options.advanced.requiredField'),\n defaultMessage: 'Required field',\n },\n description: {\n id: getTrad('color-picker.options.advanced.requiredField.description'),\n defaultMessage: \"You won't be able to create an entry if this field is empty\",\n },\n },\n ],\n },\n ],\n },\n });\n },\n async registerTrads({ locales }: { locales: string[] }) {\n const importedTrads = await Promise.all(\n locales.map((locale) => {\n return import(`./translations/${locale}.json`)\n .then(({ default: data }) => {\n return {\n data: prefixPluginTranslations(data, pluginId),\n locale,\n };\n })\n .catch(() => {\n return {\n data: {},\n locale,\n };\n });\n })\n );\n\n return Promise.resolve(importedTrads);\n },\n};\n"],"names":["styled","Flex","Icon","Paint","module","prefixPluginTranslations"],"mappings":"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"}
|
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
import { prefixPluginTranslations } from "@strapi/helper-plugin";
|
|
2
|
-
import { jsx } from "react/jsx-runtime";
|
|
3
|
-
import { Flex, Icon } from "@strapi/design-system";
|
|
4
|
-
import { Paint } from "@strapi/icons";
|
|
5
|
-
import styled from "styled-components";
|
|
6
|
-
const __variableDynamicImportRuntimeHelper = (glob, path) => {
|
|
7
|
-
const v = glob[path];
|
|
8
|
-
if (v) {
|
|
9
|
-
return typeof v === "function" ? v() : Promise.resolve(v);
|
|
10
|
-
}
|
|
11
|
-
return new Promise((_, reject) => {
|
|
12
|
-
(typeof queueMicrotask === "function" ? queueMicrotask : setTimeout)(reject.bind(null, new Error("Unknown variable dynamic import: " + path)));
|
|
13
|
-
});
|
|
14
|
-
};
|
|
15
|
-
const IconBox = styled(Flex)`
|
|
16
|
-
/* Hard code color values */
|
|
17
|
-
/* to stay consistent between themes */
|
|
18
|
-
background-color: #f0f0ff; /* primary100 */
|
|
19
|
-
border: 1px solid #d9d8ff; /* primary200 */
|
|
20
|
-
|
|
21
|
-
svg > path {
|
|
22
|
-
fill: #4945ff; /* primary600 */
|
|
23
|
-
}
|
|
24
|
-
`;
|
|
25
|
-
const ColorPickerIcon = () => {
|
|
26
|
-
return /* @__PURE__ */ jsx(IconBox, { justifyContent: "center", alignItems: "center", width: 7, height: 6, hasRadius: true, "aria-hidden": true, children: /* @__PURE__ */ jsx(Icon, { as: Paint }) });
|
|
27
|
-
};
|
|
28
|
-
const pluginId = "color-picker";
|
|
29
|
-
const getTrad = (id) => `${pluginId}.${id}`;
|
|
30
|
-
const index = {
|
|
31
|
-
/**
|
|
32
|
-
* TODO: we need to have the type for StrapiApp done from `@strapi/admin` package.
|
|
33
|
-
*/
|
|
34
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
35
|
-
register(app) {
|
|
36
|
-
app.customFields.register({
|
|
37
|
-
name: "color",
|
|
38
|
-
pluginId: "color-picker",
|
|
39
|
-
type: "string",
|
|
40
|
-
icon: ColorPickerIcon,
|
|
41
|
-
intlLabel: {
|
|
42
|
-
id: getTrad("color-picker.label"),
|
|
43
|
-
defaultMessage: "Color"
|
|
44
|
-
},
|
|
45
|
-
intlDescription: {
|
|
46
|
-
id: getTrad("color-picker.description"),
|
|
47
|
-
defaultMessage: "Select any color"
|
|
48
|
-
},
|
|
49
|
-
components: {
|
|
50
|
-
Input: async () => import("./ColorPickerInput-fKB6YXW8.mjs").then((module) => ({
|
|
51
|
-
default: module.ColorPickerInput
|
|
52
|
-
}))
|
|
53
|
-
},
|
|
54
|
-
options: {
|
|
55
|
-
advanced: [
|
|
56
|
-
{
|
|
57
|
-
intlLabel: {
|
|
58
|
-
id: getTrad("color-picker.options.advanced.regex"),
|
|
59
|
-
defaultMessage: "RegExp pattern"
|
|
60
|
-
},
|
|
61
|
-
name: "regex",
|
|
62
|
-
type: "text",
|
|
63
|
-
defaultValue: "^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$",
|
|
64
|
-
description: {
|
|
65
|
-
id: getTrad("color-picker.options.advanced.regex.description"),
|
|
66
|
-
defaultMessage: "The text of the regular expression"
|
|
67
|
-
}
|
|
68
|
-
},
|
|
69
|
-
{
|
|
70
|
-
sectionTitle: {
|
|
71
|
-
id: "global.settings",
|
|
72
|
-
defaultMessage: "Settings"
|
|
73
|
-
},
|
|
74
|
-
items: [
|
|
75
|
-
{
|
|
76
|
-
name: "required",
|
|
77
|
-
type: "checkbox",
|
|
78
|
-
intlLabel: {
|
|
79
|
-
id: getTrad("color-picker.options.advanced.requiredField"),
|
|
80
|
-
defaultMessage: "Required field"
|
|
81
|
-
},
|
|
82
|
-
description: {
|
|
83
|
-
id: getTrad("color-picker.options.advanced.requiredField.description"),
|
|
84
|
-
defaultMessage: "You won't be able to create an entry if this field is empty"
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
]
|
|
88
|
-
}
|
|
89
|
-
]
|
|
90
|
-
}
|
|
91
|
-
});
|
|
92
|
-
},
|
|
93
|
-
async registerTrads({ locales }) {
|
|
94
|
-
const importedTrads = await Promise.all(
|
|
95
|
-
locales.map((locale) => {
|
|
96
|
-
return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/cs.json": () => import("./cs-A2xRj-2-.mjs"), "./translations/en.json": () => import("./en-L6ZZWDJv.mjs"), "./translations/ru.json": () => import("./ru-LLXYEOwl.mjs"), "./translations/sv.json": () => import("./sv-QqRPNQLw.mjs"), "./translations/tr.json": () => import("./tr-qYGSw8gH.mjs"), "./translations/zh.json": () => import("./zh-fPTOIT6s.mjs") }), `./translations/${locale}.json`).then(({ default: data }) => {
|
|
97
|
-
return {
|
|
98
|
-
data: prefixPluginTranslations(data, pluginId),
|
|
99
|
-
locale
|
|
100
|
-
};
|
|
101
|
-
}).catch(() => {
|
|
102
|
-
return {
|
|
103
|
-
data: {},
|
|
104
|
-
locale
|
|
105
|
-
};
|
|
106
|
-
});
|
|
107
|
-
})
|
|
108
|
-
);
|
|
109
|
-
return Promise.resolve(importedTrads);
|
|
110
|
-
}
|
|
111
|
-
};
|
|
112
|
-
export {
|
|
113
|
-
getTrad as g,
|
|
114
|
-
index as i
|
|
115
|
-
};
|
|
116
|
-
//# sourceMappingURL=index-uOrtnJpz.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-uOrtnJpz.mjs","sources":["../../admin/src/components/ColorPickerIcon.tsx","../../admin/src/pluginId.ts","../../admin/src/utils/getTrad.ts","../../admin/src/index.ts"],"sourcesContent":["import { Flex, Icon } from '@strapi/design-system';\nimport { Paint } from '@strapi/icons';\nimport styled from 'styled-components';\n\nconst IconBox = styled(Flex)`\n /* Hard code color values */\n /* to stay consistent between themes */\n background-color: #f0f0ff; /* primary100 */\n border: 1px solid #d9d8ff; /* primary200 */\n\n svg > path {\n fill: #4945ff; /* primary600 */\n }\n`;\n\nexport const ColorPickerIcon = () => {\n return (\n <IconBox justifyContent=\"center\" alignItems=\"center\" width={7} height={6} hasRadius aria-hidden>\n <Icon as={Paint} />\n </IconBox>\n );\n};\n","export const pluginId = 'color-picker';\n","import { pluginId } from '../pluginId';\n\nexport const getTrad = (id: string) => `${pluginId}.${id}`;\n","import { prefixPluginTranslations } from '@strapi/helper-plugin';\n\nimport { ColorPickerIcon } from './components/ColorPickerIcon';\nimport { pluginId } from './pluginId';\nimport { getTrad } from './utils/getTrad';\n\n// eslint-disable-next-line import/no-default-export\nexport default {\n /**\n * TODO: we need to have the type for StrapiApp done from `@strapi/admin` package.\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n register(app: any) {\n app.customFields.register({\n name: 'color',\n pluginId: 'color-picker',\n type: 'string',\n icon: ColorPickerIcon,\n intlLabel: {\n id: getTrad('color-picker.label'),\n defaultMessage: 'Color',\n },\n intlDescription: {\n id: getTrad('color-picker.description'),\n defaultMessage: 'Select any color',\n },\n components: {\n Input: async () =>\n import('./components/ColorPickerInput').then((module) => ({\n default: module.ColorPickerInput,\n })),\n },\n options: {\n advanced: [\n {\n intlLabel: {\n id: getTrad('color-picker.options.advanced.regex'),\n defaultMessage: 'RegExp pattern',\n },\n name: 'regex',\n type: 'text',\n defaultValue: '^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$',\n description: {\n id: getTrad('color-picker.options.advanced.regex.description'),\n defaultMessage: 'The text of the regular expression',\n },\n },\n {\n sectionTitle: {\n id: 'global.settings',\n defaultMessage: 'Settings',\n },\n items: [\n {\n name: 'required',\n type: 'checkbox',\n intlLabel: {\n id: getTrad('color-picker.options.advanced.requiredField'),\n defaultMessage: 'Required field',\n },\n description: {\n id: getTrad('color-picker.options.advanced.requiredField.description'),\n defaultMessage: \"You won't be able to create an entry if this field is empty\",\n },\n },\n ],\n },\n ],\n },\n });\n },\n async registerTrads({ locales }: { locales: string[] }) {\n const importedTrads = await Promise.all(\n locales.map((locale) => {\n return import(`./translations/${locale}.json`)\n .then(({ default: data }) => {\n return {\n data: prefixPluginTranslations(data, pluginId),\n locale,\n };\n })\n .catch(() => {\n return {\n data: {},\n locale,\n };\n });\n })\n );\n\n return Promise.resolve(importedTrads);\n },\n};\n"],"names":[],"mappings":";;;;;;;;;;;;;;AAIA,MAAM,UAAU,OAAO,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWpB,MAAM,kBAAkB,MAAM;AACnC,6BACG,SAAQ,EAAA,gBAAe,UAAS,YAAW,UAAS,OAAO,GAAG,QAAQ,GAAG,WAAS,MAAC,eAAW,MAC7F,8BAAC,MAAK,EAAA,IAAI,OAAO,EACnB,CAAA;AAEJ;ACrBO,MAAM,WAAW;ACEjB,MAAM,UAAU,CAAC,OAAe,GAAG,QAAQ,IAAI,EAAE;ACKxD,MAAe,QAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAKb,SAAS,KAAU;AACjB,QAAI,aAAa,SAAS;AAAA,MACxB,MAAM;AAAA,MACN,UAAU;AAAA,MACV,MAAM;AAAA,MACN,MAAM;AAAA,MACN,WAAW;AAAA,QACT,IAAI,QAAQ,oBAAoB;AAAA,QAChC,gBAAgB;AAAA,MAClB;AAAA,MACA,iBAAiB;AAAA,QACf,IAAI,QAAQ,0BAA0B;AAAA,QACtC,gBAAgB;AAAA,MAClB;AAAA,MACA,YAAY;AAAA,QACV,OAAO,YACL,OAAO,iCAA+B,EAAE,KAAK,CAAC,YAAY;AAAA,UACxD,SAAS,OAAO;AAAA,QAAA,EAChB;AAAA,MACN;AAAA,MACA,SAAS;AAAA,QACP,UAAU;AAAA,UACR;AAAA,YACE,WAAW;AAAA,cACT,IAAI,QAAQ,qCAAqC;AAAA,cACjD,gBAAgB;AAAA,YAClB;AAAA,YACA,MAAM;AAAA,YACN,MAAM;AAAA,YACN,cAAc;AAAA,YACd,aAAa;AAAA,cACX,IAAI,QAAQ,iDAAiD;AAAA,cAC7D,gBAAgB;AAAA,YAClB;AAAA,UACF;AAAA,UACA;AAAA,YACE,cAAc;AAAA,cACZ,IAAI;AAAA,cACJ,gBAAgB;AAAA,YAClB;AAAA,YACA,OAAO;AAAA,cACL;AAAA,gBACE,MAAM;AAAA,gBACN,MAAM;AAAA,gBACN,WAAW;AAAA,kBACT,IAAI,QAAQ,6CAA6C;AAAA,kBACzD,gBAAgB;AAAA,gBAClB;AAAA,gBACA,aAAa;AAAA,kBACX,IAAI,QAAQ,yDAAyD;AAAA,kBACrE,gBAAgB;AAAA,gBAClB;AAAA,cACF;AAAA,YACF;AAAA,UACF;AAAA,QACF;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAAA,EACA,MAAM,cAAc,EAAE,WAAkC;AAChD,UAAA,gBAAgB,MAAM,QAAQ;AAAA,MAClC,QAAQ,IAAI,CAAC,WAAW;AACf,eAAA,qCAA+B,uBAAA,OAAA,EAAA,0BAAA,MAAA,OAAA,mBAAA,GAAA,0BAAA,MAAA,OAAA,mBAAA,GAAA,0BAAA,MAAA,OAAA,mBAAA,GAAA,0BAAA,MAAA,OAAA,mBAAA,GAAA,0BAAA,MAAA,OAAA,mBAAA,GAAA,0BAAA,MAAA,OAAA,mBAAA,EAAA,CAAA,GAAA,kBAAA,MAAA,OAAA,EACnC,KAAK,CAAC,EAAE,SAAS,WAAW;AACpB,iBAAA;AAAA,YACL,MAAM,yBAAyB,MAAM,QAAQ;AAAA,YAC7C;AAAA,UAAA;AAAA,QACF,CACD,EACA,MAAM,MAAM;AACJ,iBAAA;AAAA,YACL,MAAM,CAAC;AAAA,YACP;AAAA,UAAA;AAAA,QACF,CACD;AAAA,MAAA,CACJ;AAAA,IAAA;AAGI,WAAA,QAAQ,QAAQ,aAAa;AAAA,EACtC;AACF;"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
const ru = {
|
|
2
|
-
"color-picker.description": "Выбирайте любые цвета",
|
|
3
|
-
"color-picker.input.aria-label": "Введите выбранный цвет",
|
|
4
|
-
"color-picker.input.format": "HEX",
|
|
5
|
-
"color-picker.label": "Цвет",
|
|
6
|
-
"color-picker.options.advanced.regex": "Шаблон регулярного выражения (RegExp)",
|
|
7
|
-
"color-picker.options.advanced.regex.description": "Обеспечивает проверку с помощью регулярного выражение для HEX (шестнадцатеричного) HEX значения цвета",
|
|
8
|
-
"color-picker.options.advanced.requiredField": "Обязательное поле",
|
|
9
|
-
"color-picker.options.advanced.requiredField.description": "Вы не сможете продолжить, если это поле пусто",
|
|
10
|
-
"color-picker.settings": "Настройки",
|
|
11
|
-
"color-picker.toggle.aria-label": "Переключатель средства выбора цвета",
|
|
12
|
-
"plugin.description.long": "Настраиваемое поле средства выбора цвета, поддерживаемое Strapi. Используйте ползунки насыщенности и оттенка, чтобы выбрать цвет и сохранить его HEX (шестнадцатеричное) значение.",
|
|
13
|
-
"plugin.description.short": "Настраиваемое поле средства выбора цвета, поддерживаемое Strapi.",
|
|
14
|
-
"plugin.name": "Выбор цвета"
|
|
15
|
-
};
|
|
16
|
-
export {
|
|
17
|
-
ru as default
|
|
18
|
-
};
|
|
19
|
-
//# sourceMappingURL=ru-LLXYEOwl.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ru-LLXYEOwl.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const ru = {
|
|
4
|
-
"color-picker.description": "Выбирайте любые цвета",
|
|
5
|
-
"color-picker.input.aria-label": "Введите выбранный цвет",
|
|
6
|
-
"color-picker.input.format": "HEX",
|
|
7
|
-
"color-picker.label": "Цвет",
|
|
8
|
-
"color-picker.options.advanced.regex": "Шаблон регулярного выражения (RegExp)",
|
|
9
|
-
"color-picker.options.advanced.regex.description": "Обеспечивает проверку с помощью регулярного выражение для HEX (шестнадцатеричного) HEX значения цвета",
|
|
10
|
-
"color-picker.options.advanced.requiredField": "Обязательное поле",
|
|
11
|
-
"color-picker.options.advanced.requiredField.description": "Вы не сможете продолжить, если это поле пусто",
|
|
12
|
-
"color-picker.settings": "Настройки",
|
|
13
|
-
"color-picker.toggle.aria-label": "Переключатель средства выбора цвета",
|
|
14
|
-
"plugin.description.long": "Настраиваемое поле средства выбора цвета, поддерживаемое Strapi. Используйте ползунки насыщенности и оттенка, чтобы выбрать цвет и сохранить его HEX (шестнадцатеричное) значение.",
|
|
15
|
-
"plugin.description.short": "Настраиваемое поле средства выбора цвета, поддерживаемое Strapi.",
|
|
16
|
-
"plugin.name": "Выбор цвета"
|
|
17
|
-
};
|
|
18
|
-
exports.default = ru;
|
|
19
|
-
//# sourceMappingURL=ru-UXN_ByI9.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ru-UXN_ByI9.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const sv = {
|
|
4
|
-
"color-picker.description": "Välj färger",
|
|
5
|
-
"color-picker.input.aria-label": "Färgväljarinmatning",
|
|
6
|
-
"color-picker.input.format": "HEX",
|
|
7
|
-
"color-picker.label": "Färgväljare",
|
|
8
|
-
"color-picker.options.advanced.regex": "RegEx-mönster",
|
|
9
|
-
"color-picker.options.advanced.regex.description": "Ange ett regex-mönster för att validera HEX-värdet",
|
|
10
|
-
"color-picker.options.advanced.requiredField": "Obligatoriskt fält",
|
|
11
|
-
"color-picker.options.advanced.requiredField.description": "Du kommer inte att kunna skapa en post om det här fältet är tomt",
|
|
12
|
-
"color-picker.settings": "Inställningar",
|
|
13
|
-
"color-picker.toggle.aria-label": "Växla färgväljare"
|
|
14
|
-
};
|
|
15
|
-
exports.default = sv;
|
|
16
|
-
//# sourceMappingURL=sv-3-Yk9bKb.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sv-3-Yk9bKb.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;"}
|