import {
  PresenceProvider,
  usePresence
} from "./WC2HBDLJ.jsx";
import {
  composeRefs
} from "./DOBZPYAN.jsx";
import {
  RenderStrategyProvider,
  splitRenderStrategyProps,
  useRenderStrategyContext
} from "./NEBB7COJ.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/tabs/tab-content.tsx
import { mergeProps } from "@zag-js/solid";
import { Show } from "solid-js";

// src/components/tabs/use-tabs-context.ts
var [TabsProvider, useTabsContext] = createContext({
  hookName: "useTabsContext",
  providerName: "<TabsProvider />"
});

// src/components/tabs/tab-content.tsx
var TabContent = (props) => {
  const [contentProps, localProps] = createSplitProps()(props, ["value"]);
  const api = useTabsContext();
  const renderStrategyProps = useRenderStrategyContext();
  const presenceApi = usePresence(
    mergeProps(renderStrategyProps, () => ({
      present: api().value === contentProps.value,
      immediate: true
    }))
  );
  const mergedProps = mergeProps(
    () => api().getContentProps(contentProps),
    () => presenceApi().presenceProps,
    localProps
  );
  return <PresenceProvider value={presenceApi}>
      <Show when={!presenceApi().unmounted}>
        <ark.div {...mergedProps} ref={composeRefs(presenceApi().ref, props.ref)} />
      </Show>
    </PresenceProvider>;
};

// src/components/tabs/tab-indicator.tsx
import { mergeProps as mergeProps2 } from "@zag-js/solid";
var TabIndicator = (props) => {
  const api = useTabsContext();
  const mergedProps = mergeProps2(() => api().getIndicatorProps(), props);
  return <ark.div {...mergedProps} />;
};

// src/components/tabs/tab-list.tsx
import { mergeProps as mergeProps3 } from "@zag-js/solid";
var TabList = (props) => {
  const api = useTabsContext();
  const mergedProps = mergeProps3(() => api().getListProps(), props);
  return <ark.div {...mergedProps} />;
};

// src/components/tabs/tab-trigger.tsx
import { mergeProps as mergeProps4 } from "@zag-js/solid";
var TabTrigger = (props) => {
  const [triggerProps, localProps] = createSplitProps()(props, ["disabled", "value"]);
  const api = useTabsContext();
  const mergedProps = mergeProps4(() => api().getTriggerProps(triggerProps), localProps);
  return <ark.button {...mergedProps} />;
};

// src/components/tabs/tabs-context.tsx
var TabsContext = (props) => props.children(useTabsContext());

// src/components/tabs/tabs-root.tsx
import { mergeProps as mergeProps5 } from "@zag-js/solid";

// src/components/tabs/use-tabs.ts
import { normalizeProps, useMachine } from "@zag-js/solid";
import * as tabs from "@zag-js/tabs";
import { createMemo, createUniqueId } from "solid-js";
var useTabs = (props) => {
  const id = createUniqueId();
  const locale = useLocaleContext();
  const environment = useEnvironmentContext();
  const machineProps = createMemo(() => ({
    id,
    dir: locale().dir,
    getRootNode: environment().getRootNode,
    ...runIfFn(props)
  }));
  const service = useMachine(tabs.machine, machineProps);
  return createMemo(() => tabs.connect(service, normalizeProps));
};

// src/components/tabs/tabs-root.tsx
var TabsRoot = (props) => {
  const [renderStrategyProps, tabsProps] = splitRenderStrategyProps(props);
  const [useTabsProps, restProps] = createSplitProps()(tabsProps, [
    "activationMode",
    "composite",
    "defaultValue",
    "deselectable",
    "id",
    "ids",
    "loopFocus",
    "navigate",
    "onFocusChange",
    "onValueChange",
    "orientation",
    "translations",
    "value"
  ]);
  const api = useTabs(useTabsProps);
  const mergedProps = mergeProps5(() => api().getRootProps(), restProps);
  return <TabsProvider value={api}>
      <RenderStrategyProvider value={renderStrategyProps}>
        <ark.div {...mergedProps} />
      </RenderStrategyProvider>
    </TabsProvider>;
};

// src/components/tabs/tabs-root-provider.tsx
import { mergeProps as mergeProps6 } from "@zag-js/solid";
var TabsRootProvider = (props) => {
  const [renderStrategyProps, tabsProps] = splitRenderStrategyProps(props);
  const [{ value: tabs2 }, localprops] = createSplitProps()(tabsProps, ["value"]);
  const mergedProps = mergeProps6(() => tabs2().getRootProps(), localprops);
  return <TabsProvider value={tabs2}>
      <RenderStrategyProvider value={renderStrategyProps}>
        <ark.div {...mergedProps} />
      </RenderStrategyProvider>
    </TabsProvider>;
};

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

// src/components/tabs/tabs.ts
var tabs_exports = {};
__export(tabs_exports, {
  Content: () => TabContent,
  Context: () => TabsContext,
  Indicator: () => TabIndicator,
  List: () => TabList,
  Root: () => TabsRoot,
  RootProvider: () => TabsRootProvider,
  Trigger: () => TabTrigger
});

export {
  useTabsContext,
  TabContent,
  TabIndicator,
  TabList,
  TabTrigger,
  TabsContext,
  useTabs,
  TabsRoot,
  TabsRootProvider,
  anatomy,
  tabs_exports
};
