@rolster/react-components 18.21.46 → 18.22.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/dist/cjs/assets/{index-CaA_sxmM.css → index-PeMi6MeC.css} +197 -0
  2. package/dist/cjs/index.js +438 -5
  3. package/dist/cjs/index.js.map +1 -1
  4. package/dist/es/assets/{index-CaA_sxmM.css → index-PeMi6MeC.css} +197 -0
  5. package/dist/es/index.js +434 -6
  6. package/dist/es/index.js.map +1 -1
  7. package/dist/esm/components/molecules/Slider/Slider.css +60 -0
  8. package/dist/esm/components/molecules/Slider/Slider.css.map +1 -0
  9. package/dist/esm/components/molecules/Slider/Slider.d.ts +14 -0
  10. package/dist/esm/components/molecules/Slider/Slider.js +60 -0
  11. package/dist/esm/components/molecules/Slider/Slider.js.map +1 -0
  12. package/dist/esm/components/molecules/index.d.ts +1 -0
  13. package/dist/esm/components/molecules/index.js +1 -0
  14. package/dist/esm/components/molecules/index.js.map +1 -1
  15. package/dist/esm/components/organisms/ImageChooser/ImageChooser.css +37 -0
  16. package/dist/esm/components/organisms/ImageChooser/ImageChooser.css.map +1 -0
  17. package/dist/esm/components/organisms/ImageChooser/ImageChooser.d.ts +11 -0
  18. package/dist/esm/components/organisms/ImageChooser/ImageChooser.js +62 -0
  19. package/dist/esm/components/organisms/ImageChooser/ImageChooser.js.map +1 -0
  20. package/dist/esm/components/organisms/ImageEditor/ImageEditor.css +97 -0
  21. package/dist/esm/components/organisms/ImageEditor/ImageEditor.css.map +1 -0
  22. package/dist/esm/components/organisms/ImageEditor/ImageEditor.d.ts +20 -0
  23. package/dist/esm/components/organisms/ImageEditor/ImageEditor.js +201 -0
  24. package/dist/esm/components/organisms/ImageEditor/ImageEditor.js.map +1 -0
  25. package/dist/esm/components/organisms/Modal/Modal.d.ts +2 -1
  26. package/dist/esm/components/organisms/Modal/Modal.js +5 -5
  27. package/dist/esm/components/organisms/Modal/Modal.js.map +1 -1
  28. package/dist/esm/components/organisms/index.d.ts +2 -0
  29. package/dist/esm/components/organisms/index.js +2 -0
  30. package/dist/esm/components/organisms/index.js.map +1 -1
  31. package/dist/esm/controllers/RelocationOnComponentController.d.ts +8 -0
  32. package/dist/esm/controllers/RelocationOnComponentController.js +93 -0
  33. package/dist/esm/controllers/RelocationOnComponentController.js.map +1 -0
  34. package/dist/esm/controllers/ResizeController.d.ts +15 -0
  35. package/dist/esm/controllers/ResizeController.js +29 -0
  36. package/dist/esm/controllers/ResizeController.js.map +1 -0
  37. package/dist/esm/controllers/index.d.ts +2 -0
  38. package/dist/esm/controllers/index.js +2 -0
  39. package/dist/esm/controllers/index.js.map +1 -1
  40. package/dist/esm/i18n.d.ts +3 -0
  41. package/dist/esm/i18n.js +6 -0
  42. package/dist/esm/i18n.js.map +1 -1
  43. package/package.json +1 -1
