@ark-ui/solid
Version:
A collection of unstyled, accessible UI components for Solid, utilizing state machines for seamless interaction.
127 lines (121 loc) • 5.28 kB
JavaScript
import { useFieldContext } from './GBGTOFYC.js';
import { createSplitProps } from './ZMHI4GDJ.js';
import { ark } from './EPLBB4QN.js';
import { useEnvironmentContext } from './5QLLQM7E.js';
import { useLocaleContext } from './RVOPDSQY.js';
import { runIfFn } from './DT73WLR4.js';
import { createContext } from './THN5C4U6.js';
import { __export } from './ESLJRKWD.js';
import { createComponent, mergeProps as mergeProps$1 } from 'solid-js/web';
import { mergeProps, useMachine, normalizeProps } from '@zag-js/solid';
import * as numberInput from '@zag-js/number-input';
import { createUniqueId, createMemo } from 'solid-js';
// src/components/number-input/use-number-input-context.ts
var [NumberInputProvider, useNumberInputContext] = createContext({
hookName: "useNumberInputContext",
providerName: "<NumberInputProvider />"
});
// src/components/number-input/number-input-context.tsx
var NumberInputContext = (props) => props.children(useNumberInputContext());
var NumberInputControl = (props) => {
const api = useNumberInputContext();
const mergedProps = mergeProps(() => api().getControlProps(), props);
return createComponent(ark.div, mergedProps);
};
var NumberInputDecrementTrigger = (props) => {
const api = useNumberInputContext();
const mergedProps = mergeProps(() => api().getDecrementTriggerProps(), props);
return createComponent(ark.button, mergedProps);
};
var NumberInputIncrementTrigger = (props) => {
const api = useNumberInputContext();
const mergedProps = mergeProps(() => api().getIncrementTriggerProps(), props);
return createComponent(ark.button, mergedProps);
};
var NumberInputInput = (props) => {
const api = useNumberInputContext();
const mergedProps = mergeProps(() => api().getInputProps(), props);
const field = useFieldContext();
return createComponent(ark.input, mergeProps$1({
get ["aria-describedby"]() {
return field?.().ariaDescribedby;
}
}, mergedProps));
};
var NumberInputLabel = (props) => {
const api = useNumberInputContext();
const mergedProps = mergeProps(() => api().getLabelProps(), props);
return createComponent(ark.label, mergedProps);
};
var useNumberInput = (props) => {
const id = createUniqueId();
const locale = useLocaleContext();
const environment = useEnvironmentContext();
const field = useFieldContext();
const machineProps = createMemo(() => ({
id,
ids: {
label: field?.().ids.label,
input: field?.().ids.control
},
disabled: field?.().disabled,
readOnly: field?.().readOnly,
required: field?.().required,
invalid: field?.().invalid,
dir: locale().dir,
locale: locale().locale,
getRootNode: environment().getRootNode,
...runIfFn(props)
}));
const service = useMachine(numberInput.machine, machineProps);
return createMemo(() => numberInput.connect(service, normalizeProps));
};
// src/components/number-input/number-input-root.tsx
var NumberInputRoot = (props) => {
const [useNumberInputProps, localProps] = createSplitProps()(props, ["allowMouseWheel", "allowOverflow", "clampValueOnBlur", "defaultValue", "disabled", "focusInputOnChange", "form", "formatOptions", "id", "ids", "inputMode", "invalid", "locale", "max", "min", "name", "onFocusChange", "onValueChange", "onValueCommit", "onValueInvalid", "pattern", "readOnly", "required", "spinOnPress", "step", "translations", "value"]);
const api = useNumberInput(useNumberInputProps);
const mergedProps = mergeProps(() => api().getRootProps(), localProps);
return createComponent(NumberInputProvider, {
value: api,
get children() {
return createComponent(ark.div, mergedProps);
}
});
};
var NumberInputRootProvider = (props) => {
const [{
value: numberInput2
}, localProps] = createSplitProps()(props, ["value"]);
const mergedProps = mergeProps(() => numberInput2().getRootProps(), localProps);
return createComponent(NumberInputProvider, {
value: numberInput2,
get children() {
return createComponent(ark.div, mergedProps);
}
});
};
var NumberInputScrubber = (props) => {
const api = useNumberInputContext();
const mergedProps = mergeProps(() => api().getScrubberProps(), props);
return createComponent(ark.div, mergedProps);
};
var NumberInputValueText = (props) => {
const numberInput2 = useNumberInputContext();
const mergedProps = mergeProps(() => numberInput2().getValueTextProps(), props);
return createComponent(ark.span, mergedProps);
};
// src/components/number-input/number-input.ts
var number_input_exports = {};
__export(number_input_exports, {
Context: () => NumberInputContext,
Control: () => NumberInputControl,
DecrementTrigger: () => NumberInputDecrementTrigger,
IncrementTrigger: () => NumberInputIncrementTrigger,
Input: () => NumberInputInput,
Label: () => NumberInputLabel,
Root: () => NumberInputRoot,
RootProvider: () => NumberInputRootProvider,
Scrubber: () => NumberInputScrubber,
ValueText: () => NumberInputValueText
});
export { NumberInputContext, NumberInputControl, NumberInputDecrementTrigger, NumberInputIncrementTrigger, NumberInputInput, NumberInputLabel, NumberInputRoot, NumberInputRootProvider, NumberInputScrubber, NumberInputValueText, number_input_exports, useNumberInput, useNumberInputContext };