@yaredfall/class-variants 0.1.2 → 0.5.0-rc
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/LICENSE +21 -0
- package/build/chunk-6DFTYFKO.js +2 -0
- package/build/chunk-6DFTYFKO.js.map +1 -0
- package/build/chunk-6Y37KLAC.js +2 -0
- package/build/chunk-6Y37KLAC.js.map +1 -0
- package/build/chunk-BSA7R4NK.js +2 -0
- package/build/chunk-BSA7R4NK.js.map +1 -0
- package/build/chunk-FIET564E.js +2 -0
- package/build/chunk-FIET564E.js.map +1 -0
- package/build/chunk-IMTFPGTY.js +2 -0
- package/build/chunk-IMTFPGTY.js.map +1 -0
- package/build/chunk-RNIIXHL2.js +2 -0
- package/build/chunk-RNIIXHL2.js.map +1 -0
- package/build/cn.cjs +2 -0
- package/build/cn.cjs.map +1 -0
- package/build/cn.d.cts +11 -0
- package/build/cn.d.ts +11 -0
- package/build/cn.js +2 -0
- package/build/cn.js.map +1 -0
- package/build/compose.cjs +2 -0
- package/build/compose.cjs.map +1 -0
- package/build/compose.d.cts +20 -0
- package/build/compose.d.ts +20 -0
- package/build/compose.js +2 -0
- package/build/compose.js.map +1 -0
- package/build/cv-BWSJNbxE.d.cts +84 -0
- package/build/cv-WFZM6Df-.d.ts +84 -0
- package/build/cv.cjs +2 -0
- package/build/cv.cjs.map +1 -0
- package/build/cv.d.cts +4 -0
- package/build/cv.d.ts +4 -0
- package/build/cv.js +2 -0
- package/build/cv.js.map +1 -0
- package/build/define.cjs +2 -0
- package/build/define.cjs.map +1 -0
- package/build/define.d.cts +15 -0
- package/build/define.d.ts +15 -0
- package/build/define.js +2 -0
- package/build/define.js.map +1 -0
- package/build/index.cjs +1 -1
- package/build/index.cjs.map +1 -1
- package/build/index.d.cts +11 -1
- package/build/index.d.ts +11 -1
- package/build/index.js +1 -1
- package/build/index.js.map +1 -1
- package/build/tokens.cjs +2 -0
- package/build/tokens.cjs.map +1 -0
- package/build/tokens.d.cts +4 -0
- package/build/tokens.d.ts +4 -0
- package/build/tokens.js +2 -0
- package/build/tokens.js.map +1 -0
- package/build/utils.cjs +1 -1
- package/build/utils.cjs.map +1 -1
- package/build/utils.d.cts +2 -1
- package/build/utils.d.ts +2 -1
- package/build/utils.js +1 -1
- package/build/vue.cjs +1 -1
- package/build/vue.cjs.map +1 -1
- package/build/vue.d.cts +8 -5
- package/build/vue.d.ts +8 -5
- package/build/vue.js +1 -1
- package/build/vue.js.map +1 -1
- package/package.json +56 -57
- package/build/chunk-4SXOWWRN.js +0 -2
- package/build/chunk-4SXOWWRN.js.map +0 -1
- package/build/chunk-BV75ULQK.js +0 -2
- package/build/chunk-BV75ULQK.js.map +0 -1
- package/build/index-CFb2xboY.d.cts +0 -80
- package/build/index-CFb2xboY.d.ts +0 -80
package/build/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/utils.ts"],"sourcesContent":["import { ClassValue, clsx } from \"clsx\";\nimport { MarkRequired, Prettify, StrictExclude, Opaque } from \"ts-essentials\";\nimport { getEntries, getKeys, getVariantsOptions, KeysOf, VariantOptions } from \"./utils\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type VariantProps<CVR extends (args?: any) => string> = Prettify<\n Omit<NonNullable<StrictExclude<Parameters<CVR>[0], void>>, \"class\" | \"className\">\n>;\n\ntype ClassProp =\n | { class?: ClassValue; className?: never }\n | { class?: never; className?: ClassValue };\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type WithClassProp<T extends Record<string, any>> = T & ClassProp;\n\ntype BooleanStringToBoolean<T> = T extends \"true\" | \"false\" ? boolean : T;\n\nexport type CVVariantsSchema = Record<string, Record<string, ClassValue>>;\n\nexport type CVVariant<V extends CVVariantsSchema> = {\n [K in keyof V]?: BooleanStringToBoolean<keyof V[K]>;\n};\nexport type CVCompoundVariant<V extends CVVariantsSchema> = WithClassProp<{\n [K in keyof V]?:\n | BooleanStringToBoolean<keyof V[K]>\n | BooleanStringToBoolean<keyof V[K]>[]\n | CVToken;\n}>;\n\nexport type CVCompoundVariantsSchema<V extends CVVariantsSchema> = CVCompoundVariant<V>[];\n\nexport interface CVConfig<V extends CVVariantsSchema, R extends keyof V> {\n base?: ClassValue;\n variants?: V;\n compoundVariants?:\n | CVCompoundVariantsSchema<V>\n | ((arg: {\n variants: V;\n keys: KeysOf<V>;\n options: VariantOptions<V>;\n defaults: CVVariant<V>;\n }) => CVCompoundVariantsSchema<V>);\n defaultVariant?: CVVariant<V>;\n requiredProps?: R[];\n}\nexport interface CVOptions {\n merge?: (...args: ClassValue[]) => string;\n}\n\ntype CVReturnProps<V extends CVVariantsSchema, R extends keyof V = never> =\n | Prettify<WithClassProp<MarkRequired<CVVariant<V>, R>>>\n | ([R] extends [never] ? void : never);\nexport interface CVReturn<V extends CVVariantsSchema, R extends keyof V = never> {\n (props: CVReturnProps<V, R>): string;\n keys: KeysOf<V>;\n options: VariantOptions<V>;\n defaults: CVVariant<V>;\n}\n\nexport interface CV {\n // eslint-disable-next-line @typescript-eslint/prefer-function-type\n <V extends CVVariantsSchema, R extends keyof V = never>(\n config: CVConfig<V, R>,\n cvOptions?: CVOptions,\n ): CVReturn<V, R>;\n}\n\nexport const cv: CV = (config, cvOptions = {}) => {\n const merge = cvOptions.merge ?? clsx;\n\n const { variants, defaultVariant, base } = config;\n\n type ResolvedV = NonNullable<typeof variants>;\n\n const keys = variants ? getKeys(variants) : [];\n const options = variants ? getVariantsOptions(variants) : ({} as VariantOptions<ResolvedV>);\n const defaults = defaultVariant ?? ({} as CVVariant<ResolvedV>);\n\n const compoundVariants = variants\n ? typeof config.compoundVariants === \"function\"\n ? config.compoundVariants({ variants, keys, options, defaults })\n : config.compoundVariants\n : undefined;\n\n const getVariant = <V extends ResolvedV, R extends keyof V = never>(\n props: CVReturnProps<V, R>,\n ) => {\n const variantClassNames = variants\n ? keys.map((variant) => {\n const variantProp = props?.[variant];\n const defaultVariantProp = defaultVariant?.[variant];\n\n const variantKey = variantProp?.toString() || defaultVariantProp?.toString();\n\n return variantKey ? variants[variant][variantKey] : undefined;\n })\n : undefined;\n\n const compoundVariantClassNames = compoundVariants?.reduce(\n (acc, { class: cvClass, className: cvClassName, ...cvConfig }) => {\n const shouldApplyCompoundVariant = getEntries(cvConfig).every(\n ([cvKey, cvSelector]) => {\n const defaultsSelector =\n defaultVariant?.[cvKey as keyof typeof defaultVariant];\n const propsSelector = props?.[cvKey as keyof typeof props];\n\n if (typeof cvSelector === \"object\" && \"__token\" in cvSelector) {\n if (cvSelector.__token === onlyWhenDefined.__token) {\n return propsSelector !== undefined;\n } else if (cvSelector.__token === onlyWhenUndefined.__token) {\n return propsSelector === undefined;\n }\n }\n\n const selector = propsSelector ?? defaultsSelector;\n\n return Array.isArray(cvSelector)\n ? cvSelector.some((cvSelector) => selector === cvSelector)\n : selector === cvSelector;\n },\n );\n\n if (shouldApplyCompoundVariant) acc.push(cvClass, cvClassName);\n return acc;\n },\n new Array<ClassValue>(),\n );\n\n return merge(\n base,\n variantClassNames,\n compoundVariantClassNames,\n props?.class,\n props?.className,\n );\n };\n\n return Object.assign(getVariant, { keys, options, defaults });\n};\n\nexport function defineCV(options: CVOptions): CV {\n return (config) => cv(config, options);\n}\n\ntype OnlyWhenDefined = Opaque<{ __token: string }, \"OnlyWhenDefined\">;\ntype OnlyWhenUndefined = Opaque<{ __token: string }, \"OnlyWhenUndefined\">;\n\ntype CVToken = OnlyWhenDefined | OnlyWhenUndefined;\n\n/** Apply compound variant only if prop **is** specified */\nexport const onlyWhenDefined = { __token: \"OnlyWhenDefined\" } as OnlyWhenDefined;\n/** Apply compound variant only if prop **is not** specified */\nexport const onlyWhenUndefined = { __token: \"OnlyWhenUndefined\" } as OnlyWhenUndefined;\n","import { DeepReadonly, DeepWritable, Prettify, UnionToIntersection } from \"ts-essentials\";\nimport { CVVariantsSchema } from \".\";\n\nexport type KeysOf<O extends Record<string, unknown>> = (keyof O)[];\nexport function getKeys<O extends Record<string, unknown>>(obj: O) {\n return Object.keys(obj) as KeysOf<O>;\n}\n\nexport type EntriesOf<O extends Record<string, unknown>> = { [K in keyof O]: [K, O[K]] };\nexport function getEntries<O extends Record<string, unknown>>(obj: O) {\n return Object.entries(obj) as EntriesOf<O>[keyof EntriesOf<O>][];\n}\n\nexport type VariantOptions<V extends CVVariantsSchema> = {\n [K in keyof V]: KeysOf<V[K]>;\n};\nexport function getVariantsOptions<V extends CVVariantsSchema>(variants: V) {\n return Object.fromEntries(\n getEntries(variants).map(([cvKey, cvVal]) => [cvKey, getKeys(cvVal)]),\n ) as VariantOptions<V>;\n}\n\ntype Entries = [PropertyKey, unknown][] | DeepReadonly<[PropertyKey, unknown][]>;\ntype UnionFromPairs<TArr extends Entries> =\n DeepWritable<TArr> extends (infer R)[]\n ? R extends [infer key, infer val]\n ? { [prop in key & PropertyKey]: val }\n : never\n : never;\n\ntype MergeIntersectingObjects<O> = { [K in keyof O]: O[K] };\n\nexport function objectFromEntries<E extends Entries>(entries: E) {\n return Object.fromEntries(entries) as Prettify<\n MergeIntersectingObjects<UnionToIntersection<UnionFromPairs<E>>>\n >;\n}\n"],"mappings":"yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,QAAAE,EAAA,aAAAC,EAAA,oBAAAC,EAAA,sBAAAC,IAAA,eAAAC,EAAAN,GAAA,IAAAO,EAAiC,gBCI1B,SAASC,EAA2CC,EAAQ,CAC/D,OAAO,OAAO,KAAKA,CAAG,CAC1B,CAGO,SAASC,EAA8CD,EAAQ,CAClE,OAAO,OAAO,QAAQA,CAAG,CAC7B,CAKO,SAASE,EAA+CC,EAAa,CACxE,OAAO,OAAO,YACVF,EAAWE,CAAQ,EAAE,IAAI,CAAC,CAACC,EAAOC,CAAK,IAAM,CAACD,EAAOL,EAAQM,CAAK,CAAC,CAAC,CACxE,CACJ,CDgDO,IAAMC,EAAS,CAACC,EAAQC,EAAY,CAAC,IAAM,CAC9C,IAAMC,EAAQD,EAAU,OAAS,OAE3B,CAAE,SAAAE,EAAU,eAAAC,EAAgB,KAAAC,CAAK,EAAIL,EAIrCM,EAAOH,EAAWI,EAAQJ,CAAQ,EAAI,CAAC,EACvCK,EAAUL,EAAWM,EAAmBN,CAAQ,EAAK,CAAC,EACtDO,EAAWN,GAAmB,CAAC,EAE/BO,EAAmBR,EACnB,OAAOH,EAAO,kBAAqB,WAC/BA,EAAO,iBAAiB,CAAE,SAAAG,EAAU,KAAAG,EAAM,QAAAE,EAAS,SAAAE,CAAS,CAAC,EAC7DV,EAAO,iBACX,OAuDN,OAAO,OAAO,OApDVY,GACC,CACD,IAAMC,EAAoBV,EACpBG,EAAK,IAAKQ,GAAY,CAClB,IAAMC,EAAcH,IAAQE,CAAO,EAC7BE,EAAqBZ,IAAiBU,CAAO,EAE7CG,EAAaF,GAAa,SAAS,GAAKC,GAAoB,SAAS,EAE3E,OAAOC,EAAad,EAASW,CAAO,EAAEG,CAAU,EAAI,MACxD,CAAC,EACD,OAEAC,EAA4BP,GAAkB,OAChD,CAACQ,EAAK,CAAE,MAAOC,EAAS,UAAWC,EAAa,GAAGC,CAAS,KACrBC,EAAWD,CAAQ,EAAE,MACpD,CAAC,CAACE,EAAOC,CAAU,IAAM,CACrB,IAAMC,EACFtB,IAAiBoB,CAAoC,EACnDG,EAAgBf,IAAQY,CAA2B,EAEzD,GAAI,OAAOC,GAAe,UAAY,YAAaA,EAAY,CAC3D,GAAIA,EAAW,UAAYG,EAAgB,QACvC,OAAOD,IAAkB,OACtB,GAAIF,EAAW,UAAYI,EAAkB,QAChD,OAAOF,IAAkB,MAEjC,CAEA,IAAMG,EAAWH,GAAiBD,EAElC,OAAO,MAAM,QAAQD,CAAU,EACzBA,EAAW,KAAMA,GAAeK,IAAaL,CAAU,EACvDK,IAAaL,CACvB,CACJ,GAEgCN,EAAI,KAAKC,EAASC,CAAW,EACtDF,GAEX,IAAI,KACR,EAEA,OAAOjB,EACHG,EACAQ,EACAK,EACAN,GAAO,MACPA,GAAO,SACX,CACJ,EAEiC,CAAE,KAAAN,EAAM,QAAAE,EAAS,SAAAE,CAAS,CAAC,CAChE,EAEO,SAASqB,EAASvB,EAAwB,CAC7C,OAAQR,GAAWD,EAAGC,EAAQQ,CAAO,CACzC,CAQO,IAAMoB,EAAkB,CAAE,QAAS,iBAAkB,EAE/CC,EAAoB,CAAE,QAAS,mBAAoB","names":["src_exports","__export","cv","defineCV","onlyWhenDefined","onlyWhenUndefined","__toCommonJS","import_clsx","getKeys","obj","getEntries","getVariantsOptions","variants","cvKey","cvVal","cv","config","cvOptions","merge","variants","defaultVariant","base","keys","getKeys","options","getVariantsOptions","defaults","compoundVariants","props","variantClassNames","variant","variantProp","defaultVariantProp","variantKey","compoundVariantClassNames","acc","cvClass","cvClassName","cvConfig","getEntries","cvKey","cvSelector","defaultsSelector","propsSelector","onlyWhenDefined","onlyWhenUndefined","selector","defineCV"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/tokens.ts","../src/cn.ts","../src/compose.ts","../src/utils.ts","../src/cv.ts","../src/define.ts"],"sourcesContent":["import type { CN } from \"./cn\";\r\nimport type { CVCompose } from \"./compose\";\r\nimport type {\r\n ClassProp,\r\n CV,\r\n CVCompoundVariant,\r\n CVCompoundVariantsSchema,\r\n CVReturn,\r\n CVVariant,\r\n CVVariantsSchema,\r\n VariantProps,\r\n WithClassProp,\r\n} from \"./cv\";\r\nimport { type CVToken, onlyWhenDefined, onlyWhenUndefined } from \"./tokens\";\r\nimport { defineCV } from \"./define\";\r\nimport type { CVUtils } from \"./utils\";\r\n\r\nexport const { cn, cv, compose } = defineCV();\r\n\r\nexport { defineCV, onlyWhenDefined, onlyWhenUndefined };\r\nexport type {\r\n CN,\r\n CV,\r\n CVCompose,\r\n CVUtils,\r\n CVReturn,\r\n VariantProps,\r\n CVVariantsSchema,\r\n CVCompoundVariantsSchema,\r\n CVVariant,\r\n CVCompoundVariant,\r\n WithClassProp,\r\n ClassProp,\r\n CVToken,\r\n};\r\n","import type { Opaque } from \"ts-essentials\";\r\nimport type { CVPropsValue } from \"./cv\";\r\n\r\ntype OnlyWhenDefined = Opaque<{ __token: string }, \"OnlyWhenDefined\">;\r\ntype OnlyWhenUndefined = Opaque<{ __token: string }, \"OnlyWhenUndefined\">;\r\n\r\nexport type CVToken = OnlyWhenDefined | OnlyWhenUndefined;\r\n\r\n/** Apply compound variant only if prop **is** specified */\r\nexport const onlyWhenDefined = { __token: \"OnlyWhenDefined\" } as OnlyWhenDefined;\r\n/** Apply compound variant only if prop **is not** specified */\r\nexport const onlyWhenUndefined = { __token: \"OnlyWhenUndefined\" } as OnlyWhenUndefined;\r\n\r\nexport function isCVToken(token: unknown): token is CVToken {\r\n return token ? typeof token === \"object\" && \"__token\" in token : false;\r\n}\r\nfunction isSpecificCVToken<TReference extends CVToken>(token: CVToken, reference: TReference): token is TReference {\r\n return token.__token === reference.__token;\r\n}\r\n\r\nexport function shouldApplySelectorByToken(token: CVToken, selector: CVPropsValue) {\r\n if (isSpecificCVToken(token, onlyWhenDefined)) return selector !== undefined;\r\n else if (isSpecificCVToken(token, onlyWhenUndefined)) return selector === undefined;\r\n\r\n return false;\r\n}\r\n","import clsx, { type ClassValue } from \"clsx\";\r\n\r\nexport interface CNOptions {\r\n merge?: (className: string) => string;\r\n}\r\n\r\nexport interface CN {\r\n (...inputs: ClassValue[]): string;\r\n}\r\n\r\nexport function _cn({ merge = (className) => className }: CNOptions): CN {\r\n return (...inputs) => merge(clsx(...inputs));\r\n}\r\n","import type { RequiredKeys, UnionToIntersection } from \"ts-essentials\";\r\nimport type { CN } from \"./cn\";\r\nimport {\r\n type AnyCVReturn,\r\n type CVReturn,\r\n type CVReturnProps,\r\n type CVVariantsSchema,\r\n type CVPropsValue,\r\n type VariantProps,\r\n type WithClassProp,\r\n} from \"./cv\";\r\nimport type { AnyCVUtils, CVUtils } from \"./utils\";\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nexport type ExtractVariants<CVR extends AnyCVReturn> = CVR extends CVReturn<infer V, infer _> ? V : never;\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nexport type ExtractRequired<CVR extends AnyCVReturn> = CVR extends CVReturn<infer _, infer R> ? R : never;\r\n\r\ntype OnlyVariantSchema<T> = T extends CVVariantsSchema ? T : never;\r\n\r\ntype MergeVariants<T extends AnyCVReturn[]> = OnlyVariantSchema<UnionToIntersection<ExtractVariants<T[number]>>>;\r\ntype MergeRequiredKeys<T extends AnyCVReturn[]> = ExtractRequired<T[number]>;\r\n\r\nexport interface CVCompose {\r\n <T extends [AnyCVReturn, ...AnyCVReturn[]]>(...components: T): CVReturn<MergeVariants<T>, MergeRequiredKeys<T>>;\r\n}\r\n\r\nexport type CVComposeReturnProps<T extends AnyCVReturn> =\r\n | WithClassProp<VariantProps<T>>\r\n | (RequiredKeys<VariantProps<T>> extends never ? void : never);\r\n\r\nexport function _compose({ cn }: { cn: CN }): CVCompose {\r\n return <T extends AnyCVReturn[]>(...components: T) => {\r\n const utils = composeUtils(...components) as CVUtils<MergeVariants<T>, MergeRequiredKeys<T>>;\r\n\r\n const getVariant = (props: CVReturnProps<MergeVariants<T>, MergeRequiredKeys<T>>) => {\r\n const propsWithoutClass = { ...props, class: undefined, className: undefined };\r\n\r\n return cn(\r\n components.map((component) => component(propsWithoutClass)),\r\n props?.class,\r\n props?.className,\r\n );\r\n };\r\n\r\n return Object.assign(getVariant, utils);\r\n };\r\n}\r\n\r\nexport function composeUtils(...components: AnyCVReturn[]): AnyCVUtils {\r\n const variantKeys = new Set<string>();\r\n const variantMap = new Map<string, CVPropsValue[]>();\r\n const defaultVariants = new Map<string, CVPropsValue>();\r\n const requiredVariants = new Map<string, boolean>();\r\n\r\n components.forEach((component) => {\r\n for (const key of component.variantKeys) {\r\n variantKeys.add(key);\r\n const values = new Set(variantMap.get(key));\r\n for (const value of component.variantMap[key]) {\r\n values.add(value);\r\n }\r\n\r\n variantMap.set(key, Array.from(values));\r\n\r\n defaultVariants.set(key, component.defaultVariants[key]);\r\n requiredVariants.set(key, component.requiredVariants[key]);\r\n }\r\n });\r\n\r\n return {\r\n variantKeys: Array.from(variantKeys),\r\n variantMap: Object.fromEntries(variantMap),\r\n defaultVariants: Object.fromEntries(defaultVariants),\r\n requiredVariants: Object.fromEntries(requiredVariants),\r\n };\r\n}\r\n","// import type { DeepReadonly, DeepWritable, Prettify, UnionToIntersection } from \"ts-essentials\";\r\nimport type { Prettify } from \"ts-essentials\";\r\nimport type { BooleanStringToBoolean, CVConfig, CVVariant, CVVariantsSchema, CVPropsValue, CVVariantKey } from \"./cv\";\r\n\r\nexport function getKeys<O extends Record<string, unknown>>(obj: O) {\r\n return Object.keys(obj) as (keyof O)[];\r\n}\r\n\r\nexport type EntriesOf<O extends Record<string, unknown>> = { [K in keyof O]: [K, O[K]] };\r\nexport function getEntries<O extends Record<string, unknown>>(obj: O) {\r\n return Object.entries(obj) as EntriesOf<O>[keyof EntriesOf<O>][];\r\n}\r\n\r\nexport type VariantMap<V extends CVVariantsSchema> = {\r\n [K in keyof V]: BooleanStringToBoolean<keyof V[K] & CVVariantKey>[];\r\n};\r\nexport function getVariantMap<V extends CVVariantsSchema>(variants: V) {\r\n return Object.fromEntries(getEntries(variants).map(([cvKey, cvVal]) => [cvKey, getKeys(cvVal)])) as VariantMap<V>;\r\n}\r\n\r\nexport interface CVUtils<V extends CVVariantsSchema, R extends keyof V = never> {\r\n variantKeys: (keyof V & CVVariantKey)[];\r\n variantMap: Prettify<VariantMap<V>>;\r\n defaultVariants: Prettify<CVVariant<V>>;\r\n requiredVariants: Prettify<Record<R, boolean>>;\r\n}\r\nexport interface AnyCVUtils {\r\n variantKeys: string[];\r\n variantMap: Record<string, CVPropsValue[]>;\r\n defaultVariants: Record<string, CVPropsValue>;\r\n requiredVariants: Record<string, boolean>;\r\n}\r\n\r\nexport function cvUtils<V extends CVVariantsSchema, R extends keyof V>({\r\n variants,\r\n defaultVariants,\r\n requiredVariants,\r\n}: CVConfig<V, R>) {\r\n return {\r\n variantKeys: getKeys(variants ?? ({} as V)),\r\n variantMap: getVariantMap(variants ?? ({} as V)),\r\n defaultVariants: defaultVariants ?? {},\r\n requiredVariants: requiredVariants ?? {},\r\n } as CVUtils<V, R>;\r\n}\r\n\r\n// type Entries = [PropertyKey, unknown][] | DeepReadonly<[PropertyKey, unknown][]>;\r\n// type UnionFromPairs<TArr extends Entries> =\r\n// DeepWritable<TArr> extends (infer R)[]\r\n// ? R extends [infer key, infer val]\r\n// ? Record<key & PropertyKey, val>\r\n// : never\r\n// : never;\r\n\r\n// type MergeIntersectingObjects<O> = { [K in keyof O]: O[K] };\r\n\r\n// export function objectFromEntries<E extends Entries>(entries: E) {\r\n// return Object.fromEntries(entries) as Prettify<MergeIntersectingObjects<UnionToIntersection<UnionFromPairs<E>>>>;\r\n// }\r\n","import type { ClassValue } from \"clsx\";\r\nimport type { MarkRequired } from \"ts-essentials\";\r\nimport type { CN } from \"./cn\";\r\nimport { isCVToken, shouldApplySelectorByToken, type CVToken } from \"./tokens\";\r\nimport { cvUtils, type AnyCVUtils, type CVUtils } from \"./utils\";\r\n\r\nexport type VariantProps<CVR extends AnyCVReturn> = CVR extends CVReturn<infer V, infer R> ? CVProps<V, R> : never;\r\n\r\nexport type ClassProp = { class?: ClassValue; className?: never } | { class?: never; className?: ClassValue };\r\nexport type WithClassProp<T extends object> = T & ClassProp;\r\n\r\nexport type BooleanStringToBoolean<T> = T extends \"true\" | \"false\" ? boolean : T;\r\n\r\nexport type CVVariantKey = string | number;\r\n\r\nexport type CVVariantsSchema = Record<string, Record<CVVariantKey, ClassValue>>;\r\n\r\nexport type CVVariant<V extends CVVariantsSchema> = {\r\n [K in keyof V]?: BooleanStringToBoolean<keyof V[K] & CVVariantKey>;\r\n};\r\n\r\nexport type CVProps<V extends CVVariantsSchema, R extends keyof V = never> = MarkRequired<CVVariant<V>, R>;\r\n\r\nexport type CVCompoundVariant<V extends CVVariantsSchema> = WithClassProp<{\r\n [K in keyof V]?:\r\n | BooleanStringToBoolean<keyof V[K] & CVVariantKey>\r\n | BooleanStringToBoolean<keyof V[K] & CVVariantKey>[]\r\n | CVToken;\r\n}>;\r\n\r\nexport type CVCompoundVariantsSchema<V extends CVVariantsSchema> = CVCompoundVariant<V>[];\r\n\r\nexport interface CVConfig<V extends CVVariantsSchema, R extends keyof V> {\r\n base?: ClassValue;\r\n variants?: V;\r\n compoundVariants?: CVCompoundVariantsSchema<V> | ((arg: CVUtils<V, R>) => CVCompoundVariantsSchema<V>);\r\n defaultVariants?: CVVariant<V>;\r\n requiredVariants?: Record<R, boolean>;\r\n}\r\n\r\nexport type CVReturnProps<V extends CVVariantsSchema, R extends keyof V = never> =\r\n | WithClassProp<CVProps<V, R>>\r\n | ([R] extends [never] ? void : never);\r\n\r\nexport interface CVReturn<V extends CVVariantsSchema, R extends keyof V = never> extends CVUtils<V, R> {\r\n (props: CVReturnProps<V, R>): string;\r\n}\r\nexport interface AnyCVReturn extends AnyCVUtils {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n (props: any): string;\r\n}\r\n\r\nexport interface CV {\r\n <V extends CVVariantsSchema, R extends keyof V = never>(config: CVConfig<V, R>): CVReturn<V, R>;\r\n}\r\n\r\nexport function _cv({ cn }: { cn: CN }): CV {\r\n return <V extends CVVariantsSchema, R extends keyof V = never>(config: CVConfig<V, R>) => {\r\n const { base, variants, compoundVariants, defaultVariants } = config;\r\n\r\n const utils = cvUtils(config);\r\n\r\n const resolvedCompoundVariants = variants\r\n ? typeof compoundVariants === \"function\"\r\n ? compoundVariants(utils)\r\n : compoundVariants\r\n : undefined;\r\n\r\n const getVariant = (props: CVReturnProps<V, R>) => {\r\n const variantClassNames = variants\r\n ? utils.variantKeys.map((variantKey) => {\r\n const variantProp = props?.[variantKey];\r\n const defaultProp = defaultVariants?.[variantKey];\r\n\r\n const variant = variantProp?.toString() || defaultProp?.toString();\r\n\r\n return variant ? variants[variantKey][variant] : undefined;\r\n })\r\n : undefined;\r\n\r\n const compoundVariantClassNames = resolvedCompoundVariants?.reduce((acc, compoundVariant) => {\r\n if (shouldApplyCompoundVariant(props, compoundVariant, defaultVariants))\r\n acc.push(compoundVariant.class, compoundVariant.className);\r\n\r\n return acc;\r\n }, new Array<ClassValue>());\r\n\r\n return cn(base, variantClassNames, compoundVariantClassNames, props?.class, props?.className);\r\n };\r\n\r\n return Object.assign(getVariant, utils);\r\n };\r\n}\r\n\r\nfunction shouldApplyCompoundVariant<V extends CVVariantsSchema, R extends keyof V>(\r\n props: CVReturnProps<V, R>,\r\n matcher: CVCompoundVariant<V>,\r\n defaults: CVVariant<V> | undefined,\r\n) {\r\n return Object.keys(matcher).every((cvKey) => {\r\n if (cvKey === \"class\" || cvKey === \"className\") return true;\r\n\r\n const cvSelector = matcher[cvKey];\r\n\r\n const defaultsSelector = defaults?.[cvKey as keyof typeof defaults];\r\n const propsSelector = props?.[cvKey as keyof typeof props];\r\n\r\n if (isCVToken(cvSelector)) return shouldApplySelectorByToken(cvSelector, propsSelector);\r\n\r\n const selector = propsSelector ?? defaultsSelector;\r\n\r\n return Array.isArray(cvSelector)\r\n ? cvSelector.some((cvSelector) => compareSelectors(selector, cvSelector))\r\n : compareSelectors(selector, cvSelector);\r\n });\r\n}\r\n\r\nexport type CVPropsValue = CVVariantKey | boolean | undefined;\r\nfunction compareSelectors(selector1: CVPropsValue, selector2: CVPropsValue) {\r\n return selector1?.toString() === selector2?.toString();\r\n}\r\n","import { _cn, type CNOptions } from \"./cn\";\r\nimport { _compose } from \"./compose\";\r\nimport { _cv } from \"./cv\";\r\n\r\nexport interface DefineCVOptions extends CNOptions {}\r\n\r\nexport function defineCV({ merge }: DefineCVOptions = {}) {\r\n const cn = _cn({ merge });\r\n\r\n const cv = _cv({ cn });\r\n\r\n const compose = _compose({ cn });\r\n\r\n return { cn, cv, compose } as const;\r\n}\r\n"],"mappings":"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","names":["index_exports","__export","cn","compose","cv","defineCV","onlyWhenDefined","onlyWhenUndefined","__toCommonJS","onlyWhenDefined","onlyWhenUndefined","isCVToken","token","isSpecificCVToken","reference","shouldApplySelectorByToken","selector","import_clsx","_cn","merge","className","inputs","clsx","_compose","cn","components","utils","composeUtils","props","propsWithoutClass","component","variantKeys","variantMap","defaultVariants","requiredVariants","key","values","value","getKeys","obj","getEntries","getVariantMap","variants","cvKey","cvVal","cvUtils","defaultVariants","requiredVariants","_cv","cn","config","base","variants","compoundVariants","defaultVariants","utils","cvUtils","resolvedCompoundVariants","props","variantClassNames","variantKey","variantProp","defaultProp","variant","compoundVariantClassNames","acc","compoundVariant","shouldApplyCompoundVariant","matcher","defaults","cvKey","cvSelector","defaultsSelector","propsSelector","isCVToken","shouldApplySelectorByToken","selector","compareSelectors","selector1","selector2","defineCV","merge","cn","_cn","cv","_cv","compose","_compose","cn","cv","compose","defineCV"]}
|
package/build/index.d.cts
CHANGED
|
@@ -1,3 +1,13 @@
|
|
|
1
|
+
import { CN } from './cn.cjs';
|
|
2
|
+
import { CVCompose } from './compose.cjs';
|
|
3
|
+
import { C as CV } from './cv-BWSJNbxE.cjs';
|
|
4
|
+
export { g as CVCompoundVariant, e as CVCompoundVariantsSchema, c as CVReturn, i as CVToken, b as CVUtils, f as CVVariant, d as CVVariantsSchema, h as ClassProp, V as VariantProps, W as WithClassProp, o as onlyWhenDefined, a as onlyWhenUndefined } from './cv-BWSJNbxE.cjs';
|
|
5
|
+
export { defineCV } from './define.cjs';
|
|
1
6
|
import 'clsx';
|
|
2
7
|
import 'ts-essentials';
|
|
3
|
-
|
|
8
|
+
|
|
9
|
+
declare const cn: CN;
|
|
10
|
+
declare const cv: CV;
|
|
11
|
+
declare const compose: CVCompose;
|
|
12
|
+
|
|
13
|
+
export { CN, CV, CVCompose, cn, compose, cv };
|
package/build/index.d.ts
CHANGED
|
@@ -1,3 +1,13 @@
|
|
|
1
|
+
import { CN } from './cn.js';
|
|
2
|
+
import { CVCompose } from './compose.js';
|
|
3
|
+
import { C as CV } from './cv-WFZM6Df-.js';
|
|
4
|
+
export { g as CVCompoundVariant, e as CVCompoundVariantsSchema, c as CVReturn, i as CVToken, b as CVUtils, f as CVVariant, d as CVVariantsSchema, h as ClassProp, V as VariantProps, W as WithClassProp, o as onlyWhenDefined, a as onlyWhenUndefined } from './cv-WFZM6Df-.js';
|
|
5
|
+
export { defineCV } from './define.js';
|
|
1
6
|
import 'clsx';
|
|
2
7
|
import 'ts-essentials';
|
|
3
|
-
|
|
8
|
+
|
|
9
|
+
declare const cn: CN;
|
|
10
|
+
declare const cv: CV;
|
|
11
|
+
declare const compose: CVCompose;
|
|
12
|
+
|
|
13
|
+
export { CN, CV, CVCompose, cn, compose, cv };
|
package/build/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{a,b
|
|
1
|
+
import{a as o}from"./chunk-6Y37KLAC.js";import"./chunk-FIET564E.js";import"./chunk-RNIIXHL2.js";import"./chunk-BSA7R4NK.js";import{a as r,b as t}from"./chunk-IMTFPGTY.js";import"./chunk-6DFTYFKO.js";var{cn:n,cv:p,compose:V}=o();export{n as cn,V as compose,p as cv,o as defineCV,r as onlyWhenDefined,t as onlyWhenUndefined};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/build/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import type { CN } from \"./cn\";\r\nimport type { CVCompose } from \"./compose\";\r\nimport type {\r\n ClassProp,\r\n CV,\r\n CVCompoundVariant,\r\n CVCompoundVariantsSchema,\r\n CVReturn,\r\n CVVariant,\r\n CVVariantsSchema,\r\n VariantProps,\r\n WithClassProp,\r\n} from \"./cv\";\r\nimport { type CVToken, onlyWhenDefined, onlyWhenUndefined } from \"./tokens\";\r\nimport { defineCV } from \"./define\";\r\nimport type { CVUtils } from \"./utils\";\r\n\r\nexport const { cn, cv, compose } = defineCV();\r\n\r\nexport { defineCV, onlyWhenDefined, onlyWhenUndefined };\r\nexport type {\r\n CN,\r\n CV,\r\n CVCompose,\r\n CVUtils,\r\n CVReturn,\r\n VariantProps,\r\n CVVariantsSchema,\r\n CVCompoundVariantsSchema,\r\n CVVariant,\r\n CVCompoundVariant,\r\n WithClassProp,\r\n ClassProp,\r\n CVToken,\r\n};\r\n"],"mappings":"uMAiBO,GAAM,CAAE,GAAAA,EAAI,GAAAC,EAAI,QAAAC,CAAQ,EAAIC,EAAS","names":["cn","cv","compose","defineCV"]}
|
package/build/tokens.cjs
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";var i=Object.defineProperty;var l=Object.getOwnPropertyDescriptor;var s=Object.getOwnPropertyNames;var y=Object.prototype.hasOwnProperty;var u=(e,n)=>{for(var t in n)i(e,t,{get:n[t],enumerable:!0})},k=(e,n,t,f)=>{if(n&&typeof n=="object"||typeof n=="function")for(let o of s(n))!y.call(e,o)&&o!==t&&i(e,o,{get:()=>n[o],enumerable:!(f=l(n,o))||f.enumerable});return e};var _=e=>k(i({},"__esModule",{value:!0}),e);var c={};u(c,{isCVToken:()=>h,onlyWhenDefined:()=>d,onlyWhenUndefined:()=>p,shouldApplySelectorByToken:()=>O});module.exports=_(c);var d={__token:"OnlyWhenDefined"},p={__token:"OnlyWhenUndefined"};function h(e){return e?typeof e=="object"&&"__token"in e:!1}function r(e,n){return e.__token===n.__token}function O(e,n){return r(e,d)?n!==void 0:r(e,p)?n===void 0:!1}0&&(module.exports={isCVToken,onlyWhenDefined,onlyWhenUndefined,shouldApplySelectorByToken});
|
|
2
|
+
//# sourceMappingURL=tokens.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/tokens.ts"],"sourcesContent":["import type { Opaque } from \"ts-essentials\";\r\nimport type { CVPropsValue } from \"./cv\";\r\n\r\ntype OnlyWhenDefined = Opaque<{ __token: string }, \"OnlyWhenDefined\">;\r\ntype OnlyWhenUndefined = Opaque<{ __token: string }, \"OnlyWhenUndefined\">;\r\n\r\nexport type CVToken = OnlyWhenDefined | OnlyWhenUndefined;\r\n\r\n/** Apply compound variant only if prop **is** specified */\r\nexport const onlyWhenDefined = { __token: \"OnlyWhenDefined\" } as OnlyWhenDefined;\r\n/** Apply compound variant only if prop **is not** specified */\r\nexport const onlyWhenUndefined = { __token: \"OnlyWhenUndefined\" } as OnlyWhenUndefined;\r\n\r\nexport function isCVToken(token: unknown): token is CVToken {\r\n return token ? typeof token === \"object\" && \"__token\" in token : false;\r\n}\r\nfunction isSpecificCVToken<TReference extends CVToken>(token: CVToken, reference: TReference): token is TReference {\r\n return token.__token === reference.__token;\r\n}\r\n\r\nexport function shouldApplySelectorByToken(token: CVToken, selector: CVPropsValue) {\r\n if (isSpecificCVToken(token, onlyWhenDefined)) return selector !== undefined;\r\n else if (isSpecificCVToken(token, onlyWhenUndefined)) return selector === undefined;\r\n\r\n return false;\r\n}\r\n"],"mappings":"yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,eAAAE,EAAA,oBAAAC,EAAA,sBAAAC,EAAA,+BAAAC,IAAA,eAAAC,EAAAN,GASO,IAAMG,EAAkB,CAAE,QAAS,iBAAkB,EAE/CC,EAAoB,CAAE,QAAS,mBAAoB,EAEzD,SAASF,EAAUK,EAAkC,CACxD,OAAOA,EAAQ,OAAOA,GAAU,UAAY,YAAaA,EAAQ,EACrE,CACA,SAASC,EAA8CD,EAAgBE,EAA4C,CAC/G,OAAOF,EAAM,UAAYE,EAAU,OACvC,CAEO,SAASJ,EAA2BE,EAAgBG,EAAwB,CAC/E,OAAIF,EAAkBD,EAAOJ,CAAe,EAAUO,IAAa,OAC1DF,EAAkBD,EAAOH,CAAiB,EAAUM,IAAa,OAEnE,EACX","names":["tokens_exports","__export","isCVToken","onlyWhenDefined","onlyWhenUndefined","shouldApplySelectorByToken","__toCommonJS","token","isSpecificCVToken","reference","selector"]}
|
package/build/tokens.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
package/build/utils.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var r=Object.defineProperty;var f=Object.getOwnPropertyDescriptor;var p=Object.getOwnPropertyNames;var y=Object.prototype.hasOwnProperty;var c=(e,t)=>{for(var n in t)r(e,n,{get:t[n],enumerable:!0})},d=(e,t,n,V)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of p(t))!y.call(e,a)&&a!==n&&r(e,a,{get:()=>t[a],enumerable:!(V=f(t,a))||V.enumerable});return e};var u=e=>d(r({},"__esModule",{value:!0}),e);var l={};c(l,{cvUtils:()=>C,getEntries:()=>o,getKeys:()=>i,getVariantMap:()=>s});module.exports=u(l);function i(e){return Object.keys(e)}function o(e){return Object.entries(e)}function s(e){return Object.fromEntries(o(e).map(([t,n])=>[t,i(n)]))}function C({variants:e,defaultVariants:t,requiredVariants:n}){return{variantKeys:i(e??{}),variantMap:s(e??{}),defaultVariants:t??{},requiredVariants:n??{}}}0&&(module.exports={cvUtils,getEntries,getKeys,getVariantMap});
|
|
2
2
|
//# sourceMappingURL=utils.cjs.map
|
package/build/utils.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/utils.ts"],"sourcesContent":["import { DeepReadonly, DeepWritable, Prettify, UnionToIntersection } from \"ts-essentials\";\nimport {
|
|
1
|
+
{"version":3,"sources":["../src/utils.ts"],"sourcesContent":["// import type { DeepReadonly, DeepWritable, Prettify, UnionToIntersection } from \"ts-essentials\";\r\nimport type { Prettify } from \"ts-essentials\";\r\nimport type { BooleanStringToBoolean, CVConfig, CVVariant, CVVariantsSchema, CVPropsValue, CVVariantKey } from \"./cv\";\r\n\r\nexport function getKeys<O extends Record<string, unknown>>(obj: O) {\r\n return Object.keys(obj) as (keyof O)[];\r\n}\r\n\r\nexport type EntriesOf<O extends Record<string, unknown>> = { [K in keyof O]: [K, O[K]] };\r\nexport function getEntries<O extends Record<string, unknown>>(obj: O) {\r\n return Object.entries(obj) as EntriesOf<O>[keyof EntriesOf<O>][];\r\n}\r\n\r\nexport type VariantMap<V extends CVVariantsSchema> = {\r\n [K in keyof V]: BooleanStringToBoolean<keyof V[K] & CVVariantKey>[];\r\n};\r\nexport function getVariantMap<V extends CVVariantsSchema>(variants: V) {\r\n return Object.fromEntries(getEntries(variants).map(([cvKey, cvVal]) => [cvKey, getKeys(cvVal)])) as VariantMap<V>;\r\n}\r\n\r\nexport interface CVUtils<V extends CVVariantsSchema, R extends keyof V = never> {\r\n variantKeys: (keyof V & CVVariantKey)[];\r\n variantMap: Prettify<VariantMap<V>>;\r\n defaultVariants: Prettify<CVVariant<V>>;\r\n requiredVariants: Prettify<Record<R, boolean>>;\r\n}\r\nexport interface AnyCVUtils {\r\n variantKeys: string[];\r\n variantMap: Record<string, CVPropsValue[]>;\r\n defaultVariants: Record<string, CVPropsValue>;\r\n requiredVariants: Record<string, boolean>;\r\n}\r\n\r\nexport function cvUtils<V extends CVVariantsSchema, R extends keyof V>({\r\n variants,\r\n defaultVariants,\r\n requiredVariants,\r\n}: CVConfig<V, R>) {\r\n return {\r\n variantKeys: getKeys(variants ?? ({} as V)),\r\n variantMap: getVariantMap(variants ?? ({} as V)),\r\n defaultVariants: defaultVariants ?? {},\r\n requiredVariants: requiredVariants ?? {},\r\n } as CVUtils<V, R>;\r\n}\r\n\r\n// type Entries = [PropertyKey, unknown][] | DeepReadonly<[PropertyKey, unknown][]>;\r\n// type UnionFromPairs<TArr extends Entries> =\r\n// DeepWritable<TArr> extends (infer R)[]\r\n// ? R extends [infer key, infer val]\r\n// ? Record<key & PropertyKey, val>\r\n// : never\r\n// : never;\r\n\r\n// type MergeIntersectingObjects<O> = { [K in keyof O]: O[K] };\r\n\r\n// export function objectFromEntries<E extends Entries>(entries: E) {\r\n// return Object.fromEntries(entries) as Prettify<MergeIntersectingObjects<UnionToIntersection<UnionFromPairs<E>>>>;\r\n// }\r\n"],"mappings":"yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,aAAAE,EAAA,eAAAC,EAAA,YAAAC,EAAA,kBAAAC,IAAA,eAAAC,EAAAN,GAIO,SAASI,EAA2CG,EAAQ,CAC/D,OAAO,OAAO,KAAKA,CAAG,CAC1B,CAGO,SAASJ,EAA8CI,EAAQ,CAClE,OAAO,OAAO,QAAQA,CAAG,CAC7B,CAKO,SAASF,EAA0CG,EAAa,CACnE,OAAO,OAAO,YAAYL,EAAWK,CAAQ,EAAE,IAAI,CAAC,CAACC,EAAOC,CAAK,IAAM,CAACD,EAAOL,EAAQM,CAAK,CAAC,CAAC,CAAC,CACnG,CAeO,SAASR,EAAuD,CACnE,SAAAM,EACA,gBAAAG,EACA,iBAAAC,CACJ,EAAmB,CACf,MAAO,CACH,YAAaR,EAAQI,GAAa,CAAC,CAAO,EAC1C,WAAYH,EAAcG,GAAa,CAAC,CAAO,EAC/C,gBAAiBG,GAAmB,CAAC,EACrC,iBAAkBC,GAAoB,CAAC,CAC3C,CACJ","names":["utils_exports","__export","cvUtils","getEntries","getKeys","getVariantMap","__toCommonJS","obj","variants","cvKey","cvVal","defaultVariants","requiredVariants"]}
|
package/build/utils.d.cts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
import 'ts-essentials';
|
|
2
|
-
export {
|
|
2
|
+
export { j as AnyCVUtils, b as CVUtils, E as EntriesOf, p as VariantMap, r as cvUtils, n as getEntries, m as getKeys, q as getVariantMap } from './cv-BWSJNbxE.cjs';
|
|
3
3
|
import 'clsx';
|
|
4
|
+
import './cn.cjs';
|
package/build/utils.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
import 'ts-essentials';
|
|
2
|
-
export {
|
|
2
|
+
export { j as AnyCVUtils, b as CVUtils, E as EntriesOf, p as VariantMap, r as cvUtils, n as getEntries, m as getKeys, q as getVariantMap } from './cv-WFZM6Df-.js';
|
|
3
3
|
import 'clsx';
|
|
4
|
+
import './cn.js';
|
package/build/utils.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{a,b,c,d}from"./chunk-
|
|
1
|
+
import{a,b,c,d}from"./chunk-6DFTYFKO.js";export{d as cvUtils,b as getEntries,a as getKeys,c as getVariantMap};
|
|
2
2
|
//# sourceMappingURL=utils.js.map
|
package/build/vue.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var o=Object.defineProperty;var V=Object.getOwnPropertyDescriptor;var a=Object.getOwnPropertyNames;var i=Object.prototype.hasOwnProperty;var p=(t,e)=>{for(var n in e)o(t,n,{get:e[n],enumerable:!0})},f=(t,e,n,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of a(e))!i.call(t,r)&&r!==n&&o(t,r,{get:()=>e[r],enumerable:!(s=V(e,r))||s.enumerable});return t};var y=t=>f(o({},"__esModule",{value:!0}),t);var d={};p(d,{getPropsDeclaration:()=>R});module.exports=y(d);function R(t){return Object.fromEntries(t.variantKeys.map(e=>[e,{type:null,required:t.requiredVariants[e]}]))}0&&(module.exports={getPropsDeclaration});
|
|
2
2
|
//# sourceMappingURL=vue.cjs.map
|
package/build/vue.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/vue.ts","../src/index.ts","../src/utils.ts"],"sourcesContent":["import { Prettify } from \"ts-essentials\";\nimport { PropType } from \"vue\";\nimport { CVConfig, CVOptions, CVReturn, CVVariantsSchema, cv } from \".\";\nimport { getKeys, objectFromEntries } from \"./utils\";\n\ntype PropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never> = Prettify<{\n [K in keyof V]: {\n type: PropType<keyof V[K] | (K extends R ? never : undefined)>;\n required: K extends R ? true : false;\n };\n}>;\nexport interface CVWithPropsReturn<V extends CVVariantsSchema, R extends keyof V = never> {\n getClass: CVReturn<V, R>;\n props: PropsDeclaration<NoInfer<V>, NoInfer<R>>;\n}\n\nexport interface CVWithProps {\n // eslint-disable-next-line @typescript-eslint/prefer-function-type\n <V extends CVVariantsSchema, R extends keyof V = never>(\n config: CVConfig<V, R>,\n options?: CVOptions,\n ): CVWithPropsReturn<V, R>;\n}\n\nexport function getPropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never>(\n config: CVConfig<V, R>,\n) {\n if (typeof config?.variants === \"undefined\") {\n return {};\n }\n\n return objectFromEntries(\n getKeys(config.variants).map(\n (key) =>\n [\n key,\n {\n type: String,\n required: config.requiredProps?.includes(key as R),\n },\n ] as const,\n ),\n );\n}\n\nexport const cvWithProps: CVWithProps = ((config, options) => {\n const getClass = cv(config, options);\n const props = getPropsDeclaration(config);\n\n return { getClass, props };\n}) as CVWithProps;\n","import { ClassValue, clsx } from \"clsx\";\nimport { MarkRequired, Prettify, StrictExclude, Opaque } from \"ts-essentials\";\nimport { getEntries, getKeys, getVariantsOptions, KeysOf, VariantOptions } from \"./utils\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type VariantProps<CVR extends (args?: any) => string> = Prettify<\n Omit<NonNullable<StrictExclude<Parameters<CVR>[0], void>>, \"class\" | \"className\">\n>;\n\ntype ClassProp =\n | { class?: ClassValue; className?: never }\n | { class?: never; className?: ClassValue };\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type WithClassProp<T extends Record<string, any>> = T & ClassProp;\n\ntype BooleanStringToBoolean<T> = T extends \"true\" | \"false\" ? boolean : T;\n\nexport type CVVariantsSchema = Record<string, Record<string, ClassValue>>;\n\nexport type CVVariant<V extends CVVariantsSchema> = {\n [K in keyof V]?: BooleanStringToBoolean<keyof V[K]>;\n};\nexport type CVCompoundVariant<V extends CVVariantsSchema> = WithClassProp<{\n [K in keyof V]?:\n | BooleanStringToBoolean<keyof V[K]>\n | BooleanStringToBoolean<keyof V[K]>[]\n | CVToken;\n}>;\n\nexport type CVCompoundVariantsSchema<V extends CVVariantsSchema> = CVCompoundVariant<V>[];\n\nexport interface CVConfig<V extends CVVariantsSchema, R extends keyof V> {\n base?: ClassValue;\n variants?: V;\n compoundVariants?:\n | CVCompoundVariantsSchema<V>\n | ((arg: {\n variants: V;\n keys: KeysOf<V>;\n options: VariantOptions<V>;\n defaults: CVVariant<V>;\n }) => CVCompoundVariantsSchema<V>);\n defaultVariant?: CVVariant<V>;\n requiredProps?: R[];\n}\nexport interface CVOptions {\n merge?: (...args: ClassValue[]) => string;\n}\n\ntype CVReturnProps<V extends CVVariantsSchema, R extends keyof V = never> =\n | Prettify<WithClassProp<MarkRequired<CVVariant<V>, R>>>\n | ([R] extends [never] ? void : never);\nexport interface CVReturn<V extends CVVariantsSchema, R extends keyof V = never> {\n (props: CVReturnProps<V, R>): string;\n keys: KeysOf<V>;\n options: VariantOptions<V>;\n defaults: CVVariant<V>;\n}\n\nexport interface CV {\n // eslint-disable-next-line @typescript-eslint/prefer-function-type\n <V extends CVVariantsSchema, R extends keyof V = never>(\n config: CVConfig<V, R>,\n cvOptions?: CVOptions,\n ): CVReturn<V, R>;\n}\n\nexport const cv: CV = (config, cvOptions = {}) => {\n const merge = cvOptions.merge ?? clsx;\n\n const { variants, defaultVariant, base } = config;\n\n type ResolvedV = NonNullable<typeof variants>;\n\n const keys = variants ? getKeys(variants) : [];\n const options = variants ? getVariantsOptions(variants) : ({} as VariantOptions<ResolvedV>);\n const defaults = defaultVariant ?? ({} as CVVariant<ResolvedV>);\n\n const compoundVariants = variants\n ? typeof config.compoundVariants === \"function\"\n ? config.compoundVariants({ variants, keys, options, defaults })\n : config.compoundVariants\n : undefined;\n\n const getVariant = <V extends ResolvedV, R extends keyof V = never>(\n props: CVReturnProps<V, R>,\n ) => {\n const variantClassNames = variants\n ? keys.map((variant) => {\n const variantProp = props?.[variant];\n const defaultVariantProp = defaultVariant?.[variant];\n\n const variantKey = variantProp?.toString() || defaultVariantProp?.toString();\n\n return variantKey ? variants[variant][variantKey] : undefined;\n })\n : undefined;\n\n const compoundVariantClassNames = compoundVariants?.reduce(\n (acc, { class: cvClass, className: cvClassName, ...cvConfig }) => {\n const shouldApplyCompoundVariant = getEntries(cvConfig).every(\n ([cvKey, cvSelector]) => {\n const defaultsSelector =\n defaultVariant?.[cvKey as keyof typeof defaultVariant];\n const propsSelector = props?.[cvKey as keyof typeof props];\n\n if (typeof cvSelector === \"object\" && \"__token\" in cvSelector) {\n if (cvSelector.__token === onlyWhenDefined.__token) {\n return propsSelector !== undefined;\n } else if (cvSelector.__token === onlyWhenUndefined.__token) {\n return propsSelector === undefined;\n }\n }\n\n const selector = propsSelector ?? defaultsSelector;\n\n return Array.isArray(cvSelector)\n ? cvSelector.some((cvSelector) => selector === cvSelector)\n : selector === cvSelector;\n },\n );\n\n if (shouldApplyCompoundVariant) acc.push(cvClass, cvClassName);\n return acc;\n },\n new Array<ClassValue>(),\n );\n\n return merge(\n base,\n variantClassNames,\n compoundVariantClassNames,\n props?.class,\n props?.className,\n );\n };\n\n return Object.assign(getVariant, { keys, options, defaults });\n};\n\nexport function defineCV(options: CVOptions): CV {\n return (config) => cv(config, options);\n}\n\ntype OnlyWhenDefined = Opaque<{ __token: string }, \"OnlyWhenDefined\">;\ntype OnlyWhenUndefined = Opaque<{ __token: string }, \"OnlyWhenUndefined\">;\n\ntype CVToken = OnlyWhenDefined | OnlyWhenUndefined;\n\n/** Apply compound variant only if prop **is** specified */\nexport const onlyWhenDefined = { __token: \"OnlyWhenDefined\" } as OnlyWhenDefined;\n/** Apply compound variant only if prop **is not** specified */\nexport const onlyWhenUndefined = { __token: \"OnlyWhenUndefined\" } as OnlyWhenUndefined;\n","import { DeepReadonly, DeepWritable, Prettify, UnionToIntersection } from \"ts-essentials\";\nimport { CVVariantsSchema } from \".\";\n\nexport type KeysOf<O extends Record<string, unknown>> = (keyof O)[];\nexport function getKeys<O extends Record<string, unknown>>(obj: O) {\n return Object.keys(obj) as KeysOf<O>;\n}\n\nexport type EntriesOf<O extends Record<string, unknown>> = { [K in keyof O]: [K, O[K]] };\nexport function getEntries<O extends Record<string, unknown>>(obj: O) {\n return Object.entries(obj) as EntriesOf<O>[keyof EntriesOf<O>][];\n}\n\nexport type VariantOptions<V extends CVVariantsSchema> = {\n [K in keyof V]: KeysOf<V[K]>;\n};\nexport function getVariantsOptions<V extends CVVariantsSchema>(variants: V) {\n return Object.fromEntries(\n getEntries(variants).map(([cvKey, cvVal]) => [cvKey, getKeys(cvVal)]),\n ) as VariantOptions<V>;\n}\n\ntype Entries = [PropertyKey, unknown][] | DeepReadonly<[PropertyKey, unknown][]>;\ntype UnionFromPairs<TArr extends Entries> =\n DeepWritable<TArr> extends (infer R)[]\n ? R extends [infer key, infer val]\n ? { [prop in key & PropertyKey]: val }\n : never\n : never;\n\ntype MergeIntersectingObjects<O> = { [K in keyof O]: O[K] };\n\nexport function objectFromEntries<E extends Entries>(entries: E) {\n return Object.fromEntries(entries) as Prettify<\n MergeIntersectingObjects<UnionToIntersection<UnionFromPairs<E>>>\n >;\n}\n"],"mappings":"yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,iBAAAE,EAAA,wBAAAC,IAAA,eAAAC,EAAAJ,GCAA,IAAAK,EAAiC,gBCI1B,SAASC,EAA2CC,EAAQ,CAC/D,OAAO,OAAO,KAAKA,CAAG,CAC1B,CAGO,SAASC,EAA8CD,EAAQ,CAClE,OAAO,OAAO,QAAQA,CAAG,CAC7B,CAKO,SAASE,EAA+CC,EAAa,CACxE,OAAO,OAAO,YACVF,EAAWE,CAAQ,EAAE,IAAI,CAAC,CAACC,EAAOC,CAAK,IAAM,CAACD,EAAOL,EAAQM,CAAK,CAAC,CAAC,CACxE,CACJ,CAYO,SAASC,EAAqCC,EAAY,CAC7D,OAAO,OAAO,YAAYA,CAAO,CAGrC,CDgCO,IAAMC,EAAS,CAACC,EAAQC,EAAY,CAAC,IAAM,CAC9C,IAAMC,EAAQD,EAAU,OAAS,OAE3B,CAAE,SAAAE,EAAU,eAAAC,EAAgB,KAAAC,CAAK,EAAIL,EAIrCM,EAAOH,EAAWI,EAAQJ,CAAQ,EAAI,CAAC,EACvCK,EAAUL,EAAWM,EAAmBN,CAAQ,EAAK,CAAC,EACtDO,EAAWN,GAAmB,CAAC,EAE/BO,EAAmBR,EACnB,OAAOH,EAAO,kBAAqB,WAC/BA,EAAO,iBAAiB,CAAE,SAAAG,EAAU,KAAAG,EAAM,QAAAE,EAAS,SAAAE,CAAS,CAAC,EAC7DV,EAAO,iBACX,OAuDN,OAAO,OAAO,OApDVY,GACC,CACD,IAAMC,EAAoBV,EACpBG,EAAK,IAAKQ,GAAY,CAClB,IAAMC,EAAcH,IAAQE,CAAO,EAC7BE,EAAqBZ,IAAiBU,CAAO,EAE7CG,EAAaF,GAAa,SAAS,GAAKC,GAAoB,SAAS,EAE3E,OAAOC,EAAad,EAASW,CAAO,EAAEG,CAAU,EAAI,MACxD,CAAC,EACD,OAEAC,EAA4BP,GAAkB,OAChD,CAACQ,EAAK,CAAE,MAAOC,EAAS,UAAWC,EAAa,GAAGC,CAAS,KACrBC,EAAWD,CAAQ,EAAE,MACpD,CAAC,CAACE,EAAOC,CAAU,IAAM,CACrB,IAAMC,EACFtB,IAAiBoB,CAAoC,EACnDG,EAAgBf,IAAQY,CAA2B,EAEzD,GAAI,OAAOC,GAAe,UAAY,YAAaA,EAAY,CAC3D,GAAIA,EAAW,UAAYG,EAAgB,QACvC,OAAOD,IAAkB,OACtB,GAAIF,EAAW,UAAYI,EAAkB,QAChD,OAAOF,IAAkB,MAEjC,CAEA,IAAMG,EAAWH,GAAiBD,EAElC,OAAO,MAAM,QAAQD,CAAU,EACzBA,EAAW,KAAMA,GAAeK,IAAaL,CAAU,EACvDK,IAAaL,CACvB,CACJ,GAEgCN,EAAI,KAAKC,EAASC,CAAW,EACtDF,GAEX,IAAI,KACR,EAEA,OAAOjB,EACHG,EACAQ,EACAK,EACAN,GAAO,MACPA,GAAO,SACX,CACJ,EAEiC,CAAE,KAAAN,EAAM,QAAAE,EAAS,SAAAE,CAAS,CAAC,CAChE,EAYO,IAAMqB,EAAkB,CAAE,QAAS,iBAAkB,EAE/CC,EAAoB,CAAE,QAAS,mBAAoB,EDjIzD,SAASC,EACZC,EACF,CACE,OAAI,OAAOA,GAAQ,SAAa,IACrB,CAAC,EAGLC,EACHC,EAAQF,EAAO,QAAQ,EAAE,IACpBG,GACG,CACIA,EACA,CACI,KAAM,OACN,SAAUH,EAAO,eAAe,SAASG,CAAQ,CACrD,CACJ,CACR,CACJ,CACJ,CAEO,IAAMC,EAA4B,CAACJ,EAAQK,IAAY,CAC1D,IAAMC,EAAWC,EAAGP,EAAQK,CAAO,EAC7BG,EAAQT,EAAoBC,CAAM,EAExC,MAAO,CAAE,SAAAM,EAAU,MAAAE,CAAM,CAC7B","names":["vue_exports","__export","cvWithProps","getPropsDeclaration","__toCommonJS","import_clsx","getKeys","obj","getEntries","getVariantsOptions","variants","cvKey","cvVal","objectFromEntries","entries","cv","config","cvOptions","merge","variants","defaultVariant","base","keys","getKeys","options","getVariantsOptions","defaults","compoundVariants","props","variantClassNames","variant","variantProp","defaultVariantProp","variantKey","compoundVariantClassNames","acc","cvClass","cvClassName","cvConfig","getEntries","cvKey","cvSelector","defaultsSelector","propsSelector","onlyWhenDefined","onlyWhenUndefined","selector","onlyWhenDefined","onlyWhenUndefined","getPropsDeclaration","config","objectFromEntries","getKeys","key","cvWithProps","options","getClass","cv","props"]}
|
|
1
|
+
{"version":3,"sources":["../src/vue.ts"],"sourcesContent":["import type { Prettify } from \"ts-essentials\";\r\nimport { type PropType } from \"vue\";\r\nimport { type CVConfig, type CVReturn, type CVVariantsSchema } from \"./cv\";\r\n\r\ntype PropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never> = Prettify<{\r\n [K in keyof V]: {\r\n type: PropType<keyof V[K] | (K extends R ? never : undefined)>;\r\n required: K extends R ? true : false;\r\n };\r\n}>;\r\nexport interface CVWithPropsReturn<V extends CVVariantsSchema, R extends keyof V = never> {\r\n getClass: CVReturn<V, R>;\r\n props: PropsDeclaration<NoInfer<V>, NoInfer<R>>;\r\n}\r\n\r\nexport interface CVWithProps {\r\n <V extends CVVariantsSchema, R extends keyof V = never>(config: CVConfig<V, R>): CVWithPropsReturn<V, R>;\r\n}\r\n\r\nexport function getPropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never>(cv: CVReturn<V, R>) {\r\n return Object.fromEntries(\r\n cv.variantKeys.map((key) => [key, { type: null, required: cv.requiredVariants[key as R] }]),\r\n ) as unknown as { [K in keyof V]: { type: PropType<keyof V[K]>; required: K extends R ? true : false } };\r\n}\r\n"],"mappings":"yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,yBAAAE,IAAA,eAAAC,EAAAH,GAmBO,SAASE,EAA2EE,EAAoB,CAC3G,OAAO,OAAO,YACVA,EAAG,YAAY,IAAKC,GAAQ,CAACA,EAAK,CAAE,KAAM,KAAM,SAAUD,EAAG,iBAAiBC,CAAQ,CAAE,CAAC,CAAC,CAC9F,CACJ","names":["vue_exports","__export","getPropsDeclaration","__toCommonJS","cv","key"]}
|
package/build/vue.d.cts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { Prettify } from 'ts-essentials';
|
|
2
2
|
import { PropType } from 'vue';
|
|
3
|
-
import {
|
|
3
|
+
import { d as CVVariantsSchema, c as CVReturn, k as CVConfig } from './cv-BWSJNbxE.cjs';
|
|
4
4
|
import 'clsx';
|
|
5
|
+
import './cn.cjs';
|
|
5
6
|
|
|
6
7
|
type PropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never> = Prettify<{
|
|
7
8
|
[K in keyof V]: {
|
|
@@ -14,9 +15,11 @@ interface CVWithPropsReturn<V extends CVVariantsSchema, R extends keyof V = neve
|
|
|
14
15
|
props: PropsDeclaration<NoInfer<V>, NoInfer<R>>;
|
|
15
16
|
}
|
|
16
17
|
interface CVWithProps {
|
|
17
|
-
<V extends CVVariantsSchema, R extends keyof V = never>(config: CVConfig<V, R
|
|
18
|
+
<V extends CVVariantsSchema, R extends keyof V = never>(config: CVConfig<V, R>): CVWithPropsReturn<V, R>;
|
|
18
19
|
}
|
|
19
|
-
declare function getPropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never>(
|
|
20
|
-
|
|
20
|
+
declare function getPropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never>(cv: CVReturn<V, R>): { [K in keyof V]: {
|
|
21
|
+
type: PropType<keyof V[K]>;
|
|
22
|
+
required: K extends R ? true : false;
|
|
23
|
+
}; };
|
|
21
24
|
|
|
22
|
-
export { type CVWithProps, type CVWithPropsReturn,
|
|
25
|
+
export { type CVWithProps, type CVWithPropsReturn, getPropsDeclaration };
|
package/build/vue.d.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { Prettify } from 'ts-essentials';
|
|
2
2
|
import { PropType } from 'vue';
|
|
3
|
-
import {
|
|
3
|
+
import { d as CVVariantsSchema, c as CVReturn, k as CVConfig } from './cv-WFZM6Df-.js';
|
|
4
4
|
import 'clsx';
|
|
5
|
+
import './cn.js';
|
|
5
6
|
|
|
6
7
|
type PropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never> = Prettify<{
|
|
7
8
|
[K in keyof V]: {
|
|
@@ -14,9 +15,11 @@ interface CVWithPropsReturn<V extends CVVariantsSchema, R extends keyof V = neve
|
|
|
14
15
|
props: PropsDeclaration<NoInfer<V>, NoInfer<R>>;
|
|
15
16
|
}
|
|
16
17
|
interface CVWithProps {
|
|
17
|
-
<V extends CVVariantsSchema, R extends keyof V = never>(config: CVConfig<V, R
|
|
18
|
+
<V extends CVVariantsSchema, R extends keyof V = never>(config: CVConfig<V, R>): CVWithPropsReturn<V, R>;
|
|
18
19
|
}
|
|
19
|
-
declare function getPropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never>(
|
|
20
|
-
|
|
20
|
+
declare function getPropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never>(cv: CVReturn<V, R>): { [K in keyof V]: {
|
|
21
|
+
type: PropType<keyof V[K]>;
|
|
22
|
+
required: K extends R ? true : false;
|
|
23
|
+
}; };
|
|
21
24
|
|
|
22
|
-
export { type CVWithProps, type CVWithPropsReturn,
|
|
25
|
+
export { type CVWithProps, type CVWithPropsReturn, getPropsDeclaration };
|
package/build/vue.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
function r(e){return Object.fromEntries(e.variantKeys.map(t=>[t,{type:null,required:e.requiredVariants[t]}]))}export{r as getPropsDeclaration};
|
|
2
2
|
//# sourceMappingURL=vue.js.map
|
package/build/vue.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/vue.ts"],"sourcesContent":["import { Prettify } from \"ts-essentials\";\nimport { PropType } from \"vue\";\nimport { CVConfig,
|
|
1
|
+
{"version":3,"sources":["../src/vue.ts"],"sourcesContent":["import type { Prettify } from \"ts-essentials\";\r\nimport { type PropType } from \"vue\";\r\nimport { type CVConfig, type CVReturn, type CVVariantsSchema } from \"./cv\";\r\n\r\ntype PropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never> = Prettify<{\r\n [K in keyof V]: {\r\n type: PropType<keyof V[K] | (K extends R ? never : undefined)>;\r\n required: K extends R ? true : false;\r\n };\r\n}>;\r\nexport interface CVWithPropsReturn<V extends CVVariantsSchema, R extends keyof V = never> {\r\n getClass: CVReturn<V, R>;\r\n props: PropsDeclaration<NoInfer<V>, NoInfer<R>>;\r\n}\r\n\r\nexport interface CVWithProps {\r\n <V extends CVVariantsSchema, R extends keyof V = never>(config: CVConfig<V, R>): CVWithPropsReturn<V, R>;\r\n}\r\n\r\nexport function getPropsDeclaration<V extends CVVariantsSchema, R extends keyof V = never>(cv: CVReturn<V, R>) {\r\n return Object.fromEntries(\r\n cv.variantKeys.map((key) => [key, { type: null, required: cv.requiredVariants[key as R] }]),\r\n ) as unknown as { [K in keyof V]: { type: PropType<keyof V[K]>; required: K extends R ? true : false } };\r\n}\r\n"],"mappings":"AAmBO,SAASA,EAA2EC,EAAoB,CAC3G,OAAO,OAAO,YACVA,EAAG,YAAY,IAAKC,GAAQ,CAACA,EAAK,CAAE,KAAM,KAAM,SAAUD,EAAG,iBAAiBC,CAAQ,CAAE,CAAC,CAAC,CAC9F,CACJ","names":["getPropsDeclaration","cv","key"]}
|
package/package.json
CHANGED
|
@@ -1,61 +1,60 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
2
|
+
"name": "@yaredfall/class-variants",
|
|
3
|
+
"author": "yaredfall",
|
|
4
|
+
"private": false,
|
|
5
|
+
"publishConfig": {
|
|
6
|
+
"access": "public"
|
|
7
|
+
},
|
|
8
|
+
"version": "0.5.0-rc",
|
|
9
|
+
"type": "module",
|
|
10
|
+
"files": [
|
|
11
|
+
"build"
|
|
12
|
+
],
|
|
13
|
+
"main": "build/index.cjs",
|
|
14
|
+
"module": "build/index.js",
|
|
15
|
+
"types": "build/index.d.ts",
|
|
16
|
+
"exports": {
|
|
17
|
+
".": {
|
|
18
|
+
"import": {
|
|
19
|
+
"types": "./build/index.d.ts",
|
|
20
|
+
"default": "./build/index.js"
|
|
21
|
+
},
|
|
22
|
+
"require": {
|
|
23
|
+
"types": "./build/index.d.cts",
|
|
24
|
+
"default": "./build/index.cjs"
|
|
25
|
+
}
|
|
7
26
|
},
|
|
8
|
-
"
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
"build"
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
".": {
|
|
18
|
-
"import": {
|
|
19
|
-
"types": "./build/index.d.ts",
|
|
20
|
-
"default": "./build/index.js"
|
|
21
|
-
},
|
|
22
|
-
"require": {
|
|
23
|
-
"types": "./build/index.d.cts",
|
|
24
|
-
"default": "./build/index.cjs"
|
|
25
|
-
}
|
|
26
|
-
},
|
|
27
|
-
"./utils": {
|
|
28
|
-
"import": {
|
|
29
|
-
"types": "./build/utils.d.ts",
|
|
30
|
-
"default": "./build/utils.js"
|
|
31
|
-
},
|
|
32
|
-
"require": {
|
|
33
|
-
"types": "./build/utils.d.cts",
|
|
34
|
-
"default": "./build/utils.cjs"
|
|
35
|
-
}
|
|
36
|
-
},
|
|
37
|
-
"./vue": {
|
|
38
|
-
"import": {
|
|
39
|
-
"types": "./build/vue.d.ts",
|
|
40
|
-
"default": "./build/vue.js"
|
|
41
|
-
},
|
|
42
|
-
"require": {
|
|
43
|
-
"types": "./build/vue.d.cts",
|
|
44
|
-
"default": "./build/vue.cjs"
|
|
45
|
-
}
|
|
46
|
-
},
|
|
47
|
-
"./package.json": "./package.json"
|
|
27
|
+
"./utils": {
|
|
28
|
+
"import": {
|
|
29
|
+
"types": "./build/utils.d.ts",
|
|
30
|
+
"default": "./build/utils.js"
|
|
31
|
+
},
|
|
32
|
+
"require": {
|
|
33
|
+
"types": "./build/utils.d.cts",
|
|
34
|
+
"default": "./build/utils.cjs"
|
|
35
|
+
}
|
|
48
36
|
},
|
|
49
|
-
"
|
|
50
|
-
|
|
51
|
-
"
|
|
37
|
+
"./vue": {
|
|
38
|
+
"import": {
|
|
39
|
+
"types": "./build/vue.d.ts",
|
|
40
|
+
"default": "./build/vue.js"
|
|
41
|
+
},
|
|
42
|
+
"require": {
|
|
43
|
+
"types": "./build/vue.d.cts",
|
|
44
|
+
"default": "./build/vue.cjs"
|
|
45
|
+
}
|
|
52
46
|
},
|
|
53
|
-
"
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
"
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
47
|
+
"./package.json": "./package.json"
|
|
48
|
+
},
|
|
49
|
+
"devDependencies": {
|
|
50
|
+
"tsup": "^8.5.0",
|
|
51
|
+
"typescript": "^5.8.3",
|
|
52
|
+
"vue": "^3.5.16"
|
|
53
|
+
},
|
|
54
|
+
"dependencies": {
|
|
55
|
+
"clsx": "^2.1.1"
|
|
56
|
+
},
|
|
57
|
+
"scripts": {
|
|
58
|
+
"build": "tsc && tsup"
|
|
59
|
+
}
|
|
60
|
+
}
|
package/build/chunk-4SXOWWRN.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{a as c,b as m,c as x}from"./chunk-BV75ULQK.js";import{clsx as v}from"clsx";var S=(t,r={})=>{let h=r.merge??v,{variants:e,defaultVariant:V,base:k}=t,i=e?c(e):[],f=e?x(e):{},u=V??{},R=e?typeof t.compoundVariants=="function"?t.compoundVariants({variants:e,keys:i,options:f,defaults:u}):t.compoundVariants:void 0;return Object.assign(s=>{let O=e?i.map(a=>{let d=s?.[a],p=V?.[a],o=d?.toString()||p?.toString();return o?e[a][o]:void 0}):void 0,g=R?.reduce((a,{class:d,className:p,...o})=>(m(o).every(([y,n])=>{let _=V?.[y],l=s?.[y];if(typeof n=="object"&&"__token"in n){if(n.__token===W.__token)return l!==void 0;if(n.__token===N.__token)return l===void 0}let C=l??_;return Array.isArray(n)?n.some(P=>C===P):C===n})&&a.push(d,p),a),new Array);return h(k,O,g,s?.class,s?.className)},{keys:i,options:f,defaults:u})};function A(t){return r=>S(r,t)}var W={__token:"OnlyWhenDefined"},N={__token:"OnlyWhenUndefined"};export{S as a,A as b,W as c,N as d};
|
|
2
|
-
//# sourceMappingURL=chunk-4SXOWWRN.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import { ClassValue, clsx } from \"clsx\";\nimport { MarkRequired, Prettify, StrictExclude, Opaque } from \"ts-essentials\";\nimport { getEntries, getKeys, getVariantsOptions, KeysOf, VariantOptions } from \"./utils\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type VariantProps<CVR extends (args?: any) => string> = Prettify<\n Omit<NonNullable<StrictExclude<Parameters<CVR>[0], void>>, \"class\" | \"className\">\n>;\n\ntype ClassProp =\n | { class?: ClassValue; className?: never }\n | { class?: never; className?: ClassValue };\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type WithClassProp<T extends Record<string, any>> = T & ClassProp;\n\ntype BooleanStringToBoolean<T> = T extends \"true\" | \"false\" ? boolean : T;\n\nexport type CVVariantsSchema = Record<string, Record<string, ClassValue>>;\n\nexport type CVVariant<V extends CVVariantsSchema> = {\n [K in keyof V]?: BooleanStringToBoolean<keyof V[K]>;\n};\nexport type CVCompoundVariant<V extends CVVariantsSchema> = WithClassProp<{\n [K in keyof V]?:\n | BooleanStringToBoolean<keyof V[K]>\n | BooleanStringToBoolean<keyof V[K]>[]\n | CVToken;\n}>;\n\nexport type CVCompoundVariantsSchema<V extends CVVariantsSchema> = CVCompoundVariant<V>[];\n\nexport interface CVConfig<V extends CVVariantsSchema, R extends keyof V> {\n base?: ClassValue;\n variants?: V;\n compoundVariants?:\n | CVCompoundVariantsSchema<V>\n | ((arg: {\n variants: V;\n keys: KeysOf<V>;\n options: VariantOptions<V>;\n defaults: CVVariant<V>;\n }) => CVCompoundVariantsSchema<V>);\n defaultVariant?: CVVariant<V>;\n requiredProps?: R[];\n}\nexport interface CVOptions {\n merge?: (...args: ClassValue[]) => string;\n}\n\ntype CVReturnProps<V extends CVVariantsSchema, R extends keyof V = never> =\n | Prettify<WithClassProp<MarkRequired<CVVariant<V>, R>>>\n | ([R] extends [never] ? void : never);\nexport interface CVReturn<V extends CVVariantsSchema, R extends keyof V = never> {\n (props: CVReturnProps<V, R>): string;\n keys: KeysOf<V>;\n options: VariantOptions<V>;\n defaults: CVVariant<V>;\n}\n\nexport interface CV {\n // eslint-disable-next-line @typescript-eslint/prefer-function-type\n <V extends CVVariantsSchema, R extends keyof V = never>(\n config: CVConfig<V, R>,\n cvOptions?: CVOptions,\n ): CVReturn<V, R>;\n}\n\nexport const cv: CV = (config, cvOptions = {}) => {\n const merge = cvOptions.merge ?? clsx;\n\n const { variants, defaultVariant, base } = config;\n\n type ResolvedV = NonNullable<typeof variants>;\n\n const keys = variants ? getKeys(variants) : [];\n const options = variants ? getVariantsOptions(variants) : ({} as VariantOptions<ResolvedV>);\n const defaults = defaultVariant ?? ({} as CVVariant<ResolvedV>);\n\n const compoundVariants = variants\n ? typeof config.compoundVariants === \"function\"\n ? config.compoundVariants({ variants, keys, options, defaults })\n : config.compoundVariants\n : undefined;\n\n const getVariant = <V extends ResolvedV, R extends keyof V = never>(\n props: CVReturnProps<V, R>,\n ) => {\n const variantClassNames = variants\n ? keys.map((variant) => {\n const variantProp = props?.[variant];\n const defaultVariantProp = defaultVariant?.[variant];\n\n const variantKey = variantProp?.toString() || defaultVariantProp?.toString();\n\n return variantKey ? variants[variant][variantKey] : undefined;\n })\n : undefined;\n\n const compoundVariantClassNames = compoundVariants?.reduce(\n (acc, { class: cvClass, className: cvClassName, ...cvConfig }) => {\n const shouldApplyCompoundVariant = getEntries(cvConfig).every(\n ([cvKey, cvSelector]) => {\n const defaultsSelector =\n defaultVariant?.[cvKey as keyof typeof defaultVariant];\n const propsSelector = props?.[cvKey as keyof typeof props];\n\n if (typeof cvSelector === \"object\" && \"__token\" in cvSelector) {\n if (cvSelector.__token === onlyWhenDefined.__token) {\n return propsSelector !== undefined;\n } else if (cvSelector.__token === onlyWhenUndefined.__token) {\n return propsSelector === undefined;\n }\n }\n\n const selector = propsSelector ?? defaultsSelector;\n\n return Array.isArray(cvSelector)\n ? cvSelector.some((cvSelector) => selector === cvSelector)\n : selector === cvSelector;\n },\n );\n\n if (shouldApplyCompoundVariant) acc.push(cvClass, cvClassName);\n return acc;\n },\n new Array<ClassValue>(),\n );\n\n return merge(\n base,\n variantClassNames,\n compoundVariantClassNames,\n props?.class,\n props?.className,\n );\n };\n\n return Object.assign(getVariant, { keys, options, defaults });\n};\n\nexport function defineCV(options: CVOptions): CV {\n return (config) => cv(config, options);\n}\n\ntype OnlyWhenDefined = Opaque<{ __token: string }, \"OnlyWhenDefined\">;\ntype OnlyWhenUndefined = Opaque<{ __token: string }, \"OnlyWhenUndefined\">;\n\ntype CVToken = OnlyWhenDefined | OnlyWhenUndefined;\n\n/** Apply compound variant only if prop **is** specified */\nexport const onlyWhenDefined = { __token: \"OnlyWhenDefined\" } as OnlyWhenDefined;\n/** Apply compound variant only if prop **is not** specified */\nexport const onlyWhenUndefined = { __token: \"OnlyWhenUndefined\" } as OnlyWhenUndefined;\n"],"mappings":"sDAAA,OAAqB,QAAAA,MAAY,OAoE1B,IAAMC,EAAS,CAACC,EAAQC,EAAY,CAAC,IAAM,CAC9C,IAAMC,EAAQD,EAAU,OAASE,EAE3B,CAAE,SAAAC,EAAU,eAAAC,EAAgB,KAAAC,CAAK,EAAIN,EAIrCO,EAAOH,EAAWI,EAAQJ,CAAQ,EAAI,CAAC,EACvCK,EAAUL,EAAWM,EAAmBN,CAAQ,EAAK,CAAC,EACtDO,EAAWN,GAAmB,CAAC,EAE/BO,EAAmBR,EACnB,OAAOJ,EAAO,kBAAqB,WAC/BA,EAAO,iBAAiB,CAAE,SAAAI,EAAU,KAAAG,EAAM,QAAAE,EAAS,SAAAE,CAAS,CAAC,EAC7DX,EAAO,iBACX,OAuDN,OAAO,OAAO,OApDVa,GACC,CACD,IAAMC,EAAoBV,EACpBG,EAAK,IAAKQ,GAAY,CAClB,IAAMC,EAAcH,IAAQE,CAAO,EAC7BE,EAAqBZ,IAAiBU,CAAO,EAE7CG,EAAaF,GAAa,SAAS,GAAKC,GAAoB,SAAS,EAE3E,OAAOC,EAAad,EAASW,CAAO,EAAEG,CAAU,EAAI,MACxD,CAAC,EACD,OAEAC,EAA4BP,GAAkB,OAChD,CAACQ,EAAK,CAAE,MAAOC,EAAS,UAAWC,EAAa,GAAGC,CAAS,KACrBC,EAAWD,CAAQ,EAAE,MACpD,CAAC,CAACE,EAAOC,CAAU,IAAM,CACrB,IAAMC,EACFtB,IAAiBoB,CAAoC,EACnDG,EAAgBf,IAAQY,CAA2B,EAEzD,GAAI,OAAOC,GAAe,UAAY,YAAaA,EAAY,CAC3D,GAAIA,EAAW,UAAYG,EAAgB,QACvC,OAAOD,IAAkB,OACtB,GAAIF,EAAW,UAAYI,EAAkB,QAChD,OAAOF,IAAkB,MAEjC,CAEA,IAAMG,EAAWH,GAAiBD,EAElC,OAAO,MAAM,QAAQD,CAAU,EACzBA,EAAW,KAAMA,GAAeK,IAAaL,CAAU,EACvDK,IAAaL,CACvB,CACJ,GAEgCN,EAAI,KAAKC,EAASC,CAAW,EACtDF,GAEX,IAAI,KACR,EAEA,OAAOlB,EACHI,EACAQ,EACAK,EACAN,GAAO,MACPA,GAAO,SACX,CACJ,EAEiC,CAAE,KAAAN,EAAM,QAAAE,EAAS,SAAAE,CAAS,CAAC,CAChE,EAEO,SAASqB,EAASvB,EAAwB,CAC7C,OAAQT,GAAWD,EAAGC,EAAQS,CAAO,CACzC,CAQO,IAAMoB,EAAkB,CAAE,QAAS,iBAAkB,EAE/CC,EAAoB,CAAE,QAAS,mBAAoB","names":["clsx","cv","config","cvOptions","merge","clsx","variants","defaultVariant","base","keys","getKeys","options","getVariantsOptions","defaults","compoundVariants","props","variantClassNames","variant","variantProp","defaultVariantProp","variantKey","compoundVariantClassNames","acc","cvClass","cvClassName","cvConfig","getEntries","cvKey","cvSelector","defaultsSelector","propsSelector","onlyWhenDefined","onlyWhenUndefined","selector","defineCV"]}
|
package/build/chunk-BV75ULQK.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/utils.ts"],"sourcesContent":["import { DeepReadonly, DeepWritable, Prettify, UnionToIntersection } from \"ts-essentials\";\nimport { CVVariantsSchema } from \".\";\n\nexport type KeysOf<O extends Record<string, unknown>> = (keyof O)[];\nexport function getKeys<O extends Record<string, unknown>>(obj: O) {\n return Object.keys(obj) as KeysOf<O>;\n}\n\nexport type EntriesOf<O extends Record<string, unknown>> = { [K in keyof O]: [K, O[K]] };\nexport function getEntries<O extends Record<string, unknown>>(obj: O) {\n return Object.entries(obj) as EntriesOf<O>[keyof EntriesOf<O>][];\n}\n\nexport type VariantOptions<V extends CVVariantsSchema> = {\n [K in keyof V]: KeysOf<V[K]>;\n};\nexport function getVariantsOptions<V extends CVVariantsSchema>(variants: V) {\n return Object.fromEntries(\n getEntries(variants).map(([cvKey, cvVal]) => [cvKey, getKeys(cvVal)]),\n ) as VariantOptions<V>;\n}\n\ntype Entries = [PropertyKey, unknown][] | DeepReadonly<[PropertyKey, unknown][]>;\ntype UnionFromPairs<TArr extends Entries> =\n DeepWritable<TArr> extends (infer R)[]\n ? R extends [infer key, infer val]\n ? { [prop in key & PropertyKey]: val }\n : never\n : never;\n\ntype MergeIntersectingObjects<O> = { [K in keyof O]: O[K] };\n\nexport function objectFromEntries<E extends Entries>(entries: E) {\n return Object.fromEntries(entries) as Prettify<\n MergeIntersectingObjects<UnionToIntersection<UnionFromPairs<E>>>\n >;\n}\n"],"mappings":"AAIO,SAASA,EAA2CC,EAAQ,CAC/D,OAAO,OAAO,KAAKA,CAAG,CAC1B,CAGO,SAASC,EAA8CD,EAAQ,CAClE,OAAO,OAAO,QAAQA,CAAG,CAC7B,CAKO,SAASE,EAA+CC,EAAa,CACxE,OAAO,OAAO,YACVF,EAAWE,CAAQ,EAAE,IAAI,CAAC,CAACC,EAAOC,CAAK,IAAM,CAACD,EAAOL,EAAQM,CAAK,CAAC,CAAC,CACxE,CACJ,CAYO,SAASC,EAAqCC,EAAY,CAC7D,OAAO,OAAO,YAAYA,CAAO,CAGrC","names":["getKeys","obj","getEntries","getVariantsOptions","variants","cvKey","cvVal","objectFromEntries","entries"]}
|
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
import { ClassValue } from 'clsx';
|
|
2
|
-
import { Prettify, UnionToIntersection, DeepReadonly, DeepWritable, StrictExclude, MarkRequired, Opaque } from 'ts-essentials';
|
|
3
|
-
|
|
4
|
-
type KeysOf<O extends Record<string, unknown>> = (keyof O)[];
|
|
5
|
-
declare function getKeys<O extends Record<string, unknown>>(obj: O): KeysOf<O>;
|
|
6
|
-
type EntriesOf<O extends Record<string, unknown>> = {
|
|
7
|
-
[K in keyof O]: [K, O[K]];
|
|
8
|
-
};
|
|
9
|
-
declare function getEntries<O extends Record<string, unknown>>(obj: O): EntriesOf<O>[keyof EntriesOf<O>][];
|
|
10
|
-
type VariantOptions<V extends CVVariantsSchema> = {
|
|
11
|
-
[K in keyof V]: KeysOf<V[K]>;
|
|
12
|
-
};
|
|
13
|
-
declare function getVariantsOptions<V extends CVVariantsSchema>(variants: V): VariantOptions<V>;
|
|
14
|
-
type Entries = [PropertyKey, unknown][] | DeepReadonly<[PropertyKey, unknown][]>;
|
|
15
|
-
type UnionFromPairs<TArr extends Entries> = DeepWritable<TArr> extends (infer R)[] ? R extends [infer key, infer val] ? {
|
|
16
|
-
[prop in key & PropertyKey]: val;
|
|
17
|
-
} : never : never;
|
|
18
|
-
type MergeIntersectingObjects<O> = {
|
|
19
|
-
[K in keyof O]: O[K];
|
|
20
|
-
};
|
|
21
|
-
declare function objectFromEntries<E extends Entries>(entries: E): Prettify<MergeIntersectingObjects<UnionToIntersection<UnionFromPairs<E>>>>;
|
|
22
|
-
|
|
23
|
-
type VariantProps<CVR extends (args?: any) => string> = Prettify<Omit<NonNullable<StrictExclude<Parameters<CVR>[0], void>>, "class" | "className">>;
|
|
24
|
-
type ClassProp = {
|
|
25
|
-
class?: ClassValue;
|
|
26
|
-
className?: never;
|
|
27
|
-
} | {
|
|
28
|
-
class?: never;
|
|
29
|
-
className?: ClassValue;
|
|
30
|
-
};
|
|
31
|
-
type WithClassProp<T extends Record<string, any>> = T & ClassProp;
|
|
32
|
-
type BooleanStringToBoolean<T> = T extends "true" | "false" ? boolean : T;
|
|
33
|
-
type CVVariantsSchema = Record<string, Record<string, ClassValue>>;
|
|
34
|
-
type CVVariant<V extends CVVariantsSchema> = {
|
|
35
|
-
[K in keyof V]?: BooleanStringToBoolean<keyof V[K]>;
|
|
36
|
-
};
|
|
37
|
-
type CVCompoundVariant<V extends CVVariantsSchema> = WithClassProp<{
|
|
38
|
-
[K in keyof V]?: BooleanStringToBoolean<keyof V[K]> | BooleanStringToBoolean<keyof V[K]>[] | CVToken;
|
|
39
|
-
}>;
|
|
40
|
-
type CVCompoundVariantsSchema<V extends CVVariantsSchema> = CVCompoundVariant<V>[];
|
|
41
|
-
interface CVConfig<V extends CVVariantsSchema, R extends keyof V> {
|
|
42
|
-
base?: ClassValue;
|
|
43
|
-
variants?: V;
|
|
44
|
-
compoundVariants?: CVCompoundVariantsSchema<V> | ((arg: {
|
|
45
|
-
variants: V;
|
|
46
|
-
keys: KeysOf<V>;
|
|
47
|
-
options: VariantOptions<V>;
|
|
48
|
-
defaults: CVVariant<V>;
|
|
49
|
-
}) => CVCompoundVariantsSchema<V>);
|
|
50
|
-
defaultVariant?: CVVariant<V>;
|
|
51
|
-
requiredProps?: R[];
|
|
52
|
-
}
|
|
53
|
-
interface CVOptions {
|
|
54
|
-
merge?: (...args: ClassValue[]) => string;
|
|
55
|
-
}
|
|
56
|
-
type CVReturnProps<V extends CVVariantsSchema, R extends keyof V = never> = Prettify<WithClassProp<MarkRequired<CVVariant<V>, R>>> | ([R] extends [never] ? void : never);
|
|
57
|
-
interface CVReturn<V extends CVVariantsSchema, R extends keyof V = never> {
|
|
58
|
-
(props: CVReturnProps<V, R>): string;
|
|
59
|
-
keys: KeysOf<V>;
|
|
60
|
-
options: VariantOptions<V>;
|
|
61
|
-
defaults: CVVariant<V>;
|
|
62
|
-
}
|
|
63
|
-
interface CV {
|
|
64
|
-
<V extends CVVariantsSchema, R extends keyof V = never>(config: CVConfig<V, R>, cvOptions?: CVOptions): CVReturn<V, R>;
|
|
65
|
-
}
|
|
66
|
-
declare const cv: CV;
|
|
67
|
-
declare function defineCV(options: CVOptions): CV;
|
|
68
|
-
type OnlyWhenDefined = Opaque<{
|
|
69
|
-
__token: string;
|
|
70
|
-
}, "OnlyWhenDefined">;
|
|
71
|
-
type OnlyWhenUndefined = Opaque<{
|
|
72
|
-
__token: string;
|
|
73
|
-
}, "OnlyWhenUndefined">;
|
|
74
|
-
type CVToken = OnlyWhenDefined | OnlyWhenUndefined;
|
|
75
|
-
/** Apply compound variant only if prop **is** specified */
|
|
76
|
-
declare const onlyWhenDefined: OnlyWhenDefined;
|
|
77
|
-
/** Apply compound variant only if prop **is not** specified */
|
|
78
|
-
declare const onlyWhenUndefined: OnlyWhenUndefined;
|
|
79
|
-
|
|
80
|
-
export { type CVVariantsSchema as C, type EntriesOf as E, type KeysOf as K, type VariantOptions as V, type WithClassProp as W, type CVReturn as a, type CVConfig as b, type CVOptions as c, getEntries as d, getVariantsOptions as e, type VariantProps as f, getKeys as g, type CVVariant as h, type CVCompoundVariant as i, type CVCompoundVariantsSchema as j, type CV as k, cv as l, defineCV as m, onlyWhenDefined as n, objectFromEntries as o, onlyWhenUndefined as p };
|