@@ -0,0 +1,60 @@
1
+ .rls-slider {
2
+ --pvt-track-height: var(--rls-sizing-x3);
3
+ --pvt-thumb-background: var(--rls-theme-color-600);
4
+ --pvt-thumb-color: var(--rls-theme-color-050);
5
+ }
6
+ .rls-slider--empty {
7
+ --pvt-thumb-background: var(--rls-app-color-300);
8
+ --pvt-thumb-color: var(--rls-app-color-900);
9
+ }
10
+ .rls-slider__component {
11
+ position: relative;
12
+ width: calc(100% - var(--rls-sizing-x10));
13
+ margin: 0rem 5rem;
14
+ padding: var(--rls-sizing-x4) 0rem;
15
+ box-sizing: border-box;
16
+ }
17
+ .rls-slider__body {
18
+ display: flex;
19
+ column-gap: var(--rls-sizing-x4);
20
+ align-items: center;
21
+ }
22
+ .rls-slider__body .rls-icon {
23
+ padding: var(--rls-sizing-x4);
24
+ border-radius: 50%;
25
+ background: var(--rls-app-color-300);
26
+ }
27
+ .rls-slider__track {
28
+ position: relative;
29
+ width: 100%;
30
+ height: var(--pvt-track-height);
31
+ cursor: pointer;
32
+ background: var(--rls-app-color-300);
33
+ }
34
+ .rls-slider__track__on {
35
+ position: absolute;
36
+ width: 0%;
37
+ height: var(--pvt-track-height);
38
+ overflow: hidden;
39
+ z-index: var(--rls-z-index-4);
40
+ transition: width 200ms 0ms var(--rls-standard-curve);
41
+ background: var(--rls-theme-color-600);
42
+ }
43
+ .rls-slider__thumb {
44
+ position: absolute;
45
+ top: 0.5rem;
46
+ left: 0rem;
47
+ cursor: pointer;
48
+ width: var(--rls-sizing-x10);
49
+ height: var(--rls-sizing-x10);
50
+ line-height: var(--rls-sizing-x10);
51
+ text-align: center;
52
+ font-size: 3.5rem;
53
+ font-weight: var(--rls-font-weight-medium);
54
+ color: var(--pvt-thumb-color);
55
+ z-index: var(--rls-z-index-4);
56
+ border-radius: 50%;
57
+ background: var(--pvt-thumb-background);
58
+ transform: translateX(-50%);
59
+ transition: left 200ms 0ms var(--rls-standard-curve);
60
+ } /*# sourceMappingURL=Slider.css.map */
@@ -0,0 +1 @@
1
+ {"version":3,"sourceRoot":"","sources":["../../../../../src/components/molecules/Slider/Slider.scss"],"names":[],"mappings":"AAOA,YACE,yCACA,mDACA,8CAEA,mBACE,iDACA,4CAGF,uBACE,kBACA,yCACA,iBACA,kCACA,sBAGF,kBACE,aACA,gCACA,mBAEA,4BACE,6BACA,kBACA,oCAIJ,mBACE,kBACA,WACA,+BACA,eACA,oCAEA,uBACE,kBACA,SACA,+BACA,gBACA,6BACA,qDACA,sCAIJ,mBACE,kBACA,UACA,UACA,eACA,4BACA,6BACA,kCACA,kBACA,iBACA,0CACA,6BACA,6BACA,kBACA,uCACA,2BACA","file":"Slider.css"}
@@ -0,0 +1,14 @@
1
+ import { ReactControl } from '@rolster/react-forms';
2
+ import { RlsComponent } from '../../definitions';
3
+ import './Slider.css';
4
+ interface SliderProps extends RlsComponent {
5
+ disabled?: boolean;
6
+ formControl?: ReactControl<HTMLElement, number>;
7
+ maxValue?: number;
8
+ minValue?: number;
9
+ onValue?: (value: number) => void;
10
+ prefixIcon?: string;
11
+ value?: number;
12
+ }
13
+ export declare function RlsSlider(props: SliderProps): import("react/jsx-runtime").JSX.Element;
14
+ export {};
@@ -0,0 +1,60 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useCallback, useEffect, useMemo, useRef, useState } from 'react';
3
+ import { renderClassStatus } from '../../../helpers';
4
+ import { RlsIcon } from '../../atoms';
5
+ import './Slider.css';
6
+ function calculateInitialValue(value, minValue, maxValue) {
7
+ return minValue > value ? minValue : maxValue < value ? maxValue : value;
8
+ }
9
+ function calculateInitialRate(value, minValue, maxValue) {
10
+ const rateMax = maxValue - minValue;
11
+ const rateValue = value - minValue;
12
+ return Math.ceil((rateValue / rateMax) * 100);
13
+ }
14
+ export function RlsSlider(props) {
15
+ const minValue = useMemo(() => {
16
+ return props.minValue ?? 0;
17
+ }, [props.minValue]);
18
+ const maxValue = useMemo(() => {
19
+ return props.maxValue ?? 100;
20
+ }, [props.maxValue]);
21
+ const [value, setValue] = useState(calculateInitialValue(props.formControl?.value ?? props.value ?? 0, minValue, maxValue));
22
+ const [rate, setRate] = useState(calculateInitialRate(value, minValue, maxValue));
23
+ const refComponent = useRef(null);
24
+ const refTrack = useRef(null);
25
+ const refTrackOn = useRef(null);
26
+ const refThumb = useRef(null);
27
+ const className = useMemo(() => {
28
+ return renderClassStatus('rls-slider', {
29
+ complet: value === maxValue,
30
+ disabled: props.disabled,
31
+ empty: value === minValue
32
+ });
33
+ }, [value, minValue, maxValue, props.disabled]);
34
+ useEffect(() => {
35
+ const valueInitial = props.formControl?.value ?? props.value ?? 0;
36
+ refThumb.current.style.left = `${rate}%`;
37
+ refTrackOn.current.style.width = `${rate}%`;
38
+ if (valueInitial !== value) {
39
+ props.formControl?.setValue(value);
40
+ props.onValue && props.onValue(value);
41
+ }
42
+ }, []);
43
+ const calculateValueWithRate = useCallback((rate) => {
44
+ const value = Math.ceil(((maxValue - minValue) * rate) / 100);
45
+ refThumb.current.style.left = `${rate}%`;
46
+ refTrackOn.current.style.width = `${rate}%`;
47
+ const sliderValue = value + minValue;
48
+ setRate(rate);
49
+ setValue(sliderValue);
50
+ props.formControl?.setValue(sliderValue);
51
+ props.onValue && props.onValue(sliderValue);
52
+ }, [minValue, maxValue, props.formControl, props.onValue]);
53
+ const onClickTrack = useCallback((event) => {
54
+ const { left, width } = refTrack.current.getBoundingClientRect();
55
+ const rate = Math.ceil(((event.clientX - left) / width) * 100);
56
+ calculateValueWithRate(rate);
57
+ }, [minValue, maxValue]);
58
+ return (_jsxs("div", { className: className, children: [props.children && (_jsx("span", { className: "rls-slider__label", children: props.children })), _jsxs("div", { className: "rls-slider__body", children: [props.prefixIcon && _jsx(RlsIcon, { value: props.prefixIcon }), _jsxs("div", { ref: refComponent, className: "rls-slider__component", children: [_jsx("div", { ref: refTrack, className: "rls-slider__track", onClick: onClickTrack, children: _jsx("div", { ref: refTrackOn, className: "rls-slider__track__on" }) }), _jsxs("div", { ref: refThumb, className: "rls-slider__thumb", children: [rate, "%"] })] })] })] }));
59
+ }
60
+ //# sourceMappingURL=Slider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Slider.js","sourceRoot":"","sources":["../../../../../src/components/molecules/Slider/Slider.tsx"],"names":[],"mappings":"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"}
@@ -17,4 +17,5 @@ export * from './PickerDayRange/PickerDayRange';
17
17
  export * from './PickerMonth/PickerMonth';
18
18
  export * from './PickerSelectorTitle/PickerSelectorTitle';
19
19
  export * from './PickerYear/PickerYear';
20
+ export * from './Slider/Slider';
20
21
  export * from './Toolbar/Toolbar';
@@ -17,5 +17,6 @@ export * from './PickerDayRange/PickerDayRange';
17
17
  export * from './PickerMonth/PickerMonth';
18
18
  export * from './PickerSelectorTitle/PickerSelectorTitle';
19
19
  export * from './PickerYear/PickerYear';
20
+ export * from './Slider/Slider';
20
21
  export * from './Toolbar/Toolbar';
