commerce-toolkit 0.0.0 → 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../src/components/accordion/accordion.tsx","../node_modules/.pnpm/@radix-ui+react-context@1.1.2_@types+react@19.2.2_react@19.2.0/node_modules/@radix-ui/react-context/dist/index.mjs","../node_modules/.pnpm/@radix-ui+react-compose-refs@1.1.2_@types+react@19.2.2_react@19.2.0/node_modules/@radix-ui/react-compose-refs/dist/index.mjs","../node_modules/.pnpm/@radix-ui+react-slot@1.2.3_@types+react@19.2.2_react@19.2.0/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/.pnpm/@radix-ui+react-collection@1.1.7_@types+react-dom@19.2.2_@types+react@19.2.2__@types+react@19_k2fjofhzujhv5hwvt4rfkjvvre/node_modules/@radix-ui/react-collection/dist/index.mjs","../node_modules/.pnpm/@radix-ui+primitive@1.1.3/node_modules/@radix-ui/primitive/dist/index.mjs","../node_modules/.pnpm/@radix-ui+react-use-layout-effect@1.1.1_@types+react@19.2.2_react@19.2.0/node_modules/@radix-ui/react-use-layout-effect/dist/index.mjs","../node_modules/.pnpm/@radix-ui+react-use-controllable-state@1.2.2_@types+react@19.2.2_react@19.2.0/node_modules/@radix-ui/react-use-controllable-state/dist/index.mjs","../node_modules/.pnpm/@radix-ui+react-primitive@2.1.3_@types+react-dom@19.2.2_@types+react@19.2.2__@types+react@19._bvylq7i3abu4hbpi6ukh4as6qa/node_modules/@radix-ui/react-primitive/dist/index.mjs","../node_modules/.pnpm/@radix-ui+react-presence@1.1.5_@types+react-dom@19.2.2_@types+react@19.2.2__@types+react@19.2_rg5yyfyy4s5drnz7lbyqdnomsm/node_modules/@radix-ui/react-presence/dist/index.mjs","../node_modules/.pnpm/@radix-ui+react-id@1.1.1_@types+react@19.2.2_react@19.2.0/node_modules/@radix-ui/react-id/dist/index.mjs","../node_modules/.pnpm/@radix-ui+react-collapsible@1.1.12_@types+react-dom@19.2.2_@types+react@19.2.2__@types+react@_5wh3wn4mb6wukeaw22ryera4jq/node_modules/@radix-ui/react-collapsible/dist/index.mjs","../node_modules/.pnpm/@radix-ui+react-direction@1.1.1_@types+react@19.2.2_react@19.2.0/node_modules/@radix-ui/react-direction/dist/index.mjs","../node_modules/.pnpm/@radix-ui+react-accordion@1.2.12_@types+react-dom@19.2.2_@types+react@19.2.2__@types+react@19_ypscna4y3y4no7anhyuspcgzt4/node_modules/@radix-ui/react-accordion/dist/index.mjs","../node_modules/.pnpm/clsx@2.1.1/node_modules/clsx/dist/clsx.mjs","../src/components/accordion/primitives/accordion-item.tsx","../src/components/accordion/primitives/accordion-root.tsx","../src/components/accordion/primitives/accordion-content.tsx","../src/components/accordion/primitives/accordion-trigger.tsx","../src/components/accordion/primitives/accordion-provider.tsx"],"sourcesContent":["import type { ReactNode } from 'react';\n\nimport * as AccordionPrimitive from '@/components/accordion';\n\ninterface AccordionItemData {\n title: string;\n content: ReactNode;\n value?: string;\n}\n\nexport type AccordionProps = AccordionPrimitive.RootProps & {\n colorScheme?: 'light' | 'dark';\n items: AccordionItemData[];\n};\n\n/**\n * This component supports various CSS variables for theming. Here's a comprehensive list, along\n * with their default values:\n *\n * ```css\n * :root {\n * --accordion-focus: var(--primary);\n * --acordion-light-offset: var(--background);\n * --accordion-light-title-text: var(--contrast-400);\n * --accordion-light-title-text-hover: var(--foreground);\n * --accordion-light-title-icon: var(--contrast-500);\n * --accordion-light-title-icon-hover: var(--foreground);\n * --accordion-light-content-text: var(--foreground);\n * --acordion-dark-offset: var(--foreground);\n * --accordion-dark-title-text: var(--contrast-200);\n * --accordion-dark-title-text-hover: var(--background);\n * --accordion-dark-title-icon: var(--contrast-200);\n * --accordion-dark-title-icon-hover: var(--background);\n * --accordion-dark-content-text: var(--background);\n * --accordion-title-font-family: var(--font-family-mono);\n * --accordion-content-font-family: var(--font-family-body);\n * }\n * ```\n */\nexport function Accordion({ colorScheme = 'light', items, ...props }: AccordionProps) {\n return (\n <AccordionPrimitive.Provider colorScheme={colorScheme}>\n <AccordionPrimitive.Root {...props}>\n {items.map((item, index) => (\n <AccordionPrimitive.Item key={index} value={item.title}>\n <AccordionPrimitive.Trigger>{item.title}</AccordionPrimitive.Trigger>\n <AccordionPrimitive.Content>{item.content}</AccordionPrimitive.Content>\n </AccordionPrimitive.Item>\n ))}\n </AccordionPrimitive.Root>\n </AccordionPrimitive.Provider>\n );\n}\n","// packages/react/context/src/create-context.tsx\nimport * as React from \"react\";\nimport { jsx } from \"react/jsx-runtime\";\nfunction createContext2(rootComponentName, defaultContext) {\n const Context = React.createContext(defaultContext);\n const Provider = (props) => {\n const { children, ...context } = props;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName) {\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n}\nfunction createContextScope(scopeName, createContextScopeDeps = []) {\n let defaultContexts = [];\n function createContext3(rootComponentName, defaultContext) {\n const BaseContext = React.createContext(defaultContext);\n const index = defaultContexts.length;\n defaultContexts = [...defaultContexts, defaultContext];\n const Provider = (props) => {\n const { scope, children, ...context } = props;\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName, scope) {\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n }\n const createScope = () => {\n const scopeContexts = defaultContexts.map((defaultContext) => {\n return React.createContext(defaultContext);\n });\n return function useScope(scope) {\n const contexts = scope?.[scopeName] || scopeContexts;\n return React.useMemo(\n () => ({ [`__scope${scopeName}`]: { ...scope, [scopeName]: contexts } }),\n [scope, contexts]\n );\n };\n };\n createScope.scopeName = scopeName;\n return [createContext3, composeContextScopes(createScope, ...createContextScopeDeps)];\n}\nfunction composeContextScopes(...scopes) {\n const baseScope = scopes[0];\n if (scopes.length === 1) return baseScope;\n const createScope = () => {\n const scopeHooks = scopes.map((createScope2) => ({\n useScope: createScope2(),\n scopeName: createScope2.scopeName\n }));\n return function useComposedScopes(overrideScopes) {\n const nextScopes = scopeHooks.reduce((nextScopes2, { useScope, scopeName }) => {\n const scopeProps = useScope(overrideScopes);\n const currentScope = scopeProps[`__scope${scopeName}`];\n return { ...nextScopes2, ...currentScope };\n }, {});\n return React.useMemo(() => ({ [`__scope${baseScope.scopeName}`]: nextScopes }), [nextScopes]);\n };\n };\n createScope.scopeName = baseScope.scopeName;\n return createScope;\n}\nexport {\n createContext2 as createContext,\n createContextScope\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/compose-refs/src/compose-refs.tsx\nimport * as React from \"react\";\nfunction setRef(ref, value) {\n if (typeof ref === \"function\") {\n return ref(value);\n } else if (ref !== null && ref !== void 0) {\n ref.current = value;\n }\n}\nfunction composeRefs(...refs) {\n return (node) => {\n let hasCleanup = false;\n const cleanups = refs.map((ref) => {\n const cleanup = setRef(ref, node);\n if (!hasCleanup && typeof cleanup == \"function\") {\n hasCleanup = true;\n }\n return cleanup;\n });\n if (hasCleanup) {\n return () => {\n for (let i = 0; i < cleanups.length; i++) {\n const cleanup = cleanups[i];\n if (typeof cleanup == \"function\") {\n cleanup();\n } else {\n setRef(refs[i], null);\n }\n }\n };\n }\n };\n}\nfunction useComposedRefs(...refs) {\n return React.useCallback(composeRefs(...refs), refs);\n}\nexport {\n composeRefs,\n useComposedRefs\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/collection-legacy.tsx\nimport React from \"react\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nfunction createCollection(name) {\n const PROVIDER_NAME = name + \"CollectionProvider\";\n const [createCollectionContext, createCollectionScope] = createContextScope(PROVIDER_NAME);\n const [CollectionProviderImpl, useCollectionContext] = createCollectionContext(\n PROVIDER_NAME,\n { collectionRef: { current: null }, itemMap: /* @__PURE__ */ new Map() }\n );\n const CollectionProvider = (props) => {\n const { scope, children } = props;\n const ref = React.useRef(null);\n const itemMap = React.useRef(/* @__PURE__ */ new Map()).current;\n return /* @__PURE__ */ jsx(CollectionProviderImpl, { scope, itemMap, collectionRef: ref, children });\n };\n CollectionProvider.displayName = PROVIDER_NAME;\n const COLLECTION_SLOT_NAME = name + \"CollectionSlot\";\n const CollectionSlotImpl = createSlot(COLLECTION_SLOT_NAME);\n const CollectionSlot = React.forwardRef(\n (props, forwardedRef) => {\n const { scope, children } = props;\n const context = useCollectionContext(COLLECTION_SLOT_NAME, scope);\n const composedRefs = useComposedRefs(forwardedRef, context.collectionRef);\n return /* @__PURE__ */ jsx(CollectionSlotImpl, { ref: composedRefs, children });\n }\n );\n CollectionSlot.displayName = COLLECTION_SLOT_NAME;\n const ITEM_SLOT_NAME = name + \"CollectionItemSlot\";\n const ITEM_DATA_ATTR = \"data-radix-collection-item\";\n const CollectionItemSlotImpl = createSlot(ITEM_SLOT_NAME);\n const CollectionItemSlot = React.forwardRef(\n (props, forwardedRef) => {\n const { scope, children, ...itemData } = props;\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const context = useCollectionContext(ITEM_SLOT_NAME, scope);\n React.useEffect(() => {\n context.itemMap.set(ref, { ref, ...itemData });\n return () => void context.itemMap.delete(ref);\n });\n return /* @__PURE__ */ jsx(CollectionItemSlotImpl, { ...{ [ITEM_DATA_ATTR]: \"\" }, ref: composedRefs, children });\n }\n );\n CollectionItemSlot.displayName = ITEM_SLOT_NAME;\n function useCollection(scope) {\n const context = useCollectionContext(name + \"CollectionConsumer\", scope);\n const getItems = React.useCallback(() => {\n const collectionNode = context.collectionRef.current;\n if (!collectionNode) return [];\n const orderedNodes = Array.from(collectionNode.querySelectorAll(`[${ITEM_DATA_ATTR}]`));\n const items = Array.from(context.itemMap.values());\n const orderedItems = items.sort(\n (a, b) => orderedNodes.indexOf(a.ref.current) - orderedNodes.indexOf(b.ref.current)\n );\n return orderedItems;\n }, [context.collectionRef, context.itemMap]);\n return getItems;\n }\n return [\n { Provider: CollectionProvider, Slot: CollectionSlot, ItemSlot: CollectionItemSlot },\n useCollection,\n createCollectionScope\n ];\n}\n\n// src/collection.tsx\nimport React2 from \"react\";\nimport { createContextScope as createContextScope2 } from \"@radix-ui/react-context\";\nimport { useComposedRefs as useComposedRefs2 } from \"@radix-ui/react-compose-refs\";\nimport { createSlot as createSlot2 } from \"@radix-ui/react-slot\";\n\n// src/ordered-dictionary.ts\nvar __instanciated = /* @__PURE__ */ new WeakMap();\nvar OrderedDict = class _OrderedDict extends Map {\n #keys;\n constructor(entries) {\n super(entries);\n this.#keys = [...super.keys()];\n __instanciated.set(this, true);\n }\n set(key, value) {\n if (__instanciated.get(this)) {\n if (this.has(key)) {\n this.#keys[this.#keys.indexOf(key)] = key;\n } else {\n this.#keys.push(key);\n }\n }\n super.set(key, value);\n return this;\n }\n insert(index, key, value) {\n const has = this.has(key);\n const length = this.#keys.length;\n const relativeIndex = toSafeInteger(index);\n let actualIndex = relativeIndex >= 0 ? relativeIndex : length + relativeIndex;\n const safeIndex = actualIndex < 0 || actualIndex >= length ? -1 : actualIndex;\n if (safeIndex === this.size || has && safeIndex === this.size - 1 || safeIndex === -1) {\n this.set(key, value);\n return this;\n }\n const size = this.size + (has ? 0 : 1);\n if (relativeIndex < 0) {\n actualIndex++;\n }\n const keys = [...this.#keys];\n let nextValue;\n let shouldSkip = false;\n for (let i = actualIndex; i < size; i++) {\n if (actualIndex === i) {\n let nextKey = keys[i];\n if (keys[i] === key) {\n nextKey = keys[i + 1];\n }\n if (has) {\n this.delete(key);\n }\n nextValue = this.get(nextKey);\n this.set(key, value);\n } else {\n if (!shouldSkip && keys[i - 1] === key) {\n shouldSkip = true;\n }\n const currentKey = keys[shouldSkip ? i : i - 1];\n const currentValue = nextValue;\n nextValue = this.get(currentKey);\n this.delete(currentKey);\n this.set(currentKey, currentValue);\n }\n }\n return this;\n }\n with(index, key, value) {\n const copy = new _OrderedDict(this);\n copy.insert(index, key, value);\n return copy;\n }\n before(key) {\n const index = this.#keys.indexOf(key) - 1;\n if (index < 0) {\n return void 0;\n }\n return this.entryAt(index);\n }\n /**\n * Sets a new key-value pair at the position before the given key.\n */\n setBefore(key, newKey, value) {\n const index = this.#keys.indexOf(key);\n if (index === -1) {\n return this;\n }\n return this.insert(index, newKey, value);\n }\n after(key) {\n let index = this.#keys.indexOf(key);\n index = index === -1 || index === this.size - 1 ? -1 : index + 1;\n if (index === -1) {\n return void 0;\n }\n return this.entryAt(index);\n }\n /**\n * Sets a new key-value pair at the position after the given key.\n */\n setAfter(key, newKey, value) {\n const index = this.#keys.indexOf(key);\n if (index === -1) {\n return this;\n }\n return this.insert(index + 1, newKey, value);\n }\n first() {\n return this.entryAt(0);\n }\n last() {\n return this.entryAt(-1);\n }\n clear() {\n this.#keys = [];\n return super.clear();\n }\n delete(key) {\n const deleted = super.delete(key);\n if (deleted) {\n this.#keys.splice(this.#keys.indexOf(key), 1);\n }\n return deleted;\n }\n deleteAt(index) {\n const key = this.keyAt(index);\n if (key !== void 0) {\n return this.delete(key);\n }\n return false;\n }\n at(index) {\n const key = at(this.#keys, index);\n if (key !== void 0) {\n return this.get(key);\n }\n }\n entryAt(index) {\n const key = at(this.#keys, index);\n if (key !== void 0) {\n return [key, this.get(key)];\n }\n }\n indexOf(key) {\n return this.#keys.indexOf(key);\n }\n keyAt(index) {\n return at(this.#keys, index);\n }\n from(key, offset) {\n const index = this.indexOf(key);\n if (index === -1) {\n return void 0;\n }\n let dest = index + offset;\n if (dest < 0) dest = 0;\n if (dest >= this.size) dest = this.size - 1;\n return this.at(dest);\n }\n keyFrom(key, offset) {\n const index = this.indexOf(key);\n if (index === -1) {\n return void 0;\n }\n let dest = index + offset;\n if (dest < 0) dest = 0;\n if (dest >= this.size) dest = this.size - 1;\n return this.keyAt(dest);\n }\n find(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return entry;\n }\n index++;\n }\n return void 0;\n }\n findIndex(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return index;\n }\n index++;\n }\n return -1;\n }\n filter(predicate, thisArg) {\n const entries = [];\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n entries.push(entry);\n }\n index++;\n }\n return new _OrderedDict(entries);\n }\n map(callbackfn, thisArg) {\n const entries = [];\n let index = 0;\n for (const entry of this) {\n entries.push([entry[0], Reflect.apply(callbackfn, thisArg, [entry, index, this])]);\n index++;\n }\n return new _OrderedDict(entries);\n }\n reduce(...args) {\n const [callbackfn, initialValue] = args;\n let index = 0;\n let accumulator = initialValue ?? this.at(0);\n for (const entry of this) {\n if (index === 0 && args.length === 1) {\n accumulator = entry;\n } else {\n accumulator = Reflect.apply(callbackfn, this, [accumulator, entry, index, this]);\n }\n index++;\n }\n return accumulator;\n }\n reduceRight(...args) {\n const [callbackfn, initialValue] = args;\n let accumulator = initialValue ?? this.at(-1);\n for (let index = this.size - 1; index >= 0; index--) {\n const entry = this.at(index);\n if (index === this.size - 1 && args.length === 1) {\n accumulator = entry;\n } else {\n accumulator = Reflect.apply(callbackfn, this, [accumulator, entry, index, this]);\n }\n }\n return accumulator;\n }\n toSorted(compareFn) {\n const entries = [...this.entries()].sort(compareFn);\n return new _OrderedDict(entries);\n }\n toReversed() {\n const reversed = new _OrderedDict();\n for (let index = this.size - 1; index >= 0; index--) {\n const key = this.keyAt(index);\n const element = this.get(key);\n reversed.set(key, element);\n }\n return reversed;\n }\n toSpliced(...args) {\n const entries = [...this.entries()];\n entries.splice(...args);\n return new _OrderedDict(entries);\n }\n slice(start, end) {\n const result = new _OrderedDict();\n let stop = this.size - 1;\n if (start === void 0) {\n return result;\n }\n if (start < 0) {\n start = start + this.size;\n }\n if (end !== void 0 && end > 0) {\n stop = end - 1;\n }\n for (let index = start; index <= stop; index++) {\n const key = this.keyAt(index);\n const element = this.get(key);\n result.set(key, element);\n }\n return result;\n }\n every(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (!Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return false;\n }\n index++;\n }\n return true;\n }\n some(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return true;\n }\n index++;\n }\n return false;\n }\n};\nfunction at(array, index) {\n if (\"at\" in Array.prototype) {\n return Array.prototype.at.call(array, index);\n }\n const actualIndex = toSafeIndex(array, index);\n return actualIndex === -1 ? void 0 : array[actualIndex];\n}\nfunction toSafeIndex(array, index) {\n const length = array.length;\n const relativeIndex = toSafeInteger(index);\n const actualIndex = relativeIndex >= 0 ? relativeIndex : length + relativeIndex;\n return actualIndex < 0 || actualIndex >= length ? -1 : actualIndex;\n}\nfunction toSafeInteger(number) {\n return number !== number || number === 0 ? 0 : Math.trunc(number);\n}\n\n// src/collection.tsx\nimport { jsx as jsx2 } from \"react/jsx-runtime\";\nfunction createCollection2(name) {\n const PROVIDER_NAME = name + \"CollectionProvider\";\n const [createCollectionContext, createCollectionScope] = createContextScope2(PROVIDER_NAME);\n const [CollectionContextProvider, useCollectionContext] = createCollectionContext(\n PROVIDER_NAME,\n {\n collectionElement: null,\n collectionRef: { current: null },\n collectionRefObject: { current: null },\n itemMap: new OrderedDict(),\n setItemMap: () => void 0\n }\n );\n const CollectionProvider = ({ state, ...props }) => {\n return state ? /* @__PURE__ */ jsx2(CollectionProviderImpl, { ...props, state }) : /* @__PURE__ */ jsx2(CollectionInit, { ...props });\n };\n CollectionProvider.displayName = PROVIDER_NAME;\n const CollectionInit = (props) => {\n const state = useInitCollection();\n return /* @__PURE__ */ jsx2(CollectionProviderImpl, { ...props, state });\n };\n CollectionInit.displayName = PROVIDER_NAME + \"Init\";\n const CollectionProviderImpl = (props) => {\n const { scope, children, state } = props;\n const ref = React2.useRef(null);\n const [collectionElement, setCollectionElement] = React2.useState(\n null\n );\n const composeRefs = useComposedRefs2(ref, setCollectionElement);\n const [itemMap, setItemMap] = state;\n React2.useEffect(() => {\n if (!collectionElement) return;\n const observer = getChildListObserver(() => {\n });\n observer.observe(collectionElement, {\n childList: true,\n subtree: true\n });\n return () => {\n observer.disconnect();\n };\n }, [collectionElement]);\n return /* @__PURE__ */ jsx2(\n CollectionContextProvider,\n {\n scope,\n itemMap,\n setItemMap,\n collectionRef: composeRefs,\n collectionRefObject: ref,\n collectionElement,\n children\n }\n );\n };\n CollectionProviderImpl.displayName = PROVIDER_NAME + \"Impl\";\n const COLLECTION_SLOT_NAME = name + \"CollectionSlot\";\n const CollectionSlotImpl = createSlot2(COLLECTION_SLOT_NAME);\n const CollectionSlot = React2.forwardRef(\n (props, forwardedRef) => {\n const { scope, children } = props;\n const context = useCollectionContext(COLLECTION_SLOT_NAME, scope);\n const composedRefs = useComposedRefs2(forwardedRef, context.collectionRef);\n return /* @__PURE__ */ jsx2(CollectionSlotImpl, { ref: composedRefs, children });\n }\n );\n CollectionSlot.displayName = COLLECTION_SLOT_NAME;\n const ITEM_SLOT_NAME = name + \"CollectionItemSlot\";\n const ITEM_DATA_ATTR = \"data-radix-collection-item\";\n const CollectionItemSlotImpl = createSlot2(ITEM_SLOT_NAME);\n const CollectionItemSlot = React2.forwardRef(\n (props, forwardedRef) => {\n const { scope, children, ...itemData } = props;\n const ref = React2.useRef(null);\n const [element, setElement] = React2.useState(null);\n const composedRefs = useComposedRefs2(forwardedRef, ref, setElement);\n const context = useCollectionContext(ITEM_SLOT_NAME, scope);\n const { setItemMap } = context;\n const itemDataRef = React2.useRef(itemData);\n if (!shallowEqual(itemDataRef.current, itemData)) {\n itemDataRef.current = itemData;\n }\n const memoizedItemData = itemDataRef.current;\n React2.useEffect(() => {\n const itemData2 = memoizedItemData;\n setItemMap((map) => {\n if (!element) {\n return map;\n }\n if (!map.has(element)) {\n map.set(element, { ...itemData2, element });\n return map.toSorted(sortByDocumentPosition);\n }\n return map.set(element, { ...itemData2, element }).toSorted(sortByDocumentPosition);\n });\n return () => {\n setItemMap((map) => {\n if (!element || !map.has(element)) {\n return map;\n }\n map.delete(element);\n return new OrderedDict(map);\n });\n };\n }, [element, memoizedItemData, setItemMap]);\n return /* @__PURE__ */ jsx2(CollectionItemSlotImpl, { ...{ [ITEM_DATA_ATTR]: \"\" }, ref: composedRefs, children });\n }\n );\n CollectionItemSlot.displayName = ITEM_SLOT_NAME;\n function useInitCollection() {\n return React2.useState(new OrderedDict());\n }\n function useCollection(scope) {\n const { itemMap } = useCollectionContext(name + \"CollectionConsumer\", scope);\n return itemMap;\n }\n const functions = {\n createCollectionScope,\n useCollection,\n useInitCollection\n };\n return [\n { Provider: CollectionProvider, Slot: CollectionSlot, ItemSlot: CollectionItemSlot },\n functions\n ];\n}\nfunction shallowEqual(a, b) {\n if (a === b) return true;\n if (typeof a !== \"object\" || typeof b !== \"object\") return false;\n if (a == null || b == null) return false;\n const keysA = Object.keys(a);\n const keysB = Object.keys(b);\n if (keysA.length !== keysB.length) return false;\n for (const key of keysA) {\n if (!Object.prototype.hasOwnProperty.call(b, key)) return false;\n if (a[key] !== b[key]) return false;\n }\n return true;\n}\nfunction isElementPreceding(a, b) {\n return !!(b.compareDocumentPosition(a) & Node.DOCUMENT_POSITION_PRECEDING);\n}\nfunction sortByDocumentPosition(a, b) {\n return !a[1].element || !b[1].element ? 0 : isElementPreceding(a[1].element, b[1].element) ? -1 : 1;\n}\nfunction getChildListObserver(callback) {\n const observer = new MutationObserver((mutationsList) => {\n for (const mutation of mutationsList) {\n if (mutation.type === \"childList\") {\n callback();\n return;\n }\n }\n });\n return observer;\n}\nexport {\n createCollection,\n createCollection2 as unstable_createCollection\n};\n//# sourceMappingURL=index.mjs.map\n","// src/primitive.tsx\nvar canUseDOM = !!(typeof window !== \"undefined\" && window.document && window.document.createElement);\nfunction composeEventHandlers(originalEventHandler, ourEventHandler, { checkForDefaultPrevented = true } = {}) {\n return function handleEvent(event) {\n originalEventHandler?.(event);\n if (checkForDefaultPrevented === false || !event.defaultPrevented) {\n return ourEventHandler?.(event);\n }\n };\n}\nfunction getOwnerWindow(element) {\n if (!canUseDOM) {\n throw new Error(\"Cannot access window outside of the DOM\");\n }\n return element?.ownerDocument?.defaultView ?? window;\n}\nfunction getOwnerDocument(element) {\n if (!canUseDOM) {\n throw new Error(\"Cannot access document outside of the DOM\");\n }\n return element?.ownerDocument ?? document;\n}\nfunction getActiveElement(node, activeDescendant = false) {\n const { activeElement } = getOwnerDocument(node);\n if (!activeElement?.nodeName) {\n return null;\n }\n if (isFrame(activeElement) && activeElement.contentDocument) {\n return getActiveElement(activeElement.contentDocument.body, activeDescendant);\n }\n if (activeDescendant) {\n const id = activeElement.getAttribute(\"aria-activedescendant\");\n if (id) {\n const element = getOwnerDocument(activeElement).getElementById(id);\n if (element) {\n return element;\n }\n }\n }\n return activeElement;\n}\nfunction isFrame(element) {\n return element.tagName === \"IFRAME\";\n}\nexport {\n canUseDOM,\n composeEventHandlers,\n getActiveElement,\n getOwnerDocument,\n getOwnerWindow,\n isFrame\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/use-layout-effect/src/use-layout-effect.tsx\nimport * as React from \"react\";\nvar useLayoutEffect2 = globalThis?.document ? React.useLayoutEffect : () => {\n};\nexport {\n useLayoutEffect2 as useLayoutEffect\n};\n//# sourceMappingURL=index.mjs.map\n","// src/use-controllable-state.tsx\nimport * as React from \"react\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nvar useInsertionEffect = React[\" useInsertionEffect \".trim().toString()] || useLayoutEffect;\nfunction useControllableState({\n prop,\n defaultProp,\n onChange = () => {\n },\n caller\n}) {\n const [uncontrolledProp, setUncontrolledProp, onChangeRef] = useUncontrolledState({\n defaultProp,\n onChange\n });\n const isControlled = prop !== void 0;\n const value = isControlled ? prop : uncontrolledProp;\n if (true) {\n const isControlledRef = React.useRef(prop !== void 0);\n React.useEffect(() => {\n const wasControlled = isControlledRef.current;\n if (wasControlled !== isControlled) {\n const from = wasControlled ? \"controlled\" : \"uncontrolled\";\n const to = isControlled ? \"controlled\" : \"uncontrolled\";\n console.warn(\n `${caller} is changing from ${from} to ${to}. Components should not switch from controlled to uncontrolled (or vice versa). Decide between using a controlled or uncontrolled value for the lifetime of the component.`\n );\n }\n isControlledRef.current = isControlled;\n }, [isControlled, caller]);\n }\n const setValue = React.useCallback(\n (nextValue) => {\n if (isControlled) {\n const value2 = isFunction(nextValue) ? nextValue(prop) : nextValue;\n if (value2 !== prop) {\n onChangeRef.current?.(value2);\n }\n } else {\n setUncontrolledProp(nextValue);\n }\n },\n [isControlled, prop, setUncontrolledProp, onChangeRef]\n );\n return [value, setValue];\n}\nfunction useUncontrolledState({\n defaultProp,\n onChange\n}) {\n const [value, setValue] = React.useState(defaultProp);\n const prevValueRef = React.useRef(value);\n const onChangeRef = React.useRef(onChange);\n useInsertionEffect(() => {\n onChangeRef.current = onChange;\n }, [onChange]);\n React.useEffect(() => {\n if (prevValueRef.current !== value) {\n onChangeRef.current?.(value);\n prevValueRef.current = value;\n }\n }, [value, prevValueRef]);\n return [value, setValue, onChangeRef];\n}\nfunction isFunction(value) {\n return typeof value === \"function\";\n}\n\n// src/use-controllable-state-reducer.tsx\nimport * as React2 from \"react\";\nimport { useEffectEvent } from \"@radix-ui/react-use-effect-event\";\nvar SYNC_STATE = Symbol(\"RADIX:SYNC_STATE\");\nfunction useControllableStateReducer(reducer, userArgs, initialArg, init) {\n const { prop: controlledState, defaultProp, onChange: onChangeProp, caller } = userArgs;\n const isControlled = controlledState !== void 0;\n const onChange = useEffectEvent(onChangeProp);\n if (true) {\n const isControlledRef = React2.useRef(controlledState !== void 0);\n React2.useEffect(() => {\n const wasControlled = isControlledRef.current;\n if (wasControlled !== isControlled) {\n const from = wasControlled ? \"controlled\" : \"uncontrolled\";\n const to = isControlled ? \"controlled\" : \"uncontrolled\";\n console.warn(\n `${caller} is changing from ${from} to ${to}. Components should not switch from controlled to uncontrolled (or vice versa). Decide between using a controlled or uncontrolled value for the lifetime of the component.`\n );\n }\n isControlledRef.current = isControlled;\n }, [isControlled, caller]);\n }\n const args = [{ ...initialArg, state: defaultProp }];\n if (init) {\n args.push(init);\n }\n const [internalState, dispatch] = React2.useReducer(\n (state2, action) => {\n if (action.type === SYNC_STATE) {\n return { ...state2, state: action.state };\n }\n const next = reducer(state2, action);\n if (isControlled && !Object.is(next.state, state2.state)) {\n onChange(next.state);\n }\n return next;\n },\n ...args\n );\n const uncontrolledState = internalState.state;\n const prevValueRef = React2.useRef(uncontrolledState);\n React2.useEffect(() => {\n if (prevValueRef.current !== uncontrolledState) {\n prevValueRef.current = uncontrolledState;\n if (!isControlled) {\n onChange(uncontrolledState);\n }\n }\n }, [onChange, uncontrolledState, prevValueRef, isControlled]);\n const state = React2.useMemo(() => {\n const isControlled2 = controlledState !== void 0;\n if (isControlled2) {\n return { ...internalState, state: controlledState };\n }\n return internalState;\n }, [internalState, controlledState]);\n React2.useEffect(() => {\n if (isControlled && !Object.is(controlledState, internalState.state)) {\n dispatch({ type: SYNC_STATE, state: controlledState });\n }\n }, [controlledState, internalState.state, isControlled]);\n return [state, dispatch];\n}\nexport {\n useControllableState,\n useControllableStateReducer\n};\n//# sourceMappingURL=index.mjs.map\n","// src/primitive.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NODES = [\n \"a\",\n \"button\",\n \"div\",\n \"form\",\n \"h2\",\n \"h3\",\n \"img\",\n \"input\",\n \"label\",\n \"li\",\n \"nav\",\n \"ol\",\n \"p\",\n \"select\",\n \"span\",\n \"svg\",\n \"ul\"\n];\nvar Primitive = NODES.reduce((primitive, node) => {\n const Slot = createSlot(`Primitive.${node}`);\n const Node = React.forwardRef((props, forwardedRef) => {\n const { asChild, ...primitiveProps } = props;\n const Comp = asChild ? Slot : node;\n if (typeof window !== \"undefined\") {\n window[Symbol.for(\"radix-ui\")] = true;\n }\n return /* @__PURE__ */ jsx(Comp, { ...primitiveProps, ref: forwardedRef });\n });\n Node.displayName = `Primitive.${node}`;\n return { ...primitive, [node]: Node };\n}, {});\nfunction dispatchDiscreteCustomEvent(target, event) {\n if (target) ReactDOM.flushSync(() => target.dispatchEvent(event));\n}\nvar Root = Primitive;\nexport {\n Primitive,\n Root,\n dispatchDiscreteCustomEvent\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/presence.tsx\nimport * as React2 from \"react\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\n\n// src/use-state-machine.tsx\nimport * as React from \"react\";\nfunction useStateMachine(initialState, machine) {\n return React.useReducer((state, event) => {\n const nextState = machine[state][event];\n return nextState ?? state;\n }, initialState);\n}\n\n// src/presence.tsx\nvar Presence = (props) => {\n const { present, children } = props;\n const presence = usePresence(present);\n const child = typeof children === \"function\" ? children({ present: presence.isPresent }) : React2.Children.only(children);\n const ref = useComposedRefs(presence.ref, getElementRef(child));\n const forceMount = typeof children === \"function\";\n return forceMount || presence.isPresent ? React2.cloneElement(child, { ref }) : null;\n};\nPresence.displayName = \"Presence\";\nfunction usePresence(present) {\n const [node, setNode] = React2.useState();\n const stylesRef = React2.useRef(null);\n const prevPresentRef = React2.useRef(present);\n const prevAnimationNameRef = React2.useRef(\"none\");\n const initialState = present ? \"mounted\" : \"unmounted\";\n const [state, send] = useStateMachine(initialState, {\n mounted: {\n UNMOUNT: \"unmounted\",\n ANIMATION_OUT: \"unmountSuspended\"\n },\n unmountSuspended: {\n MOUNT: \"mounted\",\n ANIMATION_END: \"unmounted\"\n },\n unmounted: {\n MOUNT: \"mounted\"\n }\n });\n React2.useEffect(() => {\n const currentAnimationName = getAnimationName(stylesRef.current);\n prevAnimationNameRef.current = state === \"mounted\" ? currentAnimationName : \"none\";\n }, [state]);\n useLayoutEffect(() => {\n const styles = stylesRef.current;\n const wasPresent = prevPresentRef.current;\n const hasPresentChanged = wasPresent !== present;\n if (hasPresentChanged) {\n const prevAnimationName = prevAnimationNameRef.current;\n const currentAnimationName = getAnimationName(styles);\n if (present) {\n send(\"MOUNT\");\n } else if (currentAnimationName === \"none\" || styles?.display === \"none\") {\n send(\"UNMOUNT\");\n } else {\n const isAnimating = prevAnimationName !== currentAnimationName;\n if (wasPresent && isAnimating) {\n send(\"ANIMATION_OUT\");\n } else {\n send(\"UNMOUNT\");\n }\n }\n prevPresentRef.current = present;\n }\n }, [present, send]);\n useLayoutEffect(() => {\n if (node) {\n let timeoutId;\n const ownerWindow = node.ownerDocument.defaultView ?? window;\n const handleAnimationEnd = (event) => {\n const currentAnimationName = getAnimationName(stylesRef.current);\n const isCurrentAnimation = currentAnimationName.includes(CSS.escape(event.animationName));\n if (event.target === node && isCurrentAnimation) {\n send(\"ANIMATION_END\");\n if (!prevPresentRef.current) {\n const currentFillMode = node.style.animationFillMode;\n node.style.animationFillMode = \"forwards\";\n timeoutId = ownerWindow.setTimeout(() => {\n if (node.style.animationFillMode === \"forwards\") {\n node.style.animationFillMode = currentFillMode;\n }\n });\n }\n }\n };\n const handleAnimationStart = (event) => {\n if (event.target === node) {\n prevAnimationNameRef.current = getAnimationName(stylesRef.current);\n }\n };\n node.addEventListener(\"animationstart\", handleAnimationStart);\n node.addEventListener(\"animationcancel\", handleAnimationEnd);\n node.addEventListener(\"animationend\", handleAnimationEnd);\n return () => {\n ownerWindow.clearTimeout(timeoutId);\n node.removeEventListener(\"animationstart\", handleAnimationStart);\n node.removeEventListener(\"animationcancel\", handleAnimationEnd);\n node.removeEventListener(\"animationend\", handleAnimationEnd);\n };\n } else {\n send(\"ANIMATION_END\");\n }\n }, [node, send]);\n return {\n isPresent: [\"mounted\", \"unmountSuspended\"].includes(state),\n ref: React2.useCallback((node2) => {\n stylesRef.current = node2 ? getComputedStyle(node2) : null;\n setNode(node2);\n }, [])\n };\n}\nfunction getAnimationName(styles) {\n return styles?.animationName || \"none\";\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nvar Root = Presence;\nexport {\n Presence,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/id/src/id.tsx\nimport * as React from \"react\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nvar useReactId = React[\" useId \".trim().toString()] || (() => void 0);\nvar count = 0;\nfunction useId(deterministicId) {\n const [id, setId] = React.useState(useReactId());\n useLayoutEffect(() => {\n if (!deterministicId) setId((reactId) => reactId ?? String(count++));\n }, [deterministicId]);\n return deterministicId || (id ? `radix-${id}` : \"\");\n}\nexport {\n useId\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/collapsible.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { useId } from \"@radix-ui/react-id\";\nimport { jsx } from \"react/jsx-runtime\";\nvar COLLAPSIBLE_NAME = \"Collapsible\";\nvar [createCollapsibleContext, createCollapsibleScope] = createContextScope(COLLAPSIBLE_NAME);\nvar [CollapsibleProvider, useCollapsibleContext] = createCollapsibleContext(COLLAPSIBLE_NAME);\nvar Collapsible = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeCollapsible,\n open: openProp,\n defaultOpen,\n disabled,\n onOpenChange,\n ...collapsibleProps\n } = props;\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: onOpenChange,\n caller: COLLAPSIBLE_NAME\n });\n return /* @__PURE__ */ jsx(\n CollapsibleProvider,\n {\n scope: __scopeCollapsible,\n disabled,\n contentId: useId(),\n open,\n onOpenToggle: React.useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen]),\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-state\": getState(open),\n \"data-disabled\": disabled ? \"\" : void 0,\n ...collapsibleProps,\n ref: forwardedRef\n }\n )\n }\n );\n }\n);\nCollapsible.displayName = COLLAPSIBLE_NAME;\nvar TRIGGER_NAME = \"CollapsibleTrigger\";\nvar CollapsibleTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeCollapsible, ...triggerProps } = props;\n const context = useCollapsibleContext(TRIGGER_NAME, __scopeCollapsible);\n return /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n \"aria-controls\": context.contentId,\n \"aria-expanded\": context.open || false,\n \"data-state\": getState(context.open),\n \"data-disabled\": context.disabled ? \"\" : void 0,\n disabled: context.disabled,\n ...triggerProps,\n ref: forwardedRef,\n onClick: composeEventHandlers(props.onClick, context.onOpenToggle)\n }\n );\n }\n);\nCollapsibleTrigger.displayName = TRIGGER_NAME;\nvar CONTENT_NAME = \"CollapsibleContent\";\nvar CollapsibleContent = React.forwardRef(\n (props, forwardedRef) => {\n const { forceMount, ...contentProps } = props;\n const context = useCollapsibleContext(CONTENT_NAME, props.__scopeCollapsible);\n return /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: ({ present }) => /* @__PURE__ */ jsx(CollapsibleContentImpl, { ...contentProps, ref: forwardedRef, present }) });\n }\n);\nCollapsibleContent.displayName = CONTENT_NAME;\nvar CollapsibleContentImpl = React.forwardRef((props, forwardedRef) => {\n const { __scopeCollapsible, present, children, ...contentProps } = props;\n const context = useCollapsibleContext(CONTENT_NAME, __scopeCollapsible);\n const [isPresent, setIsPresent] = React.useState(present);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const heightRef = React.useRef(0);\n const height = heightRef.current;\n const widthRef = React.useRef(0);\n const width = widthRef.current;\n const isOpen = context.open || isPresent;\n const isMountAnimationPreventedRef = React.useRef(isOpen);\n const originalStylesRef = React.useRef(void 0);\n React.useEffect(() => {\n const rAF = requestAnimationFrame(() => isMountAnimationPreventedRef.current = false);\n return () => cancelAnimationFrame(rAF);\n }, []);\n useLayoutEffect(() => {\n const node = ref.current;\n if (node) {\n originalStylesRef.current = originalStylesRef.current || {\n transitionDuration: node.style.transitionDuration,\n animationName: node.style.animationName\n };\n node.style.transitionDuration = \"0s\";\n node.style.animationName = \"none\";\n const rect = node.getBoundingClientRect();\n heightRef.current = rect.height;\n widthRef.current = rect.width;\n if (!isMountAnimationPreventedRef.current) {\n node.style.transitionDuration = originalStylesRef.current.transitionDuration;\n node.style.animationName = originalStylesRef.current.animationName;\n }\n setIsPresent(present);\n }\n }, [context.open, present]);\n return /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-state\": getState(context.open),\n \"data-disabled\": context.disabled ? \"\" : void 0,\n id: context.contentId,\n hidden: !isOpen,\n ...contentProps,\n ref: composedRefs,\n style: {\n [`--radix-collapsible-content-height`]: height ? `${height}px` : void 0,\n [`--radix-collapsible-content-width`]: width ? `${width}px` : void 0,\n ...props.style\n },\n children: isOpen && children\n }\n );\n});\nfunction getState(open) {\n return open ? \"open\" : \"closed\";\n}\nvar Root = Collapsible;\nvar Trigger = CollapsibleTrigger;\nvar Content = CollapsibleContent;\nexport {\n Collapsible,\n CollapsibleContent,\n CollapsibleTrigger,\n Content,\n Root,\n Trigger,\n createCollapsibleScope\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/direction/src/direction.tsx\nimport * as React from \"react\";\nimport { jsx } from \"react/jsx-runtime\";\nvar DirectionContext = React.createContext(void 0);\nvar DirectionProvider = (props) => {\n const { dir, children } = props;\n return /* @__PURE__ */ jsx(DirectionContext.Provider, { value: dir, children });\n};\nfunction useDirection(localDir) {\n const globalDir = React.useContext(DirectionContext);\n return localDir || globalDir || \"ltr\";\n}\nvar Provider = DirectionProvider;\nexport {\n DirectionProvider,\n Provider,\n useDirection\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/accordion.tsx\nimport React from \"react\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { createCollection } from \"@radix-ui/react-collection\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport * as CollapsiblePrimitive from \"@radix-ui/react-collapsible\";\nimport { createCollapsibleScope } from \"@radix-ui/react-collapsible\";\nimport { useId } from \"@radix-ui/react-id\";\nimport { useDirection } from \"@radix-ui/react-direction\";\nimport { jsx } from \"react/jsx-runtime\";\nvar ACCORDION_NAME = \"Accordion\";\nvar ACCORDION_KEYS = [\"Home\", \"End\", \"ArrowDown\", \"ArrowUp\", \"ArrowLeft\", \"ArrowRight\"];\nvar [Collection, useCollection, createCollectionScope] = createCollection(ACCORDION_NAME);\nvar [createAccordionContext, createAccordionScope] = createContextScope(ACCORDION_NAME, [\n createCollectionScope,\n createCollapsibleScope\n]);\nvar useCollapsibleScope = createCollapsibleScope();\nvar Accordion = React.forwardRef(\n (props, forwardedRef) => {\n const { type, ...accordionProps } = props;\n const singleProps = accordionProps;\n const multipleProps = accordionProps;\n return /* @__PURE__ */ jsx(Collection.Provider, { scope: props.__scopeAccordion, children: type === \"multiple\" ? /* @__PURE__ */ jsx(AccordionImplMultiple, { ...multipleProps, ref: forwardedRef }) : /* @__PURE__ */ jsx(AccordionImplSingle, { ...singleProps, ref: forwardedRef }) });\n }\n);\nAccordion.displayName = ACCORDION_NAME;\nvar [AccordionValueProvider, useAccordionValueContext] = createAccordionContext(ACCORDION_NAME);\nvar [AccordionCollapsibleProvider, useAccordionCollapsibleContext] = createAccordionContext(\n ACCORDION_NAME,\n { collapsible: false }\n);\nvar AccordionImplSingle = React.forwardRef(\n (props, forwardedRef) => {\n const {\n value: valueProp,\n defaultValue,\n onValueChange = () => {\n },\n collapsible = false,\n ...accordionSingleProps\n } = props;\n const [value, setValue] = useControllableState({\n prop: valueProp,\n defaultProp: defaultValue ?? \"\",\n onChange: onValueChange,\n caller: ACCORDION_NAME\n });\n return /* @__PURE__ */ jsx(\n AccordionValueProvider,\n {\n scope: props.__scopeAccordion,\n value: React.useMemo(() => value ? [value] : [], [value]),\n onItemOpen: setValue,\n onItemClose: React.useCallback(() => collapsible && setValue(\"\"), [collapsible, setValue]),\n children: /* @__PURE__ */ jsx(AccordionCollapsibleProvider, { scope: props.__scopeAccordion, collapsible, children: /* @__PURE__ */ jsx(AccordionImpl, { ...accordionSingleProps, ref: forwardedRef }) })\n }\n );\n }\n);\nvar AccordionImplMultiple = React.forwardRef((props, forwardedRef) => {\n const {\n value: valueProp,\n defaultValue,\n onValueChange = () => {\n },\n ...accordionMultipleProps\n } = props;\n const [value, setValue] = useControllableState({\n prop: valueProp,\n defaultProp: defaultValue ?? [],\n onChange: onValueChange,\n caller: ACCORDION_NAME\n });\n const handleItemOpen = React.useCallback(\n (itemValue) => setValue((prevValue = []) => [...prevValue, itemValue]),\n [setValue]\n );\n const handleItemClose = React.useCallback(\n (itemValue) => setValue((prevValue = []) => prevValue.filter((value2) => value2 !== itemValue)),\n [setValue]\n );\n return /* @__PURE__ */ jsx(\n AccordionValueProvider,\n {\n scope: props.__scopeAccordion,\n value,\n onItemOpen: handleItemOpen,\n onItemClose: handleItemClose,\n children: /* @__PURE__ */ jsx(AccordionCollapsibleProvider, { scope: props.__scopeAccordion, collapsible: true, children: /* @__PURE__ */ jsx(AccordionImpl, { ...accordionMultipleProps, ref: forwardedRef }) })\n }\n );\n});\nvar [AccordionImplProvider, useAccordionContext] = createAccordionContext(ACCORDION_NAME);\nvar AccordionImpl = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAccordion, disabled, dir, orientation = \"vertical\", ...accordionProps } = props;\n const accordionRef = React.useRef(null);\n const composedRefs = useComposedRefs(accordionRef, forwardedRef);\n const getItems = useCollection(__scopeAccordion);\n const direction = useDirection(dir);\n const isDirectionLTR = direction === \"ltr\";\n const handleKeyDown = composeEventHandlers(props.onKeyDown, (event) => {\n if (!ACCORDION_KEYS.includes(event.key)) return;\n const target = event.target;\n const triggerCollection = getItems().filter((item) => !item.ref.current?.disabled);\n const triggerIndex = triggerCollection.findIndex((item) => item.ref.current === target);\n const triggerCount = triggerCollection.length;\n if (triggerIndex === -1) return;\n event.preventDefault();\n let nextIndex = triggerIndex;\n const homeIndex = 0;\n const endIndex = triggerCount - 1;\n const moveNext = () => {\n nextIndex = triggerIndex + 1;\n if (nextIndex > endIndex) {\n nextIndex = homeIndex;\n }\n };\n const movePrev = () => {\n nextIndex = triggerIndex - 1;\n if (nextIndex < homeIndex) {\n nextIndex = endIndex;\n }\n };\n switch (event.key) {\n case \"Home\":\n nextIndex = homeIndex;\n break;\n case \"End\":\n nextIndex = endIndex;\n break;\n case \"ArrowRight\":\n if (orientation === \"horizontal\") {\n if (isDirectionLTR) {\n moveNext();\n } else {\n movePrev();\n }\n }\n break;\n case \"ArrowDown\":\n if (orientation === \"vertical\") {\n moveNext();\n }\n break;\n case \"ArrowLeft\":\n if (orientation === \"horizontal\") {\n if (isDirectionLTR) {\n movePrev();\n } else {\n moveNext();\n }\n }\n break;\n case \"ArrowUp\":\n if (orientation === \"vertical\") {\n movePrev();\n }\n break;\n }\n const clampedIndex = nextIndex % triggerCount;\n triggerCollection[clampedIndex].ref.current?.focus();\n });\n return /* @__PURE__ */ jsx(\n AccordionImplProvider,\n {\n scope: __scopeAccordion,\n disabled,\n direction: dir,\n orientation,\n children: /* @__PURE__ */ jsx(Collection.Slot, { scope: __scopeAccordion, children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n ...accordionProps,\n \"data-orientation\": orientation,\n ref: composedRefs,\n onKeyDown: disabled ? void 0 : handleKeyDown\n }\n ) })\n }\n );\n }\n);\nvar ITEM_NAME = \"AccordionItem\";\nvar [AccordionItemProvider, useAccordionItemContext] = createAccordionContext(ITEM_NAME);\nvar AccordionItem = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAccordion, value, ...accordionItemProps } = props;\n const accordionContext = useAccordionContext(ITEM_NAME, __scopeAccordion);\n const valueContext = useAccordionValueContext(ITEM_NAME, __scopeAccordion);\n const collapsibleScope = useCollapsibleScope(__scopeAccordion);\n const triggerId = useId();\n const open = value && valueContext.value.includes(value) || false;\n const disabled = accordionContext.disabled || props.disabled;\n return /* @__PURE__ */ jsx(\n AccordionItemProvider,\n {\n scope: __scopeAccordion,\n open,\n disabled,\n triggerId,\n children: /* @__PURE__ */ jsx(\n CollapsiblePrimitive.Root,\n {\n \"data-orientation\": accordionContext.orientation,\n \"data-state\": getState(open),\n ...collapsibleScope,\n ...accordionItemProps,\n ref: forwardedRef,\n disabled,\n open,\n onOpenChange: (open2) => {\n if (open2) {\n valueContext.onItemOpen(value);\n } else {\n valueContext.onItemClose(value);\n }\n }\n }\n )\n }\n );\n }\n);\nAccordionItem.displayName = ITEM_NAME;\nvar HEADER_NAME = \"AccordionHeader\";\nvar AccordionHeader = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAccordion, ...headerProps } = props;\n const accordionContext = useAccordionContext(ACCORDION_NAME, __scopeAccordion);\n const itemContext = useAccordionItemContext(HEADER_NAME, __scopeAccordion);\n return /* @__PURE__ */ jsx(\n Primitive.h3,\n {\n \"data-orientation\": accordionContext.orientation,\n \"data-state\": getState(itemContext.open),\n \"data-disabled\": itemContext.disabled ? \"\" : void 0,\n ...headerProps,\n ref: forwardedRef\n }\n );\n }\n);\nAccordionHeader.displayName = HEADER_NAME;\nvar TRIGGER_NAME = \"AccordionTrigger\";\nvar AccordionTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAccordion, ...triggerProps } = props;\n const accordionContext = useAccordionContext(ACCORDION_NAME, __scopeAccordion);\n const itemContext = useAccordionItemContext(TRIGGER_NAME, __scopeAccordion);\n const collapsibleContext = useAccordionCollapsibleContext(TRIGGER_NAME, __scopeAccordion);\n const collapsibleScope = useCollapsibleScope(__scopeAccordion);\n return /* @__PURE__ */ jsx(Collection.ItemSlot, { scope: __scopeAccordion, children: /* @__PURE__ */ jsx(\n CollapsiblePrimitive.Trigger,\n {\n \"aria-disabled\": itemContext.open && !collapsibleContext.collapsible || void 0,\n \"data-orientation\": accordionContext.orientation,\n id: itemContext.triggerId,\n ...collapsibleScope,\n ...triggerProps,\n ref: forwardedRef\n }\n ) });\n }\n);\nAccordionTrigger.displayName = TRIGGER_NAME;\nvar CONTENT_NAME = \"AccordionContent\";\nvar AccordionContent = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAccordion, ...contentProps } = props;\n const accordionContext = useAccordionContext(ACCORDION_NAME, __scopeAccordion);\n const itemContext = useAccordionItemContext(CONTENT_NAME, __scopeAccordion);\n const collapsibleScope = useCollapsibleScope(__scopeAccordion);\n return /* @__PURE__ */ jsx(\n CollapsiblePrimitive.Content,\n {\n role: \"region\",\n \"aria-labelledby\": itemContext.triggerId,\n \"data-orientation\": accordionContext.orientation,\n ...collapsibleScope,\n ...contentProps,\n ref: forwardedRef,\n style: {\n [\"--radix-accordion-content-height\"]: \"var(--radix-collapsible-content-height)\",\n [\"--radix-accordion-content-width\"]: \"var(--radix-collapsible-content-width)\",\n ...props.style\n }\n }\n );\n }\n);\nAccordionContent.displayName = CONTENT_NAME;\nfunction getState(open) {\n return open ? \"open\" : \"closed\";\n}\nvar Root2 = Accordion;\nvar Item = AccordionItem;\nvar Header = AccordionHeader;\nvar Trigger2 = AccordionTrigger;\nvar Content2 = AccordionContent;\nexport {\n Accordion,\n AccordionContent,\n AccordionHeader,\n AccordionItem,\n AccordionTrigger,\n Content2 as Content,\n Header,\n Item,\n Root2 as Root,\n Trigger2 as Trigger,\n createAccordionScope\n};\n//# sourceMappingURL=index.mjs.map\n","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","import * as AccordionPrimitive from '@radix-ui/react-accordion';\nimport { clsx } from 'clsx';\nimport type { ComponentPropsWithoutRef } from 'react';\n\nimport { useAccordionContext } from '@/components/accordion';\n\nexport type AccordionItemProps = ComponentPropsWithoutRef<typeof AccordionPrimitive.Item>;\n\nexport function AccordionItem({ children, className, ...props }: AccordionItemProps) {\n const { colorScheme } = useAccordionContext();\n\n return (\n <AccordionPrimitive.Item\n className={clsx(\n 'focus:outline-2 has-[:focus-visible]:ring-2 has-[:focus-visible]:ring-[var(--accordion-focus,hsl(var(--primary)))] has-[:focus-visible]:ring-offset-4',\n {\n light: 'ring-offset-[var(--acordion-light-offset,hsl(var(--background)))]',\n dark: 'ring-offset-[var(--acordion-dark-offset,hsl(var(--foreground)))]',\n }[colorScheme],\n className,\n )}\n data-slot=\"accordion-item\"\n {...props}\n >\n {children}\n </AccordionPrimitive.Item>\n );\n}\n","import * as AccordionPrimitive from '@radix-ui/react-accordion';\nimport type { ComponentProps } from 'react';\n\nexport type AccordionRootProps = ComponentProps<typeof AccordionPrimitive.Root>;\n\nexport function AccordionRoot({ ...props }: AccordionRootProps) {\n return <AccordionPrimitive.Root data-slot=\"accordion-root\" {...props} />;\n}\n","import * as AccordionPrimitive from '@radix-ui/react-accordion';\nimport { clsx } from 'clsx';\nimport { useEffect, useState } from 'react';\nimport type { ComponentProps } from 'react';\n\nimport { useAccordionContext } from '@/components/accordion';\n\nexport type AccordionContentProps = ComponentProps<typeof AccordionPrimitive.Content>;\n\nexport function AccordionContent({ children, ...props }: AccordionContentProps) {\n const { colorScheme } = useAccordionContext();\n\n const [isMounted, setIsMounted] = useState(false);\n\n useEffect(() => {\n setIsMounted(true);\n }, []);\n\n return (\n <AccordionPrimitive.Content\n className={clsx(\n 'overflow-hidden',\n // We need to delay the animation until the component is mounted to avoid the animation from being triggered when the component is first rendered.\n isMounted && 'data-[state=closed]:animate-collapse data-[state=open]:animate-expand',\n )}\n {...props}\n >\n <div\n className={clsx(\n 'py-3 text-base font-[var(--accordion-content-font-family,var(--font-family-body))] font-light leading-normal',\n {\n light: 'text-[var(--accordion-light-content-text,hsl(var(--foreground)))]',\n dark: 'text-[var(--accordion-dark-content-text,hsl(var(--background)))]',\n }[colorScheme],\n )}\n >\n {children}\n </div>\n </AccordionPrimitive.Content>\n );\n}\n","import * as AccordionPrimitive from '@radix-ui/react-accordion';\nimport { clsx } from 'clsx';\nimport type { ComponentProps } from 'react';\n\nimport { useAccordionContext } from '@/components/accordion';\n\nexport type AccordionTriggerProps = ComponentProps<typeof AccordionPrimitive.Trigger>;\n\nexport function AccordionTrigger({ children, ...props }: AccordionTriggerProps) {\n const { colorScheme } = useAccordionContext();\n\n return (\n <AccordionPrimitive.Header>\n <AccordionPrimitive.Trigger\n className=\"group flex w-full cursor-pointer items-start gap-8 border-none py-3 text-start focus:outline-none @md:py-4\"\n data-slot=\"accordion-trigger\"\n {...props}\n >\n <div\n className={clsx(\n 'flex-1 select-none text-sm font-[var(--accordion-title-font-family,var(--font-family-mono))] font-normal uppercase transition-colors duration-300 ease-out',\n {\n light:\n 'text-[var(--accordion-light-title-text,hsl(var(--contrast-400)))] group-hover:text-[var(--accordion-light-title-text-hover,hsl(var(--foreground)))]',\n dark: 'text-[var(--accordion-dark-title-text,hsl(var(--contrast-200)))] group-hover:text-[var(--accordion-dark-title-text-hover,hsl(var(--background)))]',\n }[colorScheme],\n )}\n >\n {children}\n </div>\n <svg\n className={clsx(\n 'mt-1 shrink-0 [&>line]:origin-center [&>line]:transition [&>line]:duration-300 [&>line]:ease-out',\n {\n light:\n 'stroke-[var(--accordion-light-title-icon,hsl(var(--contrast-500)))] group-hover:stroke-[var(--accordion-light-title-icon-hover,hsl(var(--foreground)))]',\n dark: 'stroke-[var(--accordion-dark-title-icon,hsl(var(--contrast-200)))] group-hover:stroke-[var(--accordion-dark-title-icon-hover,hsl(var(--background)))]',\n }[colorScheme],\n )}\n data-slot=\"accordion-chevron\"\n viewBox=\"0 0 10 10\"\n width={16}\n >\n {/* Left Line of Chevron */}\n <line\n className=\"group-data-[state=open]:-translate-y-[3px] group-data-[state=open]:-rotate-90\"\n strokeLinecap=\"round\"\n x1={2}\n x2={5}\n y1={2}\n y2={5}\n />\n {/* Right Line of Chevron */}\n <line\n className=\"group-data-[state=open]:-translate-y-[3px] group-data-[state=open]:rotate-90\"\n strokeLinecap=\"round\"\n x1={8}\n x2={5}\n y1={2}\n y2={5}\n />\n </svg>\n </AccordionPrimitive.Trigger>\n </AccordionPrimitive.Header>\n );\n}\n","'use client';\n\nimport { createContext, useContext } from 'react';\nimport type { ReactNode } from 'react';\n\ninterface AccordionContext {\n colorScheme: 'light' | 'dark';\n}\n\nexport const AccordionContext = createContext<AccordionContext | undefined>(undefined);\n\nexport interface AccordionProviderProps {\n children: ReactNode;\n colorScheme?: 'light' | 'dark';\n}\n\nexport function AccordionProvider({ children, colorScheme = 'light' }: AccordionProviderProps) {\n return <AccordionContext value={{ colorScheme }}>{children}</AccordionContext>;\n}\n\nexport function useAccordionContext() {\n const context = useContext(AccordionContext);\n\n if (context === undefined) {\n throw new Error('useAccordionContext must be used within an AccordionProvider');\n }\n\n return context;\n}\n"],"names":["Accordion","colorScheme","items","props","jsx","AccordionPrimitive.Provider","AccordionPrimitive.Root","item","index","jsxs","AccordionPrimitive.Item","AccordionPrimitive.Trigger","AccordionPrimitive.Content","createContextScope","scopeName","createContextScopeDeps","defaultContexts","createContext3","rootComponentName","defaultContext","BaseContext","React","Provider","scope","children","context","Context","value","useContext2","consumerName","createScope","scopeContexts","contexts","composeContextScopes","scopes","baseScope","scopeHooks","createScope2","overrideScopes","nextScopes","nextScopes2","useScope","currentScope","setRef","ref","composeRefs","refs","node","hasCleanup","cleanups","cleanup","i","useComposedRefs","createSlot","ownerName","SlotClone","createSlotClone","Slot2","forwardedRef","slotProps","childrenArray","slottable","isSlottable","newElement","newChildren","child","childrenRef","getElementRef","props2","mergeProps","SLOTTABLE_IDENTIFIER","childProps","overrideProps","propName","slotPropValue","childPropValue","args","result","element","getter","mayWarn","createCollection","name","PROVIDER_NAME","createCollectionContext","createCollectionScope","CollectionProviderImpl","useCollectionContext","CollectionProvider","itemMap","COLLECTION_SLOT_NAME","CollectionSlotImpl","CollectionSlot","composedRefs","ITEM_SLOT_NAME","ITEM_DATA_ATTR","CollectionItemSlotImpl","CollectionItemSlot","itemData","useCollection","collectionNode","orderedNodes","a","b","composeEventHandlers","originalEventHandler","ourEventHandler","checkForDefaultPrevented","event","useLayoutEffect2","useInsertionEffect","useLayoutEffect","useControllableState","prop","defaultProp","onChange","caller","uncontrolledProp","setUncontrolledProp","onChangeRef","useUncontrolledState","isControlled","isControlledRef","wasControlled","setValue","nextValue","value2","isFunction","prevValueRef","NODES","Primitive","primitive","Slot","Node","asChild","primitiveProps","Comp","useStateMachine","initialState","machine","state","Presence","present","presence","usePresence","React2","setNode","stylesRef","prevPresentRef","prevAnimationNameRef","send","currentAnimationName","getAnimationName","styles","wasPresent","prevAnimationName","timeoutId","ownerWindow","handleAnimationEnd","isCurrentAnimation","currentFillMode","handleAnimationStart","node2","useReactId","count","useId","deterministicId","id","setId","reactId","COLLAPSIBLE_NAME","createCollapsibleContext","createCollapsibleScope","CollapsibleProvider","useCollapsibleContext","Collapsible","__scopeCollapsible","openProp","defaultOpen","disabled","onOpenChange","collapsibleProps","open","setOpen","prevOpen","getState","TRIGGER_NAME","CollapsibleTrigger","triggerProps","CONTENT_NAME","CollapsibleContent","forceMount","contentProps","CollapsibleContentImpl","isPresent","setIsPresent","heightRef","height","widthRef","width","isOpen","isMountAnimationPreventedRef","originalStylesRef","rAF","rect","Root","Trigger","Content","DirectionContext","useDirection","localDir","globalDir","ACCORDION_NAME","ACCORDION_KEYS","Collection","createAccordionContext","useCollapsibleScope","type","accordionProps","singleProps","multipleProps","AccordionImplMultiple","AccordionImplSingle","AccordionValueProvider","useAccordionValueContext","AccordionCollapsibleProvider","useAccordionCollapsibleContext","valueProp","defaultValue","onValueChange","collapsible","accordionSingleProps","AccordionImpl","accordionMultipleProps","handleItemOpen","itemValue","prevValue","handleItemClose","AccordionImplProvider","useAccordionContext","__scopeAccordion","dir","orientation","accordionRef","getItems","isDirectionLTR","handleKeyDown","target","triggerCollection","triggerIndex","triggerCount","nextIndex","homeIndex","endIndex","moveNext","movePrev","clampedIndex","ITEM_NAME","AccordionItemProvider","useAccordionItemContext","AccordionItem","accordionItemProps","accordionContext","valueContext","collapsibleScope","triggerId","CollapsiblePrimitive.Root","open2","HEADER_NAME","AccordionHeader","headerProps","itemContext","AccordionTrigger","collapsibleContext","CollapsiblePrimitive.Trigger","AccordionContent","CollapsiblePrimitive.Content","Root2","Item","Header","Trigger2","Content2","r","f","o","clsx","className","AccordionRoot","isMounted","setIsMounted","useState","useEffect","AccordionPrimitive.Header","AccordionContext","createContext","AccordionProvider","useContext"],"mappings":"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","x_google_ignoreList":[1,2,3,4,5,6,7,8,9,10,11,12,13,14]}
@@ -0,0 +1,29 @@
1
+ /* Commerce Elements CSS Variables */
2
+ :root {
3
+ --primary: 96 100% 68%;
4
+ --accent: 96 100% 88%;
5
+ --background: 0 0% 100%;
6
+ --foreground: 0 0% 7%;
7
+ --success: 116 78% 65%;
8
+ --error: 0 100% 60%;
9
+ --warning: 40 100% 60%;
10
+ --info: 220 70% 45%;
11
+ --contrast-100: 0 0% 93%;
12
+ --contrast-200: 0 0% 82%;
13
+ --contrast-300: 0 0% 70%;
14
+ --contrast-400: 0 0% 54%;
15
+ --contrast-500: 0 0% 34%;
16
+ --font-variation-settings-body: 'slnt' 0;
17
+ --font-variation-settings-heading: 'slnt' 0;
18
+ --font-size-xs: 0.75rem;
19
+ --font-size-sm: 0.875rem;
20
+ --font-size-base: 1rem;
21
+ --font-size-lg: 1.125rem;
22
+ --font-size-xl: 1.25rem;
23
+ --font-size-2xl: 1.5rem;
24
+ --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
25
+ --shadow-base: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
26
+ --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
27
+ --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
28
+ --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
29
+ }
package/package.json CHANGED
@@ -1,12 +1,138 @@
1
1
  {
2
2
  "name": "commerce-toolkit",
3
- "version": "0.0.0",
4
- "main": "index.js",
5
- "scripts": {
6
- "test": "echo \"Error: no test specified\" && exit 1"
3
+ "version": "0.0.2",
4
+ "description": "A collection of modern, accessible commerce UI components",
5
+ "type": "module",
6
+ "main": "./dist/index.cjs",
7
+ "module": "./dist/index.js",
8
+ "types": "./dist/index.d.ts",
9
+ "exports": {
10
+ ".": {
11
+ "import": {
12
+ "types": "./dist/index.d.ts",
13
+ "default": "./dist/index.js"
14
+ },
15
+ "require": {
16
+ "types": "./dist/index.d.ts",
17
+ "default": "./dist/index.cjs"
18
+ }
19
+ },
20
+ "./styles": "./dist/styles.css",
21
+ "./tailwind": "./tailwind.preset.js"
7
22
  },
8
- "keywords": [],
23
+ "files": [
24
+ "dist",
25
+ "tailwind.preset.js"
26
+ ],
27
+ "keywords": [
28
+ "react",
29
+ "components",
30
+ "ui",
31
+ "commerce",
32
+ "button",
33
+ "tailwind"
34
+ ],
9
35
  "author": "",
10
- "license": "ISC",
11
- "description": ""
12
- }
36
+ "license": "MIT",
37
+ "repository": {
38
+ "type": "git",
39
+ "url": "git+https://github.com/makeswift/commerce-elements.git"
40
+ },
41
+ "dependencies": {
42
+ "@radix-ui/react-accordion": "^1.2.12",
43
+ "@radix-ui/react-checkbox": "^1.3.3",
44
+ "@radix-ui/react-dialog": "^1.1.15",
45
+ "@radix-ui/react-dropdown-menu": "^2.1.16",
46
+ "@radix-ui/react-label": "^2.1.7",
47
+ "@radix-ui/react-navigation-menu": "^1.2.14",
48
+ "@radix-ui/react-popover": "^1.1.15",
49
+ "@radix-ui/react-portal": "^1.1.9",
50
+ "@radix-ui/react-scroll-area": "^1.2.10",
51
+ "@radix-ui/react-tabs": "^1.1.13",
52
+ "@radix-ui/react-toggle": "^1.1.10",
53
+ "clsx": "^2.1.1",
54
+ "embla-carousel-react": "^8.6.0",
55
+ "lucide-react": "^0.545.0",
56
+ "nuqs": "^2.7.2",
57
+ "react-day-picker": "^9.11.1",
58
+ "sonner": "^2.0.7"
59
+ },
60
+ "peerDependencies": {
61
+ "@tailwindcss/container-queries": "^0.1.0",
62
+ "@tailwindcss/typography": "^0.5.0",
63
+ "react": "^18.0.0 || ^19.0.0",
64
+ "react-dom": "^18.0.0 || ^19.0.0",
65
+ "tailwindcss": "^3.0.0",
66
+ "tailwindcss-animate": "^1.0.0"
67
+ },
68
+ "peerDependenciesMeta": {
69
+ "@tailwindcss/container-queries": {
70
+ "optional": true
71
+ },
72
+ "@tailwindcss/typography": {
73
+ "optional": true
74
+ },
75
+ "tailwindcss-animate": {
76
+ "optional": true
77
+ }
78
+ },
79
+ "devDependencies": {
80
+ "@changesets/cli": "^2.29.7",
81
+ "@chromatic-com/storybook": "^4.1.1",
82
+ "@eslint/js": "^9.36.0",
83
+ "@storybook/addon-a11y": "^9.1.10",
84
+ "@storybook/addon-docs": "^9.1.10",
85
+ "@storybook/addon-onboarding": "^9.1.10",
86
+ "@storybook/addon-vitest": "^9.1.10",
87
+ "@storybook/react-vite": "^9.1.10",
88
+ "@tailwindcss/container-queries": "^0.1.1",
89
+ "@tailwindcss/typography": "^0.5.19",
90
+ "@types/prop-types": "^15.7.15",
91
+ "@types/react": "^19.1.16",
92
+ "@types/react-dom": "^19.1.9",
93
+ "@typescript-eslint/eslint-plugin": "^8.46.1",
94
+ "@typescript-eslint/parser": "^8.46.1",
95
+ "@vitejs/plugin-react": "^5.0.4",
96
+ "@vitest/browser": "^3.2.4",
97
+ "@vitest/coverage-v8": "^3.2.4",
98
+ "autoprefixer": "^10.4.21",
99
+ "eslint": "^9.36.0",
100
+ "eslint-import-resolver-typescript": "^4.4.4",
101
+ "eslint-plugin-import": "^2.32.0",
102
+ "eslint-plugin-jsx-a11y": "^6.10.2",
103
+ "eslint-plugin-react": "^7.37.5",
104
+ "eslint-plugin-react-hooks": "^5.2.0",
105
+ "eslint-plugin-react-refresh": "^0.4.22",
106
+ "eslint-plugin-storybook": "^9.1.10",
107
+ "globals": "^16.4.0",
108
+ "playwright": "^1.56.0",
109
+ "postcss": "^8.5.6",
110
+ "prettier": "^3.6.2",
111
+ "prettier-plugin-tailwindcss": "^0.7.0",
112
+ "prop-types": "^15.8.1",
113
+ "react": "^19.1.1",
114
+ "react-dom": "^19.1.1",
115
+ "storybook": "^9.1.10",
116
+ "tailwindcss": "3",
117
+ "tailwindcss-animate": "^1.0.7",
118
+ "typescript": "^5.9.3",
119
+ "typescript-eslint": "^8",
120
+ "vite": "^7.1.7",
121
+ "vite-tsconfig-paths": "^5.1.4",
122
+ "vitest": "^3.2.4"
123
+ },
124
+ "scripts": {
125
+ "dev": "vite",
126
+ "build": "vite build",
127
+ "build:lib": "vite build --config vite.config.lib.js && tsc --project tsconfig.lib.json && cp src/styles.css dist/styles.css",
128
+ "lint": "eslint .",
129
+ "format": "prettier --write .",
130
+ "format:check": "prettier --check .",
131
+ "preview": "vite preview",
132
+ "story": "storybook dev -p 6006",
133
+ "build-story": "storybook build",
134
+ "changeset": "changeset",
135
+ "version": "changeset version",
136
+ "release": "changeset publish"
137
+ }
138
+ }