@react-spectrum/textfield 3.14.4 → 3.15.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/import.mjs +4 -4
- package/dist/main.js +6 -6
- package/dist/main.js.map +1 -1
- package/dist/module.js +4 -4
- package/dist/module.js.map +1 -1
- package/dist/types/src/index.d.ts +5 -0
- package/package.json +12 -37
- package/src/index.ts +6 -4
- package/dist/TextArea.main.js +0 -103
- package/dist/TextArea.main.js.map +0 -1
- package/dist/TextArea.mjs +0 -94
- package/dist/TextArea.module.js +0 -94
- package/dist/TextArea.module.js.map +0 -1
- package/dist/TextField.main.js +0 -55
- package/dist/TextField.main.js.map +0 -1
- package/dist/TextField.mjs +0 -46
- package/dist/TextField.module.js +0 -46
- package/dist/TextField.module.js.map +0 -1
- package/dist/TextFieldBase.main.js +0 -124
- package/dist/TextFieldBase.main.js.map +0 -1
- package/dist/TextFieldBase.mjs +0 -119
- package/dist/TextFieldBase.module.js +0 -119
- package/dist/TextFieldBase.module.js.map +0 -1
- package/dist/ar-AE.main.js +0 -6
- package/dist/ar-AE.main.js.map +0 -1
- package/dist/ar-AE.mjs +0 -8
- package/dist/ar-AE.module.js +0 -8
- package/dist/ar-AE.module.js.map +0 -1
- package/dist/bg-BG.main.js +0 -6
- package/dist/bg-BG.main.js.map +0 -1
- package/dist/bg-BG.mjs +0 -8
- package/dist/bg-BG.module.js +0 -8
- package/dist/bg-BG.module.js.map +0 -1
- package/dist/cs-CZ.main.js +0 -6
- package/dist/cs-CZ.main.js.map +0 -1
- package/dist/cs-CZ.mjs +0 -8
- package/dist/cs-CZ.module.js +0 -8
- package/dist/cs-CZ.module.js.map +0 -1
- package/dist/da-DK.main.js +0 -6
- package/dist/da-DK.main.js.map +0 -1
- package/dist/da-DK.mjs +0 -8
- package/dist/da-DK.module.js +0 -8
- package/dist/da-DK.module.js.map +0 -1
- package/dist/de-DE.main.js +0 -6
- package/dist/de-DE.main.js.map +0 -1
- package/dist/de-DE.mjs +0 -8
- package/dist/de-DE.module.js +0 -8
- package/dist/de-DE.module.js.map +0 -1
- package/dist/el-GR.main.js +0 -6
- package/dist/el-GR.main.js.map +0 -1
- package/dist/el-GR.mjs +0 -8
- package/dist/el-GR.module.js +0 -8
- package/dist/el-GR.module.js.map +0 -1
- package/dist/en-US.main.js +0 -6
- package/dist/en-US.main.js.map +0 -1
- package/dist/en-US.mjs +0 -8
- package/dist/en-US.module.js +0 -8
- package/dist/en-US.module.js.map +0 -1
- package/dist/es-ES.main.js +0 -6
- package/dist/es-ES.main.js.map +0 -1
- package/dist/es-ES.mjs +0 -8
- package/dist/es-ES.module.js +0 -8
- package/dist/es-ES.module.js.map +0 -1
- package/dist/et-EE.main.js +0 -6
- package/dist/et-EE.main.js.map +0 -1
- package/dist/et-EE.mjs +0 -8
- package/dist/et-EE.module.js +0 -8
- package/dist/et-EE.module.js.map +0 -1
- package/dist/fi-FI.main.js +0 -6
- package/dist/fi-FI.main.js.map +0 -1
- package/dist/fi-FI.mjs +0 -8
- package/dist/fi-FI.module.js +0 -8
- package/dist/fi-FI.module.js.map +0 -1
- package/dist/fr-FR.main.js +0 -6
- package/dist/fr-FR.main.js.map +0 -1
- package/dist/fr-FR.mjs +0 -8
- package/dist/fr-FR.module.js +0 -8
- package/dist/fr-FR.module.js.map +0 -1
- package/dist/he-IL.main.js +0 -6
- package/dist/he-IL.main.js.map +0 -1
- package/dist/he-IL.mjs +0 -8
- package/dist/he-IL.module.js +0 -8
- package/dist/he-IL.module.js.map +0 -1
- package/dist/hr-HR.main.js +0 -6
- package/dist/hr-HR.main.js.map +0 -1
- package/dist/hr-HR.mjs +0 -8
- package/dist/hr-HR.module.js +0 -8
- package/dist/hr-HR.module.js.map +0 -1
- package/dist/hu-HU.main.js +0 -6
- package/dist/hu-HU.main.js.map +0 -1
- package/dist/hu-HU.mjs +0 -8
- package/dist/hu-HU.module.js +0 -8
- package/dist/hu-HU.module.js.map +0 -1
- package/dist/intlStrings.main.js +0 -108
- package/dist/intlStrings.main.js.map +0 -1
- package/dist/intlStrings.mjs +0 -110
- package/dist/intlStrings.module.js +0 -110
- package/dist/intlStrings.module.js.map +0 -1
- package/dist/it-IT.main.js +0 -6
- package/dist/it-IT.main.js.map +0 -1
- package/dist/it-IT.mjs +0 -8
- package/dist/it-IT.module.js +0 -8
- package/dist/it-IT.module.js.map +0 -1
- package/dist/ja-JP.main.js +0 -6
- package/dist/ja-JP.main.js.map +0 -1
- package/dist/ja-JP.mjs +0 -8
- package/dist/ja-JP.module.js +0 -8
- package/dist/ja-JP.module.js.map +0 -1
- package/dist/ko-KR.main.js +0 -6
- package/dist/ko-KR.main.js.map +0 -1
- package/dist/ko-KR.mjs +0 -8
- package/dist/ko-KR.module.js +0 -8
- package/dist/ko-KR.module.js.map +0 -1
- package/dist/lt-LT.main.js +0 -6
- package/dist/lt-LT.main.js.map +0 -1
- package/dist/lt-LT.mjs +0 -8
- package/dist/lt-LT.module.js +0 -8
- package/dist/lt-LT.module.js.map +0 -1
- package/dist/lv-LV.main.js +0 -6
- package/dist/lv-LV.main.js.map +0 -1
- package/dist/lv-LV.mjs +0 -8
- package/dist/lv-LV.module.js +0 -8
- package/dist/lv-LV.module.js.map +0 -1
- package/dist/nb-NO.main.js +0 -6
- package/dist/nb-NO.main.js.map +0 -1
- package/dist/nb-NO.mjs +0 -8
- package/dist/nb-NO.module.js +0 -8
- package/dist/nb-NO.module.js.map +0 -1
- package/dist/nl-NL.main.js +0 -6
- package/dist/nl-NL.main.js.map +0 -1
- package/dist/nl-NL.mjs +0 -8
- package/dist/nl-NL.module.js +0 -8
- package/dist/nl-NL.module.js.map +0 -1
- package/dist/pl-PL.main.js +0 -6
- package/dist/pl-PL.main.js.map +0 -1
- package/dist/pl-PL.mjs +0 -8
- package/dist/pl-PL.module.js +0 -8
- package/dist/pl-PL.module.js.map +0 -1
- package/dist/pt-BR.main.js +0 -6
- package/dist/pt-BR.main.js.map +0 -1
- package/dist/pt-BR.mjs +0 -8
- package/dist/pt-BR.module.js +0 -8
- package/dist/pt-BR.module.js.map +0 -1
- package/dist/pt-PT.main.js +0 -6
- package/dist/pt-PT.main.js.map +0 -1
- package/dist/pt-PT.mjs +0 -8
- package/dist/pt-PT.module.js +0 -8
- package/dist/pt-PT.module.js.map +0 -1
- package/dist/ro-RO.main.js +0 -6
- package/dist/ro-RO.main.js.map +0 -1
- package/dist/ro-RO.mjs +0 -8
- package/dist/ro-RO.module.js +0 -8
- package/dist/ro-RO.module.js.map +0 -1
- package/dist/ru-RU.main.js +0 -6
- package/dist/ru-RU.main.js.map +0 -1
- package/dist/ru-RU.mjs +0 -8
- package/dist/ru-RU.module.js +0 -8
- package/dist/ru-RU.module.js.map +0 -1
- package/dist/sk-SK.main.js +0 -6
- package/dist/sk-SK.main.js.map +0 -1
- package/dist/sk-SK.mjs +0 -8
- package/dist/sk-SK.module.js +0 -8
- package/dist/sk-SK.module.js.map +0 -1
- package/dist/sl-SI.main.js +0 -6
- package/dist/sl-SI.main.js.map +0 -1
- package/dist/sl-SI.mjs +0 -8
- package/dist/sl-SI.module.js +0 -8
- package/dist/sl-SI.module.js.map +0 -1
- package/dist/sr-SP.main.js +0 -6
- package/dist/sr-SP.main.js.map +0 -1
- package/dist/sr-SP.mjs +0 -8
- package/dist/sr-SP.module.js +0 -8
- package/dist/sr-SP.module.js.map +0 -1
- package/dist/sv-SE.main.js +0 -6
- package/dist/sv-SE.main.js.map +0 -1
- package/dist/sv-SE.mjs +0 -8
- package/dist/sv-SE.module.js +0 -8
- package/dist/sv-SE.module.js.map +0 -1
- package/dist/textfield.54643fd6.css +0 -550
- package/dist/textfield.54643fd6.css.map +0 -1
- package/dist/textfield_vars_css.main.js +0 -74
- package/dist/textfield_vars_css.main.js.map +0 -1
- package/dist/textfield_vars_css.mjs +0 -76
- package/dist/textfield_vars_css.module.js +0 -76
- package/dist/textfield_vars_css.module.js.map +0 -1
- package/dist/tr-TR.main.js +0 -6
- package/dist/tr-TR.main.js.map +0 -1
- package/dist/tr-TR.mjs +0 -8
- package/dist/tr-TR.module.js +0 -8
- package/dist/tr-TR.module.js.map +0 -1
- package/dist/types.d.ts +0 -33
- package/dist/types.d.ts.map +0 -1
- package/dist/uk-UA.main.js +0 -6
- package/dist/uk-UA.main.js.map +0 -1
- package/dist/uk-UA.mjs +0 -8
- package/dist/uk-UA.module.js +0 -8
- package/dist/uk-UA.module.js.map +0 -1
- package/dist/zh-CN.main.js +0 -6
- package/dist/zh-CN.main.js.map +0 -1
- package/dist/zh-CN.mjs +0 -8
- package/dist/zh-CN.module.js +0 -8
- package/dist/zh-CN.module.js.map +0 -1
- package/dist/zh-TW.main.js +0 -6
- package/dist/zh-TW.main.js.map +0 -1
- package/dist/zh-TW.mjs +0 -8
- package/dist/zh-TW.module.js +0 -8
- package/dist/zh-TW.module.js.map +0 -1
- package/src/TextArea.tsx +0 -98
- package/src/TextField.tsx +0 -47
- package/src/TextFieldBase.tsx +0 -182
package/src/TextFieldBase.tsx
DELETED
|
@@ -1,182 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright 2020 Adobe. All rights reserved.
|
|
3
|
-
* This file is licensed to you under the Apache License, Version 2.0 (the "License");
|
|
4
|
-
* you may not use this file except in compliance with the License. You may obtain a copy
|
|
5
|
-
* of the License at http://www.apache.org/licenses/LICENSE-2.0
|
|
6
|
-
*
|
|
7
|
-
* Unless required by applicable law or agreed to in writing, software distributed under
|
|
8
|
-
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
|
|
9
|
-
* OF ANY KIND, either express or implied. See the License for the specific language
|
|
10
|
-
* governing permissions and limitations under the License.
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
import AlertMedium from '@spectrum-icons/ui/AlertMedium';
|
|
14
|
-
import CheckmarkMedium from '@spectrum-icons/ui/CheckmarkMedium';
|
|
15
|
-
import {classNames, createFocusableRef} from '@react-spectrum/utils';
|
|
16
|
-
import {Field} from '@react-spectrum/label';
|
|
17
|
-
// @ts-ignore
|
|
18
|
-
import intlMessages from '../intl/*.json';
|
|
19
|
-
import {mergeProps, useId} from '@react-aria/utils';
|
|
20
|
-
import {PressEvents, RefObject, ValidationResult} from '@react-types/shared';
|
|
21
|
-
import React, {cloneElement, forwardRef, HTMLAttributes, InputHTMLAttributes, LabelHTMLAttributes, ReactElement, Ref, TextareaHTMLAttributes, useImperativeHandle, useRef} from 'react';
|
|
22
|
-
import {SpectrumTextFieldProps, TextFieldRef} from '@react-types/textfield';
|
|
23
|
-
import styles from '@adobe/spectrum-css-temp/components/textfield/vars.css';
|
|
24
|
-
import {useFocusRing} from '@react-aria/focus';
|
|
25
|
-
import {useHover} from '@react-aria/interactions';
|
|
26
|
-
import {useLocalizedStringFormatter} from '@react-aria/i18n';
|
|
27
|
-
|
|
28
|
-
interface TextFieldBaseProps extends Omit<SpectrumTextFieldProps, 'onChange' | 'validate'>, PressEvents, Partial<ValidationResult> {
|
|
29
|
-
wrapperChildren?: ReactElement | ReactElement[],
|
|
30
|
-
inputClassName?: string,
|
|
31
|
-
validationIconClassName?: string,
|
|
32
|
-
multiLine?: boolean,
|
|
33
|
-
labelProps?: LabelHTMLAttributes<HTMLLabelElement>,
|
|
34
|
-
inputProps: InputHTMLAttributes<HTMLInputElement> | TextareaHTMLAttributes<HTMLTextAreaElement>,
|
|
35
|
-
descriptionProps?: HTMLAttributes<HTMLElement>,
|
|
36
|
-
errorMessageProps?: HTMLAttributes<HTMLElement>,
|
|
37
|
-
inputRef?: RefObject<HTMLInputElement | HTMLTextAreaElement | null>,
|
|
38
|
-
loadingIndicator?: ReactElement,
|
|
39
|
-
isLoading?: boolean,
|
|
40
|
-
disableFocusRing?: boolean
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
export const TextFieldBase = forwardRef(function TextFieldBase(props: TextFieldBaseProps, ref: Ref<TextFieldRef<HTMLInputElement | HTMLTextAreaElement>>) {
|
|
44
|
-
let {
|
|
45
|
-
validationState = props.isInvalid ? 'invalid' : null,
|
|
46
|
-
icon,
|
|
47
|
-
isQuiet = false,
|
|
48
|
-
isDisabled,
|
|
49
|
-
multiLine,
|
|
50
|
-
autoFocus,
|
|
51
|
-
inputClassName,
|
|
52
|
-
wrapperChildren,
|
|
53
|
-
labelProps,
|
|
54
|
-
inputProps,
|
|
55
|
-
descriptionProps,
|
|
56
|
-
errorMessageProps,
|
|
57
|
-
inputRef: userInputRef,
|
|
58
|
-
isLoading,
|
|
59
|
-
loadingIndicator,
|
|
60
|
-
validationIconClassName,
|
|
61
|
-
disableFocusRing
|
|
62
|
-
} = props;
|
|
63
|
-
let {hoverProps, isHovered} = useHover({isDisabled});
|
|
64
|
-
let domRef = useRef<HTMLDivElement>(null);
|
|
65
|
-
let defaultInputRef = useRef<HTMLInputElement | HTMLTextAreaElement>(null);
|
|
66
|
-
let inputRef = userInputRef || defaultInputRef;
|
|
67
|
-
|
|
68
|
-
// Expose imperative interface for ref
|
|
69
|
-
useImperativeHandle(ref, () => ({
|
|
70
|
-
...createFocusableRef(domRef, inputRef),
|
|
71
|
-
select() {
|
|
72
|
-
if (inputRef.current) {
|
|
73
|
-
inputRef.current.select();
|
|
74
|
-
}
|
|
75
|
-
},
|
|
76
|
-
getInputElement() {
|
|
77
|
-
return inputRef.current;
|
|
78
|
-
}
|
|
79
|
-
}));
|
|
80
|
-
|
|
81
|
-
let ElementType: React.ElementType = multiLine ? 'textarea' : 'input';
|
|
82
|
-
let isInvalid = validationState === 'invalid' && !isDisabled;
|
|
83
|
-
|
|
84
|
-
if (icon) {
|
|
85
|
-
let UNSAFE_className = classNames(
|
|
86
|
-
styles,
|
|
87
|
-
icon.props && (icon.props as any).UNSAFE_className,
|
|
88
|
-
'spectrum-Textfield-icon'
|
|
89
|
-
);
|
|
90
|
-
|
|
91
|
-
icon = cloneElement(icon, {
|
|
92
|
-
UNSAFE_className,
|
|
93
|
-
size: 'S'
|
|
94
|
-
} as any);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
let stringFormatter = useLocalizedStringFormatter(intlMessages, '@react-spectrum/textfield');
|
|
98
|
-
let validId = useId();
|
|
99
|
-
let validationIcon = isInvalid
|
|
100
|
-
? <AlertMedium />
|
|
101
|
-
: <CheckmarkMedium id={validId} aria-hidden aria-label={stringFormatter.format('valid')} />;
|
|
102
|
-
let validation = cloneElement(validationIcon, {
|
|
103
|
-
UNSAFE_className: classNames(
|
|
104
|
-
styles,
|
|
105
|
-
'spectrum-Textfield-validationIcon',
|
|
106
|
-
validationIconClassName
|
|
107
|
-
)
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
// Add validation icon IDREF to aria-describedby when validationState is valid
|
|
111
|
-
let inputPropsAriaDescribedBy = inputProps['aria-describedby'];
|
|
112
|
-
if (
|
|
113
|
-
!isInvalid && validationState === 'valid' && !isLoading && !isDisabled &&
|
|
114
|
-
(!inputPropsAriaDescribedBy || !inputPropsAriaDescribedBy.includes(validId))
|
|
115
|
-
) {
|
|
116
|
-
inputProps['aria-describedby'] = [inputPropsAriaDescribedBy, validId].join(' ').trim();
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
let {focusProps, isFocusVisible} = useFocusRing({
|
|
120
|
-
isTextInput: true,
|
|
121
|
-
autoFocus
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
let textField = (
|
|
125
|
-
<div
|
|
126
|
-
className={
|
|
127
|
-
classNames(
|
|
128
|
-
styles,
|
|
129
|
-
'spectrum-Textfield',
|
|
130
|
-
{
|
|
131
|
-
'spectrum-Textfield--invalid': isInvalid,
|
|
132
|
-
'spectrum-Textfield--valid': validationState === 'valid' && !isDisabled,
|
|
133
|
-
'spectrum-Textfield--loadable': loadingIndicator,
|
|
134
|
-
'spectrum-Textfield--quiet': isQuiet,
|
|
135
|
-
'spectrum-Textfield--multiline': multiLine,
|
|
136
|
-
'focus-ring': !disableFocusRing && isFocusVisible
|
|
137
|
-
}
|
|
138
|
-
)
|
|
139
|
-
}>
|
|
140
|
-
<ElementType
|
|
141
|
-
{...mergeProps(inputProps, hoverProps, focusProps)}
|
|
142
|
-
ref={inputRef as any}
|
|
143
|
-
rows={multiLine ? 1 : undefined}
|
|
144
|
-
className={
|
|
145
|
-
classNames(
|
|
146
|
-
styles,
|
|
147
|
-
'spectrum-Textfield-input',
|
|
148
|
-
{
|
|
149
|
-
'spectrum-Textfield-inputIcon': icon,
|
|
150
|
-
'is-hovered': isHovered
|
|
151
|
-
},
|
|
152
|
-
inputClassName
|
|
153
|
-
)
|
|
154
|
-
} />
|
|
155
|
-
{icon}
|
|
156
|
-
{validationState && !isLoading && !isDisabled ? validation : null}
|
|
157
|
-
{isLoading && loadingIndicator}
|
|
158
|
-
{wrapperChildren}
|
|
159
|
-
</div>
|
|
160
|
-
);
|
|
161
|
-
|
|
162
|
-
return (
|
|
163
|
-
<Field
|
|
164
|
-
{...props}
|
|
165
|
-
labelProps={labelProps}
|
|
166
|
-
descriptionProps={descriptionProps}
|
|
167
|
-
errorMessageProps={errorMessageProps}
|
|
168
|
-
wrapperClassName={
|
|
169
|
-
classNames(
|
|
170
|
-
styles,
|
|
171
|
-
'spectrum-Textfield-wrapper',
|
|
172
|
-
{
|
|
173
|
-
'spectrum-Textfield-wrapper--quiet': isQuiet
|
|
174
|
-
}
|
|
175
|
-
)
|
|
176
|
-
}
|
|
177
|
-
showErrorIcon={false}
|
|
178
|
-
ref={domRef}>
|
|
179
|
-
{textField}
|
|
180
|
-
</Field>
|
|
181
|
-
);
|
|
182
|
-
});
|