chiperos-ai-components-library 0.0.1 → 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.
- package/README.md +31 -17
- package/dist/chiperos-ai-components-library.cjs +59 -0
- package/dist/chiperos-ai-components-library.cjs.map +1 -0
- package/dist/chiperos-ai-components-library.js +11931 -0
- package/dist/chiperos-ai-components-library.js.map +1 -0
- package/dist/components/Input/Input.stories.d.ts +66 -0
- package/dist/components/Input/Input.test.d.ts +1 -0
- package/dist/components/Input/index.d.ts +94 -0
- package/dist/components/Select/Select.stories.d.ts +50 -0
- package/dist/components/Select/Select.test.d.ts +1 -0
- package/dist/components/Select/index.d.ts +36 -0
- package/dist/components/Table/Table.stories.d.ts +52 -0
- package/dist/components/Table/Table.test.d.ts +1 -0
- package/dist/components/Table/index.d.ts +64 -0
- package/dist/components/TableHeader/TableHeader.stories.d.ts +48 -0
- package/dist/components/TableHeader/TableHeader.test.d.ts +1 -0
- package/dist/components/TableHeader/index.d.ts +125 -0
- package/dist/components/index.d.ts +4 -0
- package/package.json +12 -10
- package/dist/chiper-components-library.cjs +0 -15
- package/dist/chiper-components-library.cjs.map +0 -1
- package/dist/chiper-components-library.js +0 -4836
- package/dist/chiper-components-library.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chiper-components-library.cjs","sources":["../node_modules/react/cjs/react-jsx-runtime.production.min.js","../node_modules/react/cjs/react-jsx-runtime.development.js","../node_modules/react/jsx-runtime.js","../node_modules/clsx/dist/clsx.mjs","../node_modules/tailwind-merge/dist/bundle-mjs.mjs","../src/lib/utils.ts","../src/components/ActionCard/index.tsx","../node_modules/lucide-react/dist/esm/shared/src/utils.js","../node_modules/lucide-react/dist/esm/defaultAttributes.js","../node_modules/lucide-react/dist/esm/Icon.js","../node_modules/lucide-react/dist/esm/createLucideIcon.js","../node_modules/lucide-react/dist/esm/icons/circle-check-big.js","../node_modules/lucide-react/dist/esm/icons/circle-check.js","../node_modules/lucide-react/dist/esm/icons/info.js","../node_modules/lucide-react/dist/esm/icons/package.js","../node_modules/lucide-react/dist/esm/icons/receipt-text.js","../node_modules/lucide-react/dist/esm/icons/route.js","../node_modules/lucide-react/dist/esm/icons/triangle-alert.js","../node_modules/lucide-react/dist/esm/icons/x.js","../src/components/BannerAlerts/index.tsx","../node_modules/@radix-ui/react-compose-refs/dist/index.mjs","../node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/class-variance-authority/dist/index.mjs","../src/components/ButtonRadix/index.tsx","../src/components/BrandIcons/index.tsx","../src/components/CardsGrid/index.tsx","../src/components/FeatureCard/index.tsx","../src/components/KPIComparison/KPIComparisonCustom.tsx","../src/components/KPIComparison/index.tsx","../src/components/KPICard/KPICardCustom.tsx","../src/components/KPICard/index.tsx","../src/components/Loader/index.tsx","../src/components/OptionCard/index.tsx","../src/components/OrderCard/OrderCardCustom.tsx","../src/components/OrderCard/index.tsx","../src/components/PaginationLib/index.tsx","../node_modules/@radix-ui/primitive/dist/index.mjs","../node_modules/@radix-ui/react-context/dist/index.mjs","../node_modules/@radix-ui/react-use-layout-effect/dist/index.mjs","../node_modules/@radix-ui/react-use-controllable-state/dist/index.mjs","../node_modules/@radix-ui/react-use-previous/dist/index.mjs","../node_modules/@radix-ui/react-use-size/dist/index.mjs","../node_modules/@radix-ui/react-primitive/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-primitive/dist/index.mjs","../node_modules/@radix-ui/react-switch/dist/index.mjs","../src/components/Switcher/index.tsx","../src/components/Toasts/index.tsx"],"sourcesContent":["/**\n * @license React\n * react-jsx-runtime.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var f=require(\"react\"),k=Symbol.for(\"react.element\"),l=Symbol.for(\"react.fragment\"),m=Object.prototype.hasOwnProperty,n=f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};\nfunction q(c,a,g){var b,d={},e=null,h=null;void 0!==g&&(e=\"\"+g);void 0!==a.key&&(e=\"\"+a.key);void 0!==a.ref&&(h=a.ref);for(b in a)m.call(a,b)&&!p.hasOwnProperty(b)&&(d[b]=a[b]);if(c&&c.defaultProps)for(b in a=c.defaultProps,a)void 0===d[b]&&(d[b]=a[b]);return{$$typeof:k,type:c,key:e,ref:h,props:d,_owner:n.current}}exports.Fragment=l;exports.jsx=q;exports.jsxs=q;\n","/**\n * @license React\n * react-jsx-runtime.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nif (process.env.NODE_ENV !== \"production\") {\n (function() {\n'use strict';\n\nvar React = require('react');\n\n// ATTENTION\n// When adding new symbols to this file,\n// Please consider also adding to 'react-devtools-shared/src/backend/ReactSymbols'\n// The Symbol used to tag the ReactElement-like types.\nvar REACT_ELEMENT_TYPE = Symbol.for('react.element');\nvar REACT_PORTAL_TYPE = Symbol.for('react.portal');\nvar REACT_FRAGMENT_TYPE = Symbol.for('react.fragment');\nvar REACT_STRICT_MODE_TYPE = Symbol.for('react.strict_mode');\nvar REACT_PROFILER_TYPE = Symbol.for('react.profiler');\nvar REACT_PROVIDER_TYPE = Symbol.for('react.provider');\nvar REACT_CONTEXT_TYPE = Symbol.for('react.context');\nvar REACT_FORWARD_REF_TYPE = Symbol.for('react.forward_ref');\nvar REACT_SUSPENSE_TYPE = Symbol.for('react.suspense');\nvar REACT_SUSPENSE_LIST_TYPE = Symbol.for('react.suspense_list');\nvar REACT_MEMO_TYPE = Symbol.for('react.memo');\nvar REACT_LAZY_TYPE = Symbol.for('react.lazy');\nvar REACT_OFFSCREEN_TYPE = Symbol.for('react.offscreen');\nvar MAYBE_ITERATOR_SYMBOL = Symbol.iterator;\nvar FAUX_ITERATOR_SYMBOL = '@@iterator';\nfunction getIteratorFn(maybeIterable) {\n if (maybeIterable === null || typeof maybeIterable !== 'object') {\n return null;\n }\n\n var maybeIterator = MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL];\n\n if (typeof maybeIterator === 'function') {\n return maybeIterator;\n }\n\n return null;\n}\n\nvar ReactSharedInternals = React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n\nfunction error(format) {\n {\n {\n for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n args[_key2 - 1] = arguments[_key2];\n }\n\n printWarning('error', format, args);\n }\n }\n}\n\nfunction printWarning(level, format, args) {\n // When changing this logic, you might want to also\n // update consoleWithStackDev.www.js as well.\n {\n var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n var stack = ReactDebugCurrentFrame.getStackAddendum();\n\n if (stack !== '') {\n format += '%s';\n args = args.concat([stack]);\n } // eslint-disable-next-line react-internal/safe-string-coercion\n\n\n var argsWithFormat = args.map(function (item) {\n return String(item);\n }); // Careful: RN currently depends on this prefix\n\n argsWithFormat.unshift('Warning: ' + format); // We intentionally don't use spread (or .apply) directly because it\n // breaks IE9: https://github.com/facebook/react/issues/13610\n // eslint-disable-next-line react-internal/no-production-logging\n\n Function.prototype.apply.call(console[level], console, argsWithFormat);\n }\n}\n\n// -----------------------------------------------------------------------------\n\nvar enableScopeAPI = false; // Experimental Create Event Handle API.\nvar enableCacheElement = false;\nvar enableTransitionTracing = false; // No known bugs, but needs performance testing\n\nvar enableLegacyHidden = false; // Enables unstable_avoidThisFallback feature in Fiber\n// stuff. Intended to enable React core members to more easily debug scheduling\n// issues in DEV builds.\n\nvar enableDebugTracing = false; // Track which Fiber(s) schedule render work.\n\nvar REACT_MODULE_REFERENCE;\n\n{\n REACT_MODULE_REFERENCE = Symbol.for('react.module.reference');\n}\n\nfunction isValidElementType(type) {\n if (typeof type === 'string' || typeof type === 'function') {\n return true;\n } // Note: typeof might be other than 'symbol' or 'number' (e.g. if it's a polyfill).\n\n\n if (type === REACT_FRAGMENT_TYPE || type === REACT_PROFILER_TYPE || enableDebugTracing || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || enableLegacyHidden || type === REACT_OFFSCREEN_TYPE || enableScopeAPI || enableCacheElement || enableTransitionTracing ) {\n return true;\n }\n\n if (typeof type === 'object' && type !== null) {\n if (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || // This needs to include all possible module reference object\n // types supported by any Flight configuration anywhere since\n // we don't know which Flight build this will end up being used\n // with.\n type.$$typeof === REACT_MODULE_REFERENCE || type.getModuleId !== undefined) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction getWrappedName(outerType, innerType, wrapperName) {\n var displayName = outerType.displayName;\n\n if (displayName) {\n return displayName;\n }\n\n var functionName = innerType.displayName || innerType.name || '';\n return functionName !== '' ? wrapperName + \"(\" + functionName + \")\" : wrapperName;\n} // Keep in sync with react-reconciler/getComponentNameFromFiber\n\n\nfunction getContextName(type) {\n return type.displayName || 'Context';\n} // Note that the reconciler package should generally prefer to use getComponentNameFromFiber() instead.\n\n\nfunction getComponentNameFromType(type) {\n if (type == null) {\n // Host root, text node or just invalid type.\n return null;\n }\n\n {\n if (typeof type.tag === 'number') {\n error('Received an unexpected object in getComponentNameFromType(). ' + 'This is likely a bug in React. Please file an issue.');\n }\n }\n\n if (typeof type === 'function') {\n return type.displayName || type.name || null;\n }\n\n if (typeof type === 'string') {\n return type;\n }\n\n switch (type) {\n case REACT_FRAGMENT_TYPE:\n return 'Fragment';\n\n case REACT_PORTAL_TYPE:\n return 'Portal';\n\n case REACT_PROFILER_TYPE:\n return 'Profiler';\n\n case REACT_STRICT_MODE_TYPE:\n return 'StrictMode';\n\n case REACT_SUSPENSE_TYPE:\n return 'Suspense';\n\n case REACT_SUSPENSE_LIST_TYPE:\n return 'SuspenseList';\n\n }\n\n if (typeof type === 'object') {\n switch (type.$$typeof) {\n case REACT_CONTEXT_TYPE:\n var context = type;\n return getContextName(context) + '.Consumer';\n\n case REACT_PROVIDER_TYPE:\n var provider = type;\n return getContextName(provider._context) + '.Provider';\n\n case REACT_FORWARD_REF_TYPE:\n return getWrappedName(type, type.render, 'ForwardRef');\n\n case REACT_MEMO_TYPE:\n var outerName = type.displayName || null;\n\n if (outerName !== null) {\n return outerName;\n }\n\n return getComponentNameFromType(type.type) || 'Memo';\n\n case REACT_LAZY_TYPE:\n {\n var lazyComponent = type;\n var payload = lazyComponent._payload;\n var init = lazyComponent._init;\n\n try {\n return getComponentNameFromType(init(payload));\n } catch (x) {\n return null;\n }\n }\n\n // eslint-disable-next-line no-fallthrough\n }\n }\n\n return null;\n}\n\nvar assign = Object.assign;\n\n// Helpers to patch console.logs to avoid logging during side-effect free\n// replaying on render function. This currently only patches the object\n// lazily which won't cover if the log function was extracted eagerly.\n// We could also eagerly patch the method.\nvar disabledDepth = 0;\nvar prevLog;\nvar prevInfo;\nvar prevWarn;\nvar prevError;\nvar prevGroup;\nvar prevGroupCollapsed;\nvar prevGroupEnd;\n\nfunction disabledLog() {}\n\ndisabledLog.__reactDisabledLog = true;\nfunction disableLogs() {\n {\n if (disabledDepth === 0) {\n /* eslint-disable react-internal/no-production-logging */\n prevLog = console.log;\n prevInfo = console.info;\n prevWarn = console.warn;\n prevError = console.error;\n prevGroup = console.group;\n prevGroupCollapsed = console.groupCollapsed;\n prevGroupEnd = console.groupEnd; // https://github.com/facebook/react/issues/19099\n\n var props = {\n configurable: true,\n enumerable: true,\n value: disabledLog,\n writable: true\n }; // $FlowFixMe Flow thinks console is immutable.\n\n Object.defineProperties(console, {\n info: props,\n log: props,\n warn: props,\n error: props,\n group: props,\n groupCollapsed: props,\n groupEnd: props\n });\n /* eslint-enable react-internal/no-production-logging */\n }\n\n disabledDepth++;\n }\n}\nfunction reenableLogs() {\n {\n disabledDepth--;\n\n if (disabledDepth === 0) {\n /* eslint-disable react-internal/no-production-logging */\n var props = {\n configurable: true,\n enumerable: true,\n writable: true\n }; // $FlowFixMe Flow thinks console is immutable.\n\n Object.defineProperties(console, {\n log: assign({}, props, {\n value: prevLog\n }),\n info: assign({}, props, {\n value: prevInfo\n }),\n warn: assign({}, props, {\n value: prevWarn\n }),\n error: assign({}, props, {\n value: prevError\n }),\n group: assign({}, props, {\n value: prevGroup\n }),\n groupCollapsed: assign({}, props, {\n value: prevGroupCollapsed\n }),\n groupEnd: assign({}, props, {\n value: prevGroupEnd\n })\n });\n /* eslint-enable react-internal/no-production-logging */\n }\n\n if (disabledDepth < 0) {\n error('disabledDepth fell below zero. ' + 'This is a bug in React. Please file an issue.');\n }\n }\n}\n\nvar ReactCurrentDispatcher = ReactSharedInternals.ReactCurrentDispatcher;\nvar prefix;\nfunction describeBuiltInComponentFrame(name, source, ownerFn) {\n {\n if (prefix === undefined) {\n // Extract the VM specific prefix used by each line.\n try {\n throw Error();\n } catch (x) {\n var match = x.stack.trim().match(/\\n( *(at )?)/);\n prefix = match && match[1] || '';\n }\n } // We use the prefix to ensure our stacks line up with native stack frames.\n\n\n return '\\n' + prefix + name;\n }\n}\nvar reentry = false;\nvar componentFrameCache;\n\n{\n var PossiblyWeakMap = typeof WeakMap === 'function' ? WeakMap : Map;\n componentFrameCache = new PossiblyWeakMap();\n}\n\nfunction describeNativeComponentFrame(fn, construct) {\n // If something asked for a stack inside a fake render, it should get ignored.\n if ( !fn || reentry) {\n return '';\n }\n\n {\n var frame = componentFrameCache.get(fn);\n\n if (frame !== undefined) {\n return frame;\n }\n }\n\n var control;\n reentry = true;\n var previousPrepareStackTrace = Error.prepareStackTrace; // $FlowFixMe It does accept undefined.\n\n Error.prepareStackTrace = undefined;\n var previousDispatcher;\n\n {\n previousDispatcher = ReactCurrentDispatcher.current; // Set the dispatcher in DEV because this might be call in the render function\n // for warnings.\n\n ReactCurrentDispatcher.current = null;\n disableLogs();\n }\n\n try {\n // This should throw.\n if (construct) {\n // Something should be setting the props in the constructor.\n var Fake = function () {\n throw Error();\n }; // $FlowFixMe\n\n\n Object.defineProperty(Fake.prototype, 'props', {\n set: function () {\n // We use a throwing setter instead of frozen or non-writable props\n // because that won't throw in a non-strict mode function.\n throw Error();\n }\n });\n\n if (typeof Reflect === 'object' && Reflect.construct) {\n // We construct a different control for this case to include any extra\n // frames added by the construct call.\n try {\n Reflect.construct(Fake, []);\n } catch (x) {\n control = x;\n }\n\n Reflect.construct(fn, [], Fake);\n } else {\n try {\n Fake.call();\n } catch (x) {\n control = x;\n }\n\n fn.call(Fake.prototype);\n }\n } else {\n try {\n throw Error();\n } catch (x) {\n control = x;\n }\n\n fn();\n }\n } catch (sample) {\n // This is inlined manually because closure doesn't do it for us.\n if (sample && control && typeof sample.stack === 'string') {\n // This extracts the first frame from the sample that isn't also in the control.\n // Skipping one frame that we assume is the frame that calls the two.\n var sampleLines = sample.stack.split('\\n');\n var controlLines = control.stack.split('\\n');\n var s = sampleLines.length - 1;\n var c = controlLines.length - 1;\n\n while (s >= 1 && c >= 0 && sampleLines[s] !== controlLines[c]) {\n // We expect at least one stack frame to be shared.\n // Typically this will be the root most one. However, stack frames may be\n // cut off due to maximum stack limits. In this case, one maybe cut off\n // earlier than the other. We assume that the sample is longer or the same\n // and there for cut off earlier. So we should find the root most frame in\n // the sample somewhere in the control.\n c--;\n }\n\n for (; s >= 1 && c >= 0; s--, c--) {\n // Next we find the first one that isn't the same which should be the\n // frame that called our sample function and the control.\n if (sampleLines[s] !== controlLines[c]) {\n // In V8, the first line is describing the message but other VMs don't.\n // If we're about to return the first line, and the control is also on the same\n // line, that's a pretty good indicator that our sample threw at same line as\n // the control. I.e. before we entered the sample frame. So we ignore this result.\n // This can happen if you passed a class to function component, or non-function.\n if (s !== 1 || c !== 1) {\n do {\n s--;\n c--; // We may still have similar intermediate frames from the construct call.\n // The next one that isn't the same should be our match though.\n\n if (c < 0 || sampleLines[s] !== controlLines[c]) {\n // V8 adds a \"new\" prefix for native classes. Let's remove it to make it prettier.\n var _frame = '\\n' + sampleLines[s].replace(' at new ', ' at '); // If our component frame is labeled \"<anonymous>\"\n // but we have a user-provided \"displayName\"\n // splice it in to make the stack more readable.\n\n\n if (fn.displayName && _frame.includes('<anonymous>')) {\n _frame = _frame.replace('<anonymous>', fn.displayName);\n }\n\n {\n if (typeof fn === 'function') {\n componentFrameCache.set(fn, _frame);\n }\n } // Return the line we found.\n\n\n return _frame;\n }\n } while (s >= 1 && c >= 0);\n }\n\n break;\n }\n }\n }\n } finally {\n reentry = false;\n\n {\n ReactCurrentDispatcher.current = previousDispatcher;\n reenableLogs();\n }\n\n Error.prepareStackTrace = previousPrepareStackTrace;\n } // Fallback to just using the name if we couldn't make it throw.\n\n\n var name = fn ? fn.displayName || fn.name : '';\n var syntheticFrame = name ? describeBuiltInComponentFrame(name) : '';\n\n {\n if (typeof fn === 'function') {\n componentFrameCache.set(fn, syntheticFrame);\n }\n }\n\n return syntheticFrame;\n}\nfunction describeFunctionComponentFrame(fn, source, ownerFn) {\n {\n return describeNativeComponentFrame(fn, false);\n }\n}\n\nfunction shouldConstruct(Component) {\n var prototype = Component.prototype;\n return !!(prototype && prototype.isReactComponent);\n}\n\nfunction describeUnknownElementTypeFrameInDEV(type, source, ownerFn) {\n\n if (type == null) {\n return '';\n }\n\n if (typeof type === 'function') {\n {\n return describeNativeComponentFrame(type, shouldConstruct(type));\n }\n }\n\n if (typeof type === 'string') {\n return describeBuiltInComponentFrame(type);\n }\n\n switch (type) {\n case REACT_SUSPENSE_TYPE:\n return describeBuiltInComponentFrame('Suspense');\n\n case REACT_SUSPENSE_LIST_TYPE:\n return describeBuiltInComponentFrame('SuspenseList');\n }\n\n if (typeof type === 'object') {\n switch (type.$$typeof) {\n case REACT_FORWARD_REF_TYPE:\n return describeFunctionComponentFrame(type.render);\n\n case REACT_MEMO_TYPE:\n // Memo may contain any component type so we recursively resolve it.\n return describeUnknownElementTypeFrameInDEV(type.type, source, ownerFn);\n\n case REACT_LAZY_TYPE:\n {\n var lazyComponent = type;\n var payload = lazyComponent._payload;\n var init = lazyComponent._init;\n\n try {\n // Lazy may contain any component type so we recursively resolve it.\n return describeUnknownElementTypeFrameInDEV(init(payload), source, ownerFn);\n } catch (x) {}\n }\n }\n }\n\n return '';\n}\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nvar loggedTypeFailures = {};\nvar ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n\nfunction setCurrentlyValidatingElement(element) {\n {\n if (element) {\n var owner = element._owner;\n var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);\n ReactDebugCurrentFrame.setExtraStackFrame(stack);\n } else {\n ReactDebugCurrentFrame.setExtraStackFrame(null);\n }\n }\n}\n\nfunction checkPropTypes(typeSpecs, values, location, componentName, element) {\n {\n // $FlowFixMe This is okay but Flow doesn't know it.\n var has = Function.call.bind(hasOwnProperty);\n\n for (var typeSpecName in typeSpecs) {\n if (has(typeSpecs, typeSpecName)) {\n var error$1 = void 0; // Prop type validation may throw. In case they do, we don't want to\n // fail the render phase where it didn't fail before. So we log it.\n // After these have been cleaned up, we'll let them throw.\n\n try {\n // This is intentionally an invariant that gets caught. It's the same\n // behavior as without this statement except with a better message.\n if (typeof typeSpecs[typeSpecName] !== 'function') {\n // eslint-disable-next-line react-internal/prod-error-codes\n var err = Error((componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' + 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' + 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.');\n err.name = 'Invariant Violation';\n throw err;\n }\n\n error$1 = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED');\n } catch (ex) {\n error$1 = ex;\n }\n\n if (error$1 && !(error$1 instanceof Error)) {\n setCurrentlyValidatingElement(element);\n\n error('%s: type specification of %s' + ' `%s` is invalid; the type checker ' + 'function must return `null` or an `Error` but returned a %s. ' + 'You may have forgotten to pass an argument to the type checker ' + 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' + 'shape all require an argument).', componentName || 'React class', location, typeSpecName, typeof error$1);\n\n setCurrentlyValidatingElement(null);\n }\n\n if (error$1 instanceof Error && !(error$1.message in loggedTypeFailures)) {\n // Only monitor this failure once because there tends to be a lot of the\n // same error.\n loggedTypeFailures[error$1.message] = true;\n setCurrentlyValidatingElement(element);\n\n error('Failed %s type: %s', location, error$1.message);\n\n setCurrentlyValidatingElement(null);\n }\n }\n }\n }\n}\n\nvar isArrayImpl = Array.isArray; // eslint-disable-next-line no-redeclare\n\nfunction isArray(a) {\n return isArrayImpl(a);\n}\n\n/*\n * The `'' + value` pattern (used in in perf-sensitive code) throws for Symbol\n * and Temporal.* types. See https://github.com/facebook/react/pull/22064.\n *\n * The functions in this module will throw an easier-to-understand,\n * easier-to-debug exception with a clear errors message message explaining the\n * problem. (Instead of a confusing exception thrown inside the implementation\n * of the `value` object).\n */\n// $FlowFixMe only called in DEV, so void return is not possible.\nfunction typeName(value) {\n {\n // toStringTag is needed for namespaced types like Temporal.Instant\n var hasToStringTag = typeof Symbol === 'function' && Symbol.toStringTag;\n var type = hasToStringTag && value[Symbol.toStringTag] || value.constructor.name || 'Object';\n return type;\n }\n} // $FlowFixMe only called in DEV, so void return is not possible.\n\n\nfunction willCoercionThrow(value) {\n {\n try {\n testStringCoercion(value);\n return false;\n } catch (e) {\n return true;\n }\n }\n}\n\nfunction testStringCoercion(value) {\n // If you ended up here by following an exception call stack, here's what's\n // happened: you supplied an object or symbol value to React (as a prop, key,\n // DOM attribute, CSS property, string ref, etc.) and when React tried to\n // coerce it to a string using `'' + value`, an exception was thrown.\n //\n // The most common types that will cause this exception are `Symbol` instances\n // and Temporal objects like `Temporal.Instant`. But any object that has a\n // `valueOf` or `[Symbol.toPrimitive]` method that throws will also cause this\n // exception. (Library authors do this to prevent users from using built-in\n // numeric operators like `+` or comparison operators like `>=` because custom\n // methods are needed to perform accurate arithmetic or comparison.)\n //\n // To fix the problem, coerce this object or symbol value to a string before\n // passing it to React. The most reliable way is usually `String(value)`.\n //\n // To find which value is throwing, check the browser or debugger console.\n // Before this exception was thrown, there should be `console.error` output\n // that shows the type (Symbol, Temporal.PlainDate, etc.) that caused the\n // problem and how that type was used: key, atrribute, input value prop, etc.\n // In most cases, this console output also shows the component and its\n // ancestor components where the exception happened.\n //\n // eslint-disable-next-line react-internal/safe-string-coercion\n return '' + value;\n}\nfunction checkKeyStringCoercion(value) {\n {\n if (willCoercionThrow(value)) {\n error('The provided key is an unsupported type %s.' + ' This value must be coerced to a string before before using it here.', typeName(value));\n\n return testStringCoercion(value); // throw (to help callers find troubleshooting comments)\n }\n }\n}\n\nvar ReactCurrentOwner = ReactSharedInternals.ReactCurrentOwner;\nvar RESERVED_PROPS = {\n key: true,\n ref: true,\n __self: true,\n __source: true\n};\nvar specialPropKeyWarningShown;\nvar specialPropRefWarningShown;\nvar didWarnAboutStringRefs;\n\n{\n didWarnAboutStringRefs = {};\n}\n\nfunction hasValidRef(config) {\n {\n if (hasOwnProperty.call(config, 'ref')) {\n var getter = Object.getOwnPropertyDescriptor(config, 'ref').get;\n\n if (getter && getter.isReactWarning) {\n return false;\n }\n }\n }\n\n return config.ref !== undefined;\n}\n\nfunction hasValidKey(config) {\n {\n if (hasOwnProperty.call(config, 'key')) {\n var getter = Object.getOwnPropertyDescriptor(config, 'key').get;\n\n if (getter && getter.isReactWarning) {\n return false;\n }\n }\n }\n\n return config.key !== undefined;\n}\n\nfunction warnIfStringRefCannotBeAutoConverted(config, self) {\n {\n if (typeof config.ref === 'string' && ReactCurrentOwner.current && self && ReactCurrentOwner.current.stateNode !== self) {\n var componentName = getComponentNameFromType(ReactCurrentOwner.current.type);\n\n if (!didWarnAboutStringRefs[componentName]) {\n error('Component \"%s\" contains the string ref \"%s\". ' + 'Support for string refs will be removed in a future major release. ' + 'This case cannot be automatically converted to an arrow function. ' + 'We ask you to manually fix this case by using useRef() or createRef() instead. ' + 'Learn more about using refs safely here: ' + 'https://reactjs.org/link/strict-mode-string-ref', getComponentNameFromType(ReactCurrentOwner.current.type), config.ref);\n\n didWarnAboutStringRefs[componentName] = true;\n }\n }\n }\n}\n\nfunction defineKeyPropWarningGetter(props, displayName) {\n {\n var warnAboutAccessingKey = function () {\n if (!specialPropKeyWarningShown) {\n specialPropKeyWarningShown = true;\n\n error('%s: `key` is not a prop. Trying to access it will result ' + 'in `undefined` being returned. If you need to access the same ' + 'value within the child component, you should pass it as a different ' + 'prop. (https://reactjs.org/link/special-props)', displayName);\n }\n };\n\n warnAboutAccessingKey.isReactWarning = true;\n Object.defineProperty(props, 'key', {\n get: warnAboutAccessingKey,\n configurable: true\n });\n }\n}\n\nfunction defineRefPropWarningGetter(props, displayName) {\n {\n var warnAboutAccessingRef = function () {\n if (!specialPropRefWarningShown) {\n specialPropRefWarningShown = true;\n\n error('%s: `ref` is not a prop. Trying to access it will result ' + 'in `undefined` being returned. If you need to access the same ' + 'value within the child component, you should pass it as a different ' + 'prop. (https://reactjs.org/link/special-props)', displayName);\n }\n };\n\n warnAboutAccessingRef.isReactWarning = true;\n Object.defineProperty(props, 'ref', {\n get: warnAboutAccessingRef,\n configurable: true\n });\n }\n}\n/**\n * Factory method to create a new React element. This no longer adheres to\n * the class pattern, so do not use new to call it. Also, instanceof check\n * will not work. Instead test $$typeof field against Symbol.for('react.element') to check\n * if something is a React Element.\n *\n * @param {*} type\n * @param {*} props\n * @param {*} key\n * @param {string|object} ref\n * @param {*} owner\n * @param {*} self A *temporary* helper to detect places where `this` is\n * different from the `owner` when React.createElement is called, so that we\n * can warn. We want to get rid of owner and replace string `ref`s with arrow\n * functions, and as long as `this` and owner are the same, there will be no\n * change in behavior.\n * @param {*} source An annotation object (added by a transpiler or otherwise)\n * indicating filename, line number, and/or other information.\n * @internal\n */\n\n\nvar ReactElement = function (type, key, ref, self, source, owner, props) {\n var element = {\n // This tag allows us to uniquely identify this as a React Element\n $$typeof: REACT_ELEMENT_TYPE,\n // Built-in properties that belong on the element\n type: type,\n key: key,\n ref: ref,\n props: props,\n // Record the component responsible for creating this element.\n _owner: owner\n };\n\n {\n // The validation flag is currently mutative. We put it on\n // an external backing store so that we can freeze the whole object.\n // This can be replaced with a WeakMap once they are implemented in\n // commonly used development environments.\n element._store = {}; // To make comparing ReactElements easier for testing purposes, we make\n // the validation flag non-enumerable (where possible, which should\n // include every environment we run tests in), so the test framework\n // ignores it.\n\n Object.defineProperty(element._store, 'validated', {\n configurable: false,\n enumerable: false,\n writable: true,\n value: false\n }); // self and source are DEV only properties.\n\n Object.defineProperty(element, '_self', {\n configurable: false,\n enumerable: false,\n writable: false,\n value: self\n }); // Two elements created in two different places should be considered\n // equal for testing purposes and therefore we hide it from enumeration.\n\n Object.defineProperty(element, '_source', {\n configurable: false,\n enumerable: false,\n writable: false,\n value: source\n });\n\n if (Object.freeze) {\n Object.freeze(element.props);\n Object.freeze(element);\n }\n }\n\n return element;\n};\n/**\n * https://github.com/reactjs/rfcs/pull/107\n * @param {*} type\n * @param {object} props\n * @param {string} key\n */\n\nfunction jsxDEV(type, config, maybeKey, source, self) {\n {\n var propName; // Reserved names are extracted\n\n var props = {};\n var key = null;\n var ref = null; // Currently, key can be spread in as a prop. This causes a potential\n // issue if key is also explicitly declared (ie. <div {...props} key=\"Hi\" />\n // or <div key=\"Hi\" {...props} /> ). We want to deprecate key spread,\n // but as an intermediary step, we will use jsxDEV for everything except\n // <div {...props} key=\"Hi\" />, because we aren't currently able to tell if\n // key is explicitly declared to be undefined or not.\n\n if (maybeKey !== undefined) {\n {\n checkKeyStringCoercion(maybeKey);\n }\n\n key = '' + maybeKey;\n }\n\n if (hasValidKey(config)) {\n {\n checkKeyStringCoercion(config.key);\n }\n\n key = '' + config.key;\n }\n\n if (hasValidRef(config)) {\n ref = config.ref;\n warnIfStringRefCannotBeAutoConverted(config, self);\n } // Remaining properties are added to a new props object\n\n\n for (propName in config) {\n if (hasOwnProperty.call(config, propName) && !RESERVED_PROPS.hasOwnProperty(propName)) {\n props[propName] = config[propName];\n }\n } // Resolve default props\n\n\n if (type && type.defaultProps) {\n var defaultProps = type.defaultProps;\n\n for (propName in defaultProps) {\n if (props[propName] === undefined) {\n props[propName] = defaultProps[propName];\n }\n }\n }\n\n if (key || ref) {\n var displayName = typeof type === 'function' ? type.displayName || type.name || 'Unknown' : type;\n\n if (key) {\n defineKeyPropWarningGetter(props, displayName);\n }\n\n if (ref) {\n defineRefPropWarningGetter(props, displayName);\n }\n }\n\n return ReactElement(type, key, ref, self, source, ReactCurrentOwner.current, props);\n }\n}\n\nvar ReactCurrentOwner$1 = ReactSharedInternals.ReactCurrentOwner;\nvar ReactDebugCurrentFrame$1 = ReactSharedInternals.ReactDebugCurrentFrame;\n\nfunction setCurrentlyValidatingElement$1(element) {\n {\n if (element) {\n var owner = element._owner;\n var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);\n ReactDebugCurrentFrame$1.setExtraStackFrame(stack);\n } else {\n ReactDebugCurrentFrame$1.setExtraStackFrame(null);\n }\n }\n}\n\nvar propTypesMisspellWarningShown;\n\n{\n propTypesMisspellWarningShown = false;\n}\n/**\n * Verifies the object is a ReactElement.\n * See https://reactjs.org/docs/react-api.html#isvalidelement\n * @param {?object} object\n * @return {boolean} True if `object` is a ReactElement.\n * @final\n */\n\n\nfunction isValidElement(object) {\n {\n return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;\n }\n}\n\nfunction getDeclarationErrorAddendum() {\n {\n if (ReactCurrentOwner$1.current) {\n var name = getComponentNameFromType(ReactCurrentOwner$1.current.type);\n\n if (name) {\n return '\\n\\nCheck the render method of `' + name + '`.';\n }\n }\n\n return '';\n }\n}\n\nfunction getSourceInfoErrorAddendum(source) {\n {\n if (source !== undefined) {\n var fileName = source.fileName.replace(/^.*[\\\\\\/]/, '');\n var lineNumber = source.lineNumber;\n return '\\n\\nCheck your code at ' + fileName + ':' + lineNumber + '.';\n }\n\n return '';\n }\n}\n/**\n * Warn if there's no key explicitly set on dynamic arrays of children or\n * object keys are not valid. This allows us to keep track of children between\n * updates.\n */\n\n\nvar ownerHasKeyUseWarning = {};\n\nfunction getCurrentComponentErrorInfo(parentType) {\n {\n var info = getDeclarationErrorAddendum();\n\n if (!info) {\n var parentName = typeof parentType === 'string' ? parentType : parentType.displayName || parentType.name;\n\n if (parentName) {\n info = \"\\n\\nCheck the top-level render call using <\" + parentName + \">.\";\n }\n }\n\n return info;\n }\n}\n/**\n * Warn if the element doesn't have an explicit key assigned to it.\n * This element is in an array. The array could grow and shrink or be\n * reordered. All children that haven't already been validated are required to\n * have a \"key\" property assigned to it. Error statuses are cached so a warning\n * will only be shown once.\n *\n * @internal\n * @param {ReactElement} element Element that requires a key.\n * @param {*} parentType element's parent's type.\n */\n\n\nfunction validateExplicitKey(element, parentType) {\n {\n if (!element._store || element._store.validated || element.key != null) {\n return;\n }\n\n element._store.validated = true;\n var currentComponentErrorInfo = getCurrentComponentErrorInfo(parentType);\n\n if (ownerHasKeyUseWarning[currentComponentErrorInfo]) {\n return;\n }\n\n ownerHasKeyUseWarning[currentComponentErrorInfo] = true; // Usually the current owner is the offender, but if it accepts children as a\n // property, it may be the creator of the child that's responsible for\n // assigning it a key.\n\n var childOwner = '';\n\n if (element && element._owner && element._owner !== ReactCurrentOwner$1.current) {\n // Give the component that originally created this child.\n childOwner = \" It was passed a child from \" + getComponentNameFromType(element._owner.type) + \".\";\n }\n\n setCurrentlyValidatingElement$1(element);\n\n error('Each child in a list should have a unique \"key\" prop.' + '%s%s See https://reactjs.org/link/warning-keys for more information.', currentComponentErrorInfo, childOwner);\n\n setCurrentlyValidatingElement$1(null);\n }\n}\n/**\n * Ensure that every element either is passed in a static location, in an\n * array with an explicit keys property defined, or in an object literal\n * with valid key property.\n *\n * @internal\n * @param {ReactNode} node Statically passed child of any type.\n * @param {*} parentType node's parent's type.\n */\n\n\nfunction validateChildKeys(node, parentType) {\n {\n if (typeof node !== 'object') {\n return;\n }\n\n if (isArray(node)) {\n for (var i = 0; i < node.length; i++) {\n var child = node[i];\n\n if (isValidElement(child)) {\n validateExplicitKey(child, parentType);\n }\n }\n } else if (isValidElement(node)) {\n // This element was passed in a valid location.\n if (node._store) {\n node._store.validated = true;\n }\n } else if (node) {\n var iteratorFn = getIteratorFn(node);\n\n if (typeof iteratorFn === 'function') {\n // Entry iterators used to provide implicit keys,\n // but now we print a separate warning for them later.\n if (iteratorFn !== node.entries) {\n var iterator = iteratorFn.call(node);\n var step;\n\n while (!(step = iterator.next()).done) {\n if (isValidElement(step.value)) {\n validateExplicitKey(step.value, parentType);\n }\n }\n }\n }\n }\n }\n}\n/**\n * Given an element, validate that its props follow the propTypes definition,\n * provided by the type.\n *\n * @param {ReactElement} element\n */\n\n\nfunction validatePropTypes(element) {\n {\n var type = element.type;\n\n if (type === null || type === undefined || typeof type === 'string') {\n return;\n }\n\n var propTypes;\n\n if (typeof type === 'function') {\n propTypes = type.propTypes;\n } else if (typeof type === 'object' && (type.$$typeof === REACT_FORWARD_REF_TYPE || // Note: Memo only checks outer props here.\n // Inner props are checked in the reconciler.\n type.$$typeof === REACT_MEMO_TYPE)) {\n propTypes = type.propTypes;\n } else {\n return;\n }\n\n if (propTypes) {\n // Intentionally inside to avoid triggering lazy initializers:\n var name = getComponentNameFromType(type);\n checkPropTypes(propTypes, element.props, 'prop', name, element);\n } else if (type.PropTypes !== undefined && !propTypesMisspellWarningShown) {\n propTypesMisspellWarningShown = true; // Intentionally inside to avoid triggering lazy initializers:\n\n var _name = getComponentNameFromType(type);\n\n error('Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?', _name || 'Unknown');\n }\n\n if (typeof type.getDefaultProps === 'function' && !type.getDefaultProps.isReactClassApproved) {\n error('getDefaultProps is only used on classic React.createClass ' + 'definitions. Use a static property named `defaultProps` instead.');\n }\n }\n}\n/**\n * Given a fragment, validate that it can only be provided with fragment props\n * @param {ReactElement} fragment\n */\n\n\nfunction validateFragmentProps(fragment) {\n {\n var keys = Object.keys(fragment.props);\n\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n\n if (key !== 'children' && key !== 'key') {\n setCurrentlyValidatingElement$1(fragment);\n\n error('Invalid prop `%s` supplied to `React.Fragment`. ' + 'React.Fragment can only have `key` and `children` props.', key);\n\n setCurrentlyValidatingElement$1(null);\n break;\n }\n }\n\n if (fragment.ref !== null) {\n setCurrentlyValidatingElement$1(fragment);\n\n error('Invalid attribute `ref` supplied to `React.Fragment`.');\n\n setCurrentlyValidatingElement$1(null);\n }\n }\n}\n\nvar didWarnAboutKeySpread = {};\nfunction jsxWithValidation(type, props, key, isStaticChildren, source, self) {\n {\n var validType = isValidElementType(type); // We warn in this case but don't throw. We expect the element creation to\n // succeed and there will likely be errors in render.\n\n if (!validType) {\n var info = '';\n\n if (type === undefined || typeof type === 'object' && type !== null && Object.keys(type).length === 0) {\n info += ' You likely forgot to export your component from the file ' + \"it's defined in, or you might have mixed up default and named imports.\";\n }\n\n var sourceInfo = getSourceInfoErrorAddendum(source);\n\n if (sourceInfo) {\n info += sourceInfo;\n } else {\n info += getDeclarationErrorAddendum();\n }\n\n var typeString;\n\n if (type === null) {\n typeString = 'null';\n } else if (isArray(type)) {\n typeString = 'array';\n } else if (type !== undefined && type.$$typeof === REACT_ELEMENT_TYPE) {\n typeString = \"<\" + (getComponentNameFromType(type.type) || 'Unknown') + \" />\";\n info = ' Did you accidentally export a JSX literal instead of a component?';\n } else {\n typeString = typeof type;\n }\n\n error('React.jsx: type is invalid -- expected a string (for ' + 'built-in components) or a class/function (for composite ' + 'components) but got: %s.%s', typeString, info);\n }\n\n var element = jsxDEV(type, props, key, source, self); // The result can be nullish if a mock or a custom function is used.\n // TODO: Drop this when these are no longer allowed as the type argument.\n\n if (element == null) {\n return element;\n } // Skip key warning if the type isn't valid since our key validation logic\n // doesn't expect a non-string/function type and can throw confusing errors.\n // We don't want exception behavior to differ between dev and prod.\n // (Rendering will throw with a helpful message and as soon as the type is\n // fixed, the key warnings will appear.)\n\n\n if (validType) {\n var children = props.children;\n\n if (children !== undefined) {\n if (isStaticChildren) {\n if (isArray(children)) {\n for (var i = 0; i < children.length; i++) {\n validateChildKeys(children[i], type);\n }\n\n if (Object.freeze) {\n Object.freeze(children);\n }\n } else {\n error('React.jsx: Static children should always be an array. ' + 'You are likely explicitly calling React.jsxs or React.jsxDEV. ' + 'Use the Babel transform instead.');\n }\n } else {\n validateChildKeys(children, type);\n }\n }\n }\n\n {\n if (hasOwnProperty.call(props, 'key')) {\n var componentName = getComponentNameFromType(type);\n var keys = Object.keys(props).filter(function (k) {\n return k !== 'key';\n });\n var beforeExample = keys.length > 0 ? '{key: someKey, ' + keys.join(': ..., ') + ': ...}' : '{key: someKey}';\n\n if (!didWarnAboutKeySpread[componentName + beforeExample]) {\n var afterExample = keys.length > 0 ? '{' + keys.join(': ..., ') + ': ...}' : '{}';\n\n error('A props object containing a \"key\" prop is being spread into JSX:\\n' + ' let props = %s;\\n' + ' <%s {...props} />\\n' + 'React keys must be passed directly to JSX without using spread:\\n' + ' let props = %s;\\n' + ' <%s key={someKey} {...props} />', beforeExample, componentName, afterExample, componentName);\n\n didWarnAboutKeySpread[componentName + beforeExample] = true;\n }\n }\n }\n\n if (type === REACT_FRAGMENT_TYPE) {\n validateFragmentProps(element);\n } else {\n validatePropTypes(element);\n }\n\n return element;\n }\n} // These two functions exist to still get child warnings in dev\n// even with the prod transform. This means that jsxDEV is purely\n// opt-in behavior for better messages but that we won't stop\n// giving you warnings if you use production apis.\n\nfunction jsxWithValidationStatic(type, props, key) {\n {\n return jsxWithValidation(type, props, key, true);\n }\n}\nfunction jsxWithValidationDynamic(type, props, key) {\n {\n return jsxWithValidation(type, props, key, false);\n }\n}\n\nvar jsx = jsxWithValidationDynamic ; // we may want to special case jsxs internally to take advantage of static children.\n// for now we can ship identical prod functions\n\nvar jsxs = jsxWithValidationStatic ;\n\nexports.Fragment = REACT_FRAGMENT_TYPE;\nexports.jsx = jsx;\nexports.jsxs = jsxs;\n })();\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-jsx-runtime.production.min.js');\n} else {\n module.exports = require('./cjs/react-jsx-runtime.development.js');\n}\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;","const CLASS_PART_SEPARATOR = '-';\nconst createClassGroupUtils = config => {\n const classMap = createClassMap(config);\n const {\n conflictingClassGroups,\n conflictingClassGroupModifiers\n } = config;\n const getClassGroupId = className => {\n const classParts = className.split(CLASS_PART_SEPARATOR);\n // Classes like `-inset-1` produce an empty string as first classPart. We assume that classes for negative values are used correctly and remove it from classParts.\n if (classParts[0] === '' && classParts.length !== 1) {\n classParts.shift();\n }\n return getGroupRecursive(classParts, classMap) || getGroupIdForArbitraryProperty(className);\n };\n const getConflictingClassGroupIds = (classGroupId, hasPostfixModifier) => {\n const conflicts = conflictingClassGroups[classGroupId] || [];\n if (hasPostfixModifier && conflictingClassGroupModifiers[classGroupId]) {\n return [...conflicts, ...conflictingClassGroupModifiers[classGroupId]];\n }\n return conflicts;\n };\n return {\n getClassGroupId,\n getConflictingClassGroupIds\n };\n};\nconst getGroupRecursive = (classParts, classPartObject) => {\n if (classParts.length === 0) {\n return classPartObject.classGroupId;\n }\n const currentClassPart = classParts[0];\n const nextClassPartObject = classPartObject.nextPart.get(currentClassPart);\n const classGroupFromNextClassPart = nextClassPartObject ? getGroupRecursive(classParts.slice(1), nextClassPartObject) : undefined;\n if (classGroupFromNextClassPart) {\n return classGroupFromNextClassPart;\n }\n if (classPartObject.validators.length === 0) {\n return undefined;\n }\n const classRest = classParts.join(CLASS_PART_SEPARATOR);\n return classPartObject.validators.find(({\n validator\n }) => validator(classRest))?.classGroupId;\n};\nconst arbitraryPropertyRegex = /^\\[(.+)\\]$/;\nconst getGroupIdForArbitraryProperty = className => {\n if (arbitraryPropertyRegex.test(className)) {\n const arbitraryPropertyClassName = arbitraryPropertyRegex.exec(className)[1];\n const property = arbitraryPropertyClassName?.substring(0, arbitraryPropertyClassName.indexOf(':'));\n if (property) {\n // I use two dots here because one dot is used as prefix for class groups in plugins\n return 'arbitrary..' + property;\n }\n }\n};\n/**\n * Exported for testing only\n */\nconst createClassMap = config => {\n const {\n theme,\n prefix\n } = config;\n const classMap = {\n nextPart: new Map(),\n validators: []\n };\n const prefixedClassGroupEntries = getPrefixedClassGroupEntries(Object.entries(config.classGroups), prefix);\n prefixedClassGroupEntries.forEach(([classGroupId, classGroup]) => {\n processClassesRecursively(classGroup, classMap, classGroupId, theme);\n });\n return classMap;\n};\nconst processClassesRecursively = (classGroup, classPartObject, classGroupId, theme) => {\n classGroup.forEach(classDefinition => {\n if (typeof classDefinition === 'string') {\n const classPartObjectToEdit = classDefinition === '' ? classPartObject : getPart(classPartObject, classDefinition);\n classPartObjectToEdit.classGroupId = classGroupId;\n return;\n }\n if (typeof classDefinition === 'function') {\n if (isThemeGetter(classDefinition)) {\n processClassesRecursively(classDefinition(theme), classPartObject, classGroupId, theme);\n return;\n }\n classPartObject.validators.push({\n validator: classDefinition,\n classGroupId\n });\n return;\n }\n Object.entries(classDefinition).forEach(([key, classGroup]) => {\n processClassesRecursively(classGroup, getPart(classPartObject, key), classGroupId, theme);\n });\n });\n};\nconst getPart = (classPartObject, path) => {\n let currentClassPartObject = classPartObject;\n path.split(CLASS_PART_SEPARATOR).forEach(pathPart => {\n if (!currentClassPartObject.nextPart.has(pathPart)) {\n currentClassPartObject.nextPart.set(pathPart, {\n nextPart: new Map(),\n validators: []\n });\n }\n currentClassPartObject = currentClassPartObject.nextPart.get(pathPart);\n });\n return currentClassPartObject;\n};\nconst isThemeGetter = func => func.isThemeGetter;\nconst getPrefixedClassGroupEntries = (classGroupEntries, prefix) => {\n if (!prefix) {\n return classGroupEntries;\n }\n return classGroupEntries.map(([classGroupId, classGroup]) => {\n const prefixedClassGroup = classGroup.map(classDefinition => {\n if (typeof classDefinition === 'string') {\n return prefix + classDefinition;\n }\n if (typeof classDefinition === 'object') {\n return Object.fromEntries(Object.entries(classDefinition).map(([key, value]) => [prefix + key, value]));\n }\n return classDefinition;\n });\n return [classGroupId, prefixedClassGroup];\n });\n};\n\n// LRU cache inspired from hashlru (https://github.com/dominictarr/hashlru/blob/v1.0.4/index.js) but object replaced with Map to improve performance\nconst createLruCache = maxCacheSize => {\n if (maxCacheSize < 1) {\n return {\n get: () => undefined,\n set: () => {}\n };\n }\n let cacheSize = 0;\n let cache = new Map();\n let previousCache = new Map();\n const update = (key, value) => {\n cache.set(key, value);\n cacheSize++;\n if (cacheSize > maxCacheSize) {\n cacheSize = 0;\n previousCache = cache;\n cache = new Map();\n }\n };\n return {\n get(key) {\n let value = cache.get(key);\n if (value !== undefined) {\n return value;\n }\n if ((value = previousCache.get(key)) !== undefined) {\n update(key, value);\n return value;\n }\n },\n set(key, value) {\n if (cache.has(key)) {\n cache.set(key, value);\n } else {\n update(key, value);\n }\n }\n };\n};\nconst IMPORTANT_MODIFIER = '!';\nconst createParseClassName = config => {\n const {\n separator,\n experimentalParseClassName\n } = config;\n const isSeparatorSingleCharacter = separator.length === 1;\n const firstSeparatorCharacter = separator[0];\n const separatorLength = separator.length;\n // parseClassName inspired by https://github.com/tailwindlabs/tailwindcss/blob/v3.2.2/src/util/splitAtTopLevelOnly.js\n const parseClassName = className => {\n const modifiers = [];\n let bracketDepth = 0;\n let modifierStart = 0;\n let postfixModifierPosition;\n for (let index = 0; index < className.length; index++) {\n let currentCharacter = className[index];\n if (bracketDepth === 0) {\n if (currentCharacter === firstSeparatorCharacter && (isSeparatorSingleCharacter || className.slice(index, index + separatorLength) === separator)) {\n modifiers.push(className.slice(modifierStart, index));\n modifierStart = index + separatorLength;\n continue;\n }\n if (currentCharacter === '/') {\n postfixModifierPosition = index;\n continue;\n }\n }\n if (currentCharacter === '[') {\n bracketDepth++;\n } else if (currentCharacter === ']') {\n bracketDepth--;\n }\n }\n const baseClassNameWithImportantModifier = modifiers.length === 0 ? className : className.substring(modifierStart);\n const hasImportantModifier = baseClassNameWithImportantModifier.startsWith(IMPORTANT_MODIFIER);\n const baseClassName = hasImportantModifier ? baseClassNameWithImportantModifier.substring(1) : baseClassNameWithImportantModifier;\n const maybePostfixModifierPosition = postfixModifierPosition && postfixModifierPosition > modifierStart ? postfixModifierPosition - modifierStart : undefined;\n return {\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition\n };\n };\n if (experimentalParseClassName) {\n return className => experimentalParseClassName({\n className,\n parseClassName\n });\n }\n return parseClassName;\n};\n/**\n * Sorts modifiers according to following schema:\n * - Predefined modifiers are sorted alphabetically\n * - When an arbitrary variant appears, it must be preserved which modifiers are before and after it\n */\nconst sortModifiers = modifiers => {\n if (modifiers.length <= 1) {\n return modifiers;\n }\n const sortedModifiers = [];\n let unsortedModifiers = [];\n modifiers.forEach(modifier => {\n const isArbitraryVariant = modifier[0] === '[';\n if (isArbitraryVariant) {\n sortedModifiers.push(...unsortedModifiers.sort(), modifier);\n unsortedModifiers = [];\n } else {\n unsortedModifiers.push(modifier);\n }\n });\n sortedModifiers.push(...unsortedModifiers.sort());\n return sortedModifiers;\n};\nconst createConfigUtils = config => ({\n cache: createLruCache(config.cacheSize),\n parseClassName: createParseClassName(config),\n ...createClassGroupUtils(config)\n});\nconst SPLIT_CLASSES_REGEX = /\\s+/;\nconst mergeClassList = (classList, configUtils) => {\n const {\n parseClassName,\n getClassGroupId,\n getConflictingClassGroupIds\n } = configUtils;\n /**\n * Set of classGroupIds in following format:\n * `{importantModifier}{variantModifiers}{classGroupId}`\n * @example 'float'\n * @example 'hover:focus:bg-color'\n * @example 'md:!pr'\n */\n const classGroupsInConflict = [];\n const classNames = classList.trim().split(SPLIT_CLASSES_REGEX);\n let result = '';\n for (let index = classNames.length - 1; index >= 0; index -= 1) {\n const originalClassName = classNames[index];\n const {\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition\n } = parseClassName(originalClassName);\n let hasPostfixModifier = Boolean(maybePostfixModifierPosition);\n let classGroupId = getClassGroupId(hasPostfixModifier ? baseClassName.substring(0, maybePostfixModifierPosition) : baseClassName);\n if (!classGroupId) {\n if (!hasPostfixModifier) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n classGroupId = getClassGroupId(baseClassName);\n if (!classGroupId) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n hasPostfixModifier = false;\n }\n const variantModifier = sortModifiers(modifiers).join(':');\n const modifierId = hasImportantModifier ? variantModifier + IMPORTANT_MODIFIER : variantModifier;\n const classId = modifierId + classGroupId;\n if (classGroupsInConflict.includes(classId)) {\n // Tailwind class omitted due to conflict\n continue;\n }\n classGroupsInConflict.push(classId);\n const conflictGroups = getConflictingClassGroupIds(classGroupId, hasPostfixModifier);\n for (let i = 0; i < conflictGroups.length; ++i) {\n const group = conflictGroups[i];\n classGroupsInConflict.push(modifierId + group);\n }\n // Tailwind class not in conflict\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n }\n return result;\n};\n\n/**\n * The code in this file is copied from https://github.com/lukeed/clsx and modified to suit the needs of tailwind-merge better.\n *\n * Specifically:\n * - Runtime code from https://github.com/lukeed/clsx/blob/v1.2.1/src/index.js\n * - TypeScript types from https://github.com/lukeed/clsx/blob/v1.2.1/clsx.d.ts\n *\n * Original code has MIT license: Copyright (c) Luke Edwards <luke.edwards05@gmail.com> (lukeed.com)\n */\nfunction twJoin() {\n let index = 0;\n let argument;\n let resolvedValue;\n let string = '';\n while (index < arguments.length) {\n if (argument = arguments[index++]) {\n if (resolvedValue = toValue(argument)) {\n string && (string += ' ');\n string += resolvedValue;\n }\n }\n }\n return string;\n}\nconst toValue = mix => {\n if (typeof mix === 'string') {\n return mix;\n }\n let resolvedValue;\n let string = '';\n for (let k = 0; k < mix.length; k++) {\n if (mix[k]) {\n if (resolvedValue = toValue(mix[k])) {\n string && (string += ' ');\n string += resolvedValue;\n }\n }\n }\n return string;\n};\nfunction createTailwindMerge(createConfigFirst, ...createConfigRest) {\n let configUtils;\n let cacheGet;\n let cacheSet;\n let functionToCall = initTailwindMerge;\n function initTailwindMerge(classList) {\n const config = createConfigRest.reduce((previousConfig, createConfigCurrent) => createConfigCurrent(previousConfig), createConfigFirst());\n configUtils = createConfigUtils(config);\n cacheGet = configUtils.cache.get;\n cacheSet = configUtils.cache.set;\n functionToCall = tailwindMerge;\n return tailwindMerge(classList);\n }\n function tailwindMerge(classList) {\n const cachedResult = cacheGet(classList);\n if (cachedResult) {\n return cachedResult;\n }\n const result = mergeClassList(classList, configUtils);\n cacheSet(classList, result);\n return result;\n }\n return function callTailwindMerge() {\n return functionToCall(twJoin.apply(null, arguments));\n };\n}\nconst fromTheme = key => {\n const themeGetter = theme => theme[key] || [];\n themeGetter.isThemeGetter = true;\n return themeGetter;\n};\nconst arbitraryValueRegex = /^\\[(?:([a-z-]+):)?(.+)\\]$/i;\nconst fractionRegex = /^\\d+\\/\\d+$/;\nconst stringLengths = /*#__PURE__*/new Set(['px', 'full', 'screen']);\nconst tshirtUnitRegex = /^(\\d+(\\.\\d+)?)?(xs|sm|md|lg|xl)$/;\nconst lengthUnitRegex = /\\d+(%|px|r?em|[sdl]?v([hwib]|min|max)|pt|pc|in|cm|mm|cap|ch|ex|r?lh|cq(w|h|i|b|min|max))|\\b(calc|min|max|clamp)\\(.+\\)|^0$/;\nconst colorFunctionRegex = /^(rgba?|hsla?|hwb|(ok)?(lab|lch))\\(.+\\)$/;\n// Shadow always begins with x and y offset separated by underscore optionally prepended by inset\nconst shadowRegex = /^(inset_)?-?((\\d+)?\\.?(\\d+)[a-z]+|0)_-?((\\d+)?\\.?(\\d+)[a-z]+|0)/;\nconst imageRegex = /^(url|image|image-set|cross-fade|element|(repeating-)?(linear|radial|conic)-gradient)\\(.+\\)$/;\nconst isLength = value => isNumber(value) || stringLengths.has(value) || fractionRegex.test(value);\nconst isArbitraryLength = value => getIsArbitraryValue(value, 'length', isLengthOnly);\nconst isNumber = value => Boolean(value) && !Number.isNaN(Number(value));\nconst isArbitraryNumber = value => getIsArbitraryValue(value, 'number', isNumber);\nconst isInteger = value => Boolean(value) && Number.isInteger(Number(value));\nconst isPercent = value => value.endsWith('%') && isNumber(value.slice(0, -1));\nconst isArbitraryValue = value => arbitraryValueRegex.test(value);\nconst isTshirtSize = value => tshirtUnitRegex.test(value);\nconst sizeLabels = /*#__PURE__*/new Set(['length', 'size', 'percentage']);\nconst isArbitrarySize = value => getIsArbitraryValue(value, sizeLabels, isNever);\nconst isArbitraryPosition = value => getIsArbitraryValue(value, 'position', isNever);\nconst imageLabels = /*#__PURE__*/new Set(['image', 'url']);\nconst isArbitraryImage = value => getIsArbitraryValue(value, imageLabels, isImage);\nconst isArbitraryShadow = value => getIsArbitraryValue(value, '', isShadow);\nconst isAny = () => true;\nconst getIsArbitraryValue = (value, label, testValue) => {\n const result = arbitraryValueRegex.exec(value);\n if (result) {\n if (result[1]) {\n return typeof label === 'string' ? result[1] === label : label.has(result[1]);\n }\n return testValue(result[2]);\n }\n return false;\n};\nconst isLengthOnly = value =>\n// `colorFunctionRegex` check is necessary because color functions can have percentages in them which which would be incorrectly classified as lengths.\n// For example, `hsl(0 0% 0%)` would be classified as a length without this check.\n// I could also use lookbehind assertion in `lengthUnitRegex` but that isn't supported widely enough.\nlengthUnitRegex.test(value) && !colorFunctionRegex.test(value);\nconst isNever = () => false;\nconst isShadow = value => shadowRegex.test(value);\nconst isImage = value => imageRegex.test(value);\nconst validators = /*#__PURE__*/Object.defineProperty({\n __proto__: null,\n isAny,\n isArbitraryImage,\n isArbitraryLength,\n isArbitraryNumber,\n isArbitraryPosition,\n isArbitraryShadow,\n isArbitrarySize,\n isArbitraryValue,\n isInteger,\n isLength,\n isNumber,\n isPercent,\n isTshirtSize\n}, Symbol.toStringTag, {\n value: 'Module'\n});\nconst getDefaultConfig = () => {\n const colors = fromTheme('colors');\n const spacing = fromTheme('spacing');\n const blur = fromTheme('blur');\n const brightness = fromTheme('brightness');\n const borderColor = fromTheme('borderColor');\n const borderRadius = fromTheme('borderRadius');\n const borderSpacing = fromTheme('borderSpacing');\n const borderWidth = fromTheme('borderWidth');\n const contrast = fromTheme('contrast');\n const grayscale = fromTheme('grayscale');\n const hueRotate = fromTheme('hueRotate');\n const invert = fromTheme('invert');\n const gap = fromTheme('gap');\n const gradientColorStops = fromTheme('gradientColorStops');\n const gradientColorStopPositions = fromTheme('gradientColorStopPositions');\n const inset = fromTheme('inset');\n const margin = fromTheme('margin');\n const opacity = fromTheme('opacity');\n const padding = fromTheme('padding');\n const saturate = fromTheme('saturate');\n const scale = fromTheme('scale');\n const sepia = fromTheme('sepia');\n const skew = fromTheme('skew');\n const space = fromTheme('space');\n const translate = fromTheme('translate');\n const getOverscroll = () => ['auto', 'contain', 'none'];\n const getOverflow = () => ['auto', 'hidden', 'clip', 'visible', 'scroll'];\n const getSpacingWithAutoAndArbitrary = () => ['auto', isArbitraryValue, spacing];\n const getSpacingWithArbitrary = () => [isArbitraryValue, spacing];\n const getLengthWithEmptyAndArbitrary = () => ['', isLength, isArbitraryLength];\n const getNumberWithAutoAndArbitrary = () => ['auto', isNumber, isArbitraryValue];\n const getPositions = () => ['bottom', 'center', 'left', 'left-bottom', 'left-top', 'right', 'right-bottom', 'right-top', 'top'];\n const getLineStyles = () => ['solid', 'dashed', 'dotted', 'double', 'none'];\n const getBlendModes = () => ['normal', 'multiply', 'screen', 'overlay', 'darken', 'lighten', 'color-dodge', 'color-burn', 'hard-light', 'soft-light', 'difference', 'exclusion', 'hue', 'saturation', 'color', 'luminosity'];\n const getAlign = () => ['start', 'end', 'center', 'between', 'around', 'evenly', 'stretch'];\n const getZeroAndEmpty = () => ['', '0', isArbitraryValue];\n const getBreaks = () => ['auto', 'avoid', 'all', 'avoid-page', 'page', 'left', 'right', 'column'];\n const getNumberAndArbitrary = () => [isNumber, isArbitraryValue];\n return {\n cacheSize: 500,\n separator: ':',\n theme: {\n colors: [isAny],\n spacing: [isLength, isArbitraryLength],\n blur: ['none', '', isTshirtSize, isArbitraryValue],\n brightness: getNumberAndArbitrary(),\n borderColor: [colors],\n borderRadius: ['none', '', 'full', isTshirtSize, isArbitraryValue],\n borderSpacing: getSpacingWithArbitrary(),\n borderWidth: getLengthWithEmptyAndArbitrary(),\n contrast: getNumberAndArbitrary(),\n grayscale: getZeroAndEmpty(),\n hueRotate: getNumberAndArbitrary(),\n invert: getZeroAndEmpty(),\n gap: getSpacingWithArbitrary(),\n gradientColorStops: [colors],\n gradientColorStopPositions: [isPercent, isArbitraryLength],\n inset: getSpacingWithAutoAndArbitrary(),\n margin: getSpacingWithAutoAndArbitrary(),\n opacity: getNumberAndArbitrary(),\n padding: getSpacingWithArbitrary(),\n saturate: getNumberAndArbitrary(),\n scale: getNumberAndArbitrary(),\n sepia: getZeroAndEmpty(),\n skew: getNumberAndArbitrary(),\n space: getSpacingWithArbitrary(),\n translate: getSpacingWithArbitrary()\n },\n classGroups: {\n // Layout\n /**\n * Aspect Ratio\n * @see https://tailwindcss.com/docs/aspect-ratio\n */\n aspect: [{\n aspect: ['auto', 'square', 'video', isArbitraryValue]\n }],\n /**\n * Container\n * @see https://tailwindcss.com/docs/container\n */\n container: ['container'],\n /**\n * Columns\n * @see https://tailwindcss.com/docs/columns\n */\n columns: [{\n columns: [isTshirtSize]\n }],\n /**\n * Break After\n * @see https://tailwindcss.com/docs/break-after\n */\n 'break-after': [{\n 'break-after': getBreaks()\n }],\n /**\n * Break Before\n * @see https://tailwindcss.com/docs/break-before\n */\n 'break-before': [{\n 'break-before': getBreaks()\n }],\n /**\n * Break Inside\n * @see https://tailwindcss.com/docs/break-inside\n */\n 'break-inside': [{\n 'break-inside': ['auto', 'avoid', 'avoid-page', 'avoid-column']\n }],\n /**\n * Box Decoration Break\n * @see https://tailwindcss.com/docs/box-decoration-break\n */\n 'box-decoration': [{\n 'box-decoration': ['slice', 'clone']\n }],\n /**\n * Box Sizing\n * @see https://tailwindcss.com/docs/box-sizing\n */\n box: [{\n box: ['border', 'content']\n }],\n /**\n * Display\n * @see https://tailwindcss.com/docs/display\n */\n display: ['block', 'inline-block', 'inline', 'flex', 'inline-flex', 'table', 'inline-table', 'table-caption', 'table-cell', 'table-column', 'table-column-group', 'table-footer-group', 'table-header-group', 'table-row-group', 'table-row', 'flow-root', 'grid', 'inline-grid', 'contents', 'list-item', 'hidden'],\n /**\n * Floats\n * @see https://tailwindcss.com/docs/float\n */\n float: [{\n float: ['right', 'left', 'none', 'start', 'end']\n }],\n /**\n * Clear\n * @see https://tailwindcss.com/docs/clear\n */\n clear: [{\n clear: ['left', 'right', 'both', 'none', 'start', 'end']\n }],\n /**\n * Isolation\n * @see https://tailwindcss.com/docs/isolation\n */\n isolation: ['isolate', 'isolation-auto'],\n /**\n * Object Fit\n * @see https://tailwindcss.com/docs/object-fit\n */\n 'object-fit': [{\n object: ['contain', 'cover', 'fill', 'none', 'scale-down']\n }],\n /**\n * Object Position\n * @see https://tailwindcss.com/docs/object-position\n */\n 'object-position': [{\n object: [...getPositions(), isArbitraryValue]\n }],\n /**\n * Overflow\n * @see https://tailwindcss.com/docs/overflow\n */\n overflow: [{\n overflow: getOverflow()\n }],\n /**\n * Overflow X\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-x': [{\n 'overflow-x': getOverflow()\n }],\n /**\n * Overflow Y\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-y': [{\n 'overflow-y': getOverflow()\n }],\n /**\n * Overscroll Behavior\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n overscroll: [{\n overscroll: getOverscroll()\n }],\n /**\n * Overscroll Behavior X\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-x': [{\n 'overscroll-x': getOverscroll()\n }],\n /**\n * Overscroll Behavior Y\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-y': [{\n 'overscroll-y': getOverscroll()\n }],\n /**\n * Position\n * @see https://tailwindcss.com/docs/position\n */\n position: ['static', 'fixed', 'absolute', 'relative', 'sticky'],\n /**\n * Top / Right / Bottom / Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n inset: [{\n inset: [inset]\n }],\n /**\n * Right / Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-x': [{\n 'inset-x': [inset]\n }],\n /**\n * Top / Bottom\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-y': [{\n 'inset-y': [inset]\n }],\n /**\n * Start\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n start: [{\n start: [inset]\n }],\n /**\n * End\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n end: [{\n end: [inset]\n }],\n /**\n * Top\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n top: [{\n top: [inset]\n }],\n /**\n * Right\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n right: [{\n right: [inset]\n }],\n /**\n * Bottom\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n bottom: [{\n bottom: [inset]\n }],\n /**\n * Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n left: [{\n left: [inset]\n }],\n /**\n * Visibility\n * @see https://tailwindcss.com/docs/visibility\n */\n visibility: ['visible', 'invisible', 'collapse'],\n /**\n * Z-Index\n * @see https://tailwindcss.com/docs/z-index\n */\n z: [{\n z: ['auto', isInteger, isArbitraryValue]\n }],\n // Flexbox and Grid\n /**\n * Flex Basis\n * @see https://tailwindcss.com/docs/flex-basis\n */\n basis: [{\n basis: getSpacingWithAutoAndArbitrary()\n }],\n /**\n * Flex Direction\n * @see https://tailwindcss.com/docs/flex-direction\n */\n 'flex-direction': [{\n flex: ['row', 'row-reverse', 'col', 'col-reverse']\n }],\n /**\n * Flex Wrap\n * @see https://tailwindcss.com/docs/flex-wrap\n */\n 'flex-wrap': [{\n flex: ['wrap', 'wrap-reverse', 'nowrap']\n }],\n /**\n * Flex\n * @see https://tailwindcss.com/docs/flex\n */\n flex: [{\n flex: ['1', 'auto', 'initial', 'none', isArbitraryValue]\n }],\n /**\n * Flex Grow\n * @see https://tailwindcss.com/docs/flex-grow\n */\n grow: [{\n grow: getZeroAndEmpty()\n }],\n /**\n * Flex Shrink\n * @see https://tailwindcss.com/docs/flex-shrink\n */\n shrink: [{\n shrink: getZeroAndEmpty()\n }],\n /**\n * Order\n * @see https://tailwindcss.com/docs/order\n */\n order: [{\n order: ['first', 'last', 'none', isInteger, isArbitraryValue]\n }],\n /**\n * Grid Template Columns\n * @see https://tailwindcss.com/docs/grid-template-columns\n */\n 'grid-cols': [{\n 'grid-cols': [isAny]\n }],\n /**\n * Grid Column Start / End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start-end': [{\n col: ['auto', {\n span: ['full', isInteger, isArbitraryValue]\n }, isArbitraryValue]\n }],\n /**\n * Grid Column Start\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start': [{\n 'col-start': getNumberWithAutoAndArbitrary()\n }],\n /**\n * Grid Column End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-end': [{\n 'col-end': getNumberWithAutoAndArbitrary()\n }],\n /**\n * Grid Template Rows\n * @see https://tailwindcss.com/docs/grid-template-rows\n */\n 'grid-rows': [{\n 'grid-rows': [isAny]\n }],\n /**\n * Grid Row Start / End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start-end': [{\n row: ['auto', {\n span: [isInteger, isArbitraryValue]\n }, isArbitraryValue]\n }],\n /**\n * Grid Row Start\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start': [{\n 'row-start': getNumberWithAutoAndArbitrary()\n }],\n /**\n * Grid Row End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-end': [{\n 'row-end': getNumberWithAutoAndArbitrary()\n }],\n /**\n * Grid Auto Flow\n * @see https://tailwindcss.com/docs/grid-auto-flow\n */\n 'grid-flow': [{\n 'grid-flow': ['row', 'col', 'dense', 'row-dense', 'col-dense']\n }],\n /**\n * Grid Auto Columns\n * @see https://tailwindcss.com/docs/grid-auto-columns\n */\n 'auto-cols': [{\n 'auto-cols': ['auto', 'min', 'max', 'fr', isArbitraryValue]\n }],\n /**\n * Grid Auto Rows\n * @see https://tailwindcss.com/docs/grid-auto-rows\n */\n 'auto-rows': [{\n 'auto-rows': ['auto', 'min', 'max', 'fr', isArbitraryValue]\n }],\n /**\n * Gap\n * @see https://tailwindcss.com/docs/gap\n */\n gap: [{\n gap: [gap]\n }],\n /**\n * Gap X\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-x': [{\n 'gap-x': [gap]\n }],\n /**\n * Gap Y\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-y': [{\n 'gap-y': [gap]\n }],\n /**\n * Justify Content\n * @see https://tailwindcss.com/docs/justify-content\n */\n 'justify-content': [{\n justify: ['normal', ...getAlign()]\n }],\n /**\n * Justify Items\n * @see https://tailwindcss.com/docs/justify-items\n */\n 'justify-items': [{\n 'justify-items': ['start', 'end', 'center', 'stretch']\n }],\n /**\n * Justify Self\n * @see https://tailwindcss.com/docs/justify-self\n */\n 'justify-self': [{\n 'justify-self': ['auto', 'start', 'end', 'center', 'stretch']\n }],\n /**\n * Align Content\n * @see https://tailwindcss.com/docs/align-content\n */\n 'align-content': [{\n content: ['normal', ...getAlign(), 'baseline']\n }],\n /**\n * Align Items\n * @see https://tailwindcss.com/docs/align-items\n */\n 'align-items': [{\n items: ['start', 'end', 'center', 'baseline', 'stretch']\n }],\n /**\n * Align Self\n * @see https://tailwindcss.com/docs/align-self\n */\n 'align-self': [{\n self: ['auto', 'start', 'end', 'center', 'stretch', 'baseline']\n }],\n /**\n * Place Content\n * @see https://tailwindcss.com/docs/place-content\n */\n 'place-content': [{\n 'place-content': [...getAlign(), 'baseline']\n }],\n /**\n * Place Items\n * @see https://tailwindcss.com/docs/place-items\n */\n 'place-items': [{\n 'place-items': ['start', 'end', 'center', 'baseline', 'stretch']\n }],\n /**\n * Place Self\n * @see https://tailwindcss.com/docs/place-self\n */\n 'place-self': [{\n 'place-self': ['auto', 'start', 'end', 'center', 'stretch']\n }],\n // Spacing\n /**\n * Padding\n * @see https://tailwindcss.com/docs/padding\n */\n p: [{\n p: [padding]\n }],\n /**\n * Padding X\n * @see https://tailwindcss.com/docs/padding\n */\n px: [{\n px: [padding]\n }],\n /**\n * Padding Y\n * @see https://tailwindcss.com/docs/padding\n */\n py: [{\n py: [padding]\n }],\n /**\n * Padding Start\n * @see https://tailwindcss.com/docs/padding\n */\n ps: [{\n ps: [padding]\n }],\n /**\n * Padding End\n * @see https://tailwindcss.com/docs/padding\n */\n pe: [{\n pe: [padding]\n }],\n /**\n * Padding Top\n * @see https://tailwindcss.com/docs/padding\n */\n pt: [{\n pt: [padding]\n }],\n /**\n * Padding Right\n * @see https://tailwindcss.com/docs/padding\n */\n pr: [{\n pr: [padding]\n }],\n /**\n * Padding Bottom\n * @see https://tailwindcss.com/docs/padding\n */\n pb: [{\n pb: [padding]\n }],\n /**\n * Padding Left\n * @see https://tailwindcss.com/docs/padding\n */\n pl: [{\n pl: [padding]\n }],\n /**\n * Margin\n * @see https://tailwindcss.com/docs/margin\n */\n m: [{\n m: [margin]\n }],\n /**\n * Margin X\n * @see https://tailwindcss.com/docs/margin\n */\n mx: [{\n mx: [margin]\n }],\n /**\n * Margin Y\n * @see https://tailwindcss.com/docs/margin\n */\n my: [{\n my: [margin]\n }],\n /**\n * Margin Start\n * @see https://tailwindcss.com/docs/margin\n */\n ms: [{\n ms: [margin]\n }],\n /**\n * Margin End\n * @see https://tailwindcss.com/docs/margin\n */\n me: [{\n me: [margin]\n }],\n /**\n * Margin Top\n * @see https://tailwindcss.com/docs/margin\n */\n mt: [{\n mt: [margin]\n }],\n /**\n * Margin Right\n * @see https://tailwindcss.com/docs/margin\n */\n mr: [{\n mr: [margin]\n }],\n /**\n * Margin Bottom\n * @see https://tailwindcss.com/docs/margin\n */\n mb: [{\n mb: [margin]\n }],\n /**\n * Margin Left\n * @see https://tailwindcss.com/docs/margin\n */\n ml: [{\n ml: [margin]\n }],\n /**\n * Space Between X\n * @see https://tailwindcss.com/docs/space\n */\n 'space-x': [{\n 'space-x': [space]\n }],\n /**\n * Space Between X Reverse\n * @see https://tailwindcss.com/docs/space\n */\n 'space-x-reverse': ['space-x-reverse'],\n /**\n * Space Between Y\n * @see https://tailwindcss.com/docs/space\n */\n 'space-y': [{\n 'space-y': [space]\n }],\n /**\n * Space Between Y Reverse\n * @see https://tailwindcss.com/docs/space\n */\n 'space-y-reverse': ['space-y-reverse'],\n // Sizing\n /**\n * Width\n * @see https://tailwindcss.com/docs/width\n */\n w: [{\n w: ['auto', 'min', 'max', 'fit', 'svw', 'lvw', 'dvw', isArbitraryValue, spacing]\n }],\n /**\n * Min-Width\n * @see https://tailwindcss.com/docs/min-width\n */\n 'min-w': [{\n 'min-w': [isArbitraryValue, spacing, 'min', 'max', 'fit']\n }],\n /**\n * Max-Width\n * @see https://tailwindcss.com/docs/max-width\n */\n 'max-w': [{\n 'max-w': [isArbitraryValue, spacing, 'none', 'full', 'min', 'max', 'fit', 'prose', {\n screen: [isTshirtSize]\n }, isTshirtSize]\n }],\n /**\n * Height\n * @see https://tailwindcss.com/docs/height\n */\n h: [{\n h: [isArbitraryValue, spacing, 'auto', 'min', 'max', 'fit', 'svh', 'lvh', 'dvh']\n }],\n /**\n * Min-Height\n * @see https://tailwindcss.com/docs/min-height\n */\n 'min-h': [{\n 'min-h': [isArbitraryValue, spacing, 'min', 'max', 'fit', 'svh', 'lvh', 'dvh']\n }],\n /**\n * Max-Height\n * @see https://tailwindcss.com/docs/max-height\n */\n 'max-h': [{\n 'max-h': [isArbitraryValue, spacing, 'min', 'max', 'fit', 'svh', 'lvh', 'dvh']\n }],\n /**\n * Size\n * @see https://tailwindcss.com/docs/size\n */\n size: [{\n size: [isArbitraryValue, spacing, 'auto', 'min', 'max', 'fit']\n }],\n // Typography\n /**\n * Font Size\n * @see https://tailwindcss.com/docs/font-size\n */\n 'font-size': [{\n text: ['base', isTshirtSize, isArbitraryLength]\n }],\n /**\n * Font Smoothing\n * @see https://tailwindcss.com/docs/font-smoothing\n */\n 'font-smoothing': ['antialiased', 'subpixel-antialiased'],\n /**\n * Font Style\n * @see https://tailwindcss.com/docs/font-style\n */\n 'font-style': ['italic', 'not-italic'],\n /**\n * Font Weight\n * @see https://tailwindcss.com/docs/font-weight\n */\n 'font-weight': [{\n font: ['thin', 'extralight', 'light', 'normal', 'medium', 'semibold', 'bold', 'extrabold', 'black', isArbitraryNumber]\n }],\n /**\n * Font Family\n * @see https://tailwindcss.com/docs/font-family\n */\n 'font-family': [{\n font: [isAny]\n }],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-normal': ['normal-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-ordinal': ['ordinal'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-slashed-zero': ['slashed-zero'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-figure': ['lining-nums', 'oldstyle-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-spacing': ['proportional-nums', 'tabular-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-fraction': ['diagonal-fractions', 'stacked-fractions'],\n /**\n * Letter Spacing\n * @see https://tailwindcss.com/docs/letter-spacing\n */\n tracking: [{\n tracking: ['tighter', 'tight', 'normal', 'wide', 'wider', 'widest', isArbitraryValue]\n }],\n /**\n * Line Clamp\n * @see https://tailwindcss.com/docs/line-clamp\n */\n 'line-clamp': [{\n 'line-clamp': ['none', isNumber, isArbitraryNumber]\n }],\n /**\n * Line Height\n * @see https://tailwindcss.com/docs/line-height\n */\n leading: [{\n leading: ['none', 'tight', 'snug', 'normal', 'relaxed', 'loose', isLength, isArbitraryValue]\n }],\n /**\n * List Style Image\n * @see https://tailwindcss.com/docs/list-style-image\n */\n 'list-image': [{\n 'list-image': ['none', isArbitraryValue]\n }],\n /**\n * List Style Type\n * @see https://tailwindcss.com/docs/list-style-type\n */\n 'list-style-type': [{\n list: ['none', 'disc', 'decimal', isArbitraryValue]\n }],\n /**\n * List Style Position\n * @see https://tailwindcss.com/docs/list-style-position\n */\n 'list-style-position': [{\n list: ['inside', 'outside']\n }],\n /**\n * Placeholder Color\n * @deprecated since Tailwind CSS v3.0.0\n * @see https://tailwindcss.com/docs/placeholder-color\n */\n 'placeholder-color': [{\n placeholder: [colors]\n }],\n /**\n * Placeholder Opacity\n * @see https://tailwindcss.com/docs/placeholder-opacity\n */\n 'placeholder-opacity': [{\n 'placeholder-opacity': [opacity]\n }],\n /**\n * Text Alignment\n * @see https://tailwindcss.com/docs/text-align\n */\n 'text-alignment': [{\n text: ['left', 'center', 'right', 'justify', 'start', 'end']\n }],\n /**\n * Text Color\n * @see https://tailwindcss.com/docs/text-color\n */\n 'text-color': [{\n text: [colors]\n }],\n /**\n * Text Opacity\n * @see https://tailwindcss.com/docs/text-opacity\n */\n 'text-opacity': [{\n 'text-opacity': [opacity]\n }],\n /**\n * Text Decoration\n * @see https://tailwindcss.com/docs/text-decoration\n */\n 'text-decoration': ['underline', 'overline', 'line-through', 'no-underline'],\n /**\n * Text Decoration Style\n * @see https://tailwindcss.com/docs/text-decoration-style\n */\n 'text-decoration-style': [{\n decoration: [...getLineStyles(), 'wavy']\n }],\n /**\n * Text Decoration Thickness\n * @see https://tailwindcss.com/docs/text-decoration-thickness\n */\n 'text-decoration-thickness': [{\n decoration: ['auto', 'from-font', isLength, isArbitraryLength]\n }],\n /**\n * Text Underline Offset\n * @see https://tailwindcss.com/docs/text-underline-offset\n */\n 'underline-offset': [{\n 'underline-offset': ['auto', isLength, isArbitraryValue]\n }],\n /**\n * Text Decoration Color\n * @see https://tailwindcss.com/docs/text-decoration-color\n */\n 'text-decoration-color': [{\n decoration: [colors]\n }],\n /**\n * Text Transform\n * @see https://tailwindcss.com/docs/text-transform\n */\n 'text-transform': ['uppercase', 'lowercase', 'capitalize', 'normal-case'],\n /**\n * Text Overflow\n * @see https://tailwindcss.com/docs/text-overflow\n */\n 'text-overflow': ['truncate', 'text-ellipsis', 'text-clip'],\n /**\n * Text Wrap\n * @see https://tailwindcss.com/docs/text-wrap\n */\n 'text-wrap': [{\n text: ['wrap', 'nowrap', 'balance', 'pretty']\n }],\n /**\n * Text Indent\n * @see https://tailwindcss.com/docs/text-indent\n */\n indent: [{\n indent: getSpacingWithArbitrary()\n }],\n /**\n * Vertical Alignment\n * @see https://tailwindcss.com/docs/vertical-align\n */\n 'vertical-align': [{\n align: ['baseline', 'top', 'middle', 'bottom', 'text-top', 'text-bottom', 'sub', 'super', isArbitraryValue]\n }],\n /**\n * Whitespace\n * @see https://tailwindcss.com/docs/whitespace\n */\n whitespace: [{\n whitespace: ['normal', 'nowrap', 'pre', 'pre-line', 'pre-wrap', 'break-spaces']\n }],\n /**\n * Word Break\n * @see https://tailwindcss.com/docs/word-break\n */\n break: [{\n break: ['normal', 'words', 'all', 'keep']\n }],\n /**\n * Hyphens\n * @see https://tailwindcss.com/docs/hyphens\n */\n hyphens: [{\n hyphens: ['none', 'manual', 'auto']\n }],\n /**\n * Content\n * @see https://tailwindcss.com/docs/content\n */\n content: [{\n content: ['none', isArbitraryValue]\n }],\n // Backgrounds\n /**\n * Background Attachment\n * @see https://tailwindcss.com/docs/background-attachment\n */\n 'bg-attachment': [{\n bg: ['fixed', 'local', 'scroll']\n }],\n /**\n * Background Clip\n * @see https://tailwindcss.com/docs/background-clip\n */\n 'bg-clip': [{\n 'bg-clip': ['border', 'padding', 'content', 'text']\n }],\n /**\n * Background Opacity\n * @deprecated since Tailwind CSS v3.0.0\n * @see https://tailwindcss.com/docs/background-opacity\n */\n 'bg-opacity': [{\n 'bg-opacity': [opacity]\n }],\n /**\n * Background Origin\n * @see https://tailwindcss.com/docs/background-origin\n */\n 'bg-origin': [{\n 'bg-origin': ['border', 'padding', 'content']\n }],\n /**\n * Background Position\n * @see https://tailwindcss.com/docs/background-position\n */\n 'bg-position': [{\n bg: [...getPositions(), isArbitraryPosition]\n }],\n /**\n * Background Repeat\n * @see https://tailwindcss.com/docs/background-repeat\n */\n 'bg-repeat': [{\n bg: ['no-repeat', {\n repeat: ['', 'x', 'y', 'round', 'space']\n }]\n }],\n /**\n * Background Size\n * @see https://tailwindcss.com/docs/background-size\n */\n 'bg-size': [{\n bg: ['auto', 'cover', 'contain', isArbitrarySize]\n }],\n /**\n * Background Image\n * @see https://tailwindcss.com/docs/background-image\n */\n 'bg-image': [{\n bg: ['none', {\n 'gradient-to': ['t', 'tr', 'r', 'br', 'b', 'bl', 'l', 'tl']\n }, isArbitraryImage]\n }],\n /**\n * Background Color\n * @see https://tailwindcss.com/docs/background-color\n */\n 'bg-color': [{\n bg: [colors]\n }],\n /**\n * Gradient Color Stops From Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from-pos': [{\n from: [gradientColorStopPositions]\n }],\n /**\n * Gradient Color Stops Via Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via-pos': [{\n via: [gradientColorStopPositions]\n }],\n /**\n * Gradient Color Stops To Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to-pos': [{\n to: [gradientColorStopPositions]\n }],\n /**\n * Gradient Color Stops From\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from': [{\n from: [gradientColorStops]\n }],\n /**\n * Gradient Color Stops Via\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via': [{\n via: [gradientColorStops]\n }],\n /**\n * Gradient Color Stops To\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to': [{\n to: [gradientColorStops]\n }],\n // Borders\n /**\n * Border Radius\n * @see https://tailwindcss.com/docs/border-radius\n */\n rounded: [{\n rounded: [borderRadius]\n }],\n /**\n * Border Radius Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-s': [{\n 'rounded-s': [borderRadius]\n }],\n /**\n * Border Radius End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-e': [{\n 'rounded-e': [borderRadius]\n }],\n /**\n * Border Radius Top\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-t': [{\n 'rounded-t': [borderRadius]\n }],\n /**\n * Border Radius Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-r': [{\n 'rounded-r': [borderRadius]\n }],\n /**\n * Border Radius Bottom\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-b': [{\n 'rounded-b': [borderRadius]\n }],\n /**\n * Border Radius Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-l': [{\n 'rounded-l': [borderRadius]\n }],\n /**\n * Border Radius Start Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ss': [{\n 'rounded-ss': [borderRadius]\n }],\n /**\n * Border Radius Start End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-se': [{\n 'rounded-se': [borderRadius]\n }],\n /**\n * Border Radius End End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ee': [{\n 'rounded-ee': [borderRadius]\n }],\n /**\n * Border Radius End Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-es': [{\n 'rounded-es': [borderRadius]\n }],\n /**\n * Border Radius Top Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tl': [{\n 'rounded-tl': [borderRadius]\n }],\n /**\n * Border Radius Top Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tr': [{\n 'rounded-tr': [borderRadius]\n }],\n /**\n * Border Radius Bottom Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-br': [{\n 'rounded-br': [borderRadius]\n }],\n /**\n * Border Radius Bottom Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-bl': [{\n 'rounded-bl': [borderRadius]\n }],\n /**\n * Border Width\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w': [{\n border: [borderWidth]\n }],\n /**\n * Border Width X\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-x': [{\n 'border-x': [borderWidth]\n }],\n /**\n * Border Width Y\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-y': [{\n 'border-y': [borderWidth]\n }],\n /**\n * Border Width Start\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-s': [{\n 'border-s': [borderWidth]\n }],\n /**\n * Border Width End\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-e': [{\n 'border-e': [borderWidth]\n }],\n /**\n * Border Width Top\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-t': [{\n 'border-t': [borderWidth]\n }],\n /**\n * Border Width Right\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-r': [{\n 'border-r': [borderWidth]\n }],\n /**\n * Border Width Bottom\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-b': [{\n 'border-b': [borderWidth]\n }],\n /**\n * Border Width Left\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-l': [{\n 'border-l': [borderWidth]\n }],\n /**\n * Border Opacity\n * @see https://tailwindcss.com/docs/border-opacity\n */\n 'border-opacity': [{\n 'border-opacity': [opacity]\n }],\n /**\n * Border Style\n * @see https://tailwindcss.com/docs/border-style\n */\n 'border-style': [{\n border: [...getLineStyles(), 'hidden']\n }],\n /**\n * Divide Width X\n * @see https://tailwindcss.com/docs/divide-width\n */\n 'divide-x': [{\n 'divide-x': [borderWidth]\n }],\n /**\n * Divide Width X Reverse\n * @see https://tailwindcss.com/docs/divide-width\n */\n 'divide-x-reverse': ['divide-x-reverse'],\n /**\n * Divide Width Y\n * @see https://tailwindcss.com/docs/divide-width\n */\n 'divide-y': [{\n 'divide-y': [borderWidth]\n }],\n /**\n * Divide Width Y Reverse\n * @see https://tailwindcss.com/docs/divide-width\n */\n 'divide-y-reverse': ['divide-y-reverse'],\n /**\n * Divide Opacity\n * @see https://tailwindcss.com/docs/divide-opacity\n */\n 'divide-opacity': [{\n 'divide-opacity': [opacity]\n }],\n /**\n * Divide Style\n * @see https://tailwindcss.com/docs/divide-style\n */\n 'divide-style': [{\n divide: getLineStyles()\n }],\n /**\n * Border Color\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color': [{\n border: [borderColor]\n }],\n /**\n * Border Color X\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-x': [{\n 'border-x': [borderColor]\n }],\n /**\n * Border Color Y\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-y': [{\n 'border-y': [borderColor]\n }],\n /**\n * Border Color S\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-s': [{\n 'border-s': [borderColor]\n }],\n /**\n * Border Color E\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-e': [{\n 'border-e': [borderColor]\n }],\n /**\n * Border Color Top\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-t': [{\n 'border-t': [borderColor]\n }],\n /**\n * Border Color Right\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-r': [{\n 'border-r': [borderColor]\n }],\n /**\n * Border Color Bottom\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-b': [{\n 'border-b': [borderColor]\n }],\n /**\n * Border Color Left\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-l': [{\n 'border-l': [borderColor]\n }],\n /**\n * Divide Color\n * @see https://tailwindcss.com/docs/divide-color\n */\n 'divide-color': [{\n divide: [borderColor]\n }],\n /**\n * Outline Style\n * @see https://tailwindcss.com/docs/outline-style\n */\n 'outline-style': [{\n outline: ['', ...getLineStyles()]\n }],\n /**\n * Outline Offset\n * @see https://tailwindcss.com/docs/outline-offset\n */\n 'outline-offset': [{\n 'outline-offset': [isLength, isArbitraryValue]\n }],\n /**\n * Outline Width\n * @see https://tailwindcss.com/docs/outline-width\n */\n 'outline-w': [{\n outline: [isLength, isArbitraryLength]\n }],\n /**\n * Outline Color\n * @see https://tailwindcss.com/docs/outline-color\n */\n 'outline-color': [{\n outline: [colors]\n }],\n /**\n * Ring Width\n * @see https://tailwindcss.com/docs/ring-width\n */\n 'ring-w': [{\n ring: getLengthWithEmptyAndArbitrary()\n }],\n /**\n * Ring Width Inset\n * @see https://tailwindcss.com/docs/ring-width\n */\n 'ring-w-inset': ['ring-inset'],\n /**\n * Ring Color\n * @see https://tailwindcss.com/docs/ring-color\n */\n 'ring-color': [{\n ring: [colors]\n }],\n /**\n * Ring Opacity\n * @see https://tailwindcss.com/docs/ring-opacity\n */\n 'ring-opacity': [{\n 'ring-opacity': [opacity]\n }],\n /**\n * Ring Offset Width\n * @see https://tailwindcss.com/docs/ring-offset-width\n */\n 'ring-offset-w': [{\n 'ring-offset': [isLength, isArbitraryLength]\n }],\n /**\n * Ring Offset Color\n * @see https://tailwindcss.com/docs/ring-offset-color\n */\n 'ring-offset-color': [{\n 'ring-offset': [colors]\n }],\n // Effects\n /**\n * Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow\n */\n shadow: [{\n shadow: ['', 'inner', 'none', isTshirtSize, isArbitraryShadow]\n }],\n /**\n * Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow-color\n */\n 'shadow-color': [{\n shadow: [isAny]\n }],\n /**\n * Opacity\n * @see https://tailwindcss.com/docs/opacity\n */\n opacity: [{\n opacity: [opacity]\n }],\n /**\n * Mix Blend Mode\n * @see https://tailwindcss.com/docs/mix-blend-mode\n */\n 'mix-blend': [{\n 'mix-blend': [...getBlendModes(), 'plus-lighter', 'plus-darker']\n }],\n /**\n * Background Blend Mode\n * @see https://tailwindcss.com/docs/background-blend-mode\n */\n 'bg-blend': [{\n 'bg-blend': getBlendModes()\n }],\n // Filters\n /**\n * Filter\n * @deprecated since Tailwind CSS v3.0.0\n * @see https://tailwindcss.com/docs/filter\n */\n filter: [{\n filter: ['', 'none']\n }],\n /**\n * Blur\n * @see https://tailwindcss.com/docs/blur\n */\n blur: [{\n blur: [blur]\n }],\n /**\n * Brightness\n * @see https://tailwindcss.com/docs/brightness\n */\n brightness: [{\n brightness: [brightness]\n }],\n /**\n * Contrast\n * @see https://tailwindcss.com/docs/contrast\n */\n contrast: [{\n contrast: [contrast]\n }],\n /**\n * Drop Shadow\n * @see https://tailwindcss.com/docs/drop-shadow\n */\n 'drop-shadow': [{\n 'drop-shadow': ['', 'none', isTshirtSize, isArbitraryValue]\n }],\n /**\n * Grayscale\n * @see https://tailwindcss.com/docs/grayscale\n */\n grayscale: [{\n grayscale: [grayscale]\n }],\n /**\n * Hue Rotate\n * @see https://tailwindcss.com/docs/hue-rotate\n */\n 'hue-rotate': [{\n 'hue-rotate': [hueRotate]\n }],\n /**\n * Invert\n * @see https://tailwindcss.com/docs/invert\n */\n invert: [{\n invert: [invert]\n }],\n /**\n * Saturate\n * @see https://tailwindcss.com/docs/saturate\n */\n saturate: [{\n saturate: [saturate]\n }],\n /**\n * Sepia\n * @see https://tailwindcss.com/docs/sepia\n */\n sepia: [{\n sepia: [sepia]\n }],\n /**\n * Backdrop Filter\n * @deprecated since Tailwind CSS v3.0.0\n * @see https://tailwindcss.com/docs/backdrop-filter\n */\n 'backdrop-filter': [{\n 'backdrop-filter': ['', 'none']\n }],\n /**\n * Backdrop Blur\n * @see https://tailwindcss.com/docs/backdrop-blur\n */\n 'backdrop-blur': [{\n 'backdrop-blur': [blur]\n }],\n /**\n * Backdrop Brightness\n * @see https://tailwindcss.com/docs/backdrop-brightness\n */\n 'backdrop-brightness': [{\n 'backdrop-brightness': [brightness]\n }],\n /**\n * Backdrop Contrast\n * @see https://tailwindcss.com/docs/backdrop-contrast\n */\n 'backdrop-contrast': [{\n 'backdrop-contrast': [contrast]\n }],\n /**\n * Backdrop Grayscale\n * @see https://tailwindcss.com/docs/backdrop-grayscale\n */\n 'backdrop-grayscale': [{\n 'backdrop-grayscale': [grayscale]\n }],\n /**\n * Backdrop Hue Rotate\n * @see https://tailwindcss.com/docs/backdrop-hue-rotate\n */\n 'backdrop-hue-rotate': [{\n 'backdrop-hue-rotate': [hueRotate]\n }],\n /**\n * Backdrop Invert\n * @see https://tailwindcss.com/docs/backdrop-invert\n */\n 'backdrop-invert': [{\n 'backdrop-invert': [invert]\n }],\n /**\n * Backdrop Opacity\n * @see https://tailwindcss.com/docs/backdrop-opacity\n */\n 'backdrop-opacity': [{\n 'backdrop-opacity': [opacity]\n }],\n /**\n * Backdrop Saturate\n * @see https://tailwindcss.com/docs/backdrop-saturate\n */\n 'backdrop-saturate': [{\n 'backdrop-saturate': [saturate]\n }],\n /**\n * Backdrop Sepia\n * @see https://tailwindcss.com/docs/backdrop-sepia\n */\n 'backdrop-sepia': [{\n 'backdrop-sepia': [sepia]\n }],\n // Tables\n /**\n * Border Collapse\n * @see https://tailwindcss.com/docs/border-collapse\n */\n 'border-collapse': [{\n border: ['collapse', 'separate']\n }],\n /**\n * Border Spacing\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing': [{\n 'border-spacing': [borderSpacing]\n }],\n /**\n * Border Spacing X\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-x': [{\n 'border-spacing-x': [borderSpacing]\n }],\n /**\n * Border Spacing Y\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-y': [{\n 'border-spacing-y': [borderSpacing]\n }],\n /**\n * Table Layout\n * @see https://tailwindcss.com/docs/table-layout\n */\n 'table-layout': [{\n table: ['auto', 'fixed']\n }],\n /**\n * Caption Side\n * @see https://tailwindcss.com/docs/caption-side\n */\n caption: [{\n caption: ['top', 'bottom']\n }],\n // Transitions and Animation\n /**\n * Tranisition Property\n * @see https://tailwindcss.com/docs/transition-property\n */\n transition: [{\n transition: ['none', 'all', '', 'colors', 'opacity', 'shadow', 'transform', isArbitraryValue]\n }],\n /**\n * Transition Duration\n * @see https://tailwindcss.com/docs/transition-duration\n */\n duration: [{\n duration: getNumberAndArbitrary()\n }],\n /**\n * Transition Timing Function\n * @see https://tailwindcss.com/docs/transition-timing-function\n */\n ease: [{\n ease: ['linear', 'in', 'out', 'in-out', isArbitraryValue]\n }],\n /**\n * Transition Delay\n * @see https://tailwindcss.com/docs/transition-delay\n */\n delay: [{\n delay: getNumberAndArbitrary()\n }],\n /**\n * Animation\n * @see https://tailwindcss.com/docs/animation\n */\n animate: [{\n animate: ['none', 'spin', 'ping', 'pulse', 'bounce', isArbitraryValue]\n }],\n // Transforms\n /**\n * Transform\n * @see https://tailwindcss.com/docs/transform\n */\n transform: [{\n transform: ['', 'gpu', 'none']\n }],\n /**\n * Scale\n * @see https://tailwindcss.com/docs/scale\n */\n scale: [{\n scale: [scale]\n }],\n /**\n * Scale X\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-x': [{\n 'scale-x': [scale]\n }],\n /**\n * Scale Y\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-y': [{\n 'scale-y': [scale]\n }],\n /**\n * Rotate\n * @see https://tailwindcss.com/docs/rotate\n */\n rotate: [{\n rotate: [isInteger, isArbitraryValue]\n }],\n /**\n * Translate X\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-x': [{\n 'translate-x': [translate]\n }],\n /**\n * Translate Y\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-y': [{\n 'translate-y': [translate]\n }],\n /**\n * Skew X\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-x': [{\n 'skew-x': [skew]\n }],\n /**\n * Skew Y\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-y': [{\n 'skew-y': [skew]\n }],\n /**\n * Transform Origin\n * @see https://tailwindcss.com/docs/transform-origin\n */\n 'transform-origin': [{\n origin: ['center', 'top', 'top-right', 'right', 'bottom-right', 'bottom', 'bottom-left', 'left', 'top-left', isArbitraryValue]\n }],\n // Interactivity\n /**\n * Accent Color\n * @see https://tailwindcss.com/docs/accent-color\n */\n accent: [{\n accent: ['auto', colors]\n }],\n /**\n * Appearance\n * @see https://tailwindcss.com/docs/appearance\n */\n appearance: [{\n appearance: ['none', 'auto']\n }],\n /**\n * Cursor\n * @see https://tailwindcss.com/docs/cursor\n */\n cursor: [{\n cursor: ['auto', 'default', 'pointer', 'wait', 'text', 'move', 'help', 'not-allowed', 'none', 'context-menu', 'progress', 'cell', 'crosshair', 'vertical-text', 'alias', 'copy', 'no-drop', 'grab', 'grabbing', 'all-scroll', 'col-resize', 'row-resize', 'n-resize', 'e-resize', 's-resize', 'w-resize', 'ne-resize', 'nw-resize', 'se-resize', 'sw-resize', 'ew-resize', 'ns-resize', 'nesw-resize', 'nwse-resize', 'zoom-in', 'zoom-out', isArbitraryValue]\n }],\n /**\n * Caret Color\n * @see https://tailwindcss.com/docs/just-in-time-mode#caret-color-utilities\n */\n 'caret-color': [{\n caret: [colors]\n }],\n /**\n * Pointer Events\n * @see https://tailwindcss.com/docs/pointer-events\n */\n 'pointer-events': [{\n 'pointer-events': ['none', 'auto']\n }],\n /**\n * Resize\n * @see https://tailwindcss.com/docs/resize\n */\n resize: [{\n resize: ['none', 'y', 'x', '']\n }],\n /**\n * Scroll Behavior\n * @see https://tailwindcss.com/docs/scroll-behavior\n */\n 'scroll-behavior': [{\n scroll: ['auto', 'smooth']\n }],\n /**\n * Scroll Margin\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-m': [{\n 'scroll-m': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Margin X\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mx': [{\n 'scroll-mx': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Margin Y\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-my': [{\n 'scroll-my': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Margin Start\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ms': [{\n 'scroll-ms': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Margin End\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-me': [{\n 'scroll-me': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Margin Top\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mt': [{\n 'scroll-mt': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Margin Right\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mr': [{\n 'scroll-mr': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Margin Bottom\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mb': [{\n 'scroll-mb': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Margin Left\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ml': [{\n 'scroll-ml': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Padding\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-p': [{\n 'scroll-p': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Padding X\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-px': [{\n 'scroll-px': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Padding Y\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-py': [{\n 'scroll-py': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Padding Start\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-ps': [{\n 'scroll-ps': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Padding End\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pe': [{\n 'scroll-pe': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Padding Top\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pt': [{\n 'scroll-pt': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Padding Right\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pr': [{\n 'scroll-pr': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Padding Bottom\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pb': [{\n 'scroll-pb': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Padding Left\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pl': [{\n 'scroll-pl': getSpacingWithArbitrary()\n }],\n /**\n * Scroll Snap Align\n * @see https://tailwindcss.com/docs/scroll-snap-align\n */\n 'snap-align': [{\n snap: ['start', 'end', 'center', 'align-none']\n }],\n /**\n * Scroll Snap Stop\n * @see https://tailwindcss.com/docs/scroll-snap-stop\n */\n 'snap-stop': [{\n snap: ['normal', 'always']\n }],\n /**\n * Scroll Snap Type\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-type': [{\n snap: ['none', 'x', 'y', 'both']\n }],\n /**\n * Scroll Snap Type Strictness\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-strictness': [{\n snap: ['mandatory', 'proximity']\n }],\n /**\n * Touch Action\n * @see https://tailwindcss.com/docs/touch-action\n */\n touch: [{\n touch: ['auto', 'none', 'manipulation']\n }],\n /**\n * Touch Action X\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-x': [{\n 'touch-pan': ['x', 'left', 'right']\n }],\n /**\n * Touch Action Y\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-y': [{\n 'touch-pan': ['y', 'up', 'down']\n }],\n /**\n * Touch Action Pinch Zoom\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-pz': ['touch-pinch-zoom'],\n /**\n * User Select\n * @see https://tailwindcss.com/docs/user-select\n */\n select: [{\n select: ['none', 'text', 'all', 'auto']\n }],\n /**\n * Will Change\n * @see https://tailwindcss.com/docs/will-change\n */\n 'will-change': [{\n 'will-change': ['auto', 'scroll', 'contents', 'transform', isArbitraryValue]\n }],\n // SVG\n /**\n * Fill\n * @see https://tailwindcss.com/docs/fill\n */\n fill: [{\n fill: [colors, 'none']\n }],\n /**\n * Stroke Width\n * @see https://tailwindcss.com/docs/stroke-width\n */\n 'stroke-w': [{\n stroke: [isLength, isArbitraryLength, isArbitraryNumber]\n }],\n /**\n * Stroke\n * @see https://tailwindcss.com/docs/stroke\n */\n stroke: [{\n stroke: [colors, 'none']\n }],\n // Accessibility\n /**\n * Screen Readers\n * @see https://tailwindcss.com/docs/screen-readers\n */\n sr: ['sr-only', 'not-sr-only'],\n /**\n * Forced Color Adjust\n * @see https://tailwindcss.com/docs/forced-color-adjust\n */\n 'forced-color-adjust': [{\n 'forced-color-adjust': ['auto', 'none']\n }]\n },\n conflictingClassGroups: {\n overflow: ['overflow-x', 'overflow-y'],\n overscroll: ['overscroll-x', 'overscroll-y'],\n inset: ['inset-x', 'inset-y', 'start', 'end', 'top', 'right', 'bottom', 'left'],\n 'inset-x': ['right', 'left'],\n 'inset-y': ['top', 'bottom'],\n flex: ['basis', 'grow', 'shrink'],\n gap: ['gap-x', 'gap-y'],\n p: ['px', 'py', 'ps', 'pe', 'pt', 'pr', 'pb', 'pl'],\n px: ['pr', 'pl'],\n py: ['pt', 'pb'],\n m: ['mx', 'my', 'ms', 'me', 'mt', 'mr', 'mb', 'ml'],\n mx: ['mr', 'ml'],\n my: ['mt', 'mb'],\n size: ['w', 'h'],\n 'font-size': ['leading'],\n 'fvn-normal': ['fvn-ordinal', 'fvn-slashed-zero', 'fvn-figure', 'fvn-spacing', 'fvn-fraction'],\n 'fvn-ordinal': ['fvn-normal'],\n 'fvn-slashed-zero': ['fvn-normal'],\n 'fvn-figure': ['fvn-normal'],\n 'fvn-spacing': ['fvn-normal'],\n 'fvn-fraction': ['fvn-normal'],\n 'line-clamp': ['display', 'overflow'],\n rounded: ['rounded-s', 'rounded-e', 'rounded-t', 'rounded-r', 'rounded-b', 'rounded-l', 'rounded-ss', 'rounded-se', 'rounded-ee', 'rounded-es', 'rounded-tl', 'rounded-tr', 'rounded-br', 'rounded-bl'],\n 'rounded-s': ['rounded-ss', 'rounded-es'],\n 'rounded-e': ['rounded-se', 'rounded-ee'],\n 'rounded-t': ['rounded-tl', 'rounded-tr'],\n 'rounded-r': ['rounded-tr', 'rounded-br'],\n 'rounded-b': ['rounded-br', 'rounded-bl'],\n 'rounded-l': ['rounded-tl', 'rounded-bl'],\n 'border-spacing': ['border-spacing-x', 'border-spacing-y'],\n 'border-w': ['border-w-s', 'border-w-e', 'border-w-t', 'border-w-r', 'border-w-b', 'border-w-l'],\n 'border-w-x': ['border-w-r', 'border-w-l'],\n 'border-w-y': ['border-w-t', 'border-w-b'],\n 'border-color': ['border-color-s', 'border-color-e', 'border-color-t', 'border-color-r', 'border-color-b', 'border-color-l'],\n 'border-color-x': ['border-color-r', 'border-color-l'],\n 'border-color-y': ['border-color-t', 'border-color-b'],\n 'scroll-m': ['scroll-mx', 'scroll-my', 'scroll-ms', 'scroll-me', 'scroll-mt', 'scroll-mr', 'scroll-mb', 'scroll-ml'],\n 'scroll-mx': ['scroll-mr', 'scroll-ml'],\n 'scroll-my': ['scroll-mt', 'scroll-mb'],\n 'scroll-p': ['scroll-px', 'scroll-py', 'scroll-ps', 'scroll-pe', 'scroll-pt', 'scroll-pr', 'scroll-pb', 'scroll-pl'],\n 'scroll-px': ['scroll-pr', 'scroll-pl'],\n 'scroll-py': ['scroll-pt', 'scroll-pb'],\n touch: ['touch-x', 'touch-y', 'touch-pz'],\n 'touch-x': ['touch'],\n 'touch-y': ['touch'],\n 'touch-pz': ['touch']\n },\n conflictingClassGroupModifiers: {\n 'font-size': ['leading']\n }\n };\n};\n\n/**\n * @param baseConfig Config where other config will be merged into. This object will be mutated.\n * @param configExtension Partial config to merge into the `baseConfig`.\n */\nconst mergeConfigs = (baseConfig, {\n cacheSize,\n prefix,\n separator,\n experimentalParseClassName,\n extend = {},\n override = {}\n}) => {\n overrideProperty(baseConfig, 'cacheSize', cacheSize);\n overrideProperty(baseConfig, 'prefix', prefix);\n overrideProperty(baseConfig, 'separator', separator);\n overrideProperty(baseConfig, 'experimentalParseClassName', experimentalParseClassName);\n for (const configKey in override) {\n overrideConfigProperties(baseConfig[configKey], override[configKey]);\n }\n for (const key in extend) {\n mergeConfigProperties(baseConfig[key], extend[key]);\n }\n return baseConfig;\n};\nconst overrideProperty = (baseObject, overrideKey, overrideValue) => {\n if (overrideValue !== undefined) {\n baseObject[overrideKey] = overrideValue;\n }\n};\nconst overrideConfigProperties = (baseObject, overrideObject) => {\n if (overrideObject) {\n for (const key in overrideObject) {\n overrideProperty(baseObject, key, overrideObject[key]);\n }\n }\n};\nconst mergeConfigProperties = (baseObject, mergeObject) => {\n if (mergeObject) {\n for (const key in mergeObject) {\n const mergeValue = mergeObject[key];\n if (mergeValue !== undefined) {\n baseObject[key] = (baseObject[key] || []).concat(mergeValue);\n }\n }\n }\n};\nconst extendTailwindMerge = (configExtension, ...createConfig) => typeof configExtension === 'function' ? createTailwindMerge(getDefaultConfig, configExtension, ...createConfig) : createTailwindMerge(() => mergeConfigs(getDefaultConfig(), configExtension), ...createConfig);\nconst twMerge = /*#__PURE__*/createTailwindMerge(getDefaultConfig);\nexport { createTailwindMerge, extendTailwindMerge, fromTheme, getDefaultConfig, mergeConfigs, twJoin, twMerge, validators };\n//# sourceMappingURL=bundle-mjs.mjs.map\n","import { type ClassValue, clsx } from \"clsx\"\nimport { twMerge } from \"tailwind-merge\"\n\n/**\n * Combina clases de forma inteligente, resolviendo conflictos de Tailwind CSS.\n * @param {...ClassValue} inputs - Clases a combinar.\n * @returns {string} - Cadena de clases finales.\n */\nexport function cn(...inputs: ClassValue[]): string {\n return twMerge(clsx(inputs))\n}\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\n\nexport interface ActionCardProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Título de la acción\n */\n title: string;\n \n /**\n * Descripción de la acción\n */\n description: string;\n \n /**\n * Ícono de la acción (React node)\n */\n icon: React.ReactNode;\n \n /**\n * Botón de acción (CTA) opcional\n */\n action?: {\n label: string;\n onClick: () => void;\n };\n \n /**\n * Callback al hacer clic en toda la card\n */\n onClick?: () => void;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n/**\n * Componente ActionCard\n * \n * Card con ícono, título, descripción y call-to-action opcional.\n * Ideal para dashboards, acciones rápidas y notificaciones.\n * \n * @example\n * ```tsx\n * <ActionCard\n * icon={<Package size={32} color=\"#d48620\" strokeWidth={2} />}\n * title=\"Identify Low Inventory Items\"\n * description=\"Find SKUs with less than 5 days of inventory remaining.\"\n * action={{\n * label: \"Show low inventory\",\n * onClick: () => navigate('/inventory/low')\n * }}\n * />\n * ```\n */\nexport const ActionCard = React.forwardRef<HTMLDivElement, ActionCardProps>(\n (\n {\n title,\n description,\n icon,\n action,\n onClick,\n className,\n ...props\n },\n ref\n ) => {\n return (\n <div\n ref={ref}\n onClick={onClick}\n className={cn(\n 'bg-white border border-[#ecebf0] rounded-xl p-5 flex gap-2',\n onClick && 'cursor-pointer hover:shadow-md transition-shadow',\n className\n )}\n style={{ width: '350px' }}\n {...props}\n >\n {/* Ícono */}\n <div className=\"flex items-center justify-center shrink-0\">\n {icon}\n </div>\n\n {/* Contenido */}\n <div className=\"flex-1 flex flex-col gap-2 min-w-0\">\n {/* Título */}\n <h3\n className=\"text-base leading-5 font-semibold text-[#312e4d] capitalize\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {title}\n </h3>\n\n {/* Descripción */}\n <p\n className=\"text-sm leading-[18px] font-normal text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {description}\n </p>\n\n {/* CTA Button */}\n {action && (\n <button\n onClick={(e) => {\n e.stopPropagation();\n action.onClick();\n }}\n className=\"text-sm leading-[18px] font-semibold text-[#00995a] hover:underline self-start\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {action.label}\n </button>\n )}\n </div>\n </div>\n );\n }\n);\n\nActionCard.displayName = 'ActionCard';\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nconst toKebabCase = (string) => string.replace(/([a-z0-9])([A-Z])/g, \"$1-$2\").toLowerCase();\nconst toCamelCase = (string) => string.replace(\n /^([A-Z])|[\\s-_]+(\\w)/g,\n (match, p1, p2) => p2 ? p2.toUpperCase() : p1.toLowerCase()\n);\nconst toPascalCase = (string) => {\n const camelCase = toCamelCase(string);\n return camelCase.charAt(0).toUpperCase() + camelCase.slice(1);\n};\nconst mergeClasses = (...classes) => classes.filter((className, index, array) => {\n return Boolean(className) && className.trim() !== \"\" && array.indexOf(className) === index;\n}).join(\" \").trim();\nconst hasA11yProp = (props) => {\n for (const prop in props) {\n if (prop.startsWith(\"aria-\") || prop === \"role\" || prop === \"title\") {\n return true;\n }\n }\n};\n\nexport { hasA11yProp, mergeClasses, toCamelCase, toKebabCase, toPascalCase };\n//# sourceMappingURL=utils.js.map\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nvar defaultAttributes = {\n xmlns: \"http://www.w3.org/2000/svg\",\n width: 24,\n height: 24,\n viewBox: \"0 0 24 24\",\n fill: \"none\",\n stroke: \"currentColor\",\n strokeWidth: 2,\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\"\n};\n\nexport { defaultAttributes as default };\n//# sourceMappingURL=defaultAttributes.js.map\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport { forwardRef, createElement } from 'react';\nimport defaultAttributes from './defaultAttributes.js';\nimport { mergeClasses, hasA11yProp } from './shared/src/utils.js';\n\nconst Icon = forwardRef(\n ({\n color = \"currentColor\",\n size = 24,\n strokeWidth = 2,\n absoluteStrokeWidth,\n className = \"\",\n children,\n iconNode,\n ...rest\n }, ref) => createElement(\n \"svg\",\n {\n ref,\n ...defaultAttributes,\n width: size,\n height: size,\n stroke: color,\n strokeWidth: absoluteStrokeWidth ? Number(strokeWidth) * 24 / Number(size) : strokeWidth,\n className: mergeClasses(\"lucide\", className),\n ...!children && !hasA11yProp(rest) && { \"aria-hidden\": \"true\" },\n ...rest\n },\n [\n ...iconNode.map(([tag, attrs]) => createElement(tag, attrs)),\n ...Array.isArray(children) ? children : [children]\n ]\n )\n);\n\nexport { Icon as default };\n//# sourceMappingURL=Icon.js.map\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport { forwardRef, createElement } from 'react';\nimport { mergeClasses, toKebabCase, toPascalCase } from './shared/src/utils.js';\nimport Icon from './Icon.js';\n\nconst createLucideIcon = (iconName, iconNode) => {\n const Component = forwardRef(\n ({ className, ...props }, ref) => createElement(Icon, {\n ref,\n iconNode,\n className: mergeClasses(\n `lucide-${toKebabCase(toPascalCase(iconName))}`,\n `lucide-${iconName}`,\n className\n ),\n ...props\n })\n );\n Component.displayName = toPascalCase(iconName);\n return Component;\n};\n\nexport { createLucideIcon as default };\n//# sourceMappingURL=createLucideIcon.js.map\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M21.801 10A10 10 0 1 1 17 3.335\", key: \"yps3ct\" }],\n [\"path\", { d: \"m9 11 3 3L22 4\", key: \"1pflzl\" }]\n];\nconst CircleCheckBig = createLucideIcon(\"circle-check-big\", __iconNode);\n\nexport { __iconNode, CircleCheckBig as default };\n//# sourceMappingURL=circle-check-big.js.map\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"circle\", { cx: \"12\", cy: \"12\", r: \"10\", key: \"1mglay\" }],\n [\"path\", { d: \"m9 12 2 2 4-4\", key: \"dzmm74\" }]\n];\nconst CircleCheck = createLucideIcon(\"circle-check\", __iconNode);\n\nexport { __iconNode, CircleCheck as default };\n//# sourceMappingURL=circle-check.js.map\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"circle\", { cx: \"12\", cy: \"12\", r: \"10\", key: \"1mglay\" }],\n [\"path\", { d: \"M12 16v-4\", key: \"1dtifu\" }],\n [\"path\", { d: \"M12 8h.01\", key: \"e9boi3\" }]\n];\nconst Info = createLucideIcon(\"info\", __iconNode);\n\nexport { __iconNode, Info as default };\n//# sourceMappingURL=info.js.map\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\n \"path\",\n {\n d: \"M11 21.73a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16V8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73z\",\n key: \"1a0edw\"\n }\n ],\n [\"path\", { d: \"M12 22V12\", key: \"d0xqtd\" }],\n [\"polyline\", { points: \"3.29 7 12 12 20.71 7\", key: \"ousv84\" }],\n [\"path\", { d: \"m7.5 4.27 9 5.15\", key: \"1c824w\" }]\n];\nconst Package = createLucideIcon(\"package\", __iconNode);\n\nexport { __iconNode, Package as default };\n//# sourceMappingURL=package.js.map\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\n \"path\",\n { d: \"M4 2v20l2-1 2 1 2-1 2 1 2-1 2 1 2-1 2 1V2l-2 1-2-1-2 1-2-1-2 1-2-1-2 1Z\", key: \"q3az6g\" }\n ],\n [\"path\", { d: \"M14 8H8\", key: \"1l3xfs\" }],\n [\"path\", { d: \"M16 12H8\", key: \"1fr5h0\" }],\n [\"path\", { d: \"M13 16H8\", key: \"wsln4y\" }]\n];\nconst ReceiptText = createLucideIcon(\"receipt-text\", __iconNode);\n\nexport { __iconNode, ReceiptText as default };\n//# sourceMappingURL=receipt-text.js.map\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"circle\", { cx: \"6\", cy: \"19\", r: \"3\", key: \"1kj8tv\" }],\n [\"path\", { d: \"M9 19h8.5a3.5 3.5 0 0 0 0-7h-11a3.5 3.5 0 0 1 0-7H15\", key: \"1d8sl\" }],\n [\"circle\", { cx: \"18\", cy: \"5\", r: \"3\", key: \"gq8acd\" }]\n];\nconst Route = createLucideIcon(\"route\", __iconNode);\n\nexport { __iconNode, Route as default };\n//# sourceMappingURL=route.js.map\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\n \"path\",\n {\n d: \"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3\",\n key: \"wmoenq\"\n }\n ],\n [\"path\", { d: \"M12 9v4\", key: \"juzpu7\" }],\n [\"path\", { d: \"M12 17h.01\", key: \"p32p05\" }]\n];\nconst TriangleAlert = createLucideIcon(\"triangle-alert\", __iconNode);\n\nexport { __iconNode, TriangleAlert as default };\n//# sourceMappingURL=triangle-alert.js.map\n","/**\n * @license lucide-react v0.534.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M18 6 6 18\", key: \"1bl5f8\" }],\n [\"path\", { d: \"m6 6 12 12\", key: \"d8bk6v\" }]\n];\nconst X = createLucideIcon(\"x\", __iconNode);\n\nexport { __iconNode, X as default };\n//# sourceMappingURL=x.js.map\n","import * as React from 'react';\nimport { AlertTriangle, Info } from 'lucide-react';\nimport { cn } from '../../lib/utils';\n\nexport interface BannerAlertsProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Variante del banner alert\n * @default \"information\"\n */\n variant?: 'warning' | 'information' | 'grey';\n \n /**\n * Título del alert\n */\n title: string;\n \n /**\n * Descripción del alert\n */\n description: string;\n \n /**\n * Icono personalizado (opcional)\n */\n icon?: React.ReactNode;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n/**\n * Componente BannerAlerts - Banners informativos con diferentes variantes\n * \n * Muestra mensajes de alerta con tres variantes:\n * - warning: Para alertas de advertencia (naranja)\n * - information: Para información general (azul)\n * - grey: Para notificaciones neutras (gris)\n * \n * Cada banner incluye un icono, título y descripción.\n */\nconst BannerAlerts = React.forwardRef<HTMLDivElement, BannerAlertsProps>(\n (\n {\n variant = 'information',\n title,\n description,\n icon,\n className,\n ...props\n },\n ref\n ) => {\n // Configuración de estilos por variante\n const variantStyles = {\n warning: {\n container: 'bg-[#fff3e8]',\n text: 'text-[#d48620]',\n icon: <AlertTriangle size={24} className=\"text-[#d48620]\" />,\n },\n information: {\n container: 'bg-[#e3f2ff]',\n text: 'text-[#4087fb]',\n icon: <Info size={24} className=\"text-[#4087fb]\" />,\n },\n grey: {\n container: 'bg-[#f4f4f4]',\n text: 'text-[#6e6f6e]',\n icon: <Info size={24} className=\"text-[#202020]\" />,\n },\n };\n\n const currentVariant = variantStyles[variant];\n const displayIcon = icon || currentVariant.icon;\n\n return (\n <div\n ref={ref}\n className={cn(\n 'flex items-center gap-3 p-4 rounded-lg',\n currentVariant.container,\n currentVariant.text,\n className\n )}\n role=\"alert\"\n aria-live=\"polite\"\n {...props}\n >\n {/* Icono */}\n <div className=\"flex-shrink-0\">{displayIcon}</div>\n\n {/* Contenido */}\n <div className=\"flex flex-col gap-0 flex-1 min-w-0\">\n {/* Título */}\n <div className=\"font-semibold text-sm leading-[18px]\">\n {title}\n </div>\n\n {/* Descripción */}\n <div className=\"font-normal text-sm leading-[18px]\">\n {description}\n </div>\n </div>\n </div>\n );\n }\n);\n\nBannerAlerts.displayName = 'BannerAlerts';\n\nexport { BannerAlerts };\n\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\";\nvar REACT_LAZY_TYPE = Symbol.for(\"react.lazy\");\nvar use = React[\" use \".trim().toString()];\nfunction isPromiseLike(value) {\n return typeof value === \"object\" && value !== null && \"then\" in value;\n}\nfunction isLazyComponent(element) {\n return element != null && typeof element === \"object\" && \"$$typeof\" in element && element.$$typeof === REACT_LAZY_TYPE && \"_payload\" in element && isPromiseLike(element._payload);\n}\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n let { children, ...slotProps } = props;\n if (isLazyComponent(children) && typeof use === \"function\") {\n children = use(children._payload);\n }\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 let { children, ...slotProps } = props;\n if (isLazyComponent(children) && typeof use === \"function\") {\n children = use(children._payload);\n }\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","/**\n * Copyright 2022 Joe Bell. All rights reserved.\n *\n * This file is licensed to you under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with the\n * License. You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR REPRESENTATIONS OF ANY KIND, either express or implied. See the\n * License for the specific language governing permissions and limitations under\n * the License.\n */ import { clsx } from \"clsx\";\nconst falsyToString = (value)=>typeof value === \"boolean\" ? `${value}` : value === 0 ? \"0\" : value;\nexport const cx = clsx;\nexport const cva = (base, config)=>(props)=>{\n var _config_compoundVariants;\n if ((config === null || config === void 0 ? void 0 : config.variants) == null) return cx(base, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);\n const { variants, defaultVariants } = config;\n const getVariantClassNames = Object.keys(variants).map((variant)=>{\n const variantProp = props === null || props === void 0 ? void 0 : props[variant];\n const defaultVariantProp = defaultVariants === null || defaultVariants === void 0 ? void 0 : defaultVariants[variant];\n if (variantProp === null) return null;\n const variantKey = falsyToString(variantProp) || falsyToString(defaultVariantProp);\n return variants[variant][variantKey];\n });\n const propsWithoutUndefined = props && Object.entries(props).reduce((acc, param)=>{\n let [key, value] = param;\n if (value === undefined) {\n return acc;\n }\n acc[key] = value;\n return acc;\n }, {});\n const getCompoundVariantClassNames = config === null || config === void 0 ? void 0 : (_config_compoundVariants = config.compoundVariants) === null || _config_compoundVariants === void 0 ? void 0 : _config_compoundVariants.reduce((acc, param)=>{\n let { class: cvClass, className: cvClassName, ...compoundVariantOptions } = param;\n return Object.entries(compoundVariantOptions).every((param)=>{\n let [key, value] = param;\n return Array.isArray(value) ? value.includes({\n ...defaultVariants,\n ...propsWithoutUndefined\n }[key]) : ({\n ...defaultVariants,\n ...propsWithoutUndefined\n })[key] === value;\n }) ? [\n ...acc,\n cvClass,\n cvClassName\n ] : acc;\n }, []);\n return cx(base, getVariantClassNames, getCompoundVariantClassNames, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);\n };\n\n","import * as React from 'react';\nimport { Slot } from '@radix-ui/react-slot';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { cn } from '../../lib/utils';\n\nconst buttonVariants = cva(\n 'inline-flex items-center justify-center gap-2 rounded font-semibold transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50',\n {\n variants: {\n variant: {\n primary:\n 'bg-[#00b56b] text-white border border-[#00b56b] hover:bg-[#00995a] hover:border-[#00995a] active:bg-[#007a48] active:border-[#007a48] disabled:bg-[#e0e0e0] disabled:border-[#e0e0e0] disabled:text-[#9e9e9e]',\n secondary:\n 'bg-transparent text-[#312e4d] border border-[#00b56b] hover:bg-[#e6f8ef] hover:border-[#00995a] active:bg-[#00b56b]/10 active:border-[#007a48] disabled:bg-transparent disabled:border-[#e0e0e0] disabled:text-[#9e9e9e]',\n alert:\n 'bg-[#ff305f] text-white border border-[#a80023] hover:bg-[#d4002c] hover:border-[#a80023] active:bg-[#a80023] active:border-[#a80023] disabled:bg-[#e0e0e0] disabled:border-[#e0e0e0] disabled:text-[#9e9e9e]',\n ghost:\n 'bg-transparent text-[#00995a] border-0 hover:bg-[#e6f8ef] hover:text-[#00995a] active:bg-[#00b56b]/10 active:text-[#007a48] disabled:bg-transparent disabled:text-[#9e9e9e]',\n plain:\n 'bg-transparent text-[#00995a] border-0 p-0 h-auto hover:text-[#00995a] hover:underline active:text-[#007a48] disabled:text-[#9e9e9e] disabled:no-underline',\n },\n size: {\n small: 'h-8 px-3 py-2 text-sm',\n medium: 'h-9 px-4 py-2 text-sm',\n large: 'h-11 px-5 py-2.5 text-base',\n },\n iconOnly: {\n true: 'aspect-square',\n },\n },\n compoundVariants: [\n {\n size: 'small',\n iconOnly: true,\n className: 'h-8 w-8 p-0',\n },\n {\n size: 'medium',\n iconOnly: true,\n className: 'h-10 w-10 p-0',\n },\n {\n size: 'large',\n iconOnly: true,\n className: 'h-11 w-11 p-0',\n },\n {\n variant: 'plain',\n size: 'small',\n className: 'h-auto px-0 py-0',\n },\n {\n variant: 'plain',\n size: 'medium',\n className: 'h-auto px-0 py-0',\n },\n {\n variant: 'plain',\n size: 'large',\n className: 'h-auto px-0 py-0',\n },\n ],\n defaultVariants: {\n variant: 'primary',\n size: 'medium',\n iconOnly: false,\n },\n }\n);\n\nexport interface ButtonProps\n extends React.ButtonHTMLAttributes<HTMLButtonElement>,\n VariantProps<typeof buttonVariants> {\n asChild?: boolean;\n leftIcon?: React.ReactNode;\n rightIcon?: React.ReactNode;\n}\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n (\n {\n className,\n variant,\n size,\n iconOnly,\n asChild = false,\n leftIcon,\n rightIcon,\n children,\n ...props\n },\n ref\n ) => {\n const Comp = asChild ? Slot : 'button';\n \n // When using asChild, we render children directly without wrapping\n if (asChild) {\n return (\n <Comp\n className={cn(buttonVariants({ variant, size, iconOnly, className }))}\n ref={ref}\n {...props}\n >\n {children}\n </Comp>\n );\n }\n \n return (\n <Comp\n className={cn(buttonVariants({ variant, size, iconOnly, className }))}\n ref={ref}\n {...props}\n >\n {leftIcon && !iconOnly && (\n <span className=\"inline-flex shrink-0\">{leftIcon}</span>\n )}\n {iconOnly ? leftIcon || children : children}\n {rightIcon && !iconOnly && (\n <span className=\"inline-flex shrink-0\">{rightIcon}</span>\n )}\n </Comp>\n );\n }\n);\n\nButton.displayName = 'Button';\n\nexport { Button, buttonVariants };\n\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\n\n// Asset URLs from Figma (valid for 7 days)\nconst LOGO_ASSETS = {\n largeDark: 'https://www.figma.com/api/mcp/asset/4d8371e7-dff3-4ec8-bbce-b93185151f4c',\n largeLight: 'https://www.figma.com/api/mcp/asset/8a7267d5-2fb8-494e-a13a-3795b42fde22',\n smallDark: 'https://www.figma.com/api/mcp/asset/9d2e5067-f587-40b6-b0a5-5ce6da0aad4c',\n smallLight: 'https://www.figma.com/api/mcp/asset/f01bbe9b-2dae-44fe-892f-97ff47e10e8e',\n gradientLarge: 'https://www.figma.com/api/mcp/asset/972e7e1a-3343-4868-9c4d-97d6dfce3ce8',\n};\n\nexport interface BrandIconsProps extends React.ImgHTMLAttributes<HTMLImageElement> {\n /**\n * Tamaño del logo\n * @default \"large\"\n */\n size?: 'large' | 'small';\n \n /**\n * Modo de color del logo\n * @default \"dark\"\n */\n mode?: 'dark' | 'light';\n \n /**\n * Si el logo tiene gradiente\n * @default false\n */\n gradient?: boolean;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n/**\n * Componente BrandIcons - Logo de Chiperos\n * \n * Muestra el logo de la marca Chiperos con diferentes variantes:\n * - Tamaños: large (143x32px) y small (40x32px)\n * - Modos: dark y light\n * - Con o sin gradiente\n */\nconst BrandIcons = React.forwardRef<HTMLImageElement, BrandIconsProps>(\n (\n {\n size = 'large',\n mode = 'dark',\n gradient = false,\n className,\n alt = 'Chiperos Logo',\n ...props\n },\n ref\n ) => {\n // Determinar la URL del asset según las props\n const getLogoSrc = (): string => {\n if (gradient && size === 'large') {\n return LOGO_ASSETS.gradientLarge;\n }\n \n if (size === 'large' && mode === 'dark') {\n return LOGO_ASSETS.largeDark;\n }\n \n if (size === 'large' && mode === 'light') {\n return LOGO_ASSETS.largeLight;\n }\n \n if (size === 'small' && mode === 'dark') {\n return LOGO_ASSETS.smallDark;\n }\n \n if (size === 'small' && mode === 'light') {\n return LOGO_ASSETS.smallLight;\n }\n \n // Default: large dark\n return LOGO_ASSETS.largeDark;\n };\n\n // Determinar las dimensiones según el tamaño\n const dimensions = {\n large: { width: 143, height: 32 },\n small: { width: 40, height: 32 },\n };\n\n const { width, height } = dimensions[size];\n\n return (\n <img\n ref={ref}\n src={getLogoSrc()}\n alt={alt}\n width={width}\n height={height}\n className={cn('inline-block', className)}\n {...props}\n />\n );\n }\n);\n\nBrandIcons.displayName = 'BrandIcons';\n\nexport { BrandIcons, LOGO_ASSETS };\n\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\n\nexport interface CardsGridProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Número de columnas del grid\n * @example 3\n */\n columns: number;\n \n /**\n * Gap entre las cards (en Tailwind units o px)\n * @default 4\n * @example 6 // gap-6\n * @example \"1.5rem\" // custom gap\n */\n gap?: number | string;\n \n /**\n * Número de columnas en tablets (opcional, responsive)\n * @example 2\n */\n tabletColumns?: number;\n \n /**\n * Número de columnas en móviles (opcional, responsive)\n * @default 1\n * @example 1\n */\n mobileColumns?: number;\n \n /**\n * Children (cards u otros componentes)\n */\n children: React.ReactNode;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n/**\n * Componente CardsGrid\n * \n * Contenedor de grid para organizar cards de forma responsive.\n * Ajusta automáticamente el ancho de las cards al 100% del espacio disponible.\n * \n * @example\n * ```tsx\n * <CardsGrid columns={3} gap={6}>\n * <FeatureCard title=\"Feature 1\" description=\"...\" icon={<Icon />} />\n * <FeatureCard title=\"Feature 2\" description=\"...\" icon={<Icon />} />\n * <FeatureCard title=\"Feature 3\" description=\"...\" icon={<Icon />} />\n * </CardsGrid>\n * ```\n * \n * @example Con responsive\n * ```tsx\n * <CardsGrid columns={3} tabletColumns={2} mobileColumns={1} gap={4}>\n * <ActionCard title=\"Action 1\" description=\"...\" icon={<Icon />} />\n * <ActionCard title=\"Action 2\" description=\"...\" icon={<Icon />} />\n * </CardsGrid>\n * ```\n */\nexport const CardsGrid = React.forwardRef<HTMLDivElement, CardsGridProps>(\n (\n {\n columns,\n gap = 4,\n tabletColumns,\n mobileColumns = 1,\n children,\n className,\n style,\n ...props\n },\n ref\n ) => {\n // Convertir gap a clase de Tailwind si es número\n const getGapClass = () => {\n if (typeof gap === 'number') {\n return `gap-${gap}`;\n }\n return '';\n };\n\n // Crear clases responsive para columnas\n const getColumnsClasses = () => {\n const classes = [];\n \n // Mobile (default)\n classes.push(`grid-cols-${mobileColumns}`);\n \n // Tablet\n if (tabletColumns) {\n classes.push(`md:grid-cols-${tabletColumns}`);\n }\n \n // Desktop\n classes.push(`lg:grid-cols-${columns}`);\n \n return classes.join(' ');\n };\n\n // Style para gap custom (si es string)\n const customStyle = typeof gap === 'string' \n ? { gap, ...style } \n : style;\n\n return (\n <div\n ref={ref}\n className={cn(\n 'grid w-full',\n getGapClass(),\n getColumnsClasses(),\n className\n )}\n style={customStyle}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n // Forzar width 100% en cada card\n return React.cloneElement(child, {\n ...child.props,\n className: cn('w-full', child.props.className),\n } as any);\n }\n return child;\n })}\n </div>\n );\n }\n);\n\nCardsGrid.displayName = 'CardsGrid';\n\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\n\nexport interface FeatureCardProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Título de la característica\n */\n title: string;\n \n /**\n * Descripción de la característica\n */\n description: string;\n \n /**\n * Ícono de la característica (React node)\n */\n icon: React.ReactNode;\n \n /**\n * Background del contenedor del ícono\n * @default \"#e6f8ef\"\n */\n iconBackground?: string;\n \n /**\n * Callback al hacer clic en la card\n */\n onClick?: () => void;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n/**\n * Componente FeatureCard\n * \n * Card centrada para destacar características o features.\n * Ideal para landing pages, páginas de bienvenida y showcase de características.\n * \n * @example\n * ```tsx\n * <FeatureCard\n * icon={<Lock size={32} color=\"#00995a\" strokeWidth={2} />}\n * title=\"Built for Security\"\n * description=\"Your data is protected by enterprise-grade, zero-trust architecture.\"\n * />\n * ```\n */\nexport const FeatureCard = React.forwardRef<HTMLDivElement, FeatureCardProps>(\n (\n {\n title,\n description,\n icon,\n iconBackground = '#e6f8ef',\n onClick,\n className,\n ...props\n },\n ref\n ) => {\n return (\n <div\n ref={ref}\n onClick={onClick}\n className={cn(\n 'bg-white border border-[#ecebf0] rounded-lg p-8 flex flex-col items-center gap-8 w-96',\n onClick && 'cursor-pointer hover:shadow-md transition-shadow',\n className\n )}\n {...props}\n >\n {/* Ícono */}\n <div\n className=\"flex items-center justify-center rounded-lg shrink-0\"\n style={{\n width: '56px',\n height: '56px',\n backgroundColor: iconBackground,\n }}\n >\n {icon}\n </div>\n\n {/* Contenido */}\n <div className=\"flex flex-col gap-2 items-center text-center\" style={{ width: '300px' }}>\n {/* Título */}\n <h3\n className=\"text-2xl leading-8 font-medium text-[#312e4d]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {title}\n </h3>\n \n {/* Descripción */}\n <p\n className=\"text-base leading-5 font-normal text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {description}\n </p>\n </div>\n </div>\n );\n }\n);\n\nFeatureCard.displayName = 'FeatureCard';\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\n\nexport interface KPIComparisonCustomProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Ícono izquierdo personalizado\n */\n icon: React.ReactNode;\n \n /**\n * Texto principal (ej: porcentaje, valor, etc.)\n */\n primaryText: string;\n \n /**\n * Color del texto principal\n * @default \"#312e4d\"\n */\n primaryTextColor?: string;\n \n /**\n * Texto secundario/label\n */\n secondaryText?: string;\n \n /**\n * Color del texto secundario\n * @default \"#575385\"\n */\n secondaryTextColor?: string;\n \n /**\n * Ícono derecho opcional (ej: warning)\n */\n rightIcon?: React.ReactNode;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n/**\n * Componente KPIComparisonCustom\n * \n * Versión completamente personalizable de KPIComparison donde puedes\n * especificar cualquier ícono, texto y colores sin limitaciones de\n * tendencias predefinidas.\n * \n * @example\n * ```tsx\n * <KPIComparisonCustom\n * icon={<CustomIcon />}\n * primaryText=\"1.2M\"\n * primaryTextColor=\"#00995a\"\n * secondaryText=\"total users\"\n * rightIcon={<InfoIcon />}\n * />\n * ```\n */\nexport const KPIComparisonCustom = React.forwardRef<HTMLDivElement, KPIComparisonCustomProps>(\n (\n {\n icon,\n primaryText,\n primaryTextColor = '#312e4d',\n secondaryText,\n secondaryTextColor = '#575385',\n rightIcon,\n className,\n ...props\n },\n ref\n ) => {\n return (\n <div\n ref={ref}\n className={cn(\n 'flex items-center justify-between w-full',\n className\n )}\n {...props}\n >\n <div className=\"flex items-center gap-1\">\n {/* Ícono izquierdo */}\n <div className=\"shrink-0\">\n {icon}\n </div>\n \n {/* Texto principal */}\n <span\n className=\"text-xs leading-[14px] font-normal whitespace-nowrap\"\n style={{ \n fontFamily: 'Causten Round, sans-serif',\n color: primaryTextColor,\n }}\n >\n {primaryText}\n </span>\n \n {/* Texto secundario */}\n {secondaryText && (\n <span\n className=\"text-xs leading-[14px] font-normal whitespace-nowrap\"\n style={{ \n fontFamily: 'Causten Round, sans-serif',\n color: secondaryTextColor,\n }}\n >\n {secondaryText}\n </span>\n )}\n </div>\n \n {/* Ícono derecho opcional */}\n {rightIcon && (\n <div className=\"shrink-0\">\n {rightIcon}\n </div>\n )}\n </div>\n );\n }\n);\n\nKPIComparisonCustom.displayName = 'KPIComparisonCustom';\n\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\n\nexport interface KPIComparisonProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Porcentaje de cambio (puede ser positivo o negativo)\n * @example 1.0, -10.5\n */\n percentage: number;\n \n /**\n * Tendencia del KPI\n * - 'positive': Verde con flecha arriba\n * - 'negative': Rojo con flecha abajo\n */\n trend: 'positive' | 'negative';\n \n /**\n * Texto descriptivo al lado del porcentaje\n * @default \"KPI comparison\"\n */\n label?: string;\n \n /**\n * Mostrar ícono de alerta/warning\n * @default false\n */\n showWarning?: boolean;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n// Ícono de tendencia arriba (TrendUp)\nconst TrendUpIcon: React.FC<{ className?: string }> = ({ className }) => (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n >\n <path\n d=\"M11 3L6.5 7.5L4 5L1 8\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M8 3H11V6\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\n// Ícono de tendencia abajo (TrendDown)\nconst TrendDownIcon: React.FC<{ className?: string }> = ({ className }) => (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n >\n <path\n d=\"M11 9L6.5 4.5L4 7L1 4\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M8 9H11V6\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\n// Ícono de advertencia (WarningCircle)\nconst WarningIcon: React.FC<{ className?: string }> = ({ className }) => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n >\n <circle\n cx=\"8\"\n cy=\"8\"\n r=\"6.375\"\n stroke=\"currentColor\"\n strokeWidth=\"1.25\"\n />\n <path\n d=\"M8 4.5V8.5\"\n stroke=\"currentColor\"\n strokeWidth=\"1.25\"\n strokeLinecap=\"round\"\n />\n <circle\n cx=\"8\"\n cy=\"11\"\n r=\"0.5\"\n fill=\"currentColor\"\n />\n </svg>\n);\n\n/**\n * Componente KPIComparison\n * \n * Muestra una comparación de KPI con tendencia (positiva o negativa)\n * y un ícono de alerta opcional.\n * \n * @example\n * ```tsx\n * <KPIComparison percentage={1.0} trend=\"positive\" label=\"KPI comparison\" />\n * <KPIComparison percentage={-10} trend=\"negative\" showWarning={true} />\n * ```\n */\nexport const KPIComparison = React.forwardRef<HTMLDivElement, KPIComparisonProps>(\n (\n {\n percentage,\n trend,\n label = 'KPI comparison',\n showWarning = false,\n className,\n ...props\n },\n ref\n ) => {\n const isPositive = trend === 'positive';\n const formattedPercentage = percentage > 0 ? `+${percentage.toFixed(1)}%` : `${percentage.toFixed(1)}%`;\n \n return (\n <div\n ref={ref}\n className={cn(\n 'flex items-center justify-between w-full',\n className\n )}\n {...props}\n >\n <div className=\"flex items-center gap-1\">\n {isPositive ? (\n <TrendUpIcon className=\"text-[#00995a] shrink-0\" />\n ) : (\n <TrendDownIcon className=\"text-[#d4002c] shrink-0\" />\n )}\n \n <span\n className={cn(\n 'text-xs leading-[14px] font-normal whitespace-nowrap',\n isPositive ? 'text-[#00995a]' : 'text-[#d4002c]'\n )}\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {formattedPercentage}\n </span>\n \n <span\n className=\"text-xs leading-[14px] font-normal text-[#575385] whitespace-nowrap\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {label}\n </span>\n </div>\n \n {showWarning && (\n <WarningIcon className=\"text-[#d4002c] shrink-0\" />\n )}\n </div>\n );\n }\n);\n\nKPIComparison.displayName = 'KPIComparison';\n\n// Export custom variant\nexport { KPIComparisonCustom } from './KPIComparisonCustom';\nexport type { KPIComparisonCustomProps } from './KPIComparisonCustom';\n\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\n\nexport interface KPICardCustomProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'content'> {\n /**\n * Título de la card\n */\n title: string;\n \n /**\n * Contenido principal (puede ser cualquier React node)\n */\n content: React.ReactNode;\n \n /**\n * Contenido secundario/descriptivo (opcional)\n */\n description?: React.ReactNode;\n \n /**\n * Contenido del footer (opcional)\n */\n footer?: React.ReactNode;\n \n /**\n * Tag personalizado (opcional)\n */\n tag?: {\n label: string;\n variant?: 'default' | 'red' | 'green' | 'blue' | 'yellow';\n };\n \n /**\n * Ícono personalizado\n */\n icon: React.ReactNode;\n \n /**\n * Callback al hacer clic en la card\n */\n onClick?: () => void;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\nconst tagStyles = {\n default: {\n bg: '#f4f4f4',\n border: '#c6c6c6',\n text: '#6e6f6e',\n },\n red: {\n bg: '#ffecf0',\n border: '#ff8ea7',\n text: '#ff305f',\n },\n green: {\n bg: '#e6f7f0',\n border: '#8ed9b8',\n text: '#00995a',\n },\n blue: {\n bg: '#e8f4fd',\n border: '#8ec9ed',\n text: '#0066cc',\n },\n yellow: {\n bg: '#fff9e6',\n border: '#ffd966',\n text: '#cc8800',\n },\n};\n\n/**\n * Componente KPICardCustom\n * \n * Versión completamente personalizable de KPICard donde puedes\n * especificar cualquier contenido usando React nodes, sin limitaciones\n * de estructura predefinida.\n * \n * @example\n * ```tsx\n * <KPICardCustom\n * title=\"Custom Metric\"\n * icon={<CustomIcon />}\n * content={\n * <div>\n * <h2>42</h2>\n * <p>Custom layout</p>\n * </div>\n * }\n * description=\"Any custom description\"\n * footer={<button>Action</button>}\n * tag={{ label: \"New\", variant: \"green\" }}\n * />\n * ```\n */\nexport const KPICardCustom = React.forwardRef<HTMLDivElement, KPICardCustomProps>(\n (\n {\n title,\n content,\n description,\n footer,\n tag,\n icon,\n onClick,\n className,\n ...props\n },\n ref\n ) => {\n const tagStyle = tag ? tagStyles[tag.variant || 'default'] : tagStyles.default;\n\n return (\n <div\n ref={ref}\n onClick={onClick}\n className={cn(\n 'bg-white border border-[#ecebf0] rounded-xl p-5 px-8 flex gap-2',\n onClick && 'cursor-pointer hover:shadow-md transition-shadow',\n className\n )}\n {...props}\n >\n {/* Ícono */}\n <div className=\"flex items-center justify-center shrink-0\">\n {icon}\n </div>\n\n {/* Contenido */}\n <div className=\"flex-1 flex flex-col gap-2 min-w-0\">\n {/* Título y Tag */}\n <div className=\"flex items-center justify-between gap-2 w-full\">\n <h3\n className=\"text-base leading-5 font-medium text-[#575385] flex-1 min-w-0\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {title}\n </h3>\n \n {tag && (\n <span\n className=\"px-2 py-1 rounded-2xl text-sm leading-[18px] font-medium border shrink-0\"\n style={{\n backgroundColor: tagStyle.bg,\n borderColor: tagStyle.border,\n color: tagStyle.text,\n fontFamily: 'Causten Round, sans-serif',\n }}\n >\n {tag.label}\n </span>\n )}\n </div>\n\n {/* Contenido principal */}\n <div className=\"min-w-0\">\n {content}\n </div>\n\n {/* Descripción */}\n {description && (\n <div className=\"min-w-0\">\n {description}\n </div>\n )}\n\n {/* Footer */}\n {footer && (\n <div className=\"min-w-0\">\n {footer}\n </div>\n )}\n </div>\n </div>\n );\n }\n);\n\nKPICardCustom.displayName = 'KPICardCustom';\n\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\nimport { KPIComparison } from '../KPIComparison';\nimport { TriangleAlert } from 'lucide-react';\n\nexport interface KPICardProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Título de la card\n */\n title: string;\n \n /**\n * Valor principal a mostrar\n */\n value: number | string;\n \n /**\n * Unidad del valor (%, x, etc.)\n * @default \"%\"\n */\n unit?: string;\n \n /**\n * Valor total para mostrar fracción (ej: 3/17)\n * Solo se usa si se proporciona\n */\n total?: number;\n \n /**\n * Texto descriptivo\n */\n description?: string;\n \n /**\n * Datos de comparación KPI (opcional)\n */\n comparison?: {\n percentage: number;\n trend: 'positive' | 'negative';\n label?: string;\n showWarning?: boolean;\n };\n \n /**\n * Tag opcional\n */\n tag?: {\n label: string;\n variant?: 'default' | 'red';\n };\n \n /**\n * Ícono personalizado\n */\n icon?: React.ReactNode;\n \n /**\n * Color del ícono\n * @default \"primary\"\n */\n iconColor?: 'primary' | 'error' | 'brand';\n \n /**\n * Texto adicional del body (para variante Text)\n */\n bodyText?: string;\n \n /**\n * Botón opcional\n */\n button?: {\n label: string;\n onClick?: () => void;\n };\n \n /**\n * Callback al hacer clic en la card\n */\n onClick?: () => void;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n// Ícono de advertencia por defecto (TriangleAlert de lucide-react)\nconst DefaultWarningIcon: React.FC<{ color?: string }> = ({ color = '#312e4d' }) => (\n <TriangleAlert \n size={32} \n color={color}\n strokeWidth={2}\n />\n);\n\n/**\n * Componente KPICard\n * \n * Card completa para mostrar KPIs con diferentes variantes:\n * - Con comparación de tendencia\n * - Con tags\n * - Con descripción\n * - Con botones\n * \n * @example\n * ```tsx\n * <KPICard\n * title=\"Active Users\"\n * value={3}\n * unit=\"%\"\n * description=\"Descriptive text goes here\"\n * comparison={{ percentage: 1.0, trend: \"positive\" }}\n * tag={{ label: \"Monthly\", variant: \"default\" }}\n * />\n * ```\n */\nexport const KPICard = React.forwardRef<HTMLDivElement, KPICardProps>(\n (\n {\n title,\n value,\n unit = '%',\n total,\n description,\n comparison,\n tag,\n icon,\n iconColor = 'primary',\n bodyText,\n button,\n onClick,\n className,\n ...props\n },\n ref\n ) => {\n const iconColors = {\n primary: '#312e4d',\n error: '#d4002c',\n brand: '#00995a',\n };\n\n const tagStyles = {\n default: {\n bg: '#f4f4f4',\n border: '#c6c6c6',\n text: '#6e6f6e',\n },\n red: {\n bg: '#ffecf0',\n border: '#ff8ea7',\n text: '#ff305f',\n },\n };\n\n const tagStyle = tagStyles[tag?.variant || 'default'];\n\n return (\n <div\n ref={ref}\n onClick={onClick}\n className={cn(\n 'bg-white border border-[#ecebf0] rounded-xl p-5 px-8 flex gap-2',\n onClick && 'cursor-pointer hover:shadow-md transition-shadow',\n className\n )}\n {...props}\n >\n {/* Ícono */}\n <div className=\"flex items-center justify-center shrink-0\">\n {icon || <DefaultWarningIcon color={iconColors[iconColor]} />}\n </div>\n\n {/* Contenido */}\n <div className=\"flex-1 flex flex-col gap-2 min-w-0\">\n {/* Título y Tag */}\n <div className=\"flex items-center justify-between gap-2 w-full\">\n <h3\n className=\"text-base leading-5 font-medium text-[#575385] flex-1 min-w-0\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {title}\n </h3>\n \n {tag && (\n <span\n className=\"px-2 py-1 rounded-2xl text-sm leading-[18px] font-medium border shrink-0\"\n style={{\n backgroundColor: tagStyle.bg,\n borderColor: tagStyle.border,\n color: tagStyle.text,\n fontFamily: 'Causten Round, sans-serif',\n }}\n >\n {tag.label}\n </span>\n )}\n </div>\n\n {/* Valor principal */}\n <div className=\"flex items-end gap-1\">\n <span\n className=\"text-xl leading-[22px] font-semibold text-[#312e4d]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {value}\n </span>\n \n {total !== undefined ? (\n <span\n className=\"text-base leading-[18px] font-medium text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n /{total}\n </span>\n ) : unit ? (\n <span\n className=\"text-xs leading-[18px] font-medium text-[#312e4d]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {unit}\n </span>\n ) : null}\n \n {description && (\n <span\n className=\"text-sm leading-[18px] font-normal text-[#575385] flex-1 overflow-hidden text-ellipsis whitespace-nowrap text-right\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {description}\n </span>\n )}\n </div>\n\n {/* Body text adicional (variante Text) */}\n {bodyText && (\n <p\n className=\"text-sm leading-[18px] font-normal text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {bodyText}\n </p>\n )}\n\n {/* Comparación */}\n {comparison && (\n <KPIComparison\n percentage={comparison.percentage}\n trend={comparison.trend}\n label={comparison.label}\n showWarning={comparison.showWarning}\n />\n )}\n\n {/* Botón */}\n {button && (\n <button\n onClick={(e) => {\n e.stopPropagation();\n button.onClick?.();\n }}\n className=\"text-sm leading-[18px] font-semibold text-[#00995a] text-left self-start hover:underline\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {button.label}\n </button>\n )}\n </div>\n </div>\n );\n }\n);\n\nKPICard.displayName = 'KPICard';\n\n// Export custom variant\nexport { KPICardCustom } from './KPICardCustom';\nexport type { KPICardCustomProps } from './KPICardCustom';\n\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\n\nexport interface LoaderProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Tipo de loader\n * @default \"spinner\"\n */\n type?: 'spinner' | 'linear';\n \n /**\n * Controla la visibilidad del loader\n * @default true\n */\n show?: boolean;\n \n /**\n * Variante del loader (active o disabled)\n * @default \"active\"\n */\n variant?: 'active' | 'disabled';\n \n /**\n * Tamaño del spinner (solo para type=\"spinner\")\n * @default 48\n */\n size?: number;\n \n /**\n * Ancho de la barra (solo para type=\"linear\")\n * @default 230\n */\n width?: number;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n/**\n * Componente Loader - Indicadores de carga\n * \n * Muestra indicadores de carga con dos tipos:\n * - spinner: Loader circular que gira\n * - linear: Barra de progreso horizontal animada\n * \n * Incluye parámetro show para controlar visibilidad.\n */\nconst Loader = React.forwardRef<HTMLDivElement, LoaderProps>(\n (\n {\n type = 'spinner',\n show = true,\n variant = 'active',\n size = 48,\n width = 230,\n className,\n ...props\n },\n ref\n ) => {\n // No renderizar si show es false\n if (!show) {\n return null;\n }\n\n // Colores según variante\n const colors = {\n active: '#00b56b',\n disabled: '#a29fba',\n };\n\n const color = colors[variant];\n\n // Spinner circular\n if (type === 'spinner') {\n return (\n <div\n ref={ref}\n className={cn('inline-flex items-center justify-center', className)}\n role=\"status\"\n aria-label=\"Cargando\"\n {...props}\n >\n <div\n className=\"rounded-full animate-spin\"\n style={{\n width: size,\n height: size,\n border: `4px solid transparent`,\n borderTopColor: color,\n borderRightColor: color,\n }}\n />\n <span className=\"sr-only\">Cargando...</span>\n </div>\n );\n }\n\n // Linear progress bar\n return (\n <div\n ref={ref}\n className={cn('relative overflow-hidden rounded-full bg-gray-200', className)}\n style={{\n width,\n height: 8,\n }}\n role=\"progressbar\"\n aria-label=\"Cargando\"\n aria-valuemin={0}\n aria-valuemax={100}\n {...props}\n >\n <div\n className=\"absolute top-0 left-0 h-full rounded-full\"\n style={{\n backgroundColor: color,\n animation: 'linear-progress 1.5s ease-in-out infinite',\n }}\n />\n <span className=\"sr-only\">Cargando...</span>\n </div>\n );\n }\n);\n\nLoader.displayName = 'Loader';\n\nexport { Loader };\n\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\n\nexport interface OptionCardProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onSelect'> {\n /**\n * Título/Nombre de la opción\n */\n title: string;\n \n /**\n * Descripción de la opción\n */\n description: string;\n \n /**\n * Valor asociado (útil para radio groups)\n */\n value: string;\n \n /**\n * Si está seleccionada\n * @default false\n */\n selected?: boolean;\n \n /**\n * Callback cuando se selecciona\n */\n onSelect?: (value: string) => void;\n \n /**\n * Si está deshabilitada\n * @default false\n */\n disabled?: boolean;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n/**\n * Componente OptionCard\n * \n * Card seleccionable con radio button integrado.\n * Ideal para selección de opciones, roles, planes, etc.\n * \n * Estados:\n * - Default: Border gris, radio sin seleccionar\n * - Selected: Border verde, radio seleccionado\n * - Disabled: Opacidad reducida, no interactivo\n * \n * @example\n * ```tsx\n * <OptionCard\n * title=\"Admin\"\n * description=\"Full access to all features and administrative settings\"\n * value=\"admin\"\n * selected={selectedRole === 'admin'}\n * onSelect={(value) => setSelectedRole(value)}\n * />\n * ```\n */\nexport const OptionCard = React.forwardRef<\n HTMLDivElement,\n OptionCardProps\n>(\n (\n {\n title,\n description,\n value,\n selected = false,\n onSelect,\n disabled,\n className,\n ...props\n },\n ref\n ) => {\n const handleClick = () => {\n if (!disabled && onSelect) {\n onSelect(value);\n }\n };\n\n return (\n <div\n ref={ref}\n onClick={handleClick}\n className={cn(\n 'bg-white border border-solid rounded-xl p-4 flex flex-col gap-1 transition-all cursor-pointer',\n selected ? 'border-[#00b56b]' : 'border-[#ecebf0]',\n disabled && 'opacity-50 cursor-not-allowed',\n !disabled && 'hover:shadow-sm',\n className\n )}\n {...props}\n >\n {/* Radio button y título */}\n <div className=\"flex gap-3 items-center h-6\">\n {/* Radio Button */}\n <div className=\"flex items-center justify-center shrink-0 w-6 h-6\">\n <div\n className={cn(\n 'w-6 h-6 rounded-full border-2 flex items-center justify-center transition-colors',\n selected ? 'border-[#00995a]' : 'border-[#a29fba]'\n )}\n >\n {selected && (\n <div className=\"w-3 h-3 rounded-full bg-[#00995a]\" />\n )}\n </div>\n </div>\n\n {/* Título */}\n <h3\n className=\"text-base leading-5 font-medium text-[#312e4d] flex-1\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {title}\n </h3>\n </div>\n\n {/* Descripción */}\n <div className=\"pl-9\">\n <p\n className=\"text-sm leading-[18px] font-normal text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {description}\n </p>\n </div>\n </div>\n );\n }\n);\n\nOptionCard.displayName = 'OptionCard';\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\n\nexport interface OrderCardCustomProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Título personalizado de la card\n */\n title: string;\n \n /**\n * Cantidad principal\n */\n count: number | string;\n \n /**\n * Etiqueta de la cantidad\n * @default \"orders\"\n */\n countLabel?: string;\n \n /**\n * Línea 1 de información (ej: \"Gross Sales: $100,000.00\")\n */\n infoLine1?: string;\n \n /**\n * Línea 2 de información (ej: \"Net Sales: $100,000.00\")\n */\n infoLine2?: string;\n \n /**\n * Ícono personalizado (React node)\n */\n icon: React.ReactNode;\n \n /**\n * Badge personalizado (opcional)\n */\n badge?: {\n label: string;\n variant?: 'default' | 'red' | 'green' | 'blue';\n onClick?: () => void;\n };\n \n /**\n * Botón personalizado (opcional)\n */\n button?: {\n label: string;\n onClick?: () => void;\n };\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\nconst badgeStyles = {\n default: {\n bg: '#f4f4f4',\n border: '#c6c6c6',\n text: '#6e6f6e',\n },\n red: {\n bg: '#ffecf0',\n border: '#ff8ea7',\n text: '#ff305f',\n },\n green: {\n bg: '#e6f7f0',\n border: '#8ed9b8',\n text: '#00995a',\n },\n blue: {\n bg: '#e8f4fd',\n border: '#8ec9ed',\n text: '#0066cc',\n },\n};\n\n/**\n * Componente OrderCardCustom\n * \n * Versión personalizable de OrderCard donde puedes especificar\n * cualquier título, ícono, información y badges sin estar limitado\n * a estados predefinidos.\n * \n * @example\n * ```tsx\n * <OrderCardCustom\n * title=\"Processing\"\n * count={42}\n * countLabel=\"items\"\n * infoLine1=\"Total: $50,000.00\"\n * infoLine2=\"Pending: 12 items\"\n * icon={<CustomIcon />}\n * badge={{ label: \"Urgent\", variant: \"red\" }}\n * button={{ label: \"View\", onClick: () => {} }}\n * />\n * ```\n */\nexport const OrderCardCustom = React.forwardRef<HTMLDivElement, OrderCardCustomProps>(\n (\n {\n title,\n count,\n countLabel = 'orders',\n infoLine1,\n infoLine2,\n icon,\n badge,\n button,\n className,\n ...props\n },\n ref\n ) => {\n const badgeStyle = badge ? badgeStyles[badge.variant || 'default'] : badgeStyles.default;\n\n return (\n <div\n ref={ref}\n className={cn(\n 'bg-white border border-[#ecebf0] rounded-xl p-5 flex gap-2',\n className\n )}\n {...props}\n >\n {/* Ícono */}\n <div className=\"flex items-center justify-center shrink-0\">\n {icon}\n </div>\n\n {/* Contenido */}\n <div className=\"flex-1 flex gap-2 items-start justify-end min-w-0\">\n {/* Información principal */}\n <div className=\"flex-1 flex flex-col gap-1 min-w-0\">\n {/* Título */}\n <h3\n className=\"text-base leading-5 font-medium text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {title}\n </h3>\n\n {/* Contador */}\n <div className=\"flex items-end gap-1\">\n <span\n className=\"text-xl leading-[22px] font-semibold text-[#312e4d]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {count}\n </span>\n <span\n className=\"text-base leading-[18px] font-medium text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {countLabel}\n </span>\n </div>\n\n {/* Info Line 1 */}\n {infoLine1 && (\n <div\n className=\"text-xs leading-normal font-normal text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {infoLine1}\n </div>\n )}\n\n {/* Info Line 2 */}\n {infoLine2 && (\n <div\n className=\"text-xs leading-normal font-normal text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {infoLine2}\n </div>\n )}\n </div>\n\n {/* Badges y botón */}\n <div className=\"flex flex-col gap-4 items-end justify-end pb-[33px]\">\n {/* Badge personalizado */}\n {badge && (\n <button\n onClick={(e) => {\n e.stopPropagation();\n badge.onClick?.();\n }}\n disabled={!badge.onClick}\n className={cn(\n 'px-2 py-1 rounded-2xl text-sm leading-[18px] font-medium border transition-opacity',\n badge.onClick && 'hover:opacity-80 cursor-pointer'\n )}\n style={{\n fontFamily: 'Causten Round, sans-serif',\n height: '24px',\n backgroundColor: badgeStyle.bg,\n borderColor: badgeStyle.border,\n color: badgeStyle.text,\n }}\n >\n {badge.label}\n </button>\n )}\n\n {/* Botón personalizado */}\n {button && (\n <button\n onClick={(e) => {\n e.stopPropagation();\n button.onClick?.();\n }}\n className=\"text-sm leading-[18px] font-semibold text-[#00995a] hover:underline\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {button.label}\n </button>\n )}\n </div>\n </div>\n </div>\n );\n }\n);\n\nOrderCardCustom.displayName = 'OrderCardCustom';\n\n","import * as React from 'react';\nimport { cn } from '../../lib/utils';\nimport { ReceiptText, Package, Route, CircleCheck } from 'lucide-react';\n\nexport interface OrderCardProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Estado de la orden (cada uno con su ícono)\n */\n state: 'received' | 'picking' | 'dispatched' | 'delivered';\n \n /**\n * Cantidad de órdenes/rutas\n */\n count: number;\n \n /**\n * Etiqueta de la cantidad\n * @default \"orders\"\n */\n countLabel?: string;\n \n /**\n * Ventas brutas\n */\n grossSales: number;\n \n /**\n * Ventas netas\n */\n netSales: number;\n \n /**\n * Mostrar badge de delays\n * @default false\n */\n hasDelays?: boolean;\n \n /**\n * Número de delays (opcional)\n */\n delayCount?: number;\n \n /**\n * Callback al hacer clic en el badge de Delays\n */\n onDelaysClick?: () => void;\n \n /**\n * Callback al hacer clic en el botón Filter\n */\n onFilterClick?: () => void;\n \n /**\n * Ícono personalizado (opcional)\n */\n icon?: React.ReactNode;\n \n /**\n * Símbolo de moneda\n * @default \"$\"\n */\n currencySymbol?: string;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n// Íconos de lucide-react con el color de marca\nconst iconColor = '#00995a';\nconst iconSize = 32;\nconst iconStrokeWidth = 2;\n\nconst ReceivedIcon: React.FC = () => (\n <ReceiptText \n size={iconSize} \n color={iconColor}\n strokeWidth={iconStrokeWidth}\n />\n);\n\nconst PickingIcon: React.FC = () => (\n <Package \n size={iconSize} \n color={iconColor}\n strokeWidth={iconStrokeWidth}\n />\n);\n\nconst DispatchedIcon: React.FC = () => (\n <Route \n size={iconSize} \n color={iconColor}\n strokeWidth={iconStrokeWidth}\n />\n);\n\nconst DeliveredIcon: React.FC = () => (\n <CircleCheck \n size={iconSize} \n color={iconColor}\n strokeWidth={iconStrokeWidth}\n />\n);\n\n// Mapeo de estados a títulos e íconos\nconst stateConfig = {\n received: {\n title: 'Received',\n icon: ReceivedIcon,\n },\n picking: {\n title: 'Picking',\n icon: PickingIcon,\n },\n dispatched: {\n title: 'Dispatched',\n icon: DispatchedIcon,\n },\n delivered: {\n title: 'Delivered',\n icon: DeliveredIcon,\n },\n};\n\n/**\n * Componente OrderCard\n * \n * Card para mostrar el estado de órdenes con métricas de ventas,\n * badges de delays opcionales, y botón de filtro.\n * \n * Estados disponibles:\n * - received: Órdenes recibidas\n * - picking: Órdenes en preparación\n * - dispatched: Órdenes despachadas\n * - delivered: Órdenes entregadas\n * \n * @example\n * ```tsx\n * <OrderCard\n * state=\"received\"\n * count={24}\n * countLabel=\"orders\"\n * grossSales={100000.00}\n * netSales={100000.00}\n * hasDelays={true}\n * onFilterClick={() => console.log('Filter')}\n * />\n * ```\n */\nexport const OrderCard = React.forwardRef<HTMLDivElement, OrderCardProps>(\n (\n {\n state,\n count,\n countLabel = 'orders',\n grossSales,\n netSales,\n hasDelays = false,\n delayCount,\n onDelaysClick,\n onFilterClick,\n icon,\n currencySymbol = '$',\n className,\n ...props\n },\n ref\n ) => {\n const config = stateConfig[state];\n const IconComponent = icon || config.icon;\n \n const formatCurrency = (amount: number): string => {\n return `${currencySymbol}${amount.toFixed(2).replace(/\\B(?=(\\d{3})+(?!\\d))/g, ',')}`;\n };\n\n return (\n <div\n ref={ref}\n className={cn(\n 'bg-white border border-[#ecebf0] rounded-xl p-5 flex gap-2',\n className\n )}\n {...props}\n >\n {/* Ícono */}\n <div className=\"flex items-start justify-center shrink-0\">\n {typeof IconComponent === 'function' ? <IconComponent /> : IconComponent}\n </div>\n\n {/* Contenido */}\n <div className=\"flex-1 flex gap-2 items-start justify-end min-w-0\">\n {/* Información de la orden */}\n <div className=\"flex-1 flex flex-col gap-1 min-w-0\">\n {/* Título */}\n <h3\n className=\"text-base leading-5 font-medium text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {config.title}\n </h3>\n\n {/* Contador */}\n <div className=\"flex items-end gap-1\">\n <span\n className=\"text-xl leading-[22px] font-semibold text-[#312e4d]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {count}\n </span>\n <span\n className=\"text-base leading-[18px] font-medium text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n {countLabel}\n </span>\n </div>\n\n {/* Gross Sales */}\n <div\n className=\"flex gap-1 text-xs leading-normal font-light text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n <span>Gross Sales:</span>\n <span>{formatCurrency(grossSales)}</span>\n </div>\n\n {/* Net Sales */}\n <div\n className=\"flex gap-1 text-xs leading-normal font-light text-[#575385]\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n <span>Net Sales:</span>\n <span>{formatCurrency(netSales)}</span>\n </div>\n </div>\n\n {/* Badges y botón */}\n <div className=\"flex flex-col gap-4 items-end justify-end pl-12 pb-[33px]\">\n {/* Badge de Delays */}\n {hasDelays && (\n <button\n onClick={(e) => {\n e.stopPropagation();\n onDelaysClick?.();\n }}\n className=\"px-2 rounded-2xl text-[12px] leading-[18px] font-light border bg-[#ffecf0] border-[#ff8ea7] text-[#ff305f] hover:opacity-80 transition-opacity\"\n style={{ fontFamily: 'Causten Round, sans-serif', height: '24px' }}\n >\n {delayCount ? `${delayCount} Delays` : 'Delays'}\n </button>\n )}\n\n {/* Botón Filter */}\n {onFilterClick && (\n <button\n onClick={(e) => {\n e.stopPropagation();\n onFilterClick();\n }}\n className=\"text-sm leading-[18px] font-medium text-[#00995a] hover:underline\"\n style={{ fontFamily: 'Causten Round, sans-serif' }}\n >\n Filter\n </button>\n )}\n </div>\n </div>\n </div>\n );\n }\n);\n\nOrderCard.displayName = 'OrderCard';\n\n// Export custom variant\nexport { OrderCardCustom } from './OrderCardCustom';\nexport type { OrderCardCustomProps } from './OrderCardCustom';\n\n","import React from 'react';\nimport { cn } from '../../lib/utils';\n\ninterface PaginationLibProps {\n currentPage: number;\n totalPages: number;\n onPageChange: (page: number) => void;\n}\n\nexport const PaginationLib: React.FC<PaginationLibProps> = ({\n currentPage,\n totalPages,\n onPageChange,\n}) => {\n const handlePrevious = () => {\n if (currentPage > 1) {\n onPageChange(currentPage - 1);\n }\n };\n\n const handleNext = () => {\n if (currentPage < totalPages) {\n onPageChange(currentPage + 1);\n }\n };\n\n const handlePageClick = (page: number) => {\n onPageChange(page);\n };\n\n // Generate page numbers to show\n const getPageNumbers = () => {\n const pages: (number | string)[] = [];\n const maxVisible = 4;\n \n if (totalPages <= maxVisible + 2) {\n // Show all pages if total is small\n for (let i = 1; i <= totalPages; i++) {\n pages.push(i);\n }\n } else {\n // Always show first page\n pages.push(1);\n \n if (currentPage <= 3) {\n // Show first few pages\n for (let i = 2; i <= 4; i++) {\n pages.push(i);\n }\n pages.push('...');\n pages.push(totalPages);\n } else if (currentPage >= totalPages - 2) {\n // Show last few pages\n pages.push('...');\n for (let i = totalPages - 2; i <= totalPages; i++) {\n pages.push(i);\n }\n } else {\n // Show pages around current\n pages.push('...');\n for (let i = currentPage - 1; i <= currentPage + 1; i++) {\n pages.push(i);\n }\n pages.push('...');\n pages.push(totalPages);\n }\n }\n \n return pages;\n };\n\n const pageNumbers = getPageNumbers();\n\n return (\n <div className=\"flex gap-1.5 items-center\">\n <button\n onClick={handlePrevious}\n disabled={currentPage === 1}\n className={cn(\n 'border rounded bg-transparent p-1 flex items-center justify-center w-[28px] h-[28px]',\n currentPage === 1\n ? 'border-[#ecebf0] cursor-not-allowed'\n : 'border-[#ecebf0] cursor-pointer hover:bg-gray-50'\n )}\n >\n <i className=\"tabler-chevron-left text-sm text-[#312e4d]\" />\n </button>\n \n {pageNumbers.map((page, index) => {\n if (page === '...') {\n return (\n <div\n key={`ellipsis-${index}`}\n className=\"border border-[#ecebf0] rounded p-1 h-[28px] w-[28px] flex items-center justify-center\"\n >\n <p className=\"text-xs text-[#575385] text-center\">...</p>\n </div>\n );\n }\n \n const pageNum = page as number;\n const isActive = pageNum === currentPage;\n \n return (\n <button\n key={pageNum}\n onClick={() => handlePageClick(pageNum)}\n className={cn(\n 'border rounded bg-transparent p-1 h-[28px] w-[28px] flex items-center justify-center px-1',\n isActive\n ? 'border-[#a29fba] bg-white'\n : 'border-[#ecebf0] hover:bg-gray-50'\n )}\n >\n <p\n className={cn(\n 'text-xs text-center',\n isActive\n ? 'text-[#312e4d]'\n : 'text-[#a29fba]'\n )}\n >\n {pageNum}\n </p>\n </button>\n );\n })}\n \n <button\n onClick={handleNext}\n disabled={currentPage === totalPages}\n className={cn(\n 'border rounded bg-transparent p-1 flex items-center justify-center h-[28px]',\n currentPage === totalPages\n ? 'border-[#ecebf0] cursor-not-allowed'\n : 'border-[#ecebf0] cursor-pointer hover:bg-gray-50'\n )}\n >\n <i className=\"tabler-chevron-right text-sm text-[#312e4d]\" />\n </button>\n </div>\n );\n};\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/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/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","// packages/react/use-previous/src/use-previous.tsx\nimport * as React from \"react\";\nfunction usePrevious(value) {\n const ref = React.useRef({ value, previous: value });\n return React.useMemo(() => {\n if (ref.current.value !== value) {\n ref.current.previous = ref.current.value;\n ref.current.value = value;\n }\n return ref.current.previous;\n }, [value]);\n}\nexport {\n usePrevious\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/use-size/src/use-size.tsx\nimport * as React from \"react\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nfunction useSize(element) {\n const [size, setSize] = React.useState(void 0);\n useLayoutEffect(() => {\n if (element) {\n setSize({ width: element.offsetWidth, height: element.offsetHeight });\n const resizeObserver = new ResizeObserver((entries) => {\n if (!Array.isArray(entries)) {\n return;\n }\n if (!entries.length) {\n return;\n }\n const entry = entries[0];\n let width;\n let height;\n if (\"borderBoxSize\" in entry) {\n const borderSizeEntry = entry[\"borderBoxSize\"];\n const borderSize = Array.isArray(borderSizeEntry) ? borderSizeEntry[0] : borderSizeEntry;\n width = borderSize[\"inlineSize\"];\n height = borderSize[\"blockSize\"];\n } else {\n width = element.offsetWidth;\n height = element.offsetHeight;\n }\n setSize({ width, height });\n });\n resizeObserver.observe(element, { box: \"border-box\" });\n return () => resizeObserver.unobserve(element);\n } else {\n setSize(void 0);\n }\n }, [element]);\n return size;\n}\nexport {\n useSize\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","// 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/switch.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { usePrevious } from \"@radix-ui/react-use-previous\";\nimport { useSize } from \"@radix-ui/react-use-size\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { jsx, jsxs } from \"react/jsx-runtime\";\nvar SWITCH_NAME = \"Switch\";\nvar [createSwitchContext, createSwitchScope] = createContextScope(SWITCH_NAME);\nvar [SwitchProvider, useSwitchContext] = createSwitchContext(SWITCH_NAME);\nvar Switch = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeSwitch,\n name,\n checked: checkedProp,\n defaultChecked,\n required,\n disabled,\n value = \"on\",\n onCheckedChange,\n form,\n ...switchProps\n } = props;\n const [button, setButton] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setButton(node));\n const hasConsumerStoppedPropagationRef = React.useRef(false);\n const isFormControl = button ? form || !!button.closest(\"form\") : true;\n const [checked, setChecked] = useControllableState({\n prop: checkedProp,\n defaultProp: defaultChecked ?? false,\n onChange: onCheckedChange,\n caller: SWITCH_NAME\n });\n return /* @__PURE__ */ jsxs(SwitchProvider, { scope: __scopeSwitch, checked, disabled, children: [\n /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n role: \"switch\",\n \"aria-checked\": checked,\n \"aria-required\": required,\n \"data-state\": getState(checked),\n \"data-disabled\": disabled ? \"\" : void 0,\n disabled,\n value,\n ...switchProps,\n ref: composedRefs,\n onClick: composeEventHandlers(props.onClick, (event) => {\n setChecked((prevChecked) => !prevChecked);\n if (isFormControl) {\n hasConsumerStoppedPropagationRef.current = event.isPropagationStopped();\n if (!hasConsumerStoppedPropagationRef.current) event.stopPropagation();\n }\n })\n }\n ),\n isFormControl && /* @__PURE__ */ jsx(\n SwitchBubbleInput,\n {\n control: button,\n bubbles: !hasConsumerStoppedPropagationRef.current,\n name,\n value,\n checked,\n required,\n disabled,\n form,\n style: { transform: \"translateX(-100%)\" }\n }\n )\n ] });\n }\n);\nSwitch.displayName = SWITCH_NAME;\nvar THUMB_NAME = \"SwitchThumb\";\nvar SwitchThumb = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSwitch, ...thumbProps } = props;\n const context = useSwitchContext(THUMB_NAME, __scopeSwitch);\n return /* @__PURE__ */ jsx(\n Primitive.span,\n {\n \"data-state\": getState(context.checked),\n \"data-disabled\": context.disabled ? \"\" : void 0,\n ...thumbProps,\n ref: forwardedRef\n }\n );\n }\n);\nSwitchThumb.displayName = THUMB_NAME;\nvar BUBBLE_INPUT_NAME = \"SwitchBubbleInput\";\nvar SwitchBubbleInput = React.forwardRef(\n ({\n __scopeSwitch,\n control,\n checked,\n bubbles = true,\n ...props\n }, forwardedRef) => {\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(ref, forwardedRef);\n const prevChecked = usePrevious(checked);\n const controlSize = useSize(control);\n React.useEffect(() => {\n const input = ref.current;\n if (!input) return;\n const inputProto = window.HTMLInputElement.prototype;\n const descriptor = Object.getOwnPropertyDescriptor(\n inputProto,\n \"checked\"\n );\n const setChecked = descriptor.set;\n if (prevChecked !== checked && setChecked) {\n const event = new Event(\"click\", { bubbles });\n setChecked.call(input, checked);\n input.dispatchEvent(event);\n }\n }, [prevChecked, checked, bubbles]);\n return /* @__PURE__ */ jsx(\n \"input\",\n {\n type: \"checkbox\",\n \"aria-hidden\": true,\n defaultChecked: checked,\n ...props,\n tabIndex: -1,\n ref: composedRefs,\n style: {\n ...props.style,\n ...controlSize,\n position: \"absolute\",\n pointerEvents: \"none\",\n opacity: 0,\n margin: 0\n }\n }\n );\n }\n);\nSwitchBubbleInput.displayName = BUBBLE_INPUT_NAME;\nfunction getState(checked) {\n return checked ? \"checked\" : \"unchecked\";\n}\nvar Root = Switch;\nvar Thumb = SwitchThumb;\nexport {\n Root,\n Switch,\n SwitchThumb,\n Thumb,\n createSwitchScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as React from 'react';\nimport * as SwitchPrimitive from '@radix-ui/react-switch';\nimport { cn } from '../../lib/utils';\n\nexport interface SwitcherProps extends Omit<React.ComponentPropsWithoutRef<typeof SwitchPrimitive.Root>, 'checked' | 'onCheckedChange' | 'onChange'> {\n /**\n * Estado del switch (on/off)\n * @default false\n */\n status?: boolean;\n \n /**\n * Si el switch está deshabilitado\n * @default false\n */\n disabled?: boolean;\n \n /**\n * Callback que recibe el nuevo estado cuando cambia\n */\n onChange?: (status: boolean) => void;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n/**\n * Componente Switcher - Toggle Switch\n * \n * Switch toggle basado en Radix UI con el diseño del Portal Design System.\n * \n * Estados:\n * - Off: Fondo gris (#e0e0e0), handle a la izquierda\n * - On: Fondo verde (#00995a), handle a la derecha\n * - Disabled: Estado deshabilitado con opacidad reducida\n * \n * Incluye callback onChange que recibe el nuevo estado.\n */\nconst Switcher = React.forwardRef<\n React.ElementRef<typeof SwitchPrimitive.Root>,\n SwitcherProps\n>(\n (\n {\n status = false,\n disabled = false,\n onChange,\n className,\n ...props\n },\n ref\n ) => {\n return (\n <SwitchPrimitive.Root\n ref={ref}\n checked={status}\n onCheckedChange={onChange}\n disabled={disabled}\n className={cn(\n 'relative inline-flex h-5 w-10 shrink-0 cursor-pointer items-center rounded-full p-0.5 transition-colors duration-200 ease-in-out',\n 'focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-[#00995a] focus-visible:ring-offset-2',\n 'disabled:cursor-not-allowed disabled:opacity-50',\n status\n ? 'bg-[#00995a]'\n : 'bg-[#e0e0e0]',\n className\n )}\n {...props}\n >\n <SwitchPrimitive.Thumb\n className={cn(\n 'pointer-events-none block h-4 w-4 rounded-full bg-white shadow-lg transition-transform duration-200 ease-in-out',\n status ? 'translate-x-5' : 'translate-x-0'\n )}\n />\n </SwitchPrimitive.Root>\n );\n }\n);\n\nSwitcher.displayName = 'Switcher';\n\nexport { Switcher };\n\n","import * as React from 'react';\nimport { CheckCircle, X } from 'lucide-react';\nimport { cn } from '../../lib/utils';\n\nexport interface ToastsProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Tipo de toast (light o dark)\n * @default \"light\"\n */\n type?: 'light' | 'dark';\n \n /**\n * Texto del toast\n */\n text: string;\n \n /**\n * Icono personalizado (opcional)\n * Por defecto muestra CheckCircle\n */\n icon?: React.ReactNode;\n \n /**\n * Callback para cerrar el toast\n */\n onClose?: () => void;\n \n /**\n * Clases CSS adicionales\n */\n className?: string;\n}\n\n/**\n * Componente Toasts - Notificaciones temporales\n * \n * Muestra notificaciones breves con dos variantes:\n * - light: Fondo claro para interfaces claras\n * - dark: Fondo oscuro para interfaces oscuras o mayor contraste\n * \n * Incluye un icono (personalizable), texto y botón de cerrar.\n */\nconst Toasts = React.forwardRef<HTMLDivElement, ToastsProps>(\n (\n {\n type = 'light',\n text,\n icon,\n onClose,\n className,\n ...props\n },\n ref\n ) => {\n // Configuración de estilos por tipo\n const typeStyles = {\n light: {\n container: 'bg-[#ecebf0]',\n text: 'text-[#575385]',\n iconColor: 'text-[#312e4d]',\n closeColor: 'text-[#312e4d]',\n },\n dark: {\n container: 'bg-[#3f3c5e]',\n text: 'text-white',\n iconColor: 'text-white',\n closeColor: 'text-white',\n },\n };\n\n const currentType = typeStyles[type];\n\n // Icono por defecto\n const defaultIcon = (\n <CheckCircle \n size={16} \n className={currentType.iconColor}\n />\n );\n\n return (\n <div\n ref={ref}\n className={cn(\n 'flex items-center gap-3 p-3 rounded',\n currentType.container,\n className\n )}\n role=\"status\"\n aria-live=\"polite\"\n {...props}\n >\n {/* Body: Icono + Texto */}\n <div className=\"flex items-center gap-2 flex-shrink-0\">\n {/* Icono */}\n <div className=\"flex-shrink-0\">\n {icon || defaultIcon}\n </div>\n\n {/* Texto */}\n <div\n className={cn(\n 'text-base leading-5 whitespace-nowrap',\n currentType.text\n )}\n >\n {text}\n </div>\n </div>\n\n {/* Botón de cerrar */}\n {onClose && (\n <button\n type=\"button\"\n onClick={onClose}\n className={cn(\n 'flex-shrink-0 opacity-99 hover:opacity-100 transition-opacity',\n currentType.closeColor\n )}\n aria-label=\"Cerrar notificación\"\n >\n <X size={12} />\n </button>\n )}\n </div>\n );\n }\n);\n\nToasts.displayName = 'Toasts';\n\nexport { Toasts };\n\n"],"names":["f","require$$0","k","l","m","n","p","q","c","a","g","b","d","e","h","reactJsxRuntime_production_min","React","REACT_ELEMENT_TYPE","REACT_PORTAL_TYPE","REACT_FRAGMENT_TYPE","REACT_STRICT_MODE_TYPE","REACT_PROFILER_TYPE","REACT_PROVIDER_TYPE","REACT_CONTEXT_TYPE","REACT_FORWARD_REF_TYPE","REACT_SUSPENSE_TYPE","REACT_SUSPENSE_LIST_TYPE","REACT_MEMO_TYPE","REACT_LAZY_TYPE","REACT_OFFSCREEN_TYPE","MAYBE_ITERATOR_SYMBOL","FAUX_ITERATOR_SYMBOL","getIteratorFn","maybeIterable","maybeIterator","ReactSharedInternals","error","format","_len2","args","_key2","printWarning","level","ReactDebugCurrentFrame","stack","argsWithFormat","item","enableScopeAPI","enableCacheElement","enableTransitionTracing","enableLegacyHidden","enableDebugTracing","REACT_MODULE_REFERENCE","isValidElementType","type","getWrappedName","outerType","innerType","wrapperName","displayName","functionName","getContextName","getComponentNameFromType","context","provider","outerName","lazyComponent","payload","init","assign","disabledDepth","prevLog","prevInfo","prevWarn","prevError","prevGroup","prevGroupCollapsed","prevGroupEnd","disabledLog","disableLogs","props","reenableLogs","ReactCurrentDispatcher","prefix","describeBuiltInComponentFrame","name","source","ownerFn","x","match","reentry","componentFrameCache","PossiblyWeakMap","describeNativeComponentFrame","fn","construct","frame","control","previousPrepareStackTrace","previousDispatcher","Fake","sample","sampleLines","controlLines","s","_frame","syntheticFrame","describeFunctionComponentFrame","shouldConstruct","Component","prototype","describeUnknownElementTypeFrameInDEV","hasOwnProperty","loggedTypeFailures","setCurrentlyValidatingElement","element","owner","checkPropTypes","typeSpecs","values","location","componentName","has","typeSpecName","error$1","err","ex","isArrayImpl","isArray","typeName","value","hasToStringTag","willCoercionThrow","testStringCoercion","checkKeyStringCoercion","ReactCurrentOwner","RESERVED_PROPS","specialPropKeyWarningShown","specialPropRefWarningShown","hasValidRef","config","getter","hasValidKey","warnIfStringRefCannotBeAutoConverted","self","defineKeyPropWarningGetter","warnAboutAccessingKey","defineRefPropWarningGetter","warnAboutAccessingRef","ReactElement","key","ref","jsxDEV","maybeKey","propName","defaultProps","ReactCurrentOwner$1","ReactDebugCurrentFrame$1","setCurrentlyValidatingElement$1","propTypesMisspellWarningShown","isValidElement","object","getDeclarationErrorAddendum","getSourceInfoErrorAddendum","ownerHasKeyUseWarning","getCurrentComponentErrorInfo","parentType","info","parentName","validateExplicitKey","currentComponentErrorInfo","childOwner","validateChildKeys","node","i","child","iteratorFn","iterator","step","validatePropTypes","propTypes","_name","validateFragmentProps","fragment","keys","didWarnAboutKeySpread","jsxWithValidation","isStaticChildren","validType","sourceInfo","typeString","children","beforeExample","afterExample","jsxWithValidationStatic","jsxWithValidationDynamic","jsx","jsxs","reactJsxRuntime_development","jsxRuntimeModule","require$$1","r","t","o","clsx","CLASS_PART_SEPARATOR","createClassGroupUtils","classMap","createClassMap","conflictingClassGroups","conflictingClassGroupModifiers","className","classParts","getGroupRecursive","getGroupIdForArbitraryProperty","classGroupId","hasPostfixModifier","conflicts","classPartObject","currentClassPart","nextClassPartObject","classGroupFromNextClassPart","classRest","validator","arbitraryPropertyRegex","arbitraryPropertyClassName","property","theme","getPrefixedClassGroupEntries","classGroup","processClassesRecursively","classDefinition","classPartObjectToEdit","getPart","isThemeGetter","path","currentClassPartObject","pathPart","func","classGroupEntries","prefixedClassGroup","createLruCache","maxCacheSize","cacheSize","cache","previousCache","update","IMPORTANT_MODIFIER","createParseClassName","separator","experimentalParseClassName","isSeparatorSingleCharacter","firstSeparatorCharacter","separatorLength","parseClassName","modifiers","bracketDepth","modifierStart","postfixModifierPosition","index","currentCharacter","baseClassNameWithImportantModifier","hasImportantModifier","baseClassName","maybePostfixModifierPosition","sortModifiers","sortedModifiers","unsortedModifiers","modifier","createConfigUtils","SPLIT_CLASSES_REGEX","mergeClassList","classList","configUtils","getClassGroupId","getConflictingClassGroupIds","classGroupsInConflict","classNames","result","originalClassName","variantModifier","modifierId","classId","conflictGroups","group","twJoin","argument","resolvedValue","string","toValue","mix","createTailwindMerge","createConfigFirst","createConfigRest","cacheGet","cacheSet","functionToCall","initTailwindMerge","previousConfig","createConfigCurrent","tailwindMerge","cachedResult","fromTheme","themeGetter","arbitraryValueRegex","fractionRegex","stringLengths","tshirtUnitRegex","lengthUnitRegex","colorFunctionRegex","shadowRegex","imageRegex","isLength","isNumber","isArbitraryLength","getIsArbitraryValue","isLengthOnly","isArbitraryNumber","isInteger","isPercent","isArbitraryValue","isTshirtSize","sizeLabels","isArbitrarySize","isNever","isArbitraryPosition","imageLabels","isArbitraryImage","isImage","isArbitraryShadow","isShadow","isAny","label","testValue","getDefaultConfig","colors","spacing","blur","brightness","borderColor","borderRadius","borderSpacing","borderWidth","contrast","grayscale","hueRotate","invert","gap","gradientColorStops","gradientColorStopPositions","inset","margin","opacity","padding","saturate","scale","sepia","skew","space","translate","getOverscroll","getOverflow","getSpacingWithAutoAndArbitrary","getSpacingWithArbitrary","getLengthWithEmptyAndArbitrary","getNumberWithAutoAndArbitrary","getPositions","getLineStyles","getBlendModes","getAlign","getZeroAndEmpty","getBreaks","getNumberAndArbitrary","twMerge","cn","inputs","ActionCard","title","description","icon","action","onClick","toKebabCase","toCamelCase","p1","p2","toPascalCase","camelCase","mergeClasses","classes","array","hasA11yProp","prop","defaultAttributes","Icon","forwardRef","color","size","strokeWidth","absoluteStrokeWidth","iconNode","rest","createElement","tag","attrs","createLucideIcon","iconName","__iconNode","CircleCheckBig","CircleCheck","Info","Package","ReceiptText","Route","TriangleAlert","X","BannerAlerts","variant","currentVariant","AlertTriangle","displayIcon","setRef","composeRefs","refs","hasCleanup","cleanups","cleanup","useComposedRefs","use","isPromiseLike","isLazyComponent","createSlot","ownerName","SlotClone","createSlotClone","Slot2","forwardedRef","slotProps","childrenArray","slottable","isSlottable","newElement","newChildren","Slot","childrenRef","getElementRef","props2","mergeProps","SLOTTABLE_IDENTIFIER","childProps","overrideProps","slotPropValue","childPropValue","mayWarn","falsyToString","cx","cva","base","_config_compoundVariants","variants","defaultVariants","getVariantClassNames","variantProp","defaultVariantProp","variantKey","propsWithoutUndefined","acc","param","getCompoundVariantClassNames","cvClass","cvClassName","compoundVariantOptions","buttonVariants","Button","iconOnly","asChild","leftIcon","rightIcon","Comp","LOGO_ASSETS","BrandIcons","mode","gradient","alt","getLogoSrc","dimensions","width","height","CardsGrid","columns","tabletColumns","mobileColumns","style","getGapClass","getColumnsClasses","customStyle","FeatureCard","iconBackground","KPIComparisonCustom","primaryText","primaryTextColor","secondaryText","secondaryTextColor","TrendUpIcon","TrendDownIcon","WarningIcon","KPIComparison","percentage","trend","showWarning","isPositive","formattedPercentage","tagStyles","KPICardCustom","content","footer","tagStyle","DefaultWarningIcon","KPICard","unit","total","comparison","iconColor","bodyText","button","iconColors","Loader","show","OptionCard","selected","onSelect","disabled","handleClick","badgeStyles","OrderCardCustom","count","countLabel","infoLine1","infoLine2","badge","badgeStyle","iconSize","iconStrokeWidth","ReceivedIcon","PickingIcon","DispatchedIcon","DeliveredIcon","stateConfig","OrderCard","state","grossSales","netSales","hasDelays","delayCount","onDelaysClick","onFilterClick","currencySymbol","IconComponent","formatCurrency","amount","PaginationLib","currentPage","totalPages","onPageChange","handlePrevious","handleNext","handlePageClick","page","pageNumbers","pages","pageNum","isActive","composeEventHandlers","originalEventHandler","ourEventHandler","checkForDefaultPrevented","event","createContextScope","scopeName","createContextScopeDeps","defaultContexts","createContext3","rootComponentName","defaultContext","BaseContext","Provider","scope","Context","useContext2","consumerName","createScope","scopeContexts","contexts","composeContextScopes","scopes","baseScope","scopeHooks","createScope2","overrideScopes","nextScopes","nextScopes2","useScope","currentScope","useLayoutEffect2","useInsertionEffect","useLayoutEffect","useControllableState","defaultProp","onChange","caller","uncontrolledProp","setUncontrolledProp","onChangeRef","useUncontrolledState","isControlled","isControlledRef","wasControlled","setValue","nextValue","value2","isFunction","prevValueRef","usePrevious","useSize","setSize","resizeObserver","entries","entry","borderSizeEntry","borderSize","NODES","Primitive","primitive","Node","primitiveProps","SWITCH_NAME","createSwitchContext","SwitchProvider","useSwitchContext","Switch","__scopeSwitch","checkedProp","defaultChecked","required","onCheckedChange","form","switchProps","setButton","composedRefs","hasConsumerStoppedPropagationRef","isFormControl","checked","setChecked","getState","prevChecked","SwitchBubbleInput","THUMB_NAME","SwitchThumb","thumbProps","BUBBLE_INPUT_NAME","bubbles","controlSize","input","inputProto","Root","Thumb","Switcher","status","SwitchPrimitive.Root","SwitchPrimitive.Thumb","Toasts","text","onClose","currentType","defaultIcon","CheckCircle"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,7,8,9,10,11,12,13,14,15,16,17,18,20,21,22,36,37,38,39,40,41,42,43,44]}
|