@itcase/ui 1.0.13 → 1.0.14
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.
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var PropTypes = require('prop-types');
|
|
5
|
+
var clsx = require('clsx');
|
|
6
|
+
var index = require('./Icon.js');
|
|
7
|
+
var useDeviceTargetClass = require('../hooks/useDeviceTargetClass.js');
|
|
8
|
+
require('react-inlinesvg');
|
|
9
|
+
require('../constants/componentProps/fill.js');
|
|
10
|
+
require('../constants/componentProps/iconSize.js');
|
|
11
|
+
require('../constants/componentProps/shape.js');
|
|
12
|
+
require('../constants/componentProps/strokeColor.js');
|
|
13
|
+
require('./Link.js');
|
|
14
|
+
require('../useStyles-e4accb53.js');
|
|
15
|
+
require('lodash/camelCase');
|
|
16
|
+
require('lodash/maxBy');
|
|
17
|
+
require('lodash/upperFirst');
|
|
18
|
+
require('../hooks/styleAttributes.js');
|
|
19
|
+
require('../context/UIContext.js');
|
|
20
|
+
require('../hooks/useMediaQueries.js');
|
|
21
|
+
require('react-responsive');
|
|
22
|
+
require('../constants/componentProps/size.js');
|
|
23
|
+
require('../constants/componentProps/textColor.js');
|
|
24
|
+
require('../constants/componentProps/textGradient.js');
|
|
25
|
+
require('../constants/componentProps/textStyle.js');
|
|
26
|
+
require('../constants/componentProps/textWeight.js');
|
|
27
|
+
require('../constants/componentProps/type.js');
|
|
28
|
+
require('../constants/componentProps/underline.js');
|
|
29
|
+
require('lodash/castArray');
|
|
30
|
+
|
|
31
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
32
|
+
|
|
33
|
+
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
34
|
+
var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
|
|
35
|
+
var clsx__default = /*#__PURE__*/_interopDefault(clsx);
|
|
36
|
+
|
|
37
|
+
var inputPasswordConfig = {
|
|
38
|
+
state: {},
|
|
39
|
+
setState: function setState(newComponent) {
|
|
40
|
+
inputPasswordConfig.state = newComponent;
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
function InputPassword(props) {
|
|
44
|
+
var _inputPasswordConfig$, _inputPasswordConfig$2, _inputPasswordConfig$3;
|
|
45
|
+
var state = props.state,
|
|
46
|
+
id = props.id,
|
|
47
|
+
iconFill = props.iconFill,
|
|
48
|
+
iconRevealableHide = props.iconRevealableHide,
|
|
49
|
+
iconRevealableShow = props.iconRevealableShow,
|
|
50
|
+
iconFillHover = props.iconFillHover,
|
|
51
|
+
iconShape = props.iconShape,
|
|
52
|
+
iconSize = props.iconSize,
|
|
53
|
+
isRevealable = props.isRevealable,
|
|
54
|
+
className = props.className,
|
|
55
|
+
placeholder = props.placeholder,
|
|
56
|
+
disabled = props.disabled,
|
|
57
|
+
value = props.value,
|
|
58
|
+
onBlur = props.onBlur,
|
|
59
|
+
onChange = props.onChange,
|
|
60
|
+
onFocus = props.onFocus,
|
|
61
|
+
onKeyDown = props.onKeyDown;
|
|
62
|
+
var fillClass = useDeviceTargetClass.useDeviceTargetClass(props, {
|
|
63
|
+
prefix: 'fill_',
|
|
64
|
+
propsKey: 'fill'
|
|
65
|
+
});
|
|
66
|
+
var sizeClass = useDeviceTargetClass.useDeviceTargetClass(props, {
|
|
67
|
+
prefix: 'input-password__input_size_',
|
|
68
|
+
propsKey: 'size'
|
|
69
|
+
});
|
|
70
|
+
var shapeClass = useDeviceTargetClass.useDeviceTargetClass(props, {
|
|
71
|
+
prefix: 'input-password__input_shape_',
|
|
72
|
+
propsKey: 'shape'
|
|
73
|
+
});
|
|
74
|
+
var textSizeClass = useDeviceTargetClass.useDeviceTargetClass(props, {
|
|
75
|
+
prefix: 'text_size_',
|
|
76
|
+
propsKey: 'textSize'
|
|
77
|
+
});
|
|
78
|
+
var textColorClass = useDeviceTargetClass.useDeviceTargetClass(props, {
|
|
79
|
+
prefix: 'text-color_',
|
|
80
|
+
propsKey: 'textColor'
|
|
81
|
+
});
|
|
82
|
+
var caretClass = useDeviceTargetClass.useDeviceTargetClass(props, {
|
|
83
|
+
prefix: 'caret-color_',
|
|
84
|
+
propsKey: 'caret'
|
|
85
|
+
});
|
|
86
|
+
var placeholderClass = useDeviceTargetClass.useDeviceTargetClass(props, {
|
|
87
|
+
prefix: 'placeholder-text-color_',
|
|
88
|
+
propsKey: 'placeholderTextColor'
|
|
89
|
+
});
|
|
90
|
+
var weightClass = useDeviceTargetClass.useDeviceTargetClass(props, {
|
|
91
|
+
prefix: 'text-weight_',
|
|
92
|
+
propsKey: 'textWeight'
|
|
93
|
+
});
|
|
94
|
+
var borderWidthClass = useDeviceTargetClass.useDeviceTargetClass(props, {
|
|
95
|
+
prefix: 'border-width_',
|
|
96
|
+
propsKey: 'borderWidth'
|
|
97
|
+
});
|
|
98
|
+
var borderColorClass = useDeviceTargetClass.useDeviceTargetClass(props, {
|
|
99
|
+
prefix: 'border-color_',
|
|
100
|
+
propsKey: 'borderColor'
|
|
101
|
+
});
|
|
102
|
+
var widthClass = useDeviceTargetClass.useDeviceTargetClass(props, {
|
|
103
|
+
prefix: 'width_',
|
|
104
|
+
propsKey: 'width'
|
|
105
|
+
});
|
|
106
|
+
var _useState = React.useState(false),
|
|
107
|
+
isRevealed = _useState[0],
|
|
108
|
+
setIsRevealed = _useState[1];
|
|
109
|
+
var inputType = React.useMemo(function () {
|
|
110
|
+
return isRevealed ? 'text' : 'password';
|
|
111
|
+
}, [isRevealed]);
|
|
112
|
+
var revealeHandler = React.useCallback(function (e) {
|
|
113
|
+
e.preventDefault();
|
|
114
|
+
setIsRevealed(function (prev) {
|
|
115
|
+
return !prev;
|
|
116
|
+
});
|
|
117
|
+
}, [setIsRevealed]);
|
|
118
|
+
return /*#__PURE__*/React__default.default.createElement("div", {
|
|
119
|
+
className: "input-password"
|
|
120
|
+
}, /*#__PURE__*/React__default.default.createElement("input", {
|
|
121
|
+
className: clsx__default.default(className, 'input-password__input', (textSizeClass || textColorClass || weightClass) && 'text', caretClass, fillClass, placeholderClass, shapeClass, textSizeClass, textColorClass, weightClass, widthClass, borderWidthClass, borderColorClass, sizeClass, ((_inputPasswordConfig$ = inputPasswordConfig.state[state]) == null ? void 0 : _inputPasswordConfig$.fillClass) && ("fill_" + inputPasswordConfig.state[state].fillClass).replace(/([A-Z])/g, '-$1').toLowerCase(), ((_inputPasswordConfig$2 = inputPasswordConfig.state[state]) == null ? void 0 : _inputPasswordConfig$2.borderColor) && ("border-color_" + inputPasswordConfig.state[state].borderColor).replace(/([A-Z])/g, '-$1').toLowerCase(), ((_inputPasswordConfig$3 = inputPasswordConfig.state[state]) == null ? void 0 : _inputPasswordConfig$3.shape) && "shape_" + inputPasswordConfig.state[state].shape),
|
|
122
|
+
type: inputType,
|
|
123
|
+
id: id,
|
|
124
|
+
disabled: disabled,
|
|
125
|
+
placeholder: placeholder,
|
|
126
|
+
value: value,
|
|
127
|
+
onBlur: onBlur,
|
|
128
|
+
onChange: onChange,
|
|
129
|
+
onFocus: onFocus,
|
|
130
|
+
onKeyDown: onKeyDown
|
|
131
|
+
}), isRevealable && /*#__PURE__*/React__default.default.createElement(index.Icon, {
|
|
132
|
+
className: "input-password__icon",
|
|
133
|
+
iconFill: iconFill,
|
|
134
|
+
iconFillHover: iconFillHover,
|
|
135
|
+
SvgImage: isRevealed ? iconRevealableHide : iconRevealableShow,
|
|
136
|
+
imageSrc: isRevealed ? iconRevealableHide : iconRevealableShow,
|
|
137
|
+
shape: iconShape,
|
|
138
|
+
size: iconSize,
|
|
139
|
+
onClick: revealeHandler
|
|
140
|
+
}));
|
|
141
|
+
}
|
|
142
|
+
InputPassword.propTypes = {
|
|
143
|
+
id: PropTypes__default.default.string,
|
|
144
|
+
className: PropTypes__default.default.string,
|
|
145
|
+
placeholder: PropTypes__default.default.string,
|
|
146
|
+
value: PropTypes__default.default.string,
|
|
147
|
+
checked: PropTypes__default.default.bool,
|
|
148
|
+
disabled: PropTypes__default.default.bool,
|
|
149
|
+
onBlur: PropTypes__default.default.func,
|
|
150
|
+
onChange: PropTypes__default.default.func,
|
|
151
|
+
onKeyDown: PropTypes__default.default.func,
|
|
152
|
+
type: PropTypes__default.default.string
|
|
153
|
+
};
|
|
154
|
+
InputPassword.defaultProps = {
|
|
155
|
+
size: 'm',
|
|
156
|
+
type: 'text'
|
|
157
|
+
};
|
|
158
|
+
|
|
159
|
+
exports.InputPassword = InputPassword;
|
|
160
|
+
exports.inputPasswordConfig = inputPasswordConfig;
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
.input-password {
|
|
2
|
+
position: relative;
|
|
3
|
+
&__icon {
|
|
4
|
+
position: absolute;
|
|
5
|
+
right: 8px;
|
|
6
|
+
top: 50%;
|
|
7
|
+
transform: translate(0, -50%);
|
|
8
|
+
}
|
|
9
|
+
&__input {
|
|
10
|
+
border: none;
|
|
11
|
+
appearance: none;
|
|
12
|
+
padding: 0;
|
|
13
|
+
margin: 0;
|
|
14
|
+
min-width: unset;
|
|
15
|
+
box-shadow: none;
|
|
16
|
+
outline: 0;
|
|
17
|
+
position: relative;
|
|
18
|
+
caret-color: var(--input-password-caret-color);
|
|
19
|
+
&:focus {
|
|
20
|
+
outline: none;
|
|
21
|
+
}
|
|
22
|
+
&:hover {
|
|
23
|
+
border: solid 1px var(--input-password-state-hover-border);
|
|
24
|
+
background: var(--input-password-state-hover-background);
|
|
25
|
+
}
|
|
26
|
+
&&_state {
|
|
27
|
+
&_success {
|
|
28
|
+
border: solid 1px var(--input-password-state-success-border);
|
|
29
|
+
background: var(--input-password-state-success-background);
|
|
30
|
+
}
|
|
31
|
+
&_error {
|
|
32
|
+
border: solid 1px var(--input-password-state-error-border);
|
|
33
|
+
background: var(--input-password-state-error-background);
|
|
34
|
+
}
|
|
35
|
+
&_focus {
|
|
36
|
+
border: solid 1px var(--input-password-state-focus-border);
|
|
37
|
+
background: var(--input-password-state-focus-background);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
.input-password {
|
|
43
|
+
&__input {
|
|
44
|
+
&_shape {
|
|
45
|
+
&_rounded {
|
|
46
|
+
border-radius: 4px;
|
|
47
|
+
position: relative;
|
|
48
|
+
}
|
|
49
|
+
&_underline {
|
|
50
|
+
position: relative;
|
|
51
|
+
border-left: none !important;
|
|
52
|
+
border-right: none !important;
|
|
53
|
+
border-top: none !important;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
.input-password {
|
|
59
|
+
&__input {
|
|
60
|
+
&&_size {
|
|
61
|
+
@each $size in xs, s, m, l, xl, xxl, normal, tiny, compact, large {
|
|
62
|
+
&_$(size) {
|
|
63
|
+
padding: var(--input-password-size-$(size)-padding);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|