@veracity/vui 2.5.0-beta.1 → 2.5.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/checkbox/checkbox.types.d.ts +1 -1
- package/dist/cjs/checkbox/checkbox.types.d.ts.map +1 -1
- package/dist/cjs/checkbox/checkboxGroup.types.d.ts +1 -1
- package/dist/cjs/checkbox/checkboxGroup.types.d.ts.map +1 -1
- package/dist/cjs/core/vuiProvider/globalStyle.d.ts.map +1 -1
- package/dist/cjs/core/vuiProvider/globalStyle.js +5 -2
- package/dist/cjs/icons/baseIcons/fal/falClockRotateLeft.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fal/falClockRotateLeft.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fal/falClockRotateLeft.js +7 -0
- package/dist/cjs/icons/baseIcons/icons.d.ts +1 -0
- package/dist/cjs/icons/baseIcons/icons.d.ts.map +1 -1
- package/dist/cjs/icons/baseIcons/icons.js +7 -5
- package/dist/cjs/icons/baseIcons/types.d.ts +1 -1
- package/dist/cjs/icons/baseIcons/types.d.ts.map +1 -1
- package/dist/cjs/input/inputInput.d.ts.map +1 -1
- package/dist/cjs/input/inputInput.js +0 -5
- package/dist/cjs/panel/theme.js +1 -1
- package/dist/cjs/progress/progress.js +2 -2
- package/dist/cjs/progress/theme.d.ts +15 -1
- package/dist/cjs/progress/theme.d.ts.map +1 -1
- package/dist/cjs/progress/theme.js +16 -2
- package/dist/cjs/progressCircular/progressCircular.d.ts.map +1 -1
- package/dist/cjs/progressCircular/progressCircular.js +7 -9
- package/dist/cjs/progressCircular/theme.d.ts +24 -2
- package/dist/cjs/progressCircular/theme.d.ts.map +1 -1
- package/dist/cjs/progressCircular/theme.js +26 -3
- package/dist/cjs/radio/radio.types.d.ts +1 -1
- package/dist/cjs/radio/radio.types.d.ts.map +1 -1
- package/dist/cjs/radio/radioGroup.types.d.ts +1 -1
- package/dist/cjs/radio/radioGroup.types.d.ts.map +1 -1
- package/dist/cjs/switch/consts.d.ts +9 -0
- package/dist/cjs/switch/consts.d.ts.map +1 -0
- package/dist/cjs/switch/consts.js +11 -0
- package/dist/cjs/switch/switch.types.d.ts +2 -2
- package/dist/cjs/switch/switch.types.d.ts.map +1 -1
- package/dist/cjs/switch/switchButton.d.ts.map +1 -1
- package/dist/cjs/switch/switchButton.js +19 -21
- package/dist/cjs/switch/switchMain.d.ts.map +1 -1
- package/dist/cjs/switch/switchMain.js +2 -3
- package/dist/cjs/switch/theme.d.ts +30 -14
- package/dist/cjs/switch/theme.d.ts.map +1 -1
- package/dist/cjs/switch/theme.js +33 -17
- package/dist/cjs/textarea/textarea.d.ts.map +1 -1
- package/dist/cjs/textarea/textarea.js +8 -17
- package/dist/cjs/textarea/textarea.types.d.ts +2 -2
- package/dist/cjs/textarea/textarea.types.d.ts.map +1 -1
- package/dist/cjs/textarea/theme.d.ts +29 -12
- package/dist/cjs/textarea/theme.d.ts.map +1 -1
- package/dist/cjs/textarea/theme.js +28 -17
- package/dist/cjs/theme/components.d.ts +87 -14
- package/dist/cjs/theme/components.d.ts.map +1 -1
- package/dist/cjs/theme/defaultTheme.d.ts +87 -14
- package/dist/cjs/theme/defaultTheme.d.ts.map +1 -1
- package/dist/cjs/tutorial/consts.d.ts +6 -0
- package/dist/cjs/tutorial/consts.d.ts.map +1 -0
- package/dist/cjs/tutorial/consts.js +8 -0
- package/dist/cjs/tutorial/tutorial.d.ts +1 -1
- package/dist/cjs/tutorial/tutorial.d.ts.map +1 -1
- package/dist/cjs/tutorial/tutorial.js +2 -2
- package/dist/cjs/tutorial/tutorial.types.d.ts +20 -12
- package/dist/cjs/tutorial/tutorial.types.d.ts.map +1 -1
- package/dist/cjs/tutorial/tutorialCard.d.ts +1 -1
- package/dist/cjs/tutorial/tutorialCard.d.ts.map +1 -1
- package/dist/cjs/tutorial/tutorialCard.js +19 -18
- package/dist/cjs/tutorial/tutorialStep.d.ts +1 -1
- package/dist/cjs/tutorial/tutorialStep.d.ts.map +1 -1
- package/dist/cjs/tutorial/tutorialStep.js +4 -5
- package/dist/esm/checkbox/checkbox.types.d.ts +1 -1
- package/dist/esm/checkbox/checkbox.types.d.ts.map +1 -1
- package/dist/esm/checkbox/checkboxGroup.types.d.ts +1 -1
- package/dist/esm/checkbox/checkboxGroup.types.d.ts.map +1 -1
- package/dist/esm/core/vuiProvider/globalStyle.d.ts.map +1 -1
- package/dist/esm/core/vuiProvider/globalStyle.js +5 -2
- package/dist/esm/icons/baseIcons/fal/falClockRotateLeft.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fal/falClockRotateLeft.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fal/falClockRotateLeft.js +5 -0
- package/dist/esm/icons/baseIcons/icons.d.ts +1 -0
- package/dist/esm/icons/baseIcons/icons.d.ts.map +1 -1
- package/dist/esm/icons/baseIcons/icons.js +1 -0
- package/dist/esm/icons/baseIcons/types.d.ts +1 -1
- package/dist/esm/icons/baseIcons/types.d.ts.map +1 -1
- package/dist/esm/input/inputInput.d.ts.map +1 -1
- package/dist/esm/input/inputInput.js +0 -5
- package/dist/esm/panel/theme.js +1 -1
- package/dist/esm/progress/progress.js +2 -2
- package/dist/esm/progress/theme.d.ts +15 -1
- package/dist/esm/progress/theme.d.ts.map +1 -1
- package/dist/esm/progress/theme.js +16 -2
- package/dist/esm/progressCircular/progressCircular.d.ts.map +1 -1
- package/dist/esm/progressCircular/progressCircular.js +7 -9
- package/dist/esm/progressCircular/theme.d.ts +24 -2
- package/dist/esm/progressCircular/theme.d.ts.map +1 -1
- package/dist/esm/progressCircular/theme.js +26 -3
- package/dist/esm/radio/radio.types.d.ts +1 -1
- package/dist/esm/radio/radio.types.d.ts.map +1 -1
- package/dist/esm/radio/radioGroup.types.d.ts +1 -1
- package/dist/esm/radio/radioGroup.types.d.ts.map +1 -1
- package/dist/esm/switch/consts.d.ts +9 -0
- package/dist/esm/switch/consts.d.ts.map +1 -0
- package/dist/esm/switch/consts.js +8 -0
- package/dist/esm/switch/switch.types.d.ts +2 -2
- package/dist/esm/switch/switch.types.d.ts.map +1 -1
- package/dist/esm/switch/switchButton.d.ts.map +1 -1
- package/dist/esm/switch/switchButton.js +19 -21
- package/dist/esm/switch/switchMain.d.ts.map +1 -1
- package/dist/esm/switch/switchMain.js +2 -3
- package/dist/esm/switch/theme.d.ts +30 -14
- package/dist/esm/switch/theme.d.ts.map +1 -1
- package/dist/esm/switch/theme.js +33 -17
- package/dist/esm/textarea/textarea.d.ts.map +1 -1
- package/dist/esm/textarea/textarea.js +8 -17
- package/dist/esm/textarea/textarea.types.d.ts +2 -2
- package/dist/esm/textarea/textarea.types.d.ts.map +1 -1
- package/dist/esm/textarea/theme.d.ts +29 -12
- package/dist/esm/textarea/theme.d.ts.map +1 -1
- package/dist/esm/textarea/theme.js +28 -17
- package/dist/esm/theme/components.d.ts +87 -14
- package/dist/esm/theme/components.d.ts.map +1 -1
- package/dist/esm/theme/defaultTheme.d.ts +87 -14
- package/dist/esm/theme/defaultTheme.d.ts.map +1 -1
- package/dist/esm/tutorial/consts.d.ts +6 -0
- package/dist/esm/tutorial/consts.d.ts.map +1 -0
- package/dist/esm/tutorial/consts.js +5 -0
- package/dist/esm/tutorial/tutorial.d.ts +1 -1
- package/dist/esm/tutorial/tutorial.d.ts.map +1 -1
- package/dist/esm/tutorial/tutorial.js +2 -2
- package/dist/esm/tutorial/tutorial.types.d.ts +20 -12
- package/dist/esm/tutorial/tutorial.types.d.ts.map +1 -1
- package/dist/esm/tutorial/tutorialCard.d.ts +1 -1
- package/dist/esm/tutorial/tutorialCard.d.ts.map +1 -1
- package/dist/esm/tutorial/tutorialCard.js +20 -19
- package/dist/esm/tutorial/tutorialStep.d.ts +1 -1
- package/dist/esm/tutorial/tutorialStep.d.ts.map +1 -1
- package/dist/esm/tutorial/tutorialStep.js +5 -6
- package/package.json +1 -1
- package/src/checkbox/checkbox.types.ts +1 -1
- package/src/checkbox/checkboxGroup.types.ts +1 -1
- package/src/core/vuiProvider/globalStyle.tsx +5 -2
- package/src/icons/baseIcons/fal/falClockRotateLeft.ts +8 -0
- package/src/icons/baseIcons/icons.ts +1 -0
- package/src/icons/baseIcons/types.ts +1 -0
- package/src/input/inputInput.tsx +0 -5
- package/src/panel/theme.ts +1 -1
- package/src/progress/progress.tsx +2 -2
- package/src/progress/theme.ts +16 -2
- package/src/progressCircular/progressCircular.tsx +14 -7
- package/src/progressCircular/theme.ts +27 -3
- package/src/radio/radio.types.ts +1 -1
- package/src/radio/radioGroup.types.ts +1 -1
- package/src/switch/consts.ts +8 -0
- package/src/switch/switch.types.ts +2 -2
- package/src/switch/switchButton.tsx +20 -20
- package/src/switch/switchMain.tsx +1 -3
- package/src/switch/theme.ts +34 -22
- package/src/textarea/textarea.tsx +7 -17
- package/src/textarea/textarea.types.ts +2 -2
- package/src/textarea/theme.ts +28 -23
- package/src/tutorial/consts.ts +5 -0
- package/src/tutorial/tutorial.tsx +7 -5
- package/src/tutorial/tutorial.types.ts +20 -12
- package/src/tutorial/tutorialCard.tsx +71 -80
- package/src/tutorial/tutorialStep.tsx +5 -11
- package/dist/cjs/textarea/consts.d.ts +0 -4
- package/dist/cjs/textarea/consts.d.ts.map +0 -1
- package/dist/cjs/textarea/consts.js +0 -6
- package/dist/esm/textarea/consts.d.ts +0 -4
- package/dist/esm/textarea/consts.d.ts.map +0 -1
- package/dist/esm/textarea/consts.js +0 -3
- package/src/textarea/consts.ts +0 -3
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import React, { useEffect, useRef, useState } from 'react';
|
|
2
2
|
import { omitThemingProps, styled, useStyleConfig, vui } from '../core';
|
|
3
3
|
import { cs, filterUndefined } from '../utils';
|
|
4
|
+
import { switchColors } from './consts';
|
|
4
5
|
import { useSwitchContext } from './context';
|
|
5
6
|
const SwitchInput = styled.inputBox `
|
|
6
7
|
cursor: inherit;
|
|
@@ -14,41 +15,38 @@ const SwitchInput = styled.inputBox `
|
|
|
14
15
|
width: calc(100% + 10px);
|
|
15
16
|
z-index: 1;
|
|
16
17
|
`;
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
border-radius: round;
|
|
18
|
+
const SwitchFoundation = styled.spanBox `
|
|
19
|
+
border-radius: 100px;
|
|
20
20
|
display: inline-flex;
|
|
21
21
|
flex-shrink: 0;
|
|
22
|
-
position: absolute;
|
|
23
22
|
transition-duration: fast;
|
|
23
|
+
position: relative;
|
|
24
|
+
`;
|
|
25
|
+
/** Circular element that moves along the track when toggled. */
|
|
26
|
+
const SwitchThumb = styled(SwitchFoundation) `
|
|
27
|
+
position: absolute;
|
|
24
28
|
`;
|
|
25
29
|
/** Track element along which the thumb moves when toggled. */
|
|
26
|
-
const SwitchTrack = styled
|
|
30
|
+
const SwitchTrack = styled(SwitchFoundation) `
|
|
27
31
|
align-items: center;
|
|
28
|
-
border-radius: round;
|
|
29
|
-
display: inline-flex;
|
|
30
32
|
flex: 1;
|
|
31
|
-
position: relative;
|
|
32
|
-
transition-duration: fast;
|
|
33
33
|
`;
|
|
34
|
-
export const SwitchButtonBase = styled
|
|
34
|
+
export const SwitchButtonBase = styled(SwitchFoundation) `
|
|
35
35
|
color: white;
|
|
36
36
|
cursor: pointer;
|
|
37
|
-
|
|
38
|
-
flex-shrink: 0;
|
|
39
|
-
position: relative;
|
|
37
|
+
--x-ring-color: green;
|
|
40
38
|
|
|
41
39
|
&[aria-disabled='true'] {
|
|
42
40
|
cursor: not-allowed;
|
|
43
41
|
|
|
44
42
|
.vui-switchThumb {
|
|
45
|
-
background-color: disabled
|
|
43
|
+
background-color: ${switchColors.disabled};
|
|
46
44
|
}
|
|
47
45
|
|
|
48
46
|
.vui-switchTrack {
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
47
|
+
--x-ring-color: ${switchColors.disabled};
|
|
48
|
+
background-color: ${switchColors.disabledBg};
|
|
49
|
+
color: ${switchColors.disabled};
|
|
52
50
|
}
|
|
53
51
|
}
|
|
54
52
|
`;
|
|
@@ -92,14 +90,14 @@ export const SwitchButton = vui((props, ref) => {
|
|
|
92
90
|
ring: isFocused ? thumbStyles.ring : 0
|
|
93
91
|
});
|
|
94
92
|
const trackAliasedProps = filterUndefined({
|
|
95
|
-
bg: isChecked ? trackStyles.bg :
|
|
93
|
+
bg: isChecked ? trackStyles.bg : switchColors.disabled,
|
|
96
94
|
pl: isChecked ? 1 : labelOffset,
|
|
97
95
|
pr: isChecked ? labelOffset : 1,
|
|
98
|
-
ring: !disabled ? (isFocused ? trackStyles.ring : 0) :
|
|
96
|
+
ring: !disabled ? (isFocused ? trackStyles.ring : 0) : 3
|
|
99
97
|
});
|
|
100
98
|
return (React.createElement(SwitchButtonBase, { className: cs('vui-switchButton', className), ref: ref, ...buttonStyles, ...aliasedProps, ...rest },
|
|
101
|
-
React.createElement(SwitchInput, { className: "vui-switchInput", onBlur: handleOnBlur, onChange: handleOnChange, onFocus: handleOnFocus, ref: inputRef, type: "checkbox", ...{ checked, defaultChecked, disabled, id, name, required, value }, ...inputProps }),
|
|
102
|
-
React.createElement(SwitchTrack, { className: "vui-switchTrack", ...trackStyles, ...trackAliasedProps },
|
|
99
|
+
React.createElement(SwitchInput, { className: "vui-switchInput", onBlur: handleOnBlur, onChange: handleOnChange, onFocus: handleOnFocus, ref: inputRef, tabIndex: -1, type: "checkbox", ...{ checked, defaultChecked, disabled, id, name, required, value }, ...inputProps }),
|
|
100
|
+
React.createElement(SwitchTrack, { className: "vui-switchTrack", tabIndex: 0, ...trackStyles, ...trackAliasedProps },
|
|
103
101
|
!isChecked && innerLabelOff,
|
|
104
102
|
React.createElement(SwitchThumb, { className: "vui-switchThumb", ...thumbStyles, ...thumbAliasedProps }),
|
|
105
103
|
isChecked && innerLabelOn)));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"switchMain.d.ts","sourceRoot":"","sources":["../../../src/switch/switchMain.tsx"],"names":[],"mappings":"AAEA,OAAO,EAA+B,YAAY,EAAE,MAAM,SAAS,CAAA;AAGnE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C,eAAO,MAAM,UAAU,iIActB,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,MAAM;
|
|
1
|
+
{"version":3,"file":"switchMain.d.ts","sourceRoot":"","sources":["../../../src/switch/switchMain.tsx"],"names":[],"mappings":"AAEA,OAAO,EAA+B,YAAY,EAAE,MAAM,SAAS,CAAA;AAGnE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C,eAAO,MAAM,UAAU,iIActB,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,MAAM;YA6DT,mBAAmB;WACpB,kBAAkB;CAC1B,CAAA;AAKD,eAAe,MAAM,CAAA"}
|
|
@@ -24,11 +24,10 @@ export const SwitchBase = styled.labelBox `
|
|
|
24
24
|
* Forwards many relevant props to the innner input element. Exposes some props to the children via context.
|
|
25
25
|
*/
|
|
26
26
|
export const Switch = vui((props, ref) => {
|
|
27
|
-
const { button, checked, children, className,
|
|
27
|
+
const { button, checked, children, className, defaultChecked, disabled, id, innerLabelOff, innerLabelOn, inputProps, inputRef, labelLeft, labelRight, name, onBlur, onChange, onFocus, required, size, value, variant, ...rest } = props;
|
|
28
28
|
const styles = useStyleConfig('Switch', props);
|
|
29
29
|
const context = useMemo(() => filterUndefined({
|
|
30
30
|
checked,
|
|
31
|
-
colorScheme,
|
|
32
31
|
defaultChecked,
|
|
33
32
|
disabled,
|
|
34
33
|
name,
|
|
@@ -39,7 +38,7 @@ export const Switch = vui((props, ref) => {
|
|
|
39
38
|
size,
|
|
40
39
|
value,
|
|
41
40
|
variant
|
|
42
|
-
}), [checked,
|
|
41
|
+
}), [checked, defaultChecked, disabled, name, onBlur, onChange, onFocus, required, size, value, variant]);
|
|
43
42
|
const aliasedProps = filterUndefined({
|
|
44
43
|
'aria-disabled': disabled
|
|
45
44
|
});
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { Dict } from '../utils';
|
|
2
1
|
declare function sizeLg(): {
|
|
3
2
|
button: {
|
|
4
3
|
fontSize: string;
|
|
@@ -47,21 +46,18 @@ declare function sizeSm(): {
|
|
|
47
46
|
size: string;
|
|
48
47
|
};
|
|
49
48
|
};
|
|
50
|
-
declare
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
49
|
+
declare const _default: {
|
|
50
|
+
baseStyle: {
|
|
51
|
+
button: {
|
|
52
|
+
thumb: {
|
|
53
|
+
bg: string;
|
|
54
|
+
};
|
|
55
|
+
track: {
|
|
56
|
+
ring: number;
|
|
57
|
+
};
|
|
58
58
|
};
|
|
59
59
|
};
|
|
60
|
-
};
|
|
61
|
-
declare const _default: {
|
|
62
|
-
baseStyle: {};
|
|
63
60
|
defaultProps: {
|
|
64
|
-
colorScheme: string;
|
|
65
61
|
size: string;
|
|
66
62
|
variant: string;
|
|
67
63
|
};
|
|
@@ -72,7 +68,27 @@ declare const _default: {
|
|
|
72
68
|
lg: typeof sizeLg;
|
|
73
69
|
};
|
|
74
70
|
variants: {
|
|
75
|
-
|
|
71
|
+
primary: {
|
|
72
|
+
button: {
|
|
73
|
+
track: {
|
|
74
|
+
bg: string;
|
|
75
|
+
};
|
|
76
|
+
};
|
|
77
|
+
};
|
|
78
|
+
green: {
|
|
79
|
+
button: {
|
|
80
|
+
track: {
|
|
81
|
+
bg: string;
|
|
82
|
+
};
|
|
83
|
+
};
|
|
84
|
+
};
|
|
85
|
+
red: {
|
|
86
|
+
button: {
|
|
87
|
+
track: {
|
|
88
|
+
bg: string;
|
|
89
|
+
};
|
|
90
|
+
};
|
|
91
|
+
};
|
|
76
92
|
};
|
|
77
93
|
};
|
|
78
94
|
export default _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["../../../src/switch/theme.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["../../../src/switch/theme.ts"],"names":[],"mappings":"AAaA,iBAAS,MAAM;;;;;;;;;;;;;;;EAkBd;AAED,iBAAS,MAAM;;;;;;;;;;;;;;;EAkBd;AAED,iBAAS,MAAM;;;;;;;;;;;;;;;EAkBd;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuCD,wBAMC"}
|
package/dist/esm/switch/theme.js
CHANGED
|
@@ -1,3 +1,14 @@
|
|
|
1
|
+
import { switchColors } from './consts';
|
|
2
|
+
const baseStyle = {
|
|
3
|
+
button: {
|
|
4
|
+
thumb: {
|
|
5
|
+
bg: 'white'
|
|
6
|
+
},
|
|
7
|
+
track: {
|
|
8
|
+
ring: 3
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
};
|
|
1
12
|
function sizeLg() {
|
|
2
13
|
const button = {
|
|
3
14
|
fontSize: 'md',
|
|
@@ -49,24 +60,9 @@ function sizeSm() {
|
|
|
49
60
|
};
|
|
50
61
|
return { button, label };
|
|
51
62
|
}
|
|
52
|
-
function variantContained(props) {
|
|
53
|
-
const { colorScheme: c } = props;
|
|
54
|
-
const button = {
|
|
55
|
-
thumb: {
|
|
56
|
-
bg: 'white'
|
|
57
|
-
},
|
|
58
|
-
track: {
|
|
59
|
-
bg: `${c}.80`,
|
|
60
|
-
ring: 3
|
|
61
|
-
}
|
|
62
|
-
};
|
|
63
|
-
return { button };
|
|
64
|
-
}
|
|
65
|
-
const baseStyle = {};
|
|
66
63
|
const defaultProps = {
|
|
67
|
-
colorScheme: 'blue',
|
|
68
64
|
size: 'md',
|
|
69
|
-
variant: '
|
|
65
|
+
variant: 'primary'
|
|
70
66
|
};
|
|
71
67
|
const parts = ['container', 'button', 'label'];
|
|
72
68
|
const sizes = {
|
|
@@ -75,7 +71,27 @@ const sizes = {
|
|
|
75
71
|
lg: sizeLg
|
|
76
72
|
};
|
|
77
73
|
const variants = {
|
|
78
|
-
|
|
74
|
+
primary: {
|
|
75
|
+
button: {
|
|
76
|
+
track: {
|
|
77
|
+
bg: switchColors.main
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
},
|
|
81
|
+
green: {
|
|
82
|
+
button: {
|
|
83
|
+
track: {
|
|
84
|
+
bg: switchColors.green
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
},
|
|
88
|
+
red: {
|
|
89
|
+
button: {
|
|
90
|
+
track: {
|
|
91
|
+
bg: switchColors.red
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
79
95
|
};
|
|
80
96
|
export default {
|
|
81
97
|
baseStyle,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"textarea.d.ts","sourceRoot":"","sources":["../../../src/textarea/textarea.tsx"],"names":[],"mappings":"AAOA,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;
|
|
1
|
+
{"version":3,"file":"textarea.d.ts","sourceRoot":"","sources":["../../../src/textarea/textarea.tsx"],"names":[],"mappings":"AAOA,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AAkBhD,eAAO,MAAM,YAAY,+HAKxB,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,QAAQ,sDA+FnB,CAAA;AAEF,eAAe,QAAQ,CAAA"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import React, { useEffect, useState } from 'react';
|
|
2
2
|
import { omitThemingProps, styled, useStyleConfig, vui } from '../core';
|
|
3
|
+
import { inputColors } from '../input/consts';
|
|
3
4
|
import T from '../t';
|
|
4
5
|
import { cs, filterUndefined } from '../utils';
|
|
5
|
-
import { greyColor, greyLightColor, redColor } from './consts';
|
|
6
6
|
import { getInitialCount } from './helpers';
|
|
7
7
|
const TextareaTextarea = styled.textareaBox `
|
|
8
8
|
border-radius: none;
|
|
@@ -13,15 +13,9 @@ const TextareaTextarea = styled.textareaBox `
|
|
|
13
13
|
transition-duration: fast;
|
|
14
14
|
width: 100%;
|
|
15
15
|
|
|
16
|
-
&::placeholder {
|
|
17
|
-
color: grey.60;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
16
|
&[aria-disabled='true'],
|
|
21
17
|
&[aria-disabled='true']::placeholder {
|
|
22
|
-
|
|
23
|
-
border-color: disabled.border;
|
|
24
|
-
color: disabled.color;
|
|
18
|
+
opacity: 0.5;
|
|
25
19
|
cursor: not-allowed;
|
|
26
20
|
}
|
|
27
21
|
`;
|
|
@@ -36,13 +30,10 @@ export const TextareaBase = styled.divBox `
|
|
|
36
30
|
* Forwards many relevant props to the inner textarea. Exposes some props to the children via context.
|
|
37
31
|
*/
|
|
38
32
|
export const Textarea = vui((props, ref) => {
|
|
39
|
-
const { autoFocus, className, colorScheme: colorSchemeProp, cols, defaultValue, disabled, id,
|
|
33
|
+
const { autoFocus, className, colorScheme: colorSchemeProp, cols, defaultValue, disabled, id, maxLength, name, onBlur, onChange: onChangeProp, onFocus, placeholder, readOnly, required, resize = 'none', rows, showCount, textareaProps = {}, textareaRef, value, ...rest } = omitThemingProps(props);
|
|
40
34
|
const [count, setCount] = useState(getInitialCount(props));
|
|
41
35
|
const [valueInternal, setValueInternal] = useState(defaultValue);
|
|
42
|
-
const
|
|
43
|
-
colorScheme: colorSchemeProp ?? (isInvalid ? 'red' : undefined)
|
|
44
|
-
});
|
|
45
|
-
const styles = useStyleConfig('Textarea', { ...colorProps, ...props });
|
|
36
|
+
const styles = useStyleConfig('Textarea', props);
|
|
46
37
|
function onChange(e) {
|
|
47
38
|
setValueInternal(e.target.value);
|
|
48
39
|
setCount(e.target.value.length);
|
|
@@ -53,9 +44,9 @@ export const Textarea = vui((props, ref) => {
|
|
|
53
44
|
});
|
|
54
45
|
const textareaAliasedProps = filterUndefined({
|
|
55
46
|
'aria-disabled': disabled,
|
|
56
|
-
bg: readOnly ?
|
|
57
|
-
|
|
58
|
-
|
|
47
|
+
bg: readOnly ? inputColors.disabled : undefined,
|
|
48
|
+
focusWithinBorderColor: !readOnly ? 'transparent' : undefined,
|
|
49
|
+
focusWithinRingColor: readOnly ? 'transparent' : undefined
|
|
59
50
|
});
|
|
60
51
|
useEffect(() => {
|
|
61
52
|
setValueInternal(value);
|
|
@@ -79,7 +70,7 @@ export const Textarea = vui((props, ref) => {
|
|
|
79
70
|
resize,
|
|
80
71
|
rows
|
|
81
72
|
}, value: valueInternal, ...styles.textarea, ...textareaAliasedProps, ...textareaProps }),
|
|
82
|
-
showCount && (React.createElement(T, { className: "vui-textareaCount", color: maxLength && count > maxLength ?
|
|
73
|
+
showCount && (React.createElement(T, { className: "vui-textareaCount", color: maxLength && count > maxLength ? inputColors.error : inputColors.helpText, position: "absolute", right: 0, size: "sm", top: "calc(100% + 1px)" },
|
|
83
74
|
count,
|
|
84
75
|
" ",
|
|
85
76
|
maxLength ? `/ ${maxLength}` : null))));
|
|
@@ -7,7 +7,7 @@ export declare type TextareaProps = SystemProps & ThemingProps<'Textarea'> & {
|
|
|
7
7
|
autoFocus?: boolean;
|
|
8
8
|
/** Children are disabled for this component. */
|
|
9
9
|
children?: never;
|
|
10
|
-
/**
|
|
10
|
+
/** Deprecated. Please use variant instead. @deprecated */
|
|
11
11
|
colorScheme?: 'green' | 'grey' | 'red';
|
|
12
12
|
/** Passed to the inner input. */
|
|
13
13
|
cols?: number;
|
|
@@ -15,7 +15,7 @@ export declare type TextareaProps = SystemProps & ThemingProps<'Textarea'> & {
|
|
|
15
15
|
defaultValue?: number | string;
|
|
16
16
|
/** Passed to the inner input. */
|
|
17
17
|
disabled?: boolean;
|
|
18
|
-
/**
|
|
18
|
+
/** Deprecated. Please use variant="red" instead. @deprecated*/
|
|
19
19
|
isInvalid?: boolean;
|
|
20
20
|
/** Passed to the inner input. */
|
|
21
21
|
maxLength?: number;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"textarea.types.d.ts","sourceRoot":"","sources":["../../../src/textarea/textarea.types.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AACvC,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,OAAO,EAAE,MAAM,UAAU,CAAA;AAEzE,oBAAY,aAAa,GAAG,WAAW,GACrC,YAAY,CAAC,UAAU,CAAC,GAAG;IACzB,iCAAiC;IACjC,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,gDAAgD;IAChD,QAAQ,CAAC,EAAE,KAAK,CAAA;IAChB
|
|
1
|
+
{"version":3,"file":"textarea.types.d.ts","sourceRoot":"","sources":["../../../src/textarea/textarea.types.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AACvC,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,OAAO,EAAE,MAAM,UAAU,CAAA;AAEzE,oBAAY,aAAa,GAAG,WAAW,GACrC,YAAY,CAAC,UAAU,CAAC,GAAG;IACzB,iCAAiC;IACjC,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,gDAAgD;IAChD,QAAQ,CAAC,EAAE,KAAK,CAAA;IAChB,2DAA2D;IAC3D,WAAW,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,KAAK,CAAA;IACtC,iCAAiC;IACjC,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,iCAAiC;IACjC,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IAC9B,iCAAiC;IACjC,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,+DAA+D;IAC/D,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,iCAAiC;IACjC,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,iCAAiC;IACjC,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,iCAAiC;IACjC,MAAM,CAAC,EAAE,iBAAiB,CAAC,mBAAmB,CAAC,CAAA;IAC/C,iCAAiC;IACjC,QAAQ,CAAC,EAAE,kBAAkB,CAAC,mBAAmB,CAAC,CAAA;IAClD,iCAAiC;IACjC,OAAO,CAAC,EAAE,iBAAiB,CAAC,mBAAmB,CAAC,CAAA;IAChD,iCAAiC;IACjC,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,iCAAiC;IACjC,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,iCAAiC;IACjC,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,iCAAiC;IACjC,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,iEAAiE;IACjE,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,iDAAiD;IACjD,aAAa,CAAC,EAAE,OAAO,CAAC,UAAU,EAAE,WAAW,CAAC,CAAA;IAChD,wCAAwC;IACxC,WAAW,CAAC,EAAE,KAAK,CAAC,gBAAgB,CAAC,mBAAmB,GAAG,IAAI,CAAC,GAAG,IAAI,CAAA;IACvE,iCAAiC;IACjC,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;CACxB,CAAA"}
|
|
@@ -1,22 +1,39 @@
|
|
|
1
|
-
import { Dict } from '../utils';
|
|
2
|
-
declare function variantDefault(props: Dict): {
|
|
3
|
-
container: {};
|
|
4
|
-
textarea: {
|
|
5
|
-
borderColor: string;
|
|
6
|
-
focusRing: number;
|
|
7
|
-
focusRingColor: string;
|
|
8
|
-
};
|
|
9
|
-
};
|
|
10
1
|
declare const _default: {
|
|
11
|
-
baseStyle: {
|
|
2
|
+
baseStyle: {
|
|
3
|
+
textarea: {
|
|
4
|
+
focusWithinRing: number;
|
|
5
|
+
color: string;
|
|
6
|
+
};
|
|
7
|
+
input: {
|
|
8
|
+
color: {
|
|
9
|
+
placeholder: string;
|
|
10
|
+
};
|
|
11
|
+
};
|
|
12
|
+
};
|
|
12
13
|
defaultProps: {
|
|
13
|
-
colorScheme: string;
|
|
14
14
|
variant: string;
|
|
15
15
|
};
|
|
16
16
|
parts: string[];
|
|
17
17
|
sizes: {};
|
|
18
18
|
variants: {
|
|
19
|
-
|
|
19
|
+
grey: {
|
|
20
|
+
textarea: {
|
|
21
|
+
borderColor: string;
|
|
22
|
+
focusWithinRingColor: string;
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
green: {
|
|
26
|
+
textarea: {
|
|
27
|
+
borderColor: string;
|
|
28
|
+
focusWithinRingColor: string;
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
red: {
|
|
32
|
+
textarea: {
|
|
33
|
+
borderColor: string;
|
|
34
|
+
focusWithinRingColor: string;
|
|
35
|
+
};
|
|
36
|
+
};
|
|
20
37
|
};
|
|
21
38
|
};
|
|
22
39
|
export default _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["../../../src/textarea/theme.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["../../../src/textarea/theme.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyCA,wBAMC"}
|
|
@@ -1,26 +1,37 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
if (c === 'grey') {
|
|
10
|
-
textarea.borderColor = `${c}.60`;
|
|
11
|
-
textarea.focusRingColor = 'blue.50';
|
|
1
|
+
import { inputColors } from '../input/consts';
|
|
2
|
+
const baseStyle = {
|
|
3
|
+
textarea: {
|
|
4
|
+
focusWithinRing: 2,
|
|
5
|
+
color: inputColors.inputText
|
|
6
|
+
},
|
|
7
|
+
input: {
|
|
8
|
+
color: { placeholder: inputColors.placeholder }
|
|
12
9
|
}
|
|
13
|
-
|
|
14
|
-
}
|
|
15
|
-
const baseStyle = {};
|
|
10
|
+
};
|
|
16
11
|
const defaultProps = {
|
|
17
|
-
|
|
18
|
-
variant: 'default'
|
|
12
|
+
variant: 'grey'
|
|
19
13
|
};
|
|
20
14
|
const parts = ['container', 'textarea'];
|
|
21
15
|
const sizes = {};
|
|
22
16
|
const variants = {
|
|
23
|
-
|
|
17
|
+
grey: {
|
|
18
|
+
textarea: {
|
|
19
|
+
borderColor: inputColors.border,
|
|
20
|
+
focusWithinRingColor: inputColors.focus
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
green: {
|
|
24
|
+
textarea: {
|
|
25
|
+
borderColor: inputColors.success,
|
|
26
|
+
focusWithinRingColor: inputColors.success
|
|
27
|
+
}
|
|
28
|
+
},
|
|
29
|
+
red: {
|
|
30
|
+
textarea: {
|
|
31
|
+
borderColor: inputColors.error,
|
|
32
|
+
focusWithinRingColor: inputColors.error
|
|
33
|
+
}
|
|
34
|
+
}
|
|
24
35
|
};
|
|
25
36
|
export default {
|
|
26
37
|
baseStyle,
|
|
@@ -1335,6 +1335,7 @@ declare const _default: {
|
|
|
1335
1335
|
baseStyle: {};
|
|
1336
1336
|
defaultProps: {
|
|
1337
1337
|
size: string;
|
|
1338
|
+
variant: string;
|
|
1338
1339
|
};
|
|
1339
1340
|
sizes: {
|
|
1340
1341
|
sm: {
|
|
@@ -1374,12 +1375,28 @@ declare const _default: {
|
|
|
1374
1375
|
};
|
|
1375
1376
|
};
|
|
1376
1377
|
};
|
|
1377
|
-
variants: {
|
|
1378
|
+
variants: {
|
|
1379
|
+
primary: {
|
|
1380
|
+
bg: string;
|
|
1381
|
+
color: string;
|
|
1382
|
+
};
|
|
1383
|
+
green: {
|
|
1384
|
+
bg: string;
|
|
1385
|
+
color: string;
|
|
1386
|
+
};
|
|
1387
|
+
red: {
|
|
1388
|
+
bg: string;
|
|
1389
|
+
color: string;
|
|
1390
|
+
};
|
|
1391
|
+
};
|
|
1378
1392
|
};
|
|
1379
1393
|
ProgressCircular: {
|
|
1380
|
-
baseStyle: {
|
|
1394
|
+
baseStyle: {
|
|
1395
|
+
color: string;
|
|
1396
|
+
};
|
|
1381
1397
|
defaultProps: {
|
|
1382
1398
|
size: string;
|
|
1399
|
+
variant: string;
|
|
1383
1400
|
};
|
|
1384
1401
|
sizes: {
|
|
1385
1402
|
sm: {
|
|
@@ -1407,7 +1424,26 @@ declare const _default: {
|
|
|
1407
1424
|
fontSize: number;
|
|
1408
1425
|
};
|
|
1409
1426
|
};
|
|
1410
|
-
variants: {
|
|
1427
|
+
variants: {
|
|
1428
|
+
primary: {
|
|
1429
|
+
stroke: {
|
|
1430
|
+
main: string;
|
|
1431
|
+
progress: string;
|
|
1432
|
+
};
|
|
1433
|
+
};
|
|
1434
|
+
green: {
|
|
1435
|
+
stroke: {
|
|
1436
|
+
main: string;
|
|
1437
|
+
progress: string;
|
|
1438
|
+
};
|
|
1439
|
+
};
|
|
1440
|
+
red: {
|
|
1441
|
+
stroke: {
|
|
1442
|
+
main: string;
|
|
1443
|
+
progress: string;
|
|
1444
|
+
};
|
|
1445
|
+
};
|
|
1446
|
+
};
|
|
1411
1447
|
};
|
|
1412
1448
|
Popover: {
|
|
1413
1449
|
baseStyle: {};
|
|
@@ -1607,9 +1643,17 @@ declare const _default: {
|
|
|
1607
1643
|
};
|
|
1608
1644
|
};
|
|
1609
1645
|
Switch: {
|
|
1610
|
-
baseStyle: {
|
|
1646
|
+
baseStyle: {
|
|
1647
|
+
button: {
|
|
1648
|
+
thumb: {
|
|
1649
|
+
bg: string;
|
|
1650
|
+
};
|
|
1651
|
+
track: {
|
|
1652
|
+
ring: number;
|
|
1653
|
+
};
|
|
1654
|
+
};
|
|
1655
|
+
};
|
|
1611
1656
|
defaultProps: {
|
|
1612
|
-
colorScheme: string;
|
|
1613
1657
|
size: string;
|
|
1614
1658
|
variant: string;
|
|
1615
1659
|
};
|
|
@@ -1665,14 +1709,24 @@ declare const _default: {
|
|
|
1665
1709
|
};
|
|
1666
1710
|
};
|
|
1667
1711
|
variants: {
|
|
1668
|
-
|
|
1712
|
+
primary: {
|
|
1669
1713
|
button: {
|
|
1670
|
-
|
|
1714
|
+
track: {
|
|
1715
|
+
bg: string;
|
|
1716
|
+
};
|
|
1717
|
+
};
|
|
1718
|
+
};
|
|
1719
|
+
green: {
|
|
1720
|
+
button: {
|
|
1721
|
+
track: {
|
|
1671
1722
|
bg: string;
|
|
1672
1723
|
};
|
|
1724
|
+
};
|
|
1725
|
+
};
|
|
1726
|
+
red: {
|
|
1727
|
+
button: {
|
|
1673
1728
|
track: {
|
|
1674
1729
|
bg: string;
|
|
1675
|
-
ring: number;
|
|
1676
1730
|
};
|
|
1677
1731
|
};
|
|
1678
1732
|
};
|
|
@@ -2030,20 +2084,39 @@ declare const _default: {
|
|
|
2030
2084
|
};
|
|
2031
2085
|
};
|
|
2032
2086
|
Textarea: {
|
|
2033
|
-
baseStyle: {
|
|
2087
|
+
baseStyle: {
|
|
2088
|
+
textarea: {
|
|
2089
|
+
focusWithinRing: number;
|
|
2090
|
+
color: string;
|
|
2091
|
+
};
|
|
2092
|
+
input: {
|
|
2093
|
+
color: {
|
|
2094
|
+
placeholder: string;
|
|
2095
|
+
};
|
|
2096
|
+
};
|
|
2097
|
+
};
|
|
2034
2098
|
defaultProps: {
|
|
2035
|
-
colorScheme: string;
|
|
2036
2099
|
variant: string;
|
|
2037
2100
|
};
|
|
2038
2101
|
parts: string[];
|
|
2039
2102
|
sizes: {};
|
|
2040
2103
|
variants: {
|
|
2041
|
-
|
|
2042
|
-
|
|
2104
|
+
grey: {
|
|
2105
|
+
textarea: {
|
|
2106
|
+
borderColor: string;
|
|
2107
|
+
focusWithinRingColor: string;
|
|
2108
|
+
};
|
|
2109
|
+
};
|
|
2110
|
+
green: {
|
|
2111
|
+
textarea: {
|
|
2112
|
+
borderColor: string;
|
|
2113
|
+
focusWithinRingColor: string;
|
|
2114
|
+
};
|
|
2115
|
+
};
|
|
2116
|
+
red: {
|
|
2043
2117
|
textarea: {
|
|
2044
2118
|
borderColor: string;
|
|
2045
|
-
|
|
2046
|
-
focusRingColor: string;
|
|
2119
|
+
focusWithinRingColor: string;
|
|
2047
2120
|
};
|
|
2048
2121
|
};
|
|
2049
2122
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"components.d.ts","sourceRoot":"","sources":["../../../src/theme/components.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"components.d.ts","sourceRoot":"","sources":["../../../src/theme/components.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkDA,wBA6CC"}
|