@react-spectrum/s2
Version:
Spectrum 2 UI components in React
402 lines (385 loc) • 18.7 kB
JavaScript
require("./NumberField.css");
var $54686c7c3f031ee2$exports = require("./Add.cjs");
var $84c37b7bd5c1374e$exports = require("./Dash.cjs");
var $a0b996a550bb0891$exports = require("./Field.cjs");
var $bfa4962d90c8af48$exports = require("./Form.cjs");
var $2061c83559b50a66$exports = require("./pressScale.cjs");
var $ac757a4c2bd72aee$exports = require("../icons/useSpectrumContextProps.cjs");
var $fwzUK$reactjsxruntime = require("react/jsx-runtime");
var $fwzUK$reactariacomponents = require("react-aria-components");
var $fwzUK$react = require("react");
var $fwzUK$reactspectrumutils = require("@react-spectrum/utils");
var $fwzUK$reactariautils = require("@react-aria/utils");
var $fwzUK$reactaria = require("react-aria");
function $parcel$export(e, n, v, s) {
Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true});
}
$parcel$export(module.exports, "NumberFieldContext", () => $a366ef8f467b1cb5$export$b414a48cf5dcbc11);
$parcel$export(module.exports, "NumberField", () => $a366ef8f467b1cb5$export$63c5fa0b2fdccd2e);
/*
* 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 $a366ef8f467b1cb5$export$b414a48cf5dcbc11 = /*#__PURE__*/ (0, $fwzUK$react.createContext)(null);
const $a366ef8f467b1cb5$var$inputButton = function anonymous(props) {
let rules = " ";
if (props.size === "XL") rules += ' -SFnbic-_JaP8ec1';
else if (props.size === "L") rules += ' -SFnbic-_J0K2hn1';
else if (props.size === "S") rules += ' -SFnbic-_JJOW22b1';
else if (props.size === "XS") rules += ' -SFnbic-_JICefdd1';
else rules += ' -SFnbic-_Jb1';
rules += ' -Bu7z1c-oa1';
rules += ' oj1';
rules += ' nj1';
rules += ' kj1';
rules += ' jj1';
rules += ' sd1';
rules += ' _Le1';
rules += ' _Wa1';
rules += ' _je1';
rules += ' eb1';
rules += ' _Ca1';
if (props.size === "XL") rules += ' ZC1';
else if (props.size === "L") rules += ' Zo1';
else if (props.size === "M") rules += ' Zm1';
else if (props.size === "S") rules += ' Zu1';
rules += ' Fd1';
if (props.type === "increment") rules += ' Iy1';
else rules += ' Iw1';
rules += ' fa1';
rules += ' _va1';
rules += ' Ma1';
rules += ' Yd1';
rules += ' Yle1';
rules += ' Xb1';
rules += ' Xlb1';
rules += ' _2b1';
rules += ' _2lb1';
if (props.isDisabled) rules += ' gH1';
else {
if (props.isPressed) rules += ' gF1';
else if (props.isFocusVisible) rules += ' gF1';
else if (props.isHovered) rules += ' gF1';
else rules += ' gH1';
}
if (props.isDisabled) rules += ' gld1';
else if (props.isHovered) rules += ' gle1';
else rules += ' glc1';
if (props.isDisabled) rules += ' pp1';
else {
if (props.isPressed) rules += ' po1';
else if (props.isFocusVisible) rules += ' po1';
else if (props.isHovered) rules += ' po1';
else rules += ' pt1';
}
rules += ' pla1';
rules += ' ri1';
return rules;
};
const $a366ef8f467b1cb5$var$iconStyles = " _va1 -_8sjo0b-t5ZbAob1";
const $a366ef8f467b1cb5$var$stepperContainerStyles = function anonymous(props) {
let rules = " ";
rules += ' sd1';
rules += ' _tc1';
if (props.size === "XL") rules += ' Ue1';
else if (props.size === "L") rules += ' Ue1';
else if (props.size === "M") rules += ' Ub1';
else if (props.size === "S") rules += ' Ue1';
if (props.size === "XL") rules += ' qe1';
else if (props.size === "L") rules += ' qe1';
else if (props.size === "M") rules += ' qb1';
else if (props.size === "S") rules += ' qe1';
if (props.size === "XL") rules += ' HWJpoB1';
else if (props.size === "L") rules += ' HWJpoB1';
else if (props.size === "M") rules += ' Hs1';
else if (props.size === "S") rules += ' Hr1';
return rules;
};
const $a366ef8f467b1cb5$export$63c5fa0b2fdccd2e = /*#__PURE__*/ (0, $fwzUK$react.forwardRef)(function NumberField(props1, ref) {
[props1, ref] = (0, $ac757a4c2bd72aee$exports.useSpectrumContextProps)(props1, ref, $a366ef8f467b1cb5$export$b414a48cf5dcbc11);
props1 = (0, $bfa4962d90c8af48$exports.useFormProps)(props1);
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, $fwzUK$react.useContext)((0, $bfa4962d90c8af48$exports.FormContext));
let domRef = (0, $fwzUK$react.useRef)(null);
let inputRef = (0, $fwzUK$react.useRef)(null);
let decrementButtonRef = (0, $fwzUK$react.useRef)(null);
let incrementButtonRef = (0, $fwzUK$react.useRef)(null);
// Expose imperative interface for ref
(0, $fwzUK$react.useImperativeHandle)(ref, ()=>({
...(0, $fwzUK$reactspectrumutils.createFocusableRef)(domRef, inputRef),
select () {
if (inputRef.current) inputRef.current.select();
},
getInputElement () {
return inputRef.current;
}
}));
return /*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)((0, $fwzUK$reactariacomponents.NumberField), {
ref: domRef,
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|_6|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 += ' se1';
if (props.isInForm) {
if (!gridColumnStart) rules += ' z2mU1';
}
if (props.isInForm) {
if (props.labelPosition === "side") {
if (!gridColumnEnd) rules += ' yvoofG1';
}
}
if (props.isInForm) rules += ' DLwlgod1';
else {
if (props.labelPosition === "side") rules += ' DPlN5qb1';
else if (props.labelPosition === "top") rules += ' DM8Mfn1';
}
if (props.labelPosition === "side") rules += ' EPlN5qb1';
else if (props.labelPosition === "top") rules += ' E4w1sLc1';
if (props.labelPosition === "side") rules += ' CbRM95c1';
else if (props.labelPosition === "top") rules += ' Cxaocre1';
if (props.size === "XL") {
rules += ' -_6BNtrc-e1';
rules += ' vx1';
} else if (props.size === "L") {
rules += ' -_6BNtrc-d1';
rules += ' vx1';
} else if (props.size === "S") {
rules += ' -_6BNtrc-b1';
rules += ' vx1';
} else if (props.size === "XS") {
rules += ' -_6BNtrc-a1';
rules += ' vx1';
} else {
rules += ' -_6BNtrc-c1';
rules += ' vx1';
}
rules += ' ea1';
rules += ' _Fd1';
rules += ' _FnuYUweb1';
if (props.size === "XL") rules += ' -BhX7R-Fz1';
else if (props.size === "L") rules += ' -BhX7R-Fv1';
else if (props.size === "S") rules += ' -BhX7R-Fp1';
else if (props.size === "XS") rules += ' -BhX7R-Fn1';
else rules += ' -BhX7R-Fx1';
rules += ' -AJjOLd-UVkF0Db1';
rules += ' qg1';
rules += ' __ca1';
return rules;
}({
isInForm: !!formContext,
labelPosition: labelPosition,
size: size
}, props1.styles),
children: ({ isDisabled: isDisabled, isInvalid: isInvalid })=>{
return /*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsxs)((0, $fwzUK$reactjsxruntime.Fragment), {
children: [
/*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)((0, $a0b996a550bb0891$exports.FieldLabel), {
isDisabled: isDisabled,
isRequired: isRequired,
size: size,
labelPosition: labelPosition,
labelAlign: labelAlign,
necessityIndicator: necessityIndicator,
contextualHelp: contextualHelp,
children: label
}),
/*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsxs)((0, $a0b996a550bb0891$exports.FieldGroup), {
size: size,
styles: function anonymous(props) {
let rules = " ";
rules += ' zXcEWr1';
rules += ' yXcEWr1';
rules += ' BXcEWr1';
rules += ' AXcEWr1';
if (props.size === "XL") rules += ' Nl1';
else if (props.size === "L") rules += ' Nj1';
else if (props.size === "S") rules += ' Nf1';
else if (props.size === "XS") rules += ' Ne1';
else rules += ' Nk1';
if (props.isQuiet) rules += ' _qd1';
else rules += ' _qtb1';
if (props.size === "XL") rules += ' -Anxdcc-Zt1';
else if (props.size === "L") rules += ' -Anxdcc-ZStdtne1';
else if (props.size === "S") rules += ' -Anxdcc-Zr1';
else rules += ' -Anxdcc-Z3fn9H1';
rules += ' __v6TNLWb1';
rules += ' SMBFGYc1';
rules += ' RfBFGYc1';
rules += ' -S_-Sv1';
if (props.isStepperHidden) rules += ' -R_-Rv1';
else rules += ' -R_-Rd1';
return rules;
}({
size: size,
isStepperHidden: hideStepper
}),
children: [
/*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)((0, $fwzUK$reactariacomponents.InputContext).Consumer, {
children: (ctx)=>/*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)((0, $fwzUK$reactariacomponents.InputContext).Provider, {
value: {
...ctx,
ref: (0, $fwzUK$reactariautils.mergeRefs)(ctx?.ref, inputRef)
},
children: /*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)((0, $a0b996a550bb0891$exports.Input), {})
})
}),
isInvalid && /*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)((0, $a0b996a550bb0891$exports.FieldErrorIcon), {
isDisabled: isDisabled
}),
!hideStepper && /*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsxs)("div", {
className: $a366ef8f467b1cb5$var$stepperContainerStyles({
size: size
}),
children: [
/*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)($a366ef8f467b1cb5$var$StepButton, {
ref: decrementButtonRef,
slot: "decrement",
style: (renderProps)=>(0, $2061c83559b50a66$exports.pressScale)(decrementButtonRef)(renderProps),
className: (renderProps)=>$a366ef8f467b1cb5$var$inputButton({
...renderProps,
type: 'decrement',
size: size
}),
children: /*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)((0, $84c37b7bd5c1374e$exports.default), {
size: size,
className: $a366ef8f467b1cb5$var$iconStyles
})
}),
/*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)($a366ef8f467b1cb5$var$StepButton, {
ref: incrementButtonRef,
slot: "increment",
style: (renderProps)=>(0, $2061c83559b50a66$exports.pressScale)(incrementButtonRef)(renderProps),
className: (renderProps)=>$a366ef8f467b1cb5$var$inputButton({
...renderProps,
type: 'increment',
size: size
}),
children: /*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)((0, $54686c7c3f031ee2$exports.default), {
size: size,
className: $a366ef8f467b1cb5$var$iconStyles
})
})
]
})
]
}),
/*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)((0, $a0b996a550bb0891$exports.HelpText), {
size: size,
isDisabled: isDisabled,
isInvalid: isInvalid,
description: descriptionMessage,
children: errorMessage
})
]
});
}
});
});
const $a366ef8f467b1cb5$var$additionalButtonHTMLAttributes = new Set([
'form',
'formAction',
'formEncType',
'formMethod',
'formNoValidate',
'formTarget',
'name',
'value'
]);
let $a366ef8f467b1cb5$var$StepButton = /*#__PURE__*/ (0, $fwzUK$react.forwardRef)((props, ref)=>{
[props, ref] = (0, $fwzUK$reactariacomponents.useContextProps)(props, ref, (0, $fwzUK$reactariacomponents.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, $fwzUK$reactaria.useButton)({
...props,
elementType: 'div'
}, ref);
let { focusProps: focusProps, isFocused: isFocused, isFocusVisible: isFocusVisible } = (0, $fwzUK$reactaria.useFocusRing)(props);
let { hoverProps: hoverProps, isHovered: isHovered } = (0, $fwzUK$reactaria.useHover)(props);
let renderProps = $a366ef8f467b1cb5$var$useRenderProps({
...props,
values: {
isHovered: isHovered,
isPressed: isPressed,
isFocused: isFocused,
isFocusVisible: isFocusVisible,
isDisabled: props.isDisabled || false
},
defaultClassName: 'react-aria-Button'
});
return /*#__PURE__*/ (0, $fwzUK$reactjsxruntime.jsx)("div", {
...(0, $fwzUK$reactariautils.filterDOMProps)(props, {
propNames: $a366ef8f467b1cb5$var$additionalButtonHTMLAttributes
}),
...(0, $fwzUK$reactariautils.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 $a366ef8f467b1cb5$var$useRenderProps(props) {
let { className: className, style: style, children: children, defaultClassName: defaultClassName, defaultChildren: defaultChildren, defaultStyle: defaultStyle, values: values } = props;
return (0, $fwzUK$react.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
]);
}
//# sourceMappingURL=NumberField.cjs.map