21
22
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/molecules/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,iCAAiC,CAAC;AAChD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,uBAAuB,CAAC;AACtC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,qCAAqC,CAAC;AACpD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,qCAAqC,CAAC;AACpD,cAAc,yBAAyB,CAAC;AACxC,cAAc,uBAAuB,CAAC;AACtC,cAAc,iCAAiC,CAAC;AAChD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,2CAA2C,CAAC;AAC1D,cAAc,yBAAyB,CAAC;AACxC,cAAc,mBAAmB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/molecules/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,iCAAiC,CAAC;AAChD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,uBAAuB,CAAC;AACtC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,qCAAqC,CAAC;AACpD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,qCAAqC,CAAC;AACpD,cAAc,yBAAyB,CAAC;AACxC,cAAc,uBAAuB,CAAC;AACtC,cAAc,iCAAiC,CAAC;AAChD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,2CAA2C,CAAC;AAC1D,cAAc,yBAAyB,CAAC;AACxC,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC"}
@@ -0,0 +1,37 @@
1
+ .rls-image-chooser {
2
+ position: relative;
3
+ width: var(--rlc-image-chooser-width, 48rem);
4
+ height: var(--rlc-image-chooser-height, 48rem);
5
+ border-radius: var(--rlc-image-chooser-radius, 50%);
6
+ overflow: hidden;
7
+ }
8
+ .rls-image-chooser__avatar {
9
+ display: flex;
10
+ width: 100%;
11
+ height: 100%;
12
+ justify-content: center;
13
+ align-items: center;
14
+ background: var(--rls-theme-color-600);
15
+ }
16
+ .rls-image-chooser__avatar img {
17
+ width: 100%;
18
+ }
19
+ .rls-image-chooser > input[type='file'] {
20
+ position: absolute;
21
+ z-index: -1;
22
+ visibility: hidden;
23
+ }
24
+ .rls-image-chooser__modal {
25
+ --rlc-image-editor-footer-padding: 0rem var(--rls-sizing-x12)
26
+ var(--rls-sizing-x12) var(--rls-sizing-x12);
27
+ --pvt-modal-max-width: 240rem;
28
+ width: 100%;
29
+ max-width: var(--pvt-modal-max-width);
30
+ }
31
+ @media only screen and (max-width: 420px) {
32
+ .rls-image-chooser__modal {
33
+ --rlc-image-editor-footer-padding: 0rem var(--rls-sizing-x8)
34
+ var(--rls-sizing-x8) var(--rls-sizing-x8);
35
+ --pvt-modal-max-width: 160rem;
36
+ }
37
+ } /*# sourceMappingURL=ImageChooser.css.map */
@@ -0,0 +1 @@
1
+ {"version":3,"sourceRoot":"","sources":["../../../../../src/components/organisms/ImageChooser/ImageChooser.scss"],"names":[],"mappings":"AAOA,mBACE,kBACA,4CACA,8CACA,mDACA,gBAEA,2BACE,aACA,WACA,YACA,uBACA,mBACA,sCAEA,+BACE,WAIJ,oCACE,kBACA,WACA,kBAGF,0BACE,0GAGA,8BAEA,WACA,qCAIJ,0CACE,0BACE,uGAGA","file":"ImageChooser.css"}
@@ -0,0 +1,11 @@
1
+ import { ReactControl } from '@rolster/react-forms';
2
+ import { ImageEditorValue } from '../ImageEditor/ImageEditor';
3
+ import './ImageChooser.css';
4
+ interface ImageChooserProps {
5
+ disabled?: boolean;
6
+ formControl?: ReactControl<HTMLElement, ImageEditorValue>;
7
+ onValue?: (result: ImageEditorValue) => void;
8
+ src?: string;
9
+ }
10
+ export declare function RlsImageChooser(props: ImageChooserProps): import("react/jsx-runtime").JSX.Element;
11
+ export {};
@@ -0,0 +1,62 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { i18nSubscribe } from '@rolster/i18n';
3
+ import { useCallback, useEffect, useRef, useState } from 'react';
4
+ import { reactI18n } from '../../../i18n';
5
+ import { RlsButton } from '../../atoms';
6
+ import { RlsImageEditor } from '../ImageEditor/ImageEditor';
7
+ import { RlsModal } from '../Modal/Modal';
8
+ import './ImageChooser.css';
9
+ const mimeTypeSupports = [
10
+ 'image/png',
11
+ 'image/jpg',
12
+ 'image/jpeg',
13
+ 'image/bmp',
14
+ 'image/webp',
15
+ 'image/gif',
16
+ 'image/svg+xml'
17
+ ];
18
+ export function RlsImageChooser(props) {
19
+ const refInput = useRef(null);
20
+ const [labels, setLabels] = useState({
21
+ actionCancel: reactI18n('chooserImageActionCancel')
22
+ });
23
+ const [src, setSrc] = useState();
24
+ const [srcEditor, setSrcEditor] = useState();
25
+ const onSelect = useCallback(() => {
26
+ refInput.current.click();
27
+ }, []);
28
+ const processImage = useCallback((file) => {
29
+ const reader = new FileReader();
30
+ reader.onload = function () {
31
+ setSrcEditor(reader.result);
32
+ refInput.current.value = '';
33
+ };
34
+ reader.readAsDataURL(file);
35
+ }, []);
36
+ useEffect(() => {
37
+ refInput.current.onchange = () => {
38
+ if (refInput.current.files &&
39
+ mimeTypeSupports.includes(refInput.current.files[0].type)) {
40
+ processImage(refInput.current.files[0]);
41
+ }
42
+ };
43
+ return i18nSubscribe(() => {
44
+ setLabels({
45
+ actionCancel: reactI18n('chooserImageActionCancel')
46
+ });
47
+ });
48
+ }, []);
49
+ useEffect(() => {
50
+ props.src && setSrc(props.src);
51
+ }, [props.src]);
52
+ const onEditorValue = useCallback((image) => {
53
+ setSrc(image.base64);
54
+ setSrcEditor(undefined);
55
+ props.onValue && props.onValue(image);
56
+ }, [props.onValue]);
57
+ const onCancel = useCallback(() => {
58
+ setSrcEditor(undefined);
59
+ }, []);
60
+ return (_jsxs("div", { className: "rls-image-chooser", children: [_jsx("div", { className: "rls-image-chooser__avatar", onClick: onSelect, children: src && _jsx("img", { src: src }) }), srcEditor && (_jsx(RlsModal, { className: "rls-image-chooser__modal", visible: true, children: _jsx(RlsImageEditor, { src: srcEditor, formControl: props.formControl, onValue: onEditorValue, children: _jsx(RlsButton, { type: "flat", rlsTheme: "danger", onClick: onCancel, disabled: props.disabled, children: labels.actionCancel }) }) })), _jsx("input", { ref: refInput, type: "file", disabled: props.disabled })] }));
61
+ }
62
+ //# sourceMappingURL=ImageChooser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageChooser.js","sourceRoot":"","sources":["../../../../../src/components/organisms/ImageChooser/ImageChooser.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,97 @@
1
+ .rls-image-editor {
2
+ --pvt-overlay-background: var(--rls-theme-backdrop-900);
3
+ --pvt-sliders-padding: 0rem var(--rls-sizing-x8);
4
+ --pvt-actions-direction: row;
5
+ --pvt-actions-row-gap: 0rem;
6
+ --pvt-actions-column-gap: var(--rls-sizing-x8);
7
+ position: relative;
8
+ display: flex;
9
+ height: 100%;
10
+ flex-direction: column;
11
+ row-gap: var(--rls-sizing-x12);
12
+ }
13
+ .rls-image-editor__body {
14
+ position: relative;
15
+ display: flex;
16
+ height: 100%;
17
+ justify-content: center;
18
+ background: var(--rls-app-color-900);
19
+ }
20
+ .rls-image-editor__body__image {
21
+ overflow: hidden;
22
+ }
23
+ .rls-image-editor__body__selection {
24
+ position: absolute;
25
+ cursor: move;
26
+ box-sizing: border-box;
27
+ z-index: var(--rls-z-index-4);
28
+ border: var(
29
+ --rlc-image-editor-selection-border,
30
+ 2px dashed var(--rls-app-color-050)
31
+ );
32
+ user-select: none;
33
+ }
34
+ .rls-image-editor__body__overlay--top {
35
+ position: absolute;
36
+ top: 0rem;
37
+ z-index: var(--rls-z-index-2);
38
+ background: var(--pvt-overlay-background);
39
+ }
40
+ .rls-image-editor__body__overlay--right {
41
+ position: absolute;
42
+ right: 0rem;
43
+ height: 100%;
44
+ z-index: var(--rls-z-index-2);
45
+ background: var(--pvt-overlay-background);
46
+ }
47
+ .rls-image-editor__body__overlay--bottom {
48
+ position: absolute;
49
+ bottom: 0rem;
50
+ z-index: var(--rls-z-index-2);
51
+ background: var(--pvt-overlay-background);
52
+ }
53
+ .rls-image-editor__body__overlay--left {
54
+ position: absolute;
55
+ right: 0rem;
56
+ height: 100%;
57
+ z-index: var(--rls-z-index-2);
58
+ background: var(--pvt-overlay-background);
59
+ }
60
+ .rls-image-editor__footer {
61
+ display: flex;
62
+ flex-direction: column;
63
+ row-gap: var(--rls-sizing-x12);
64
+ padding: var(--rlc-image-editor-footer-padding, 0rem);
65
+ box-sizing: border-box;
66
+ }
67
+ .rls-image-editor__sliders {
68
+ display: flex;
69
+ flex-direction: column;
70
+ row-gap: var(--rls-sizing-x6);
71
+ padding: var(--pvt-sliders-padding);
72
+ box-sizing: border-box;
73
+ }
74
+ .rls-image-editor__actions {
75
+ display: flex;
76
+ flex-direction: var(--pvt-actions-direction);
77
+ justify-content: center;
78
+ row-gap: var(--pvt-actions-row-gap);
79
+ column-gap: var(--pvt-actions-column-gap);
80
+ }
81
+ .rls-image-editor > canvas {
82
+ position: absolute;
83
+ top: 0rem;
84
+ left: 0rem;
85
+ z-index: -1;
86
+ visibility: hidden;
87
+ pointer-events: none;
88
+ }
89
+ @media only screen and (max-width: 420px) {
90
+ .rls-image-editor {
91
+ --pvt-sliders-padding: 0rem;
92
+ --pvt-actions-direction: column;
93
+ --pvt-actions-row-gap: var(--rls-sizing-x6);
94
+ --pvt-actions-column-gap: 0rem;
95
+ row-gap: var(--rls-sizing-x8);
96
+ }
97
+ } /*# sourceMappingURL=ImageEditor.css.map */
@@ -0,0 +1 @@
1
+ {"version":3,"sourceRoot":"","sources":["../../../../../src/components/organisms/ImageEditor/ImageEditor.scss"],"names":[],"mappings":"AAOA,kBACE,wDACA,iDACA,6BACA,4BACA,+CAEA,kBACA,aACA,YACA,sBACA,8BAEA,wBACE,kBACA,aACA,YACA,uBACA,oCAEA,+BACE,gBAGF,mCACE,kBACA,YACA,sBACA,6BACA,qFAIA,iBAGF,sCACE,kBACA,SACA,6BACA,yCAGF,wCACE,kBACA,WACA,YACA,6BACA,yCAGF,yCACE,kBACA,YACA,6BACA,yCAGF,uCACE,kBACA,WACA,YACA,6BACA,yCAIJ,0BACE,aACA,sBACA,8BACA,qDACA,sBAGF,2BACE,aACA,sBACA,6BACA,mCACA,sBAGF,2BACE,aACA,4CACA,uBACA,mCACA,yCAGF,yBACE,kBACA,SACA,UACA,WACA,kBACA,oBAIJ,0CACE,kBACE,4BACA,gCACA,4CACA,+BAEA","file":"ImageEditor.css"}
@@ -0,0 +1,20 @@
1
+ import { ReactControl } from '@rolster/react-forms';
2
+ import { RlsComponent } from '../../definitions';
3
+ import './ImageEditor.css';
4
+ type ImageRatio = '1:1' | '3:4' | '4:3' | '3:2' | '8:5' | '16:9';
5
+ type ImageMymeType = 'image/png' | 'image/jpg' | 'image/jpeg' | 'image/bmp' | 'image/webp';
6
+ export interface ImageEditorValue {
7
+ base64: string;
8
+ blob: Blob;
9
+ }
10
+ interface ImageEditorProps extends RlsComponent {
11
+ disabled?: boolean;
12
+ formControl?: ReactControl<HTMLElement, ImageEditorValue>;
13
+ mimeType?: ImageMymeType;
14
+ onValue?: (result: ImageEditorValue) => void;
15
+ rateSelection?: number;
16
+ ratio?: ImageRatio;
17
+ src?: string;
18
+ }
19
+ export declare function RlsImageEditor(props: ImageEditorProps): import("react/jsx-runtime").JSX.Element;
20
+ export {};
@@ -0,0 +1,201 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { i18nSubscribe } from '@rolster/i18n';
3
+ import { useCallback, useEffect, useRef, useState } from 'react';
4
+ import { useRelocationOnComponent, useResize } from '../../../controllers';
5
+ import { reactI18n } from '../../../i18n';
6
+ import { RlsButton } from '../../atoms';
7
+ import { RlsSlider } from '../../molecules';
8
+ import './ImageEditor.css';
9
+ function getRatioFactor(ratio) {
10
+ switch (ratio) {
11
+ case '16:9':
12
+ return 9 / 16;
13
+ case '8:5':
14
+ return 5 / 8;
15
+ case '4:3':
16
+ return 3 / 4;
17
+ case '3:4':
18
+ return 4 / 3;
19
+ case '3:2':
20
+ return 2 / 3;
21
+ default:
22
+ return 1;
23
+ }
24
+ }
25
+ function simpleThreeRule(value1, value2, proportion) {
26
+ return (value2 * proportion) / value1;
27
+ }
28
+ export function RlsImageEditor(props) {
29
+ const [selection, setSelection] = useState(props.rateSelection ?? 60);
30
+ const [labels, setLabels] = useState({
31
+ actionRestore: reactI18n('editorImageActionRestore'),
32
+ actionSelect: reactI18n('editorImageActionSelect')
33
+ });
34
+ const refBody = useRef(null);
35
+ const refImage = useRef(null);
36
+ const refSelection = useRef(null);
37
+ const refOverlayTop = useRef(null);
38
+ const refOverlayBottom = useRef(null);
39
+ const refOverlayLeft = useRef(null);
40
+ const refOverlayRight = useRef(null);
41
+ const refCanvas = useRef(null);
42
+ const refPicture = useRef(null);
43
+ const image = useRef(new Image());
44
+ const originalImage = useRef();
45
+ const getCropProperties = useCallback(() => {
46
+ return {
47
+ height: simpleThreeRule(refImage.current.offsetHeight, image.current.height, refSelection.current.offsetHeight),
48
+ left: simpleThreeRule(refImage.current.offsetWidth, image.current.width, refSelection.current.offsetLeft),
49
+ top: simpleThreeRule(refImage.current.offsetHeight, image.current.height, refSelection.current.offsetTop),
50
+ width: simpleThreeRule(refImage.current.offsetWidth, image.current.width, refSelection.current.offsetWidth)
51
+ };
52
+ }, []);
53
+ const refreshOverlaysStyle = useCallback(() => {
54
+ const width = refSelection.current.offsetWidth;
55
+ const height = refSelection.current.offsetHeight;
56
+ const top = refSelection.current.offsetTop;
57
+ const left = refSelection.current.offsetLeft;
58
+ refOverlayTop.current.style.width = `${width}px`;
59
+ refOverlayTop.current.style.bottom = `calc(100% - ${top}px)`;
60
+ refOverlayTop.current.style.left = `${left}px`;
61
+ refOverlayRight.current.style.left = `calc(${width + left}px)`;
62
+ refOverlayRight.current.style.width = `calc(100% - ${width + left}px)`;
63
+ refOverlayBottom.current.style.width = `${width}px`;
64
+ refOverlayBottom.current.style.top = `calc(${height + top}px)`;
65
+ refOverlayBottom.current.style.left = `${left}px`;
66
+ refOverlayLeft.current.style.right = `calc(100% - ${left}px)`;
67
+ refOverlayLeft.current.style.width = `calc(${left}px)`;
68
+ }, []);
69
+ const refreshSelectionFromWidth = useCallback((rateSelection) => {
70
+ const _ratio = rateSelection * getRatioFactor(props.ratio || '1:1');
71
+ let width = (refImage.current.offsetWidth * rateSelection) / 100;
72
+ let height = (refImage.current.offsetWidth * _ratio) / 100;
73
+ if (height > refImage.current.offsetHeight) {
74
+ height = refImage.current.offsetHeight;
75
+ width =
76
+ (height * refImage.current.offsetHeight) /
77
+ refImage.current.offsetHeight;
78
+ }
79
+ return { height, width };
80
+ }, [props.ratio]);
81
+ const refreshSelectionFromHeight = useCallback((rateSelection) => {
82
+ const _ratio = rateSelection * getRatioFactor(props.ratio || '1:1');
83
+ let height = (refImage.current.offsetHeight * rateSelection) / 100;
84
+ let width = (refImage.current.offsetHeight * _ratio) / 100;
85
+ if (width > refImage.current.offsetWidth) {
86
+ width = refImage.current.offsetWidth;
87
+ height =
88
+ (width * refImage.current.offsetWidth) / refImage.current.offsetWidth;
89
+ }
90
+ return { height, width };
91
+ }, [props.ratio]);
92
+ const refreshSelectionStyle = useCallback((rateSelection) => {
93
+ if (image.current.width > 0 && image.current.height > 0) {
94
+ const { height, width } = image.current.width >= image.current.height
95
+ ? refreshSelectionFromHeight(rateSelection)
96
+ : refreshSelectionFromWidth(rateSelection);
97
+ refSelection.current.style.width = `${width}px`;
98
+ refSelection.current.style.height = `${height}px`;
99
+ if (refSelection.current.offsetLeft + width >
100
+ refImage.current.offsetWidth) {
101
+ const selectionLeft = refImage.current.offsetWidth - width;
102
+ refSelection.current.style.left = `${selectionLeft}px`;
103
+ }
104
+ if (refSelection.current.offsetTop + height >
105
+ refImage.current.offsetHeight) {
106
+ const selectionTop = refImage.current.offsetHeight - height;
107
+ refSelection.current.style.top = `${selectionTop}px`;
108
+ }
109
+ refreshOverlaysStyle();
110
+ }
111
+ }, [props.ratio]);
112
+ const setImageStyle = useCallback((width, height) => {
113
+ refImage.current.style.width = width;
114
+ refImage.current.style.height = height;
115
+ refCanvas.current.style.width = width;
116
+ refCanvas.current.style.height = height;
117
+ }, []);
118
+ const refreshImageStyle = useCallback(() => {
119
+ if (image.current.width <= 0 || image.current.height <= 0) {
120
+ return setImageStyle('0%', '0%');
121
+ }
122
+ const height = (refBody.current.offsetWidth * image.current.height) /
123
+ image.current.width;
124
+ if (height <= refBody.current.offsetHeight) {
125
+ return setImageStyle('100%', `${height}px`);
126
+ }
127
+ const width = (refBody.current.offsetHeight * image.current.width) /
128
+ image.current.height;
129
+ return setImageStyle(`${width}px`, '100%');
130
+ }, []);
131
+ useEffect(() => {
132
+ image.current.onload = () => {
133
+ const context = refCanvas.current.getContext('2d', {
134
+ willReadFrequently: true
135
+ });
136
+ refCanvas.current.width = image.current.width;
137
+ refCanvas.current.height = image.current.height;
138
+ context?.drawImage(image.current, 0, 0, image.current.width, image.current.height);
139
+ originalImage.current = context?.getImageData(0, 0, refCanvas.current.width, refCanvas.current.height);
140
+ refreshImageStyle();
141
+ refreshSelectionStyle(selection);
142
+ };
143
+ const unsubscription = i18nSubscribe(() => {
144
+ setLabels({
145
+ actionRestore: reactI18n('editorImageActionRestore'),
146
+ actionSelect: reactI18n('editorImageActionSelect')
147
+ });
148
+ });
149
+ window.addEventListener('resize', refreshImageStyle);
150
+ return () => {
151
+ window.removeEventListener('resize', refreshImageStyle);
152
+ unsubscription();
153
+ };
154
+ }, []);
155
+ useEffect(() => {
156
+ image.current.src = props.src || '';
157
+ }, [props.src]);
158
+ useEffect(() => {
159
+ refreshSelectionStyle(selection);
160
+ }, [selection]);
161
+ const onResizeElement = useCallback(() => {
162
+ refreshSelectionStyle(selection);
163
+ }, [selection]);
164
+ useRelocationOnComponent({
165
+ container: refImage,
166
+ element: refSelection,
167
+ onDrag: refreshOverlaysStyle
168
+ });
169
+ useResize({ refElement: refImage, onResize: onResizeElement });
170
+ const onCropImage = useCallback(() => {
171
+ const cropProps = getCropProperties();
172
+ const width = cropProps.width;
173
+ const height = width * getRatioFactor(props.ratio || '1:1');
174
+ refPicture.current.width = width;
175
+ refPicture.current.height = height;
176
+ const context = refPicture.current.getContext('2d');
177
+ context?.drawImage(refCanvas.current, cropProps.left, cropProps.top, cropProps.width, cropProps.height, 0, 0, width, height);
178
+ refPicture.current.toBlob((blob) => {
179
+ if (blob) {
180
+ const reader = new FileReader();
181
+ reader.readAsDataURL(blob);
182
+ reader.onloadend = function () {
183
+ const value = {
184
+ base64: reader.result,
185
+ blob
186
+ };
187
+ props.onValue && props.onValue(value);
188
+ props.formControl?.setValue(value);
189
+ };
190
+ }
191
+ }, props.mimeType || 'image/jpeg', 1);
192
+ }, [props.ratio, props.mimeType, props.onValue, props.formControl]);
193
+ const onRestore = useCallback(() => {
194
+ const context = refCanvas.current.getContext('2d');
195
+ if (originalImage.current) {
196
+ context?.putImageData(originalImage.current, 0, 0);
197
+ }
198
+ }, []);
199
+ return (_jsxs("div", { className: "rls-image-editor", children: [_jsx("div", { ref: refBody, className: "rls-image-editor__body", children: _jsxs("div", { ref: refImage, className: "rls-image-editor__body__image", children: [_jsx("div", { ref: refSelection, className: "rls-image-editor__body__selection" }), _jsx("div", { ref: refOverlayTop, className: "rls-image-editor__body__overlay--top" }), _jsx("div", { ref: refOverlayRight, className: "rls-image-editor__body__overlay--right" }), _jsx("div", { ref: refOverlayBottom, className: "rls-image-editor__body__overlay--bottom" }), _jsx("div", { ref: refOverlayLeft, className: "rls-image-editor__body__overlay--left" }), _jsx("canvas", { ref: refCanvas })] }) }), _jsxs("div", { className: "rls-image-editor__footer", children: [_jsx("div", { className: "rls-image-editor__sliders", children: _jsx(RlsSlider, { prefixIcon: "external-link", value: selection, minValue: 50, maxValue: 100, onValue: setSelection, disabled: props.disabled }) }), _jsxs("div", { className: "rls-image-editor__actions", children: [props.children, _jsx(RlsButton, { type: "classic", prefixIcon: "refresh", onClick: onRestore, disabled: props.disabled, children: labels.actionRestore }), _jsx(RlsButton, { type: "raised", prefixIcon: "crop", onClick: onCropImage, disabled: props.disabled, children: labels.actionSelect })] })] }), _jsx("canvas", { ref: refPicture })] }));
200
+ }
201
+ //# sourceMappingURL=ImageEditor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageEditor.js","sourceRoot":"","sources":["../../../../../src/components/organisms/ImageEditor/ImageEditor.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAE9C,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjE,OAAO,EAAE,wBAAwB,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAC3E,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,mBAAmB,CAAC;AA0B3B,SAAS,cAAc,CAAC,KAAiB;IACvC,QAAQ,KAAK,EAAE,CAAC;QACd,KAAK,MAAM;YACT,OAAO,CAAC,GAAG,EAAE,CAAC;QAChB,KAAK,KAAK;YACR,OAAO,CAAC,GAAG,CAAC,CAAC;QACf,KAAK,KAAK;YACR,OAAO,CAAC,GAAG,CAAC,CAAC;QACf,KAAK,KAAK;YACR,OAAO,CAAC,GAAG,CAAC,CAAC;QACf,KAAK,KAAK;YACR,OAAO,CAAC,GAAG,CAAC,CAAC;QACf;YACE,OAAO,CAAC,CAAC;IACb,CAAC;AACH,CAAC;AAED,SAAS,eAAe,CACtB,MAAc,EACd,MAAc,EACd,UAAkB;IAElB,OAAO,CAAC,MAAM,GAAG,UAAU,CAAC,GAAG,MAAM,CAAC;AACxC,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,KAAuB;IACpD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;IAEtE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC;QACnC,aAAa,EAAE,SAAS,CAAC,0BAA0B,CAAC;QACpD,YAAY,EAAE,SAAS,CAAC,yBAAyB,CAAC;KACnD,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,MAAM,CAAiB,IAAK,CAAC,CAAC;IAC9C,MAAM,QAAQ,GAAG,MAAM,CAAiB,IAAK,CAAC,CAAC;IAC/C,MAAM,YAAY,GAAG,MAAM,CAAiB,IAAK,CAAC,CAAC;IACnD,MAAM,aAAa,GAAG,MAAM,CAAiB,IAAK,CAAC,CAAC;IACpD,MAAM,gBAAgB,GAAG,MAAM,CAAiB,IAAK,CAAC,CAAC;IACvD,MAAM,cAAc,GAAG,MAAM,CAAiB,IAAK,CAAC,CAAC;IACrD,MAAM,eAAe,GAAG,MAAM,CAAiB,IAAK,CAAC,CAAC;IACtD,MAAM,SAAS,GAAG,MAAM,CAAoB,IAAK,CAAC,CAAC;IACnD,MAAM,UAAU,GAAG,MAAM,CAAoB,IAAK,CAAC,CAAC;IAEpD,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC,CAAC;IAClC,MAAM,aAAa,GAAG,MAAM,EAAa,CAAC;IAE1C,MAAM,iBAAiB,GAAG,WAAW,CAAC,GAAG,EAAE;QACzC,OAAO;YACL,MAAM,EAAE,eAAe,CACrB,QAAQ,CAAC,OAAO,CAAC,YAAY,EAC7B,KAAK,CAAC,OAAO,CAAC,MAAM,EACpB,YAAY,CAAC,OAAO,CAAC,YAAY,CAClC;YACD,IAAI,EAAE,eAAe,CACnB,QAAQ,CAAC,OAAO,CAAC,WAAW,EAC5B,KAAK,CAAC,OAAO,CAAC,KAAK,EACnB,YAAY,CAAC,OAAO,CAAC,UAAU,CAChC;YACD,GAAG,EAAE,eAAe,CAClB,QAAQ,CAAC,OAAO,CAAC,YAAY,EAC7B,KAAK,CAAC,OAAO,CAAC,MAAM,EACpB,YAAY,CAAC,OAAO,CAAC,SAAS,CAC/B;YACD,KAAK,EAAE,eAAe,CACpB,QAAQ,CAAC,OAAO,CAAC,WAAW,EAC5B,KAAK,CAAC,OAAO,CAAC,KAAK,EACnB,YAAY,CAAC,OAAO,CAAC,WAAW,CACjC;SACF,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,oBAAoB,GAAG,WAAW,CAAC,GAAG,EAAE;QAC5C,MAAM,KAAK,GAAG,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC;QAC/C,MAAM,MAAM,GAAG,YAAY,CAAC,OAAO,CAAC,YAAY,CAAC;QACjD,MAAM,GAAG,GAAG,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC;QAC3C,MAAM,IAAI,GAAG,YAAY,CAAC,OAAO,CAAC,UAAU,CAAC;QAE7C,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,KAAK,IAAI,CAAC;QACjD,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,eAAe,GAAG,KAAK,CAAC;QAC7D,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,IAAI,IAAI,CAAC;QAE/C,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,QAAQ,KAAK,GAAG,IAAI,KAAK,CAAC;QAC/D,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,eAAe,KAAK,GAAG,IAAI,KAAK,CAAC;QAEvE,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,KAAK,IAAI,CAAC;QACpD,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,GAAG,QAAQ,MAAM,GAAG,GAAG,KAAK,CAAC;QAC/D,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,IAAI,IAAI,CAAC;QAElD,cAAc,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,eAAe,IAAI,KAAK,CAAC;QAC9D,cAAc,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,QAAQ,IAAI,KAAK,CAAC;IACzD,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,yBAAyB,GAAG,WAAW,CAC3C,CAAC,aAAqB,EAAE,EAAE;QACxB,MAAM,MAAM,GAAG,aAAa,GAAG,cAAc,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,CAAC;QAEpE,IAAI,KAAK,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,WAAW,GAAG,aAAa,CAAC,GAAG,GAAG,CAAC;QACjE,IAAI,MAAM,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,WAAW,GAAG,MAAM,CAAC,GAAG,GAAG,CAAC;QAE3D,IAAI,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;YAC3C,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,YAAY,CAAC;YAEvC,KAAK;gBACH,CAAC,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,YAAY,CAAC;oBACxC,QAAQ,CAAC,OAAO,CAAC,YAAY,CAAC;QAClC,CAAC;QAED,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;IAC3B,CAAC,EACD,CAAC,KAAK,CAAC,KAAK,CAAC,CACd,CAAC;IAEF,MAAM,0BAA0B,GAAG,WAAW,CAC5C,CAAC,aAAqB,EAAE,EAAE;QACxB,MAAM,MAAM,GAAG,aAAa,GAAG,cAAc,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,CAAC;QAEpE,IAAI,MAAM,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,YAAY,GAAG,aAAa,CAAC,GAAG,GAAG,CAAC;QACnE,IAAI,KAAK,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,YAAY,GAAG,MAAM,CAAC,GAAG,GAAG,CAAC;QAE3D,IAAI,KAAK,GAAG,QAAQ,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;YACzC,KAAK,GAAG,QAAQ,CAAC,OAAO,CAAC,WAAW,CAAC;YAErC,MAAM;gBACJ,CAAC,KAAK,GAAG,QAAQ,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,WAAW,CAAC;QAC1E,CAAC;QAED,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;IAC3B,CAAC,EACD,CAAC,KAAK,CAAC,KAAK,CAAC,CACd,CAAC;IAEF,MAAM,qBAAqB,GAAG,WAAW,CACvC,CAAC,aAAqB,EAAE,EAAE;QACxB,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,GAAG,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxD,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GACrB,KAAK,CAAC,OAAO,CAAC,KAAK,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM;gBACzC,CAAC,CAAC,0BAA0B,CAAC,aAAa,CAAC;gBAC3C,CAAC,CAAC,yBAAyB,CAAC,aAAa,CAAC,CAAC;YAE/C,YAAY,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,KAAK,IAAI,CAAC;YAChD,YAAY,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC;YAElD,IACE,YAAY,CAAC,OAAO,CAAC,UAAU,GAAG,KAAK;gBACvC,QAAQ,CAAC,OAAO,CAAC,WAAW,EAC5B,CAAC;gBACD,MAAM,aAAa,GAAG,QAAQ,CAAC,OAAO,CAAC,WAAW,GAAG,KAAK,CAAC;gBAC3D,YAAY,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,aAAa,IAAI,CAAC;YACzD,CAAC;YAED,IACE,YAAY,CAAC,OAAO,CAAC,SAAS,GAAG,MAAM;gBACvC,QAAQ,CAAC,OAAO,CAAC,YAAY,EAC7B,CAAC;gBACD,MAAM,YAAY,GAAG,QAAQ,CAAC,OAAO,CAAC,YAAY,GAAG,MAAM,CAAC;gBAC5D,YAAY,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,YAAY,IAAI,CAAC;YACvD,CAAC;YAED,oBAAoB,EAAE,CAAC;QACzB,CAAC;IACH,CAAC,EACD,CAAC,KAAK,CAAC,KAAK,CAAC,CACd,CAAC;IAEF,MAAM,aAAa,GAAG,WAAW,CAAC,CAAC,KAAa,EAAE,MAAc,EAAE,EAAE;QAClE,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;QACrC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;QACvC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;QACtC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;IAC1C,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,iBAAiB,GAAG,WAAW,CAAC,GAAG,EAAE;QACzC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAC1D,OAAO,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QACnC,CAAC;QAED,MAAM,MAAM,GACV,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;YACpD,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;QAEtB,IAAI,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;YAC3C,OAAO,aAAa,CAAC,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,CAAC;QAC9C,CAAC;QAED,MAAM,KAAK,GACT,CAAC,OAAO,CAAC,OAAO,CAAC,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;YACpD,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;QAEvB,OAAO,aAAa,CAAC,GAAG,KAAK,IAAI,EAAE,MAAM,CAAC,CAAC;IAC7C,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,SAAS,CAAC,GAAG,EAAE;QACb,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,GAAG,EAAE;YAC1B,MAAM,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,EAAE;gBACjD,kBAAkB,EAAE,IAAI;aACzB,CAAC,CAAC;YAEH,SAAS,CAAC,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;YAC9C,SAAS,CAAC,OAAO,CAAC,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;YAEhD,OAAO,EAAE,SAAS,CAChB,KAAK,CAAC,OAAO,EACb,CAAC,EACD,CAAC,EACD,KAAK,CAAC,OAAO,CAAC,KAAK,EACnB,KAAK,CAAC,OAAO,CAAC,MAAM,CACrB,CAAC;YAEF,aAAa,CAAC,OAAO,GAAG,OAAO,EAAE,YAAY,CAC3C,CAAC,EACD,CAAC,EACD,SAAS,CAAC,OAAO,CAAC,KAAK,EACvB,SAAS,CAAC,OAAO,CAAC,MAAM,CACzB,CAAC;YAEF,iBAAiB,EAAE,CAAC;YACpB,qBAAqB,CAAC,SAAS,CAAC,CAAC;QACnC,CAAC,CAAC;QAEF,MAAM,cAAc,GAAG,aAAa,CAAC,GAAG,EAAE;YACxC,SAAS,CAAC;gBACR,aAAa,EAAE,SAAS,CAAC,0BAA0B,CAAC;gBACpD,YAAY,EAAE,SAAS,CAAC,yBAAyB,CAAC;aACnD,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;QAErD,OAAO,GAAG,EAAE;YACV,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;YACxD,cAAc,EAAE,CAAC;QACnB,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,SAAS,CAAC,GAAG,EAAE;QACb,KAAK,CAAC,OAAO,CAAC,GAAG,GAAG,KAAK,CAAC,GAAG,IAAI,EAAE,CAAC;IACtC,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;IAEhB,SAAS,CAAC,GAAG,EAAE;QACb,qBAAqB,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,MAAM,eAAe,GAAG,WAAW,CAAC,GAAG,EAAE;QACvC,qBAAqB,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,wBAAwB,CAAC;QACvB,SAAS,EAAE,QAAQ;QACnB,OAAO,EAAE,YAAY;QACrB,MAAM,EAAE,oBAAoB;KAC7B,CAAC,CAAC;IAEH,SAAS,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,eAAe,EAAE,CAAC,CAAC;IAE/D,MAAM,WAAW,GAAG,WAAW,CAAC,GAAG,EAAE;QACnC,MAAM,SAAS,GAAG,iBAAiB,EAAE,CAAC;QAEtC,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC;QAC9B,MAAM,MAAM,GAAG,KAAK,GAAG,cAAc,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,CAAC;QAE5D,UAAU,CAAC,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC;QACjC,UAAU,CAAC,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC;QAEnC,MAAM,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAEpD,OAAO,EAAE,SAAS,CAChB,SAAS,CAAC,OAAO,EACjB,SAAS,CAAC,IAAI,EACd,SAAS,CAAC,GAAG,EACb,SAAS,CAAC,KAAK,EACf,SAAS,CAAC,MAAM,EAChB,CAAC,EACD,CAAC,EACD,KAAK,EACL,MAAM,CACP,CAAC;QAEF,UAAU,CAAC,OAAO,CAAC,MAAM,CACvB,CAAC,IAAI,EAAE,EAAE;YACP,IAAI,IAAI,EAAE,CAAC;gBACT,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;gBAChC,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;gBAE3B,MAAM,CAAC,SAAS,GAAG;oBACjB,MAAM,KAAK,GAAqB;wBAC9B,MAAM,EAAE,MAAM,CAAC,MAAgB;wBAC/B,IAAI;qBACL,CAAC;oBAEF,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;oBACtC,KAAK,CAAC,WAAW,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACrC,CAAC,CAAC;YACJ,CAAC;QACH,CAAC,EACD,KAAK,CAAC,QAAQ,IAAI,YAAY,EAC9B,CAAC,CACF,CAAC;IACJ,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;IAEpE,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,EAAE;QACjC,MAAM,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAEnD,IAAI,aAAa,CAAC,OAAO,EAAE,CAAC;YAC1B,OAAO,EAAE,YAAY,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACrD,CAAC;IACH,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,eAAK,SAAS,EAAC,kBAAkB,aAC/B,cAAK,GAAG,EAAE,OAAO,EAAE,SAAS,EAAC,wBAAwB,YACnD,eAAK,GAAG,EAAE,QAAQ,EAAE,SAAS,EAAC,+BAA+B,aAC3D,cACE,GAAG,EAAE,YAAY,EACjB,SAAS,EAAC,mCAAmC,GACxC,EAEP,cACE,GAAG,EAAE,aAAa,EAClB,SAAS,EAAC,sCAAsC,GAC3C,EAEP,cACE,GAAG,EAAE,eAAe,EACpB,SAAS,EAAC,wCAAwC,GAC7C,EAEP,cACE,GAAG,EAAE,gBAAgB,EACrB,SAAS,EAAC,yCAAyC,GAC9C,EAEP,cACE,GAAG,EAAE,cAAc,EACnB,SAAS,EAAC,uCAAuC,GAC5C,EAEP,iBAAQ,GAAG,EAAE,SAAS,GAAW,IAC7B,GACF,EAEN,eAAK,SAAS,EAAC,0BAA0B,aACvC,cAAK,SAAS,EAAC,2BAA2B,YACxC,KAAC,SAAS,IACR,UAAU,EAAC,eAAe,EAC1B,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,EAAE,EACZ,QAAQ,EAAE,GAAG,EACb,OAAO,EAAE,YAAY,EACrB,QAAQ,EAAE,KAAK,CAAC,QAAQ,GACxB,GACE,EAEN,eAAK,SAAS,EAAC,2BAA2B,aACvC,KAAK,CAAC,QAAQ,EAEf,KAAC,SAAS,IACR,IAAI,EAAC,SAAS,EACd,UAAU,EAAC,SAAS,EACpB,OAAO,EAAE,SAAS,EAClB,QAAQ,EAAE,KAAK,CAAC,QAAQ,YAEvB,MAAM,CAAC,aAAa,GACX,EAEZ,KAAC,SAAS,IACR,IAAI,EAAC,QAAQ,EACb,UAAU,EAAC,MAAM,EACjB,OAAO,EAAE,WAAW,EACpB,QAAQ,EAAE,KAAK,CAAC,QAAQ,YAEvB,MAAM,CAAC,YAAY,GACV,IACR,IACF,EAEN,iBAAQ,GAAG,EAAE,UAAU,GAAW,IAC9B,CACP,CAAC;AACJ,CAAC"}