@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.
- package/dist/cjs/assets/{index-CaA_sxmM.css → index-PeMi6MeC.css} +197 -0
- package/dist/cjs/index.js +438 -5
- package/dist/cjs/index.js.map +1 -1
- package/dist/es/assets/{index-CaA_sxmM.css → index-PeMi6MeC.css} +197 -0
- package/dist/es/index.js +434 -6
- package/dist/es/index.js.map +1 -1
- package/dist/esm/components/molecules/Slider/Slider.css +60 -0
- package/dist/esm/components/molecules/Slider/Slider.css.map +1 -0
- package/dist/esm/components/molecules/Slider/Slider.d.ts +14 -0
- package/dist/esm/components/molecules/Slider/Slider.js +60 -0
- package/dist/esm/components/molecules/Slider/Slider.js.map +1 -0
- package/dist/esm/components/molecules/index.d.ts +1 -0
- package/dist/esm/components/molecules/index.js +1 -0
- package/dist/esm/components/molecules/index.js.map +1 -1
- package/dist/esm/components/organisms/ImageChooser/ImageChooser.css +37 -0
- package/dist/esm/components/organisms/ImageChooser/ImageChooser.css.map +1 -0
- package/dist/esm/components/organisms/ImageChooser/ImageChooser.d.ts +11 -0
- package/dist/esm/components/organisms/ImageChooser/ImageChooser.js +62 -0
- package/dist/esm/components/organisms/ImageChooser/ImageChooser.js.map +1 -0
- package/dist/esm/components/organisms/ImageEditor/ImageEditor.css +97 -0
- package/dist/esm/components/organisms/ImageEditor/ImageEditor.css.map +1 -0
- package/dist/esm/components/organisms/ImageEditor/ImageEditor.d.ts +20 -0
- package/dist/esm/components/organisms/ImageEditor/ImageEditor.js +201 -0
- package/dist/esm/components/organisms/ImageEditor/ImageEditor.js.map +1 -0
- package/dist/esm/components/organisms/Modal/Modal.d.ts +2 -1
- package/dist/esm/components/organisms/Modal/Modal.js +5 -5
- package/dist/esm/components/organisms/Modal/Modal.js.map +1 -1
- package/dist/esm/components/organisms/index.d.ts +2 -0
- package/dist/esm/components/organisms/index.js +2 -0
- package/dist/esm/components/organisms/index.js.map +1 -1
- package/dist/esm/controllers/RelocationOnComponentController.d.ts +8 -0
- package/dist/esm/controllers/RelocationOnComponentController.js +93 -0
- package/dist/esm/controllers/RelocationOnComponentController.js.map +1 -0
- package/dist/esm/controllers/ResizeController.d.ts +15 -0
- package/dist/esm/controllers/ResizeController.js +29 -0
- package/dist/esm/controllers/ResizeController.js.map +1 -0
- package/dist/esm/controllers/index.d.ts +2 -0
- package/dist/esm/controllers/index.js +2 -0
- package/dist/esm/controllers/index.js.map +1 -1
- package/dist/esm/i18n.d.ts +3 -0
- package/dist/esm/i18n.js +6 -0
- package/dist/esm/i18n.js.map +1 -1
- 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":"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"}
|