@chayns-components/color-picker 5.0.0-beta.1000

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.
Files changed (158) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +34 -0
  3. package/lib/cjs/api/color/get.js +33 -0
  4. package/lib/cjs/api/color/get.js.map +1 -0
  5. package/lib/cjs/api/color/put.js +37 -0
  6. package/lib/cjs/api/color/put.js.map +1 -0
  7. package/lib/cjs/components/ColorPickerProvider.js +96 -0
  8. package/lib/cjs/components/ColorPickerProvider.js.map +1 -0
  9. package/lib/cjs/components/color-picker/ColorPicker.js +43 -0
  10. package/lib/cjs/components/color-picker/ColorPicker.js.map +1 -0
  11. package/lib/cjs/components/color-picker/ColorPicker.styles.js +12 -0
  12. package/lib/cjs/components/color-picker/ColorPicker.styles.js.map +1 -0
  13. package/lib/cjs/components/color-picker/color-picker-wrapper/ColorPickerWrapper.js +50 -0
  14. package/lib/cjs/components/color-picker/color-picker-wrapper/ColorPickerWrapper.js.map +1 -0
  15. package/lib/cjs/components/color-picker/color-picker-wrapper/ColorPickerWrapper.styles.js +64 -0
  16. package/lib/cjs/components/color-picker/color-picker-wrapper/ColorPickerWrapper.styles.js.map +1 -0
  17. package/lib/cjs/components/color-picker-popup/ColorPickerPopup.js +32 -0
  18. package/lib/cjs/components/color-picker-popup/ColorPickerPopup.js.map +1 -0
  19. package/lib/cjs/components/color-picker-popup/ColorPickerPopup.styles.js +13 -0
  20. package/lib/cjs/components/color-picker-popup/ColorPickerPopup.styles.js.map +1 -0
  21. package/lib/cjs/components/color-picker-popup/color-area/ColorArea.js +246 -0
  22. package/lib/cjs/components/color-picker-popup/color-area/ColorArea.js.map +1 -0
  23. package/lib/cjs/components/color-picker-popup/color-area/ColorArea.styles.js +45 -0
  24. package/lib/cjs/components/color-picker-popup/color-area/ColorArea.styles.js.map +1 -0
  25. package/lib/cjs/components/color-picker-popup/more-options/MoreOptions.js +90 -0
  26. package/lib/cjs/components/color-picker-popup/more-options/MoreOptions.js.map +1 -0
  27. package/lib/cjs/components/color-picker-popup/more-options/MoreOptions.styles.js +35 -0
  28. package/lib/cjs/components/color-picker-popup/more-options/MoreOptions.styles.js.map +1 -0
  29. package/lib/cjs/components/color-picker-popup/preset-colors/PresetColors.js +148 -0
  30. package/lib/cjs/components/color-picker-popup/preset-colors/PresetColors.js.map +1 -0
  31. package/lib/cjs/components/color-picker-popup/preset-colors/PresetColors.styles.js +15 -0
  32. package/lib/cjs/components/color-picker-popup/preset-colors/PresetColors.styles.js.map +1 -0
  33. package/lib/cjs/components/color-picker-popup/preset-colors/preset-button/PresetButton.js +47 -0
  34. package/lib/cjs/components/color-picker-popup/preset-colors/preset-button/PresetButton.js.map +1 -0
  35. package/lib/cjs/components/color-picker-popup/preset-colors/preset-button/PresetButton.styles.js +28 -0
  36. package/lib/cjs/components/color-picker-popup/preset-colors/preset-button/PresetButton.styles.js.map +1 -0
  37. package/lib/cjs/components/color-picker-popup/preset-colors/preset-color/PresetColor.js +50 -0
  38. package/lib/cjs/components/color-picker-popup/preset-colors/preset-color/PresetColor.js.map +1 -0
  39. package/lib/cjs/components/color-picker-popup/preset-colors/preset-color/PresetColor.styles.js +44 -0
  40. package/lib/cjs/components/color-picker-popup/preset-colors/preset-color/PresetColor.styles.js.map +1 -0
  41. package/lib/cjs/components/color-picker-popup/sliders/Sliders.js +75 -0
  42. package/lib/cjs/components/color-picker-popup/sliders/Sliders.js.map +1 -0
  43. package/lib/cjs/components/color-picker-popup/sliders/Sliders.styles.js +20 -0
  44. package/lib/cjs/components/color-picker-popup/sliders/Sliders.styles.js.map +1 -0
  45. package/lib/cjs/components/color-picker-popup/sliders/color-preview/ColorPreview.js +22 -0
  46. package/lib/cjs/components/color-picker-popup/sliders/color-preview/ColorPreview.js.map +1 -0
  47. package/lib/cjs/components/color-picker-popup/sliders/color-preview/ColorPreview.styles.js +46 -0
  48. package/lib/cjs/components/color-picker-popup/sliders/color-preview/ColorPreview.styles.js.map +1 -0
  49. package/lib/cjs/components/hue-slider/HueSlider.js +135 -0
  50. package/lib/cjs/components/hue-slider/HueSlider.js.map +1 -0
  51. package/lib/cjs/components/hue-slider/HueSlider.styles.js +88 -0
  52. package/lib/cjs/components/hue-slider/HueSlider.styles.js.map +1 -0
  53. package/lib/cjs/components/transparency-slider/TransparencySlider.js +122 -0
  54. package/lib/cjs/components/transparency-slider/TransparencySlider.js.map +1 -0
  55. package/lib/cjs/components/transparency-slider/TransparencySlider.styles.js +123 -0
  56. package/lib/cjs/components/transparency-slider/TransparencySlider.styles.js.map +1 -0
  57. package/lib/cjs/constants/color.js +72 -0
  58. package/lib/cjs/constants/color.js.map +1 -0
  59. package/lib/cjs/index.js +48 -0
  60. package/lib/cjs/index.js.map +1 -0
  61. package/lib/cjs/types/colorPicker.js +2 -0
  62. package/lib/cjs/types/colorPicker.js.map +1 -0
  63. package/lib/cjs/utils/color.js +245 -0
  64. package/lib/cjs/utils/color.js.map +1 -0
  65. package/lib/esm/api/color/get.js +26 -0
  66. package/lib/esm/api/color/get.js.map +1 -0
  67. package/lib/esm/api/color/put.js +30 -0
  68. package/lib/esm/api/color/put.js.map +1 -0
  69. package/lib/esm/components/ColorPickerProvider.js +89 -0
  70. package/lib/esm/components/ColorPickerProvider.js.map +1 -0
  71. package/lib/esm/components/color-picker/ColorPicker.js +39 -0
  72. package/lib/esm/components/color-picker/ColorPicker.js.map +1 -0
  73. package/lib/esm/components/color-picker/ColorPicker.styles.js +5 -0
  74. package/lib/esm/components/color-picker/ColorPicker.styles.js.map +1 -0
  75. package/lib/esm/components/color-picker/color-picker-wrapper/ColorPickerWrapper.js +42 -0
  76. package/lib/esm/components/color-picker/color-picker-wrapper/ColorPickerWrapper.js.map +1 -0
  77. package/lib/esm/components/color-picker/color-picker-wrapper/ColorPickerWrapper.styles.js +69 -0
  78. package/lib/esm/components/color-picker/color-picker-wrapper/ColorPickerWrapper.styles.js.map +1 -0
  79. package/lib/esm/components/color-picker-popup/ColorPickerPopup.js +28 -0
  80. package/lib/esm/components/color-picker-popup/ColorPickerPopup.js.map +1 -0
  81. package/lib/esm/components/color-picker-popup/ColorPickerPopup.styles.js +6 -0
  82. package/lib/esm/components/color-picker-popup/ColorPickerPopup.styles.js.map +1 -0
  83. package/lib/esm/components/color-picker-popup/color-area/ColorArea.js +237 -0
  84. package/lib/esm/components/color-picker-popup/color-area/ColorArea.js.map +1 -0
  85. package/lib/esm/components/color-picker-popup/color-area/ColorArea.styles.js +38 -0
  86. package/lib/esm/components/color-picker-popup/color-area/ColorArea.styles.js.map +1 -0
  87. package/lib/esm/components/color-picker-popup/more-options/MoreOptions.js +82 -0
  88. package/lib/esm/components/color-picker-popup/more-options/MoreOptions.js.map +1 -0
  89. package/lib/esm/components/color-picker-popup/more-options/MoreOptions.styles.js +37 -0
  90. package/lib/esm/components/color-picker-popup/more-options/MoreOptions.styles.js.map +1 -0
  91. package/lib/esm/components/color-picker-popup/preset-colors/PresetColors.js +152 -0
  92. package/lib/esm/components/color-picker-popup/preset-colors/PresetColors.js.map +1 -0
  93. package/lib/esm/components/color-picker-popup/preset-colors/PresetColors.styles.js +8 -0
  94. package/lib/esm/components/color-picker-popup/preset-colors/PresetColors.styles.js.map +1 -0
  95. package/lib/esm/components/color-picker-popup/preset-colors/preset-button/PresetButton.js +40 -0
  96. package/lib/esm/components/color-picker-popup/preset-colors/preset-button/PresetButton.js.map +1 -0
  97. package/lib/esm/components/color-picker-popup/preset-colors/preset-button/PresetButton.styles.js +27 -0
  98. package/lib/esm/components/color-picker-popup/preset-colors/preset-button/PresetButton.styles.js.map +1 -0
  99. package/lib/esm/components/color-picker-popup/preset-colors/preset-color/PresetColor.js +43 -0
  100. package/lib/esm/components/color-picker-popup/preset-colors/preset-color/PresetColor.js.map +1 -0
  101. package/lib/esm/components/color-picker-popup/preset-colors/preset-color/PresetColor.styles.js +43 -0
  102. package/lib/esm/components/color-picker-popup/preset-colors/preset-color/PresetColor.styles.js.map +1 -0
  103. package/lib/esm/components/color-picker-popup/sliders/Sliders.js +67 -0
  104. package/lib/esm/components/color-picker-popup/sliders/Sliders.js.map +1 -0
  105. package/lib/esm/components/color-picker-popup/sliders/Sliders.styles.js +13 -0
  106. package/lib/esm/components/color-picker-popup/sliders/Sliders.styles.js.map +1 -0
  107. package/lib/esm/components/color-picker-popup/sliders/color-preview/ColorPreview.js +14 -0
  108. package/lib/esm/components/color-picker-popup/sliders/color-preview/ColorPreview.js.map +1 -0
  109. package/lib/esm/components/color-picker-popup/sliders/color-preview/ColorPreview.styles.js +42 -0
  110. package/lib/esm/components/color-picker-popup/sliders/color-preview/ColorPreview.styles.js.map +1 -0
  111. package/lib/esm/components/hue-slider/HueSlider.js +128 -0
  112. package/lib/esm/components/hue-slider/HueSlider.js.map +1 -0
  113. package/lib/esm/components/hue-slider/HueSlider.styles.js +84 -0
  114. package/lib/esm/components/hue-slider/HueSlider.styles.js.map +1 -0
  115. package/lib/esm/components/transparency-slider/TransparencySlider.js +115 -0
  116. package/lib/esm/components/transparency-slider/TransparencySlider.js.map +1 -0
  117. package/lib/esm/components/transparency-slider/TransparencySlider.styles.js +125 -0
  118. package/lib/esm/components/transparency-slider/TransparencySlider.styles.js.map +1 -0
  119. package/lib/esm/constants/color.js +66 -0
  120. package/lib/esm/constants/color.js.map +1 -0
  121. package/lib/esm/index.js +6 -0
  122. package/lib/esm/index.js.map +1 -0
  123. package/lib/esm/types/colorPicker.js +2 -0
  124. package/lib/esm/types/colorPicker.js.map +1 -0
  125. package/lib/esm/utils/color.js +229 -0
  126. package/lib/esm/utils/color.js.map +1 -0
  127. package/lib/types/api/color/get.d.ts +1 -0
  128. package/lib/types/api/color/put.d.ts +2 -0
  129. package/lib/types/components/ColorPickerProvider.d.ts +35 -0
  130. package/lib/types/components/color-picker/ColorPicker.d.ts +61 -0
  131. package/lib/types/components/color-picker/ColorPicker.styles.d.ts +1 -0
  132. package/lib/types/components/color-picker/color-picker-wrapper/ColorPickerWrapper.d.ts +20 -0
  133. package/lib/types/components/color-picker/color-picker-wrapper/ColorPickerWrapper.styles.d.ts +18 -0
  134. package/lib/types/components/color-picker-popup/ColorPickerPopup.d.ts +16 -0
  135. package/lib/types/components/color-picker-popup/ColorPickerPopup.styles.d.ts +1 -0
  136. package/lib/types/components/color-picker-popup/color-area/ColorArea.d.ts +6 -0
  137. package/lib/types/components/color-picker-popup/color-area/ColorArea.styles.d.ts +267 -0
  138. package/lib/types/components/color-picker-popup/more-options/MoreOptions.d.ts +6 -0
  139. package/lib/types/components/color-picker-popup/more-options/MoreOptions.styles.d.ts +9 -0
  140. package/lib/types/components/color-picker-popup/preset-colors/PresetColors.d.ts +13 -0
  141. package/lib/types/components/color-picker-popup/preset-colors/PresetColors.styles.d.ts +1 -0
  142. package/lib/types/components/color-picker-popup/preset-colors/preset-button/PresetButton.d.ts +13 -0
  143. package/lib/types/components/color-picker-popup/preset-colors/preset-button/PresetButton.styles.d.ts +6 -0
  144. package/lib/types/components/color-picker-popup/preset-colors/preset-color/PresetColor.d.ts +10 -0
  145. package/lib/types/components/color-picker-popup/preset-colors/preset-color/PresetColor.styles.d.ts +12 -0
  146. package/lib/types/components/color-picker-popup/sliders/Sliders.d.ts +9 -0
  147. package/lib/types/components/color-picker-popup/sliders/Sliders.styles.d.ts +2 -0
  148. package/lib/types/components/color-picker-popup/sliders/color-preview/ColorPreview.d.ts +6 -0
  149. package/lib/types/components/color-picker-popup/sliders/color-preview/ColorPreview.styles.d.ts +10 -0
  150. package/lib/types/components/hue-slider/HueSlider.d.ts +25 -0
  151. package/lib/types/components/hue-slider/HueSlider.styles.d.ts +15 -0
  152. package/lib/types/components/transparency-slider/TransparencySlider.d.ts +24 -0
  153. package/lib/types/components/transparency-slider/TransparencySlider.styles.d.ts +24 -0
  154. package/lib/types/constants/color.d.ts +3 -0
  155. package/lib/types/index.d.ts +6 -0
  156. package/lib/types/types/colorPicker.d.ts +27 -0
  157. package/lib/types/utils/color.d.ts +32 -0
  158. package/package.json +86 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HueSlider.js","names":["_colors","require","_chaynsApi","_react","_interopRequireWildcard","_color","_HueSlider","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","HueSlider","onChange","onStart","onEnd","opacity","color","editedValue","setEditedValue","useState","hslColor","setHslColor","internalOpacity","setInternalOpacity","sliderThumbRef","useRef","sliderRef","useEffect","rgb","isValidRGBA","splitRgb","hexToRgb","g","b","hsl","convertColorToHsl","match","toString","parseInt","handleInputChange","useCallback","event","Number","target","value","percentage","hue","saturation","lightness","hslToRgb255","h","s","l","sliderThumbPosition","useMemo","current","offsetWidth","handleStart","setRefreshScrollEnabled","extractHsl","handleEnd","createElement","StyledHueSlider","StyledHueSliderInput","ref","$color","type","min","max","onPointerDown","onPointerUp","StyledHueSliderThumb","$position","displayName","_default","exports"],"sources":["../../../../src/components/hue-slider/HueSlider.tsx"],"sourcesContent":["import { hslToRgb255 } from '@chayns/colors';\nimport { setRefreshScrollEnabled } from 'chayns-api';\nimport React, {\n ChangeEvent,\n CSSProperties,\n FC,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { convertColorToHsl, extractHsl, hexToRgb, isValidRGBA, splitRgb } from '../../utils/color';\nimport { StyledHueSlider, StyledHueSliderInput, StyledHueSliderThumb } from './HueSlider.styles';\n\nexport type HueSliderProps = {\n /**\n * The color that should be selected.\n */\n color?: CSSProperties['color'];\n /**\n * Function that will be executed when the color is changed.\n */\n onChange?: (rgb: CSSProperties['color'], hsl: CSSProperties['color']) => void;\n /**\n * Function that will be executed when the color is ending to change.\n */\n onEnd?: (rgb: CSSProperties['color'], hsl: CSSProperties['color']) => void;\n /**\n * Function that will be executed when the color is starting to change.\n */\n onStart?: (rgb: CSSProperties['color'], hsl: CSSProperties['color']) => void;\n /**\n * The opacity of the Color. Is used if the color has no opacity value.\n */\n opacity?: number;\n};\n\nconst HueSlider: FC<HueSliderProps> = ({\n onChange,\n onStart,\n onEnd,\n opacity,\n color = 'rgba(255, 0, 0, 1)',\n}) => {\n const [editedValue, setEditedValue] = useState(0);\n const [hslColor, setHslColor] = useState<CSSProperties['color']>('hsl(0, 0, 100)');\n const [internalOpacity, setInternalOpacity] = useState(1);\n\n const sliderThumbRef = useRef<HTMLDivElement>(null);\n const sliderRef = useRef<HTMLInputElement>(null);\n\n useEffect(() => {\n if (color) {\n let rgb;\n\n if (isValidRGBA(color)) {\n rgb = splitRgb(color);\n } else {\n rgb = hexToRgb(color);\n }\n\n if (!rgb) {\n return;\n }\n\n const { r, g, b, a } = rgb;\n\n setInternalOpacity(a);\n\n const hsl = convertColorToHsl(`rgba(${r}, ${g}, ${b}, 1)`);\n const match = hsl?.toString().match(/hsl\\((\\d+),\\s*([\\d.]+)%,\\s*([\\d.]+)%\\)/);\n\n if (!match || !match[1]) {\n return;\n }\n\n setHslColor(`hsl(${match[1]}, 100%, 50%)`);\n setEditedValue(parseInt(match[1], 10));\n }\n }, [color]);\n\n const handleInputChange = useCallback(\n (event: ChangeEvent<HTMLInputElement>) => {\n setEditedValue(Number(event.target.value));\n\n const percentage = (Number(event.target.value) / 360) * 100;\n const hue = (percentage / 100) * 360;\n const saturation = 100;\n const lightness = 50;\n\n const hsl = `hsl(${hue}, ${saturation}%, ${lightness}%)`;\n setHslColor(hsl);\n\n if (typeof onChange === 'function') {\n const rgb = hslToRgb255({ h: hue, s: 1, l: 0.5 });\n\n if (!rgb) {\n return;\n }\n\n onChange(`rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${opacity ?? internalOpacity})`, hsl);\n }\n },\n [internalOpacity, onChange, opacity],\n );\n\n const sliderThumbPosition = useMemo(() => {\n if (sliderRef.current && sliderThumbRef.current) {\n return (\n (editedValue / 360) *\n (sliderRef.current.offsetWidth - sliderThumbRef.current.offsetWidth / 2)\n );\n }\n return 0;\n }, [editedValue]);\n\n const handleStart = useCallback(() => {\n void setRefreshScrollEnabled(false);\n\n if (typeof onStart === 'function' && hslColor) {\n const hsl = extractHsl(hslColor);\n\n if (!hsl) {\n return;\n }\n\n const rgb = hslToRgb255(hsl);\n\n if (!rgb) {\n return;\n }\n\n const { r, g, b } = rgb;\n\n onStart(`rgba(${r}, ${g}, ${b}, ${opacity ?? internalOpacity})`, hslColor);\n }\n }, [hslColor, internalOpacity, onStart, opacity]);\n\n const handleEnd = useCallback(() => {\n void setRefreshScrollEnabled(true);\n\n if (typeof onEnd === 'function' && hslColor) {\n const hsl = extractHsl(hslColor);\n\n if (!hsl) {\n return;\n }\n\n const rgb = hslToRgb255(hsl);\n\n if (!rgb) {\n return;\n }\n\n const { r, g, b } = rgb;\n\n onEnd(`rgba(${r}, ${g}, ${b}, ${opacity ?? internalOpacity})`, hslColor);\n }\n }, [hslColor, internalOpacity, onEnd, opacity]);\n\n return useMemo(\n () => (\n <StyledHueSlider>\n <StyledHueSliderInput\n ref={sliderRef}\n $color={hslColor}\n type=\"range\"\n min={0}\n max={360}\n value={editedValue}\n onChange={handleInputChange}\n onPointerDown={handleStart}\n onPointerUp={handleEnd}\n />\n <StyledHueSliderThumb\n ref={sliderThumbRef}\n $position={sliderThumbPosition}\n $color={hslColor}\n />\n </StyledHueSlider>\n ),\n [editedValue, handleEnd, handleInputChange, handleStart, hslColor, sliderThumbPosition],\n );\n};\n\nHueSlider.displayName = 'HueSlider';\n\nexport default HueSlider;\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,88 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.StyledHueSliderThumb = exports.StyledHueSliderInput = exports.StyledHueSlider = void 0;
7
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
8
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
9
+ const StyledHueSlider = exports.StyledHueSlider = _styledComponents.default.div`
10
+ width: 100%;
11
+ height: 30px;
12
+ cursor: pointer;
13
+ position: relative;
14
+ display: flex;
15
+ align-items: center;
16
+ justify-content: center;
17
+ touch-action: none;
18
+ `;
19
+ const StyledHueSliderInput = exports.StyledHueSliderInput = _styledComponents.default.input`
20
+ width: calc(100% - 10px);
21
+ border-radius: 100px;
22
+ -webkit-appearance: none;
23
+ height: 10px;
24
+ background: linear-gradient(
25
+ to right,
26
+ hsl(0, 100%, 50%),
27
+ hsl(30, 100%, 50%),
28
+ hsl(60, 100%, 50%),
29
+ hsl(90, 100%, 50%),
30
+ hsl(120, 100%, 50%),
31
+ hsl(150, 100%, 50%),
32
+ hsl(180, 100%, 50%),
33
+ hsl(210, 100%, 50%),
34
+ hsl(240, 100%, 50%),
35
+ hsl(270, 100%, 50%),
36
+ hsl(300, 100%, 50%),
37
+ hsl(330, 100%, 50%),
38
+ hsl(360, 100%, 50%)
39
+ );
40
+ outline: none;
41
+ opacity: 0.7;
42
+ -webkit-transition: 0.2s;
43
+ transition: opacity 0.2s;
44
+
45
+ // Slider thumb for chrome
46
+ &::-webkit-slider-thumb {
47
+ -webkit-appearance: none;
48
+ appearance: none;
49
+ width: 20px;
50
+ height: 20px;
51
+ opacity: 0;
52
+ cursor: pointer;
53
+ border-radius: 50%;
54
+ }
55
+
56
+ // slider thumb for firefox
57
+ &::-moz-range-thumb {
58
+ width: 20px;
59
+ opacity: 0;
60
+ height: 20px;
61
+ cursor: pointer;
62
+ border-radius: 50%;
63
+ }
64
+ `;
65
+ const StyledHueSliderThumb = exports.StyledHueSliderThumb = _styledComponents.default.div.attrs(({
66
+ $position,
67
+ $color
68
+ }) => ({
69
+ style: {
70
+ left: `${$position}px`,
71
+ backgroundColor: $color
72
+ }
73
+ }))`
74
+ min-width: 20px;
75
+ height: 20px;
76
+ cursor: pointer;
77
+ border-radius: 100px;
78
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);
79
+ pointer-events: none;
80
+ z-index: 3;
81
+ position: absolute;
82
+ display: flex;
83
+ align-items: center;
84
+ justify-content: center;
85
+ padding: 0 8px;
86
+ white-space: nowrap;
87
+ `;
88
+ //# sourceMappingURL=HueSlider.styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HueSlider.styles.js","names":["_styledComponents","_interopRequireDefault","require","e","__esModule","default","StyledHueSlider","exports","styled","div","StyledHueSliderInput","input","StyledHueSliderThumb","attrs","$position","$color","style","left","backgroundColor"],"sources":["../../../../src/components/hue-slider/HueSlider.styles.ts"],"sourcesContent":["import type { WithTheme } from '@chayns-components/core';\nimport type { CSSProperties } from 'react';\nimport styled from 'styled-components';\n\nexport const StyledHueSlider = styled.div`\n width: 100%;\n height: 30px;\n cursor: pointer;\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n touch-action: none;\n`;\n\ntype StyledHueSliderInputProps = WithTheme<{\n $color: CSSProperties['color'];\n}>;\n\nexport const StyledHueSliderInput = styled.input<StyledHueSliderInputProps>`\n width: calc(100% - 10px);\n border-radius: 100px;\n -webkit-appearance: none;\n height: 10px;\n background: linear-gradient(\n to right,\n hsl(0, 100%, 50%),\n hsl(30, 100%, 50%),\n hsl(60, 100%, 50%),\n hsl(90, 100%, 50%),\n hsl(120, 100%, 50%),\n hsl(150, 100%, 50%),\n hsl(180, 100%, 50%),\n hsl(210, 100%, 50%),\n hsl(240, 100%, 50%),\n hsl(270, 100%, 50%),\n hsl(300, 100%, 50%),\n hsl(330, 100%, 50%),\n hsl(360, 100%, 50%)\n );\n outline: none;\n opacity: 0.7;\n -webkit-transition: 0.2s;\n transition: opacity 0.2s;\n\n // Slider thumb for chrome\n &::-webkit-slider-thumb {\n -webkit-appearance: none;\n appearance: none;\n width: 20px;\n height: 20px;\n opacity: 0;\n cursor: pointer;\n border-radius: 50%;\n }\n\n // slider thumb for firefox\n &::-moz-range-thumb {\n width: 20px;\n opacity: 0;\n height: 20px;\n cursor: pointer;\n border-radius: 50%;\n }\n`;\n\ntype StyledHueSliderThumbProps = WithTheme<{ $position: number; $color: CSSProperties['color'] }>;\n\nexport const StyledHueSliderThumb = styled.div.attrs<StyledHueSliderThumbProps>(\n ({ $position, $color }) => ({\n style: {\n left: `${$position}px`,\n backgroundColor: $color,\n },\n }),\n)`\n min-width: 20px;\n height: 20px;\n cursor: pointer;\n border-radius: 100px;\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);\n pointer-events: none;\n z-index: 3;\n position: absolute;\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 0 8px;\n white-space: nowrap;\n`;\n"],"mappings":";;;;;;AAEA,IAAAA,iBAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAuC,SAAAD,uBAAAE,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAEhC,MAAMG,eAAe,GAAAC,OAAA,CAAAD,eAAA,GAAGE,yBAAM,CAACC,GAAG;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AAMM,MAAMC,oBAAoB,GAAAH,OAAA,CAAAG,oBAAA,GAAGF,yBAAM,CAACG,KAAgC;AAC3E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AAIM,MAAMC,oBAAoB,GAAAL,OAAA,CAAAK,oBAAA,GAAGJ,yBAAM,CAACC,GAAG,CAACI,KAAK,CAChD,CAAC;EAAEC,SAAS;EAAEC;AAAO,CAAC,MAAM;EACxBC,KAAK,EAAE;IACHC,IAAI,EAAE,GAAGH,SAAS,IAAI;IACtBI,eAAe,EAAEH;EACrB;AACJ,CAAC,CACL,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC","ignoreList":[]}
@@ -0,0 +1,122 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _chaynsApi = require("chayns-api");
8
+ var _react = _interopRequireWildcard(require("react"));
9
+ var _color = require("../../utils/color");
10
+ var _TransparencySlider = require("./TransparencySlider.styles");
11
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
12
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
13
+ const TransparencySlider = ({
14
+ onChange,
15
+ onStart,
16
+ onEnd,
17
+ color = 'rgba(255, 0, 0, 1)'
18
+ }) => {
19
+ const [editedValue, setEditedValue] = (0, _react.useState)(0);
20
+ const [pureColor, setPureColor] = (0, _react.useState)();
21
+ const [previewColor, setPreviewColor] = (0, _react.useState)();
22
+ const sliderThumbRef = (0, _react.useRef)(null);
23
+ const sliderRef = (0, _react.useRef)(null);
24
+ (0, _react.useEffect)(() => {
25
+ if (color) {
26
+ let rgb;
27
+ if ((0, _color.isValidRGBA)(color)) {
28
+ rgb = (0, _color.splitRgb)(color);
29
+ } else {
30
+ rgb = (0, _color.hexToRgb)(color);
31
+ }
32
+ if (!rgb) {
33
+ return;
34
+ }
35
+ const {
36
+ r,
37
+ g,
38
+ b,
39
+ a
40
+ } = rgb;
41
+ const newColor = `rgba(${r}, ${g}, ${b}, ${a})`;
42
+ setPreviewColor(newColor);
43
+ setPureColor(`rgb(${r},${g},${b},1)`);
44
+ setEditedValue(100 - a * 100);
45
+ }
46
+ }, [color]);
47
+ const handleInputChange = (0, _react.useCallback)(event => {
48
+ const a = Number(event.target.value);
49
+ setEditedValue(a);
50
+ const rgb = (0, _color.splitRgb)(pureColor);
51
+ if (!rgb) {
52
+ return;
53
+ }
54
+ const {
55
+ r,
56
+ g,
57
+ b
58
+ } = rgb;
59
+ const newColor = `rgba(${r}, ${g}, ${b}, ${(100 - a) / 100})`;
60
+ setPreviewColor(newColor);
61
+ if (typeof onChange === 'function') {
62
+ onChange(newColor);
63
+ }
64
+ }, [onChange, pureColor]);
65
+ const sliderThumbPosition = (0, _react.useMemo)(() => {
66
+ if (sliderRef.current && sliderThumbRef.current) {
67
+ return editedValue / 100 * (sliderRef.current.offsetWidth - sliderThumbRef.current.offsetWidth / 2);
68
+ }
69
+ return 0;
70
+ }, [editedValue]);
71
+ const handleStart = (0, _react.useCallback)(() => {
72
+ void (0, _chaynsApi.setRefreshScrollEnabled)(false);
73
+ if (typeof onStart === 'function') {
74
+ const rgb = (0, _color.splitRgb)(pureColor);
75
+ if (!rgb) {
76
+ return;
77
+ }
78
+ const {
79
+ r,
80
+ g,
81
+ b
82
+ } = rgb;
83
+ const newColor = `rgba(${r}, ${g}, ${b}, ${(100 - editedValue) / 100})`;
84
+ onStart(newColor);
85
+ }
86
+ }, [editedValue, onStart, pureColor]);
87
+ const handleEnd = (0, _react.useCallback)(() => {
88
+ void (0, _chaynsApi.setRefreshScrollEnabled)(true);
89
+ if (typeof onEnd === 'function') {
90
+ const rgb = (0, _color.splitRgb)(pureColor);
91
+ if (!rgb) {
92
+ return;
93
+ }
94
+ const {
95
+ r,
96
+ g,
97
+ b
98
+ } = rgb;
99
+ const newColor = `rgba(${r}, ${g}, ${b}, ${(100 - editedValue) / 100})`;
100
+ onEnd(newColor);
101
+ }
102
+ }, [editedValue, onEnd, pureColor]);
103
+ return /*#__PURE__*/_react.default.createElement(_TransparencySlider.StyledTransparencySlider, null, /*#__PURE__*/_react.default.createElement(_TransparencySlider.StyledTransparencySliderInput, {
104
+ ref: sliderRef,
105
+ $color: pureColor,
106
+ type: "range",
107
+ min: 0,
108
+ max: 100,
109
+ value: editedValue,
110
+ onPointerDown: handleStart,
111
+ onPointerUp: handleEnd,
112
+ onChange: handleInputChange
113
+ }), /*#__PURE__*/_react.default.createElement(_TransparencySlider.StyledTransparencySliderBackground, null), /*#__PURE__*/_react.default.createElement(_TransparencySlider.StyledTransparencySliderThumbWrapper, {
114
+ ref: sliderThumbRef,
115
+ $position: sliderThumbPosition
116
+ }, /*#__PURE__*/_react.default.createElement(_TransparencySlider.StyledTransparencySliderThumbBackground, null), /*#__PURE__*/_react.default.createElement(_TransparencySlider.StyledTransparencySliderThumb, {
117
+ $color: previewColor
118
+ })));
119
+ };
120
+ TransparencySlider.displayName = 'TransparencySlider';
121
+ var _default = exports.default = TransparencySlider;
122
+ //# sourceMappingURL=TransparencySlider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TransparencySlider.js","names":["_chaynsApi","require","_react","_interopRequireWildcard","_color","_TransparencySlider","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","TransparencySlider","onChange","onStart","onEnd","color","editedValue","setEditedValue","useState","pureColor","setPureColor","previewColor","setPreviewColor","sliderThumbRef","useRef","sliderRef","useEffect","rgb","isValidRGBA","splitRgb","hexToRgb","g","b","newColor","handleInputChange","useCallback","event","Number","target","value","sliderThumbPosition","useMemo","current","offsetWidth","handleStart","setRefreshScrollEnabled","handleEnd","createElement","StyledTransparencySlider","StyledTransparencySliderInput","ref","$color","type","min","max","onPointerDown","onPointerUp","StyledTransparencySliderBackground","StyledTransparencySliderThumbWrapper","$position","StyledTransparencySliderThumbBackground","StyledTransparencySliderThumb","displayName","_default","exports"],"sources":["../../../../src/components/transparency-slider/TransparencySlider.tsx"],"sourcesContent":["import { setRefreshScrollEnabled } from 'chayns-api';\nimport React, { ChangeEvent, useCallback, useEffect, useMemo, useRef, useState } from 'react';\nimport { hexToRgb, isValidRGBA, splitRgb } from '../../utils/color';\nimport {\n StyledTransparencySlider,\n StyledTransparencySliderBackground,\n StyledTransparencySliderInput,\n StyledTransparencySliderThumb,\n StyledTransparencySliderThumbBackground,\n StyledTransparencySliderThumbWrapper,\n} from './TransparencySlider.styles';\n\ninterface TransparencySliderProps {\n /**\n * The color that should be selected.\n */\n color?: string;\n /**\n * Function that will be executed when the opacity is changed.\n */\n onChange?: (color: string) => void;\n /**\n * Function that will be executed when the opacity is ending to change.\n */\n onEnd?: (color: string) => void;\n /**\n * Function that will be executed when the opacity is starting to change.\n */\n onStart?: (color: string) => void;\n}\n\nconst TransparencySlider = ({\n onChange,\n onStart,\n onEnd,\n color = 'rgba(255, 0, 0, 1)',\n}: TransparencySliderProps) => {\n const [editedValue, setEditedValue] = useState(0);\n const [pureColor, setPureColor] = useState<string>();\n const [previewColor, setPreviewColor] = useState<string>();\n\n const sliderThumbRef = useRef<HTMLDivElement>(null);\n const sliderRef = useRef<HTMLInputElement>(null);\n\n useEffect(() => {\n if (color) {\n let rgb;\n\n if (isValidRGBA(color)) {\n rgb = splitRgb(color);\n } else {\n rgb = hexToRgb(color);\n }\n\n if (!rgb) {\n return;\n }\n\n const { r, g, b, a } = rgb;\n\n const newColor = `rgba(${r}, ${g}, ${b}, ${a})`;\n\n setPreviewColor(newColor);\n setPureColor(`rgb(${r},${g},${b},1)`);\n setEditedValue(100 - a * 100);\n }\n }, [color]);\n\n const handleInputChange = useCallback(\n (event: ChangeEvent<HTMLInputElement>) => {\n const a = Number(event.target.value);\n\n setEditedValue(a);\n\n const rgb = splitRgb(pureColor);\n\n if (!rgb) {\n return;\n }\n\n const { r, g, b } = rgb;\n\n const newColor = `rgba(${r}, ${g}, ${b}, ${(100 - a) / 100})`;\n\n setPreviewColor(newColor);\n\n if (typeof onChange === 'function') {\n onChange(newColor);\n }\n },\n [onChange, pureColor],\n );\n\n const sliderThumbPosition = useMemo(() => {\n if (sliderRef.current && sliderThumbRef.current) {\n return (\n (editedValue / 100) *\n (sliderRef.current.offsetWidth - sliderThumbRef.current.offsetWidth / 2)\n );\n }\n return 0;\n }, [editedValue]);\n\n const handleStart = useCallback(() => {\n void setRefreshScrollEnabled(false);\n\n if (typeof onStart === 'function') {\n const rgb = splitRgb(pureColor);\n\n if (!rgb) {\n return;\n }\n\n const { r, g, b } = rgb;\n\n const newColor = `rgba(${r}, ${g}, ${b}, ${(100 - editedValue) / 100})`;\n\n onStart(newColor);\n }\n }, [editedValue, onStart, pureColor]);\n\n const handleEnd = useCallback(() => {\n void setRefreshScrollEnabled(true);\n\n if (typeof onEnd === 'function') {\n const rgb = splitRgb(pureColor);\n\n if (!rgb) {\n return;\n }\n\n const { r, g, b } = rgb;\n\n const newColor = `rgba(${r}, ${g}, ${b}, ${(100 - editedValue) / 100})`;\n\n onEnd(newColor);\n }\n }, [editedValue, onEnd, pureColor]);\n\n return (\n <StyledTransparencySlider>\n <StyledTransparencySliderInput\n ref={sliderRef}\n $color={pureColor}\n type=\"range\"\n min={0}\n max={100}\n value={editedValue}\n onPointerDown={handleStart}\n onPointerUp={handleEnd}\n onChange={handleInputChange}\n />\n <StyledTransparencySliderBackground />\n <StyledTransparencySliderThumbWrapper\n ref={sliderThumbRef}\n $position={sliderThumbPosition}\n >\n <StyledTransparencySliderThumbBackground />\n <StyledTransparencySliderThumb $color={previewColor} />\n </StyledTransparencySliderThumbWrapper>\n </StyledTransparencySlider>\n );\n};\n\nTransparencySlider.displayName = 'TransparencySlider';\n\nexport default TransparencySlider;\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,123 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.StyledTransparencySliderThumbWrapper = exports.StyledTransparencySliderThumbBackground = exports.StyledTransparencySliderThumb = exports.StyledTransparencySliderInput = exports.StyledTransparencySliderBackground = exports.StyledTransparencySlider = void 0;
7
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
8
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
9
+ const StyledTransparencySlider = exports.StyledTransparencySlider = _styledComponents.default.div`
10
+ width: 100%;
11
+ height: 30px;
12
+ cursor: pointer;
13
+ position: relative;
14
+ display: flex;
15
+ align-items: center;
16
+ justify-content: center;
17
+ touch-action: none;
18
+ `;
19
+ const StyledTransparencySliderBackground = exports.StyledTransparencySliderBackground = _styledComponents.default.div`
20
+ height: 10px;
21
+ background-color: #fff;
22
+ background-image: linear-gradient(45deg, #a0a0a0 25%, #0000 0),
23
+ linear-gradient(-45deg, #a0a0a0 25%, #0000 0), linear-gradient(45deg, #0000 75%, #a0a0a0 0),
24
+ linear-gradient(-45deg, #0000 75%, #a0a0a0 0);
25
+ background-position:
26
+ 0 0,
27
+ 0 4px,
28
+ 4px -4px,
29
+ -4px 0;
30
+ background-repeat: repeat;
31
+ border-radius: 100px;
32
+ background-size: 8px 8px;
33
+ content: '';
34
+ position: absolute;
35
+ width: calc(100% - 10px);
36
+ `;
37
+ const StyledTransparencySliderInput = exports.StyledTransparencySliderInput = _styledComponents.default.input.attrs(({
38
+ $color
39
+ }) => ({
40
+ style: {
41
+ background: `linear-gradient(90deg, ${$color ?? ''}, transparent)`
42
+ }
43
+ }))`
44
+ width: calc(100% - 10px);
45
+ border-radius: 100px;
46
+ -webkit-appearance: none;
47
+ height: 10px;
48
+ outline: none;
49
+ opacity: 0.7;
50
+ -webkit-transition: 0.2s;
51
+ transition: opacity 0.2s;
52
+ z-index: 4;
53
+
54
+ // Slider thumb for chrome
55
+ &::-webkit-slider-thumb {
56
+ -webkit-appearance: none;
57
+ appearance: none;
58
+ opacity: 0;
59
+ width: 20px;
60
+ height: 20px;
61
+ cursor: pointer;
62
+ border-radius: 50%;
63
+ }
64
+
65
+ // slider thumb for firefox
66
+ &::-moz-range-thumb {
67
+ width: 20px;
68
+ height: 20px;
69
+ opacity: 0;
70
+ cursor: pointer;
71
+ border-radius: 50%;
72
+ }
73
+ `;
74
+ const StyledTransparencySliderThumbWrapper = exports.StyledTransparencySliderThumbWrapper = _styledComponents.default.div.attrs(({
75
+ $position
76
+ }) => ({
77
+ style: {
78
+ left: $position
79
+ }
80
+ }))`
81
+ position: absolute;
82
+ min-width: 20px;
83
+ height: 20px;
84
+ cursor: pointer;
85
+ border-radius: 100px;
86
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);
87
+ pointer-events: none;
88
+ z-index: 3;
89
+ display: flex;
90
+ align-items: center;
91
+ justify-content: center;
92
+ overflow: hidden;
93
+ padding: 0 8px;
94
+ white-space: nowrap;
95
+ `;
96
+ const StyledTransparencySliderThumbBackground = exports.StyledTransparencySliderThumbBackground = _styledComponents.default.div`
97
+ position: absolute;
98
+ background-color: #fff;
99
+ background-image: linear-gradient(45deg, #a0a0a0 25%, #0000 0),
100
+ linear-gradient(-45deg, #a0a0a0 25%, #0000 0), linear-gradient(45deg, #0000 75%, #a0a0a0 0),
101
+ linear-gradient(-45deg, #0000 75%, #a0a0a0 0);
102
+ background-position:
103
+ 0 0,
104
+ 0 4px,
105
+ 4px -4px,
106
+ -4px 0;
107
+ background-repeat: repeat;
108
+ background-size: 8px 8px;
109
+ height: 100%;
110
+ width: 100%;
111
+ `;
112
+ const StyledTransparencySliderThumb = exports.StyledTransparencySliderThumb = _styledComponents.default.div.attrs(({
113
+ $color
114
+ }) => ({
115
+ style: {
116
+ backgroundColor: $color
117
+ }
118
+ }))`
119
+ height: 100%;
120
+ width: 100%;
121
+ position: absolute;
122
+ `;
123
+ //# sourceMappingURL=TransparencySlider.styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TransparencySlider.styles.js","names":["_styledComponents","_interopRequireDefault","require","e","__esModule","default","StyledTransparencySlider","exports","styled","div","StyledTransparencySliderBackground","StyledTransparencySliderInput","input","attrs","$color","style","background","StyledTransparencySliderThumbWrapper","$position","left","StyledTransparencySliderThumbBackground","StyledTransparencySliderThumb","backgroundColor"],"sources":["../../../../src/components/transparency-slider/TransparencySlider.styles.ts"],"sourcesContent":["import type { WithTheme } from '@chayns-components/core';\nimport type { CSSProperties } from 'react';\nimport styled from 'styled-components';\n\nexport const StyledTransparencySlider = styled.div`\n width: 100%;\n height: 30px;\n cursor: pointer;\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n touch-action: none;\n`;\n\nexport const StyledTransparencySliderBackground = styled.div`\n height: 10px;\n background-color: #fff;\n background-image: linear-gradient(45deg, #a0a0a0 25%, #0000 0),\n linear-gradient(-45deg, #a0a0a0 25%, #0000 0), linear-gradient(45deg, #0000 75%, #a0a0a0 0),\n linear-gradient(-45deg, #0000 75%, #a0a0a0 0);\n background-position:\n 0 0,\n 0 4px,\n 4px -4px,\n -4px 0;\n background-repeat: repeat;\n border-radius: 100px;\n background-size: 8px 8px;\n content: '';\n position: absolute;\n width: calc(100% - 10px);\n`;\n\ntype StyledTransparencySliderInputProps = WithTheme<{ $color?: string }>;\n\nexport const StyledTransparencySliderInput = styled.input.attrs<StyledTransparencySliderInputProps>(\n ({ $color }) => ({\n style: {\n background: `linear-gradient(90deg, ${$color ?? ''}, transparent)`,\n },\n }),\n)`\n width: calc(100% - 10px);\n border-radius: 100px;\n -webkit-appearance: none;\n height: 10px;\n outline: none;\n opacity: 0.7;\n -webkit-transition: 0.2s;\n transition: opacity 0.2s;\n z-index: 4;\n\n // Slider thumb for chrome\n &::-webkit-slider-thumb {\n -webkit-appearance: none;\n appearance: none;\n opacity: 0;\n width: 20px;\n height: 20px;\n cursor: pointer;\n border-radius: 50%;\n }\n\n // slider thumb for firefox\n &::-moz-range-thumb {\n width: 20px;\n height: 20px;\n opacity: 0;\n cursor: pointer;\n border-radius: 50%;\n }\n`;\n\ntype StyledTransparencySliderThumbWrapperProps = WithTheme<{\n $position: number;\n}>;\n\nexport const StyledTransparencySliderThumbWrapper = styled.div.attrs<StyledTransparencySliderThumbWrapperProps>(\n ({ $position }) => ({\n style: {\n left: $position,\n },\n }),\n)`\n position: absolute;\n min-width: 20px;\n height: 20px;\n cursor: pointer;\n border-radius: 100px;\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);\n pointer-events: none;\n z-index: 3;\n display: flex;\n align-items: center;\n justify-content: center;\n overflow: hidden;\n padding: 0 8px;\n white-space: nowrap;\n`;\n\nexport const StyledTransparencySliderThumbBackground = styled.div`\n position: absolute;\n background-color: #fff;\n background-image: linear-gradient(45deg, #a0a0a0 25%, #0000 0),\n linear-gradient(-45deg, #a0a0a0 25%, #0000 0), linear-gradient(45deg, #0000 75%, #a0a0a0 0),\n linear-gradient(-45deg, #0000 75%, #a0a0a0 0);\n background-position:\n 0 0,\n 0 4px,\n 4px -4px,\n -4px 0;\n background-repeat: repeat;\n background-size: 8px 8px;\n height: 100%;\n width: 100%;\n`;\n\ntype StyledTransparencySliderThumbProps = WithTheme<{\n $color: CSSProperties['color'];\n}>;\n\nexport const StyledTransparencySliderThumb = styled.div.attrs<StyledTransparencySliderThumbProps>(\n ({ $color }) => ({\n style: {\n backgroundColor: $color,\n },\n }),\n)`\n height: 100%;\n width: 100%;\n position: absolute;\n`;\n"],"mappings":";;;;;;AAEA,IAAAA,iBAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAuC,SAAAD,uBAAAE,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAEhC,MAAMG,wBAAwB,GAAAC,OAAA,CAAAD,wBAAA,GAAGE,yBAAM,CAACC,GAAG;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AAEM,MAAMC,kCAAkC,GAAAH,OAAA,CAAAG,kCAAA,GAAGF,yBAAM,CAACC,GAAG;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AAIM,MAAME,6BAA6B,GAAAJ,OAAA,CAAAI,6BAAA,GAAGH,yBAAM,CAACI,KAAK,CAACC,KAAK,CAC3D,CAAC;EAAEC;AAAO,CAAC,MAAM;EACbC,KAAK,EAAE;IACHC,UAAU,EAAE,0BAA0BF,MAAM,IAAI,EAAE;EACtD;AACJ,CAAC,CACL,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AAMM,MAAMG,oCAAoC,GAAAV,OAAA,CAAAU,oCAAA,GAAGT,yBAAM,CAACC,GAAG,CAACI,KAAK,CAChE,CAAC;EAAEK;AAAU,CAAC,MAAM;EAChBH,KAAK,EAAE;IACHI,IAAI,EAAED;EACV;AACJ,CAAC,CACL,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AAEM,MAAME,uCAAuC,GAAAb,OAAA,CAAAa,uCAAA,GAAGZ,yBAAM,CAACC,GAAG;AACjE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AAMM,MAAMY,6BAA6B,GAAAd,OAAA,CAAAc,6BAAA,GAAGb,yBAAM,CAACC,GAAG,CAACI,KAAK,CACzD,CAAC;EAAEC;AAAO,CAAC,MAAM;EACbC,KAAK,EAAE;IACHO,eAAe,EAAER;EACrB;AACJ,CAAC,CACL,CAAC;AACD;AACA;AACA;AACA,CAAC","ignoreList":[]}
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.PRESETCOLORS = exports.ITEM_STORAGE_URL = void 0;
7
+ const PRESETCOLORS = exports.PRESETCOLORS = [{
8
+ id: '0',
9
+ color: 'rgba(0,0,0,1)'
10
+ }, {
11
+ id: '1',
12
+ color: 'rgba(67,67,67,1)'
13
+ }, {
14
+ id: '2',
15
+ color: 'rgba(102,102,102,1)'
16
+ }, {
17
+ id: '3',
18
+ color: 'rgba(153,153,153,1)'
19
+ }, {
20
+ id: '4',
21
+ color: 'rgba(183,183,183,1)'
22
+ }, {
23
+ id: '5',
24
+ color: 'rgba(204,204,204,1)'
25
+ }, {
26
+ id: '6',
27
+ color: 'rgba(217,217,217,1)'
28
+ }, {
29
+ id: '7',
30
+ color: 'rgba(239,239,239,1)'
31
+ }, {
32
+ id: '8',
33
+ color: 'rgba(243,243,243,1)'
34
+ }, {
35
+ id: '9',
36
+ color: 'rgba(255,255,255,1)'
37
+ }, {
38
+ id: '10',
39
+ color: 'rgba(244,67,54,1)'
40
+ }, {
41
+ id: '11',
42
+ color: 'rgba(255,152,0,1)'
43
+ }, {
44
+ id: '12',
45
+ color: 'rgba(255,235,59,1)'
46
+ }, {
47
+ id: '13',
48
+ color: 'rgba(0,150,136,1)'
49
+ }, {
50
+ id: '14',
51
+ color: 'rgba(121,85,72,1)'
52
+ }, {
53
+ id: '15',
54
+ color: 'rgba(139,195,74,1)'
55
+ }, {
56
+ id: '16',
57
+ color: 'rgba(76,175,80,1)'
58
+ }, {
59
+ id: '17',
60
+ color: 'rgba(156,39,176,1)'
61
+ }, {
62
+ id: '18',
63
+ color: 'rgba(63,81,181,1)'
64
+ }, {
65
+ id: '19',
66
+ color: 'rgba(3,169,244,1)'
67
+ }, {
68
+ id: '20',
69
+ color: 'rgba(0,94,184,1)'
70
+ }];
71
+ const ITEM_STORAGE_URL = exports.ITEM_STORAGE_URL = 'https://cube.tobit.cloud/item-storage/api/v1.0';
72
+ //# sourceMappingURL=color.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"color.js","names":["PRESETCOLORS","exports","id","color","ITEM_STORAGE_URL"],"sources":["../../../src/constants/color.ts"],"sourcesContent":["import type { IPresetColor } from '../types/colorPicker';\n\nexport const PRESETCOLORS: IPresetColor[] = [\n { id: '0', color: 'rgba(0,0,0,1)' },\n { id: '1', color: 'rgba(67,67,67,1)' },\n { id: '2', color: 'rgba(102,102,102,1)' },\n { id: '3', color: 'rgba(153,153,153,1)' },\n { id: '4', color: 'rgba(183,183,183,1)' },\n { id: '5', color: 'rgba(204,204,204,1)' },\n { id: '6', color: 'rgba(217,217,217,1)' },\n { id: '7', color: 'rgba(239,239,239,1)' },\n { id: '8', color: 'rgba(243,243,243,1)' },\n { id: '9', color: 'rgba(255,255,255,1)' },\n { id: '10', color: 'rgba(244,67,54,1)' },\n { id: '11', color: 'rgba(255,152,0,1)' },\n { id: '12', color: 'rgba(255,235,59,1)' },\n { id: '13', color: 'rgba(0,150,136,1)' },\n { id: '14', color: 'rgba(121,85,72,1)' },\n { id: '15', color: 'rgba(139,195,74,1)' },\n { id: '16', color: 'rgba(76,175,80,1)' },\n { id: '17', color: 'rgba(156,39,176,1)' },\n { id: '18', color: 'rgba(63,81,181,1)' },\n { id: '19', color: 'rgba(3,169,244,1)' },\n { id: '20', color: 'rgba(0,94,184,1)' },\n];\n\nexport const ITEM_STORAGE_URL = 'https://cube.tobit.cloud/item-storage/api/v1.0';\n"],"mappings":";;;;;;AAEO,MAAMA,YAA4B,GAAAC,OAAA,CAAAD,YAAA,GAAG,CACxC;EAAEE,EAAE,EAAE,GAAG;EAAEC,KAAK,EAAE;AAAgB,CAAC,EACnC;EAAED,EAAE,EAAE,GAAG;EAAEC,KAAK,EAAE;AAAmB,CAAC,EACtC;EAAED,EAAE,EAAE,GAAG;EAAEC,KAAK,EAAE;AAAsB,CAAC,EACzC;EAAED,EAAE,EAAE,GAAG;EAAEC,KAAK,EAAE;AAAsB,CAAC,EACzC;EAAED,EAAE,EAAE,GAAG;EAAEC,KAAK,EAAE;AAAsB,CAAC,EACzC;EAAED,EAAE,EAAE,GAAG;EAAEC,KAAK,EAAE;AAAsB,CAAC,EACzC;EAAED,EAAE,EAAE,GAAG;EAAEC,KAAK,EAAE;AAAsB,CAAC,EACzC;EAAED,EAAE,EAAE,GAAG;EAAEC,KAAK,EAAE;AAAsB,CAAC,EACzC;EAAED,EAAE,EAAE,GAAG;EAAEC,KAAK,EAAE;AAAsB,CAAC,EACzC;EAAED,EAAE,EAAE,GAAG;EAAEC,KAAK,EAAE;AAAsB,CAAC,EACzC;EAAED,EAAE,EAAE,IAAI;EAAEC,KAAK,EAAE;AAAoB,CAAC,EACxC;EAAED,EAAE,EAAE,IAAI;EAAEC,KAAK,EAAE;AAAoB,CAAC,EACxC;EAAED,EAAE,EAAE,IAAI;EAAEC,KAAK,EAAE;AAAqB,CAAC,EACzC;EAAED,EAAE,EAAE,IAAI;EAAEC,KAAK,EAAE;AAAoB,CAAC,EACxC;EAAED,EAAE,EAAE,IAAI;EAAEC,KAAK,EAAE;AAAoB,CAAC,EACxC;EAAED,EAAE,EAAE,IAAI;EAAEC,KAAK,EAAE;AAAqB,CAAC,EACzC;EAAED,EAAE,EAAE,IAAI;EAAEC,KAAK,EAAE;AAAoB,CAAC,EACxC;EAAED,EAAE,EAAE,IAAI;EAAEC,KAAK,EAAE;AAAqB,CAAC,EACzC;EAAED,EAAE,EAAE,IAAI;EAAEC,KAAK,EAAE;AAAoB,CAAC,EACxC;EAAED,EAAE,EAAE,IAAI;EAAEC,KAAK,EAAE;AAAoB,CAAC,EACxC;EAAED,EAAE,EAAE,IAAI;EAAEC,KAAK,EAAE;AAAmB,CAAC,CAC1C;AAEM,MAAMC,gBAAgB,GAAAH,OAAA,CAAAG,gBAAA,GAAG,gDAAgD","ignoreList":[]}
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "ColorPicker", {
7
+ enumerable: true,
8
+ get: function () {
9
+ return _ColorPicker.default;
10
+ }
11
+ });
12
+ Object.defineProperty(exports, "ColorPickerPopup", {
13
+ enumerable: true,
14
+ get: function () {
15
+ return _ColorPickerPopup.default;
16
+ }
17
+ });
18
+ Object.defineProperty(exports, "HueSlider", {
19
+ enumerable: true,
20
+ get: function () {
21
+ return _HueSlider.default;
22
+ }
23
+ });
24
+ Object.defineProperty(exports, "TransparencySlider", {
25
+ enumerable: true,
26
+ get: function () {
27
+ return _TransparencySlider.default;
28
+ }
29
+ });
30
+ Object.defineProperty(exports, "hexToRgb", {
31
+ enumerable: true,
32
+ get: function () {
33
+ return _color.hexToRgb;
34
+ }
35
+ });
36
+ Object.defineProperty(exports, "rgbToHex", {
37
+ enumerable: true,
38
+ get: function () {
39
+ return _color.rgbToHex;
40
+ }
41
+ });
42
+ var _ColorPickerPopup = _interopRequireDefault(require("./components/color-picker-popup/ColorPickerPopup"));
43
+ var _ColorPicker = _interopRequireDefault(require("./components/color-picker/ColorPicker"));
44
+ var _HueSlider = _interopRequireDefault(require("./components/hue-slider/HueSlider"));
45
+ var _TransparencySlider = _interopRequireDefault(require("./components/transparency-slider/TransparencySlider"));
46
+ var _color = require("./utils/color");
47
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
48
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":["_ColorPickerPopup","_interopRequireDefault","require","_ColorPicker","_HueSlider","_TransparencySlider","_color","e","__esModule","default"],"sources":["../../src/index.ts"],"sourcesContent":["export { default as ColorPickerPopup } from './components/color-picker-popup/ColorPickerPopup';\nexport { default as ColorPicker } from './components/color-picker/ColorPicker';\nexport { default as HueSlider } from './components/hue-slider/HueSlider';\nexport { default as TransparencySlider } from './components/transparency-slider/TransparencySlider';\nexport type { IPresetColor as PresetColor, RGB, RGBA } from './types/colorPicker';\nexport { hexToRgb, rgbToHex } from './utils/color';\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAAA,iBAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,YAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,UAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,mBAAA,GAAAJ,sBAAA,CAAAC,OAAA;AAEA,IAAAI,MAAA,GAAAJ,OAAA;AAAmD,SAAAD,uBAAAM,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+
2
+ //# sourceMappingURL=colorPicker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"colorPicker.js","names":[],"sources":["../../../src/types/colorPicker.ts"],"sourcesContent":["export interface Coordinates {\n x: number;\n y: number;\n}\n\nexport interface Scale {\n scaleX: number;\n scaleY: number;\n}\n\nexport interface RGB {\n r: number;\n g: number;\n b: number;\n}\n\nexport interface RGBA extends RGB {\n a: number;\n}\n\nexport interface IPresetColor {\n isCustom?: boolean;\n id: string;\n color: string;\n}\n\nexport interface ItemStorageResult {\n schemeId?: string;\n siteId?: string;\n key?: string;\n value: string[];\n}\n"],"mappings":"","ignoreList":[]}