import {
  useFieldContext
} from "./4HPQVVRP.jsx";
import {
  createSplitProps
} from "./6WEDGJKQ.jsx";
import {
  ark
} from "./UFYZ7HLU.jsx";
import {
  useEnvironmentContext
} from "./D2Z5BEON.jsx";
import {
  useLocaleContext
} from "./RCXMZN3G.jsx";
import {
  createContext
} from "./TVCIHLER.jsx";
import {
  runIfFn
} from "./KGOB2IMX.jsx";
import {
  __export
} from "./7IUG3E2V.jsx";

// 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());

// src/components/number-input/number-input-control.tsx
import { mergeProps } from "@zag-js/solid";
var NumberInputControl = (props) => {
  const api = useNumberInputContext();
  const mergedProps = mergeProps(() => api().getControlProps(), props);
  return <ark.div {...mergedProps} />;
};

// src/components/number-input/number-input-decrement-trigger.tsx
import { mergeProps as mergeProps2 } from "@zag-js/solid";
var NumberInputDecrementTrigger = (props) => {
  const api = useNumberInputContext();
  const mergedProps = mergeProps2(() => api().getDecrementTriggerProps(), props);
  return <ark.button {...mergedProps} />;
};

// src/components/number-input/number-input-increment-trigger.tsx
import { mergeProps as mergeProps3 } from "@zag-js/solid";
var NumberInputIncrementTrigger = (props) => {
  const api = useNumberInputContext();
  const mergedProps = mergeProps3(() => api().getIncrementTriggerProps(), props);
  return <ark.button {...mergedProps} />;
};

// src/components/number-input/number-input-input.tsx
import { mergeProps as mergeProps4 } from "@zag-js/solid";
var NumberInputInput = (props) => {
  const api = useNumberInputContext();
  const mergedProps = mergeProps4(() => api().getInputProps(), props);
  const field = useFieldContext();
  return <ark.input aria-describedby={field?.().ariaDescribedby} {...mergedProps} />;
};

// src/components/number-input/number-input-label.tsx
import { mergeProps as mergeProps5 } from "@zag-js/solid";
var NumberInputLabel = (props) => {
  const api = useNumberInputContext();
  const mergedProps = mergeProps5(() => api().getLabelProps(), props);
  return <ark.label {...mergedProps} />;
};

// src/components/number-input/number-input-root.tsx
import { mergeProps as mergeProps6 } from "@zag-js/solid";

// src/components/number-input/use-number-input.ts
import * as numberInput from "@zag-js/number-input";
import { normalizeProps, useMachine } from "@zag-js/solid";
import { createMemo, createUniqueId } from "solid-js";
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",
    "onValueInvalid",
    "pattern",
    "readOnly",
    "required",
    "spinOnPress",
    "step",
    "translations",
    "value"
  ]);
  const api = useNumberInput(useNumberInputProps);
  const mergedProps = mergeProps6(() => api().getRootProps(), localProps);
  return <NumberInputProvider value={api}>
      <ark.div {...mergedProps} />
    </NumberInputProvider>;
};

// src/components/number-input/number-input-root-provider.tsx
import { mergeProps as mergeProps7 } from "@zag-js/solid";
var NumberInputRootProvider = (props) => {
  const [{ value: numberInput2 }, localProps] = createSplitProps()(props, ["value"]);
  const mergedProps = mergeProps7(() => numberInput2().getRootProps(), localProps);
  return <NumberInputProvider value={numberInput2}>
      <ark.div {...mergedProps} />
    </NumberInputProvider>;
};

// src/components/number-input/number-input-scrubber.tsx
import { mergeProps as mergeProps8 } from "@zag-js/solid";
var NumberInputScrubber = (props) => {
  const api = useNumberInputContext();
  const mergedProps = mergeProps8(() => api().getScrubberProps(), props);
  return <ark.div {...mergedProps} />;
};

// src/components/number-input/number-input-value-text.tsx
import { mergeProps as mergeProps9 } from "@zag-js/solid";
var NumberInputValueText = (props) => {
  const numberInput2 = useNumberInputContext();
  const mergedProps = mergeProps9(() => numberInput2().getValueTextProps(), props);
  return <ark.span {...mergedProps} />;
};

// src/components/number-input/number-input.anatomy.ts
import { anatomy } from "@zag-js/number-input";

// 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 {
  useNumberInputContext,
  NumberInputContext,
  NumberInputControl,
  NumberInputDecrementTrigger,
  NumberInputIncrementTrigger,
  NumberInputInput,
  NumberInputLabel,
  useNumberInput,
  NumberInputRoot,
  NumberInputRootProvider,
  NumberInputScrubber,
  NumberInputValueText,
  anatomy,
  number_input_exports
};
