@react-spectrum/s2
Version:
Spectrum 2 UI components in React
397 lines (382 loc) • 19.1 kB
JavaScript
import "./NumberField.css";
import $053de6aaf5f9b7bd$export$2e2bcd8739ae039 from "./Add.mjs";
import $f17037051ff08dc2$export$2e2bcd8739ae039 from "./Dash.mjs";
import {FieldErrorIcon as $9afd80978c252040$export$bda0d075e0e342c9, FieldGroup as $9afd80978c252040$export$f0fe469072bc6950, FieldLabel as $9afd80978c252040$export$1acdcf5a973a8414, HelpText as $9afd80978c252040$export$a67c0bc59081311a, Input as $9afd80978c252040$export$f5b8910cec6cf069} from "./Field.mjs";
import {FormContext as $9b916426527cebe7$export$c24727297075ec6a} from "./Form.mjs";
import {pressScale as $10ea7662e51a285b$export$56e8cba416805d8d} from "./pressScale.mjs";
import {useSpectrumContextProps as $5ce63c423902f47d$export$764f6146fadd77f7} from "../icons/useSpectrumContextProps.mjs";
import {jsx as $5qJVF$jsx, jsxs as $5qJVF$jsxs, Fragment as $5qJVF$Fragment} from "react/jsx-runtime";
import {NumberField as $5qJVF$NumberField, InputContext as $5qJVF$InputContext, useContextProps as $5qJVF$useContextProps, ButtonContext as $5qJVF$ButtonContext} from "react-aria-components";
import {createContext as $5qJVF$createContext, forwardRef as $5qJVF$forwardRef, useContext as $5qJVF$useContext, useRef as $5qJVF$useRef, useImperativeHandle as $5qJVF$useImperativeHandle, useMemo as $5qJVF$useMemo} from "react";
import {createFocusableRef as $5qJVF$createFocusableRef} from "@react-spectrum/utils";
import {mergeRefs as $5qJVF$mergeRefs, filterDOMProps as $5qJVF$filterDOMProps, mergeProps as $5qJVF$mergeProps} from "@react-aria/utils";
import {useButton as $5qJVF$useButton, useFocusRing as $5qJVF$useFocusRing, useHover as $5qJVF$useHover} from "react-aria";
/*
* Copyright 2024 Adobe. All rights reserved.
* This file is licensed to you under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. You may obtain a copy
* of the License at http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
* OF ANY KIND, either express or implied. See the License for the specific language
* governing permissions and limitations under the License.
*/
const $675eca1a78ccd399$export$b414a48cf5dcbc11 = /*#__PURE__*/ (0, $5qJVF$createContext)(null);
const $675eca1a78ccd399$var$inputButton = function anonymous(props) {
let rules = " ";
if (props.size === "XL") rules += ' -SFnbic-_JaP8ec91';
else if (props.size === "L") rules += ' -SFnbic-_J0K2hn91';
else if (props.size === "S") rules += ' -SFnbic-_JJOW22b91';
else if (props.size === "XS") rules += ' -SFnbic-_JICefdd91';
else rules += ' -SFnbic-_Jb91';
rules += ' -Bu7z1c-oa91';
rules += ' oj91';
rules += ' nj91';
rules += ' kj91';
rules += ' jj91';
rules += ' sd91';
rules += ' _Le91';
rules += ' _Wa91';
rules += ' _je91';
rules += ' eb91';
rules += ' _Ca91';
if (props.size === "XL") rules += ' ZC91';
else if (props.size === "L") rules += ' Zo91';
else if (props.size === "M") rules += ' Zm91';
else if (props.size === "S") rules += ' Zu91';
rules += ' Fd91';
if (props.type === "increment") rules += ' Iy91';
else rules += ' Iw91';
rules += ' fa91';
rules += ' _va91';
rules += ' Ma91';
rules += ' Yd91';
rules += ' Yle91';
rules += ' Xb91';
rules += ' Xlb91';
rules += ' _2b91';
rules += ' _2lb91';
if (props.isDisabled) rules += ' gH91';
else {
if (props.isPressed) rules += ' gF91';
else if (props.isFocusVisible) rules += ' gF91';
else if (props.isHovered) rules += ' gF91';
else rules += ' gH91';
}
if (props.isDisabled) rules += ' gld91';
else if (props.isHovered) rules += ' gle91';
else rules += ' glc91';
if (props.isDisabled) rules += ' pp91';
else {
if (props.isPressed) rules += ' po91';
else if (props.isFocusVisible) rules += ' po91';
else if (props.isHovered) rules += ' po91';
else rules += ' pt91';
}
rules += ' pla91';
rules += ' ri91';
return rules;
};
const $675eca1a78ccd399$var$iconStyles = " _va91 -_8sjo0b-t5ZbAob91";
const $675eca1a78ccd399$var$stepperContainerStyles = function anonymous(props) {
let rules = " ";
rules += ' sd91';
rules += ' _tc91';
if (props.size === "XL") rules += ' Ue91';
else if (props.size === "L") rules += ' Ue91';
else if (props.size === "M") rules += ' Ub91';
else if (props.size === "S") rules += ' Ue91';
if (props.size === "XL") rules += ' qe91';
else if (props.size === "L") rules += ' qe91';
else if (props.size === "M") rules += ' qb91';
else if (props.size === "S") rules += ' qe91';
if (props.size === "XL") rules += ' HWJpoB91';
else if (props.size === "L") rules += ' HWJpoB91';
else if (props.size === "M") rules += ' Hs91';
else if (props.size === "S") rules += ' Hr91';
return rules;
};
const $675eca1a78ccd399$export$63c5fa0b2fdccd2e = /*#__PURE__*/ (0, $5qJVF$forwardRef)(function NumberField(props1, ref) {
[props1, ref] = (0, $5ce63c423902f47d$export$764f6146fadd77f7)(props1, ref, $675eca1a78ccd399$export$b414a48cf5dcbc11);
let { label: label, contextualHelp: contextualHelp, description: descriptionMessage, errorMessage: errorMessage, hideStepper: hideStepper, isRequired: isRequired, size: size = 'M', labelPosition: labelPosition = 'top', necessityIndicator: necessityIndicator, labelAlign: labelAlign = 'start', UNSAFE_className: UNSAFE_className = '', UNSAFE_style: UNSAFE_style, ...numberFieldProps } = props1;
let formContext = (0, $5qJVF$useContext)((0, $9b916426527cebe7$export$c24727297075ec6a));
let domRef = (0, $5qJVF$useRef)(null);
let inputRef = (0, $5qJVF$useRef)(null);
let decrementButtonRef = (0, $5qJVF$useRef)(null);
let incrementButtonRef = (0, $5qJVF$useRef)(null);
// Expose imperative interface for ref
(0, $5qJVF$useImperativeHandle)(ref, ()=>({
...(0, $5qJVF$createFocusableRef)(domRef, inputRef),
select () {
if (inputRef.current) inputRef.current.select();
},
getInputElement () {
return inputRef.current;
}
}));
return /*#__PURE__*/ (0, $5qJVF$jsx)((0, $5qJVF$NumberField), {
isRequired: isRequired,
...numberFieldProps,
style: UNSAFE_style,
className: UNSAFE_className + function anonymous(props, overrides) {
let rules = " ";
let gridColumnStart = false;
let gridColumnEnd = false;
let matches = (overrides || '').matchAll(/(?:^|\s)(J|G|I|H|_u|_v|_s|__A|_d|_J|z|y|B|A|_P|_9|W|_l|_A|_z|Z|N|L)[^\s]+/g);
for (let p of matches){
if (p[1] === "z") gridColumnStart = true;
if (p[1] === "y") gridColumnEnd = true;
rules += p[0];
}
rules += ' se91';
if (props.isInForm) {
if (!gridColumnStart) rules += ' z2mU91';
}
if (props.isInForm) {
if (props.labelPosition === "side") {
if (!gridColumnEnd) rules += ' yvoofG91';
}
}
if (props.isInForm) rules += ' DLwlgod91';
else {
if (props.labelPosition === "side") rules += ' DPlN5qb91';
else if (props.labelPosition === "top") rules += ' DM8Mfn91';
}
if (props.labelPosition === "side") rules += ' EPlN5qb91';
else if (props.labelPosition === "top") rules += ' E4w1sLc91';
if (props.labelPosition === "side") rules += ' CbRM95c91';
else if (props.labelPosition === "top") rules += ' Cxaocre91';
if (props.size === "XL") {
rules += ' vg91';
rules += ' vsj91';
} else if (props.size === "L") {
rules += ' vp91';
rules += ' vsh91';
} else if (props.size === "S") {
rules += ' vb91';
rules += ' vse91';
} else if (props.size === "XS") {
rules += ' va91';
rules += ' vsc91';
} else {
rules += ' vd91';
rules += ' vsf91';
}
rules += ' ea91';
rules += ' _Fa91';
rules += ' _Ffb91';
if (props.size === "XL") rules += ' -BhX7R-Fz91';
else if (props.size === "L") rules += ' -BhX7R-Fv91';
else if (props.size === "S") rules += ' -BhX7R-Fp91';
else if (props.size === "XS") rules += ' -BhX7R-Fn91';
else rules += ' -BhX7R-Fx91';
rules += ' -AJjOLd-UVkF0Db91';
rules += ' qg91';
rules += ' __ca91';
return rules;
}({
isInForm: !!formContext,
labelPosition: labelPosition,
size: size
}, props1.styles),
children: ({ isDisabled: isDisabled, isInvalid: isInvalid })=>{
return /*#__PURE__*/ (0, $5qJVF$jsxs)((0, $5qJVF$Fragment), {
children: [
/*#__PURE__*/ (0, $5qJVF$jsx)((0, $9afd80978c252040$export$1acdcf5a973a8414), {
isDisabled: isDisabled,
isRequired: isRequired,
size: size,
labelPosition: labelPosition,
labelAlign: labelAlign,
necessityIndicator: necessityIndicator,
contextualHelp: contextualHelp,
children: label
}),
/*#__PURE__*/ (0, $5qJVF$jsxs)((0, $9afd80978c252040$export$f0fe469072bc6950), {
role: "presentation",
isDisabled: isDisabled,
isInvalid: isInvalid,
size: size,
styles: function anonymous(props) {
let rules = " ";
rules += ' zXcEWr91';
rules += ' yXcEWr91';
rules += ' BXcEWr91';
rules += ' AXcEWr91';
if (props.size === "XL") rules += ' Nl91';
else if (props.size === "L") rules += ' Nj91';
else if (props.size === "S") rules += ' Nf91';
else if (props.size === "XS") rules += ' Ne91';
else rules += ' Nk91';
if (props.isQuiet) rules += ' _qd91';
else rules += ' _qtb91';
if (props.size === "XL") rules += ' -Anxdcc-Zt91';
else if (props.size === "L") rules += ' -Anxdcc-ZStdtne91';
else if (props.size === "S") rules += ' -Anxdcc-Zr91';
else rules += ' -Anxdcc-Z3fn9H91';
rules += ' __v6TNLWb91';
rules += ' SMBFGYc91';
rules += ' RfBFGYc91';
rules += ' -S_-Sv91';
if (props.isStepperHidden) rules += ' -R_-Rv91';
else rules += ' -R_-Rd91';
return rules;
}({
size: size,
isStepperHidden: hideStepper
}),
children: [
/*#__PURE__*/ (0, $5qJVF$jsx)((0, $5qJVF$InputContext).Consumer, {
children: (ctx)=>/*#__PURE__*/ (0, $5qJVF$jsx)((0, $5qJVF$InputContext).Provider, {
value: {
...ctx,
ref: (0, $5qJVF$mergeRefs)(ctx?.ref, inputRef)
},
children: /*#__PURE__*/ (0, $5qJVF$jsx)((0, $9afd80978c252040$export$f5b8910cec6cf069), {})
})
}),
isInvalid && /*#__PURE__*/ (0, $5qJVF$jsx)((0, $9afd80978c252040$export$bda0d075e0e342c9), {
isDisabled: isDisabled
}),
!hideStepper && /*#__PURE__*/ (0, $5qJVF$jsxs)("div", {
className: $675eca1a78ccd399$var$stepperContainerStyles({
size: size
}),
children: [
/*#__PURE__*/ (0, $5qJVF$jsx)($675eca1a78ccd399$var$StepButton, {
ref: decrementButtonRef,
slot: "decrement",
style: (renderProps)=>(0, $10ea7662e51a285b$export$56e8cba416805d8d)(decrementButtonRef)(renderProps),
className: (renderProps)=>$675eca1a78ccd399$var$inputButton({
...renderProps,
type: 'decrement',
size: size
}),
children: /*#__PURE__*/ (0, $5qJVF$jsx)((0, $f17037051ff08dc2$export$2e2bcd8739ae039), {
size: size,
className: $675eca1a78ccd399$var$iconStyles
})
}),
/*#__PURE__*/ (0, $5qJVF$jsx)($675eca1a78ccd399$var$StepButton, {
ref: incrementButtonRef,
slot: "increment",
style: (renderProps)=>(0, $10ea7662e51a285b$export$56e8cba416805d8d)(incrementButtonRef)(renderProps),
className: (renderProps)=>$675eca1a78ccd399$var$inputButton({
...renderProps,
type: 'increment',
size: size
}),
children: /*#__PURE__*/ (0, $5qJVF$jsx)((0, $053de6aaf5f9b7bd$export$2e2bcd8739ae039), {
size: size,
className: $675eca1a78ccd399$var$iconStyles
})
})
]
})
]
}),
/*#__PURE__*/ (0, $5qJVF$jsx)((0, $9afd80978c252040$export$a67c0bc59081311a), {
size: size,
isDisabled: isDisabled,
isInvalid: isInvalid,
description: descriptionMessage,
children: errorMessage
})
]
});
}
});
});
const $675eca1a78ccd399$var$additionalButtonHTMLAttributes = new Set([
'form',
'formAction',
'formEncType',
'formMethod',
'formNoValidate',
'formTarget',
'name',
'value'
]);
let $675eca1a78ccd399$var$StepButton = /*#__PURE__*/ (0, $5qJVF$forwardRef)((props, ref)=>{
[props, ref] = (0, $5qJVF$useContextProps)(props, ref, (0, $5qJVF$ButtonContext));
let ctx = props;
/**
* Must use div for now because Safari pointer event bugs on disabled form elements.
* Link https://bugs.webkit.org/show_bug.cgi?id=219188.
*/ let { buttonProps: buttonProps, isPressed: isPressed } = (0, $5qJVF$useButton)({
...props,
elementType: 'div'
}, ref);
let { focusProps: focusProps, isFocused: isFocused, isFocusVisible: isFocusVisible } = (0, $5qJVF$useFocusRing)(props);
let { hoverProps: hoverProps, isHovered: isHovered } = (0, $5qJVF$useHover)(props);
let renderProps = $675eca1a78ccd399$var$useRenderProps({
...props,
values: {
isHovered: isHovered,
isPressed: isPressed,
isFocused: isFocused,
isFocusVisible: isFocusVisible,
isDisabled: props.isDisabled || false
},
defaultClassName: 'react-aria-Button'
});
return /*#__PURE__*/ (0, $5qJVF$jsx)("div", {
...(0, $5qJVF$filterDOMProps)(props, {
propNames: $675eca1a78ccd399$var$additionalButtonHTMLAttributes
}),
...(0, $5qJVF$mergeProps)(buttonProps, focusProps, hoverProps),
...renderProps,
ref: ref,
slot: props.slot || undefined,
"data-disabled": props.isDisabled || undefined,
"data-pressed": ctx.isPressed || isPressed || undefined,
"data-hovered": isHovered || undefined,
"data-focused": isFocused || undefined,
"data-focus-visible": isFocusVisible || undefined
});
});
// replace from RAC
function $675eca1a78ccd399$var$useRenderProps(props) {
let { className: className, style: style, children: children, defaultClassName: defaultClassName, defaultChildren: defaultChildren, defaultStyle: defaultStyle, values: values } = props;
return (0, $5qJVF$useMemo)(()=>{
let computedClassName;
let computedStyle;
let computedChildren;
if (typeof className === 'function') computedClassName = className({
...values,
defaultClassName: defaultClassName
});
else computedClassName = className;
if (typeof style === 'function') computedStyle = style({
...values,
defaultStyle: defaultStyle || {}
});
else computedStyle = style;
if (typeof children === 'function') computedChildren = children({
...values,
defaultChildren: defaultChildren
});
else if (children == null) computedChildren = defaultChildren;
else computedChildren = children;
return {
className: computedClassName ?? defaultClassName,
style: computedStyle || defaultStyle ? {
...defaultStyle,
...computedStyle
} : undefined,
children: computedChildren ?? defaultChildren,
'data-rac': ''
};
}, [
className,
style,
children,
defaultClassName,
defaultChildren,
defaultStyle,
values
]);
}
export {$675eca1a78ccd399$export$b414a48cf5dcbc11 as NumberFieldContext, $675eca1a78ccd399$export$63c5fa0b2fdccd2e as NumberField};
//# sourceMappingURL=NumberField.mjs.map