@tenoxui/moxie 0.3.1 → 0.3.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/dist/index.cjs CHANGED
@@ -1,2 +1,372 @@
1
- "use strict";var Z=Object.defineProperty;var R=Object.getOwnPropertySymbols;var z=Object.prototype.hasOwnProperty,_=Object.prototype.propertyIsEnumerable;var V=(v,s,e)=>s in v?Z(v,s,{enumerable:!0,configurable:!0,writable:!0,value:e}):v[s]=e,W=(v,s)=>{for(var e in s||(s={}))z.call(s,e)&&V(v,e,s[e]);if(R)for(var e of R(s))_.call(s,e)&&V(v,e,s[e]);return v};Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});class S{constructor({property:s={},values:e={},classes:t={},aliases:i={}}={}){this.property=W({moxie:({key:r})=>r},s),this.values=e,this.classes=t,this.aliases=i}toKebabCase(s){if(/^(webkit|moz|ms|o)[A-Z]/.test(s)){const e=s.match(/^(webkit|moz|ms|o)/);if(e){const t=e[0];return`-${t}${s.slice(t.length).replace(/[A-Z]/g,i=>`-${i.toLowerCase()}`)}`}}return s.replace(/[A-Z]/g,e=>`-${e.toLowerCase()}`)}escapeCSSSelector(s){return s.replace(/([ #{}.:;?%&,@+*~'"!^$[\]()=>|/])/g,"\\$1")}getAllClassNames(s){if(!s)return[];const e=new Set;return Object.entries(s).forEach(([t,i])=>{i&&typeof i=="object"&&Object.keys(i).forEach(r=>{e.add(r)})}),Array.from(e)}getTypePrefixes(s=[]){const e=this.property,t=this.classes,i=Object.keys(e);if(!t)return[...i,...s].sort((n,l)=>l.length-n.length).join("|");const o=[...this.getAllClassNames(t)];return[...i,...o,...s].sort((n,l)=>l.length-n.length).join("|")}generateClassNameRegEx(s){const e=this.getTypePrefixes(s),t="\\[[^\\]]+\\]",i="\\([^()]*(?:\\([^()]*\\)[^()]*)*\\)",r="\\{[^{}]*(?:\\{[^{}]*\\}[^{}]*)*\\}",o="(?:([a-zA-Z0-9_-]+|[a-zA-Z0-9_-]+(?:-"+t+")|"+t+"|"+i+"|"+r+"):)?",n=`(${e}|\\[[^\\]]+\\])`,l="(?:-)?",h="(-?(?:\\d+(?:\\.\\d+)?)|(?:[a-zA-Z0-9_]+(?:-[a-zA-Z0-9_]+)*(?:-[a-zA-Z0-9_]+)*)|(?:#[0-9a-fA-F]+)|"+t+"|"+r+"|"+i+"|(?:\\$[^\\s\\/]+))",f="([a-zA-Z%]*)",a="(?:\\/(-?(?:\\d+(?:\\.\\d+)?)|(?:[a-zA-Z0-9_]+(?:-[a-zA-Z0-9_]+)*(?:-[a-zA-Z0-9_]+)*)|(?:#[0-9a-fA-F]+)|"+t+"|"+r+"|"+i+"|(?:\\$[^\\s\\/]+))([a-zA-Z%]*))?";return new RegExp(o+n+l+h+f+a)}parse(s,e){if(Object.values(this.classes).some(p=>p==null?void 0:p[s]))return[void 0,s,"","",void 0,void 0];const t=this.generateClassNameRegEx(e),i=(s+"-dummy").match(t);if(!i)return null;const[,r,o,n,l,h,f]=i,a=n==="dummy"?"":n.replace("-dummy","");return[r,o,a,l||"",h,f]}processValue(s,e,t){if(!s)return"";const i=r=>r.replace(/\{([^}]+)\}/g,(o,n)=>{const l=this.values,h=l!==null?typeof l[t]=="object"?l[t][n]:l[n]:void 0;return typeof h=="string"?h:o});if(typeof this.values=="object"&&this.values!==null&&(this.values[t]&&typeof this.values[t]=="object"&&this.values[t][s]||this.values[s]))return typeof this.values[t]=="object"&&this.values[t]!==null?this.values[t][s]:this.values[s];if(s.startsWith("$"))return`var(--${s.slice(1)})`;if(s.startsWith("[")&&s.endsWith("]")||s.startsWith("(")&&s.endsWith(")")){const r=s.slice(1,-1).replace(/_/g," ");return r.includes("{")?i(r):r.startsWith("--")?`var(${r})`:r}return s+(e||"")}processShorthand(s="",e="",t="",i,r="",o="",n=!0){const l=this.property[s],h=/^(?:\(|\[)([^:]+):(.+)(?:\)|\])$/;let f=null,a=e||"";const p=a.match(h);p&&(f=p[1].trim(),a=p[2].trim());let y;e.includes(f+":")?y=e.startsWith("(")?`(${a})`:`[${a}]`:y=e;const c=this.processValue(y,t,s),$=this.processValue(r,o,s);if(s.startsWith("[")&&s.endsWith("]")){const C=s.slice(1,-1).split(",").map(m=>m.trim()).map(m=>{const u=this.property[m]||m;return`${typeof u=="string"&&u.startsWith("--")?String(u):this.toKebabCase(String(u))}: ${c}`}).join("; ");return{className:`${`[${s.slice(1,-1)}]${n?"-":""}${e}${t}`}`,cssRules:C,value:null,prefix:i}}if(l){if(typeof l=="object"&&"property"in l&&"value"in l){const C=l.group||s,m=this.values[C][c]?this.values[C][c]:t?e:c,u=typeof l.property=="function"?l.property({value:m,unit:t,secondValue:o?r:$,secondUnit:o,key:f}):l.property,g=l.value;let A;if(typeof g=="function")A=g({value:m,unit:t,secondValue:o?r:$,secondUnit:o,key:f,property:u});else if(g&&typeof g=="string"){const b=this.processValue(y,t,C);A=this.values[y]||this.values[C][y]||y.includes("{")||g.includes("{")?this.parseValuePattern(C,g,b,"",$,""):c}else A=null;return{className:`${s}${e?`${n&&n?"-":""}${e}${t}`:""}${r?`/${r}${o}`:""}`,cssRules:Array.isArray(u)||typeof u=="string"&&u.includes(":")?u:this.toKebabCase(String(u)),value:g===null?null:e.startsWith("[")?c:A,prefix:i}}const d=typeof l=="function"?l({value:t?e:c,unit:t,secondValue:o?r:$,secondUnit:o,key:f}):l;return{className:`${s}${e?(n?"-":"")+e+t:""}`,cssRules:Array.isArray(l)?d:typeof d=="string"&&d.startsWith("value:")?d.slice(6):this.toKebabCase(String(d)),value:typeof d=="string"&&d.startsWith("value:")?null:c,prefix:i}}return null}parseValuePattern(s,e,t,i,r,o){if(!e.includes("{0}")&&!e.includes("{1")&&!e.includes("||"))return e;const[n,l]=e.split("||").map(a=>a.trim()),h=this.processValue(t,i,s),f=this.processValue(r,o,s);if(e.includes("{0}")&&e.includes("{1")||e.includes("{1")){let a=n;if(t&&(a=a.replace("{0}",h)),e.includes("{1")){const p=a.match(/{1([^}]*)}/);if(e.includes("{1}"))r?a=r.startsWith("[")?f:a.replace("{1}",f):a=l;else if(p){const y=p[0],c=p[1].trim();let $=f;!$&&c.includes("|")?$=c.split("|")[1].trim():$||($=""),a=t.startsWith("[")?h:a.replace(y,$)}}return t?a:l||n}else return t?t.startsWith("[")?h:n.replace("{0}",h):l||n}getParentClass(s){return Object.keys(this.classes).filter(e=>Object.prototype.hasOwnProperty.call(this.classes[e],s))}processCustomClass(s,e="",t="",i="",r="",o="",n=!0){if(!s)return null;const l=this.getParentClass(s);if(l.length>0){const h=l.map(p=>{const y=this.classes[p];if(!y)return"";const c=this.parseValuePattern(s,y[s]||"",e,t,r,o);return`${this.toKebabCase(String(p))}: ${c}`}).filter(Boolean).join("; "),f=s.slice(-(e+t).length),a=`${s}${e?`${n?"-":""}${e}${t}`:""}${r?`/${r}${o}`:""}`;return{className:e===f?s:a,cssRules:h,value:null,prefix:i}}return null}processAlias(s,e=""){const t=this.aliases[s];if(!t)return null;const i=t.split(" "),r=[];return i.forEach(o=>{const[n,l]=o.split(":"),h=l||n,f=l?n:void 0,a=this.parse(o),p=a||[f,h,"",""];if(!p)return;const[y,c,$,d,C,m]=p,u=this.processShorthand(c,$,d,void 0,C,m),g=this.processCustomClass(c,$,d,y,C,m);if(g){const{cssRules:A}=g;r.push(A);return}if(u){const A=u.value!==null?`: ${u.value}`:"";Array.isArray(u.cssRules)?u.cssRules.forEach(P=>{r.push(`${this.toKebabCase(P)}${A}`)}):r.push(`${u.cssRules}${A}`)}}),{className:s,cssRules:r.join("; "),value:null,prefix:e}}process(s){const e=Array.isArray(s)?s:s.split(/\s+/),t=[];return e.forEach(i=>{if(!i)return this;const[r,o]=i.split(":"),n=o||r,l=o?r:void 0,h=this.processAlias(n,l);if(h){const{className:P,cssRules:b}=h;t.push({className:P,cssRules:b,value:null,prefix:l});return}const f=this.parse(i),a=f||[l,n,"",""];if(!a)return this;const[p,y,c,$,d,C]=a,m=!i.includes((y||"")+(c||"")),u=this.getParentClass(`${y}${m?"-":""}${c}`).length>0?`${y}${m?"-":""}${c}`:y,g=this.processCustomClass(u,c,$,p,d,C,m);if(g){const{className:P,cssRules:b,prefix:x}=g;t.push({className:P,cssRules:b,value:null,prefix:x});return}const A=this.processShorthand(y,c,$,p,d,C,m);if(A){const{className:P,cssRules:b,value:x,prefix:j}=A;t.push({className:P,cssRules:b,value:x,prefix:j})}}),t}}exports.TenoxUI=S;exports.default=S;
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
6
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
7
+ var __spreadValues = (a, b) => {
8
+ for (var prop in b || (b = {}))
9
+ if (__hasOwnProp.call(b, prop))
10
+ __defNormalProp(a, prop, b[prop]);
11
+ if (__getOwnPropSymbols)
12
+ for (var prop of __getOwnPropSymbols(b)) {
13
+ if (__propIsEnum.call(b, prop))
14
+ __defNormalProp(a, prop, b[prop]);
15
+ }
16
+ return a;
17
+ };
18
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
19
+ class TenoxUI {
20
+ constructor({ property = {}, values = {}, classes = {}, aliases = {} } = {}) {
21
+ this.property = __spreadValues({
22
+ moxie: ({ key }) => key
23
+ }, property);
24
+ this.values = values;
25
+ this.classes = classes;
26
+ this.aliases = aliases;
27
+ }
28
+ toKebabCase(str) {
29
+ if (/^(webkit|moz|ms|o)[A-Z]/.test(str)) {
30
+ const match = str.match(/^(webkit|moz|ms|o)/);
31
+ if (match) {
32
+ const prefix = match[0];
33
+ return `-${prefix}${str.slice(prefix.length).replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`)}`;
34
+ }
35
+ }
36
+ return str.replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`);
37
+ }
38
+ escapeCSSSelector(str) {
39
+ return str.replace(/([ #{}.:;?%&,@+*~'"!^$[\]()=>|/])/g, "\\$1");
40
+ }
41
+ getAllClassNames(classRegistry) {
42
+ if (!classRegistry) return [];
43
+ const classNames = /* @__PURE__ */ new Set();
44
+ Object.entries(classRegistry).forEach(([property, classObj]) => {
45
+ if (classObj && typeof classObj === "object") {
46
+ Object.keys(classObj).forEach((className) => {
47
+ classNames.add(className);
48
+ });
49
+ }
50
+ });
51
+ return Array.from(classNames);
52
+ }
53
+ getTypePrefixes(safelist = []) {
54
+ const styleAttribute = this.property;
55
+ const classRegistry = this.classes;
56
+ const propertyTypes = Object.keys(styleAttribute);
57
+ if (!classRegistry) {
58
+ return [...propertyTypes, ...safelist].sort((a, b) => b.length - a.length).join("|");
59
+ }
60
+ const classConfigs = this.getAllClassNames(classRegistry);
61
+ const classPatterns = [...classConfigs];
62
+ return [...propertyTypes, ...classPatterns, ...safelist].sort((a, b) => b.length - a.length).join("|");
63
+ }
64
+ generateClassNameRegEx(safelist) {
65
+ const typePrefixes = this.getTypePrefixes(safelist);
66
+ const nestedBracketPattern = "\\[[^\\]]+\\]";
67
+ const nestedParenPattern = "\\([^()]*(?:\\([^()]*\\)[^()]*)*\\)";
68
+ const nestedBracePattern = "\\{[^{}]*(?:\\{[^{}]*\\}[^{}]*)*\\}";
69
+ const prefixPattern = "(?:([a-zA-Z0-9_-]+|[a-zA-Z0-9_-]+(?:-" + nestedBracketPattern + ")|" + // Direct bracket, parenthesis, or brace content
70
+ nestedBracketPattern + "|" + nestedParenPattern + "|" + nestedBracePattern + "):)?";
71
+ const typePattern = `(${typePrefixes}|\\[[^\\]]+\\])`;
72
+ const separator = "(?:-)?";
73
+ const valuePattern = "(-?(?:\\d+(?:\\.\\d+)?)|(?:[a-zA-Z0-9_]+(?:-[a-zA-Z0-9_]+)*(?:-[a-zA-Z0-9_]+)*)|(?:#[0-9a-fA-F]+)|" + // Hex colors
74
+ nestedBracketPattern + "|" + // Bracket content
75
+ nestedBracePattern + "|" + // Curly brace content
76
+ nestedParenPattern + "|(?:\\$[^\\s\\/]+))";
77
+ const unitPattern = "([a-zA-Z%]*)";
78
+ const secondaryPattern = "(?:\\/(-?(?:\\d+(?:\\.\\d+)?)|(?:[a-zA-Z0-9_]+(?:-[a-zA-Z0-9_]+)*(?:-[a-zA-Z0-9_]+)*)|(?:#[0-9a-fA-F]+)|" + nestedBracketPattern + "|" + nestedBracePattern + "|" + nestedParenPattern + "|(?:\\$[^\\s\\/]+))([a-zA-Z%]*))?";
79
+ return new RegExp(
80
+ prefixPattern + typePattern + separator + valuePattern + unitPattern + secondaryPattern
81
+ );
82
+ }
83
+ parse(className, safelist) {
84
+ if (Object.values(this.classes).some((classObj) => classObj == null ? void 0 : classObj[className])) {
85
+ return [void 0, className, "", "", void 0, void 0];
86
+ }
87
+ const classNameRegEx = this.generateClassNameRegEx(safelist);
88
+ const match = (className + "-dummy").match(classNameRegEx);
89
+ if (!match) return null;
90
+ const [, prefix, type, value, unit, secValue, secUnit] = match;
91
+ const finalValue = value === "dummy" ? "" : value.replace("-dummy", "");
92
+ return [prefix, type, finalValue, unit || "", secValue, secUnit];
93
+ }
94
+ // unique value parser
95
+ processValue(value, unit, group) {
96
+ if (!value) return "";
97
+ const replaceWithValueRegistry = (text) => {
98
+ return text.replace(/\{([^}]+)\}/g, (match, key) => {
99
+ const valueRegistry = this.values;
100
+ const val = valueRegistry !== null ? typeof valueRegistry[group] === "object" ? valueRegistry[group][key] : valueRegistry[key] : void 0;
101
+ return typeof val === "string" ? val : match;
102
+ });
103
+ };
104
+ if (typeof this.values === "object" && this.values !== null && (this.values[group] && typeof this.values[group] === "object" && this.values[group][value] || this.values[value])) {
105
+ if (typeof this.values[group] === "object" && this.values[group] !== null) {
106
+ return this.values[group][value];
107
+ }
108
+ return this.values[value];
109
+ } else if (value.startsWith("$")) {
110
+ return `var(--${value.slice(1)})`;
111
+ } else if (value.startsWith("[") && value.endsWith("]") || value.startsWith("(") && value.endsWith(")")) {
112
+ const cleanValue = value.slice(1, -1).replace(/_/g, " ");
113
+ if (cleanValue.includes("{")) {
114
+ return replaceWithValueRegistry(cleanValue);
115
+ }
116
+ return cleanValue.startsWith("--") ? `var(${cleanValue})` : cleanValue;
117
+ }
118
+ return value + (unit || "");
119
+ }
120
+ processShorthand(type = "", value = "", unit = "", prefix, secondValue = "", secondUnit = "", isHyphen = true) {
121
+ const properties = this.property[type];
122
+ const pattern = /^(?:\(|\[)([^:]+):(.+)(?:\)|\])$/;
123
+ let extractedFor = null;
124
+ let cleanValue = value || "";
125
+ const matchValue = cleanValue.match(pattern);
126
+ if (matchValue) {
127
+ extractedFor = matchValue[1].trim();
128
+ cleanValue = matchValue[2].trim();
129
+ }
130
+ let finalCleanValue;
131
+ if (value.includes(extractedFor + ":")) {
132
+ finalCleanValue = value.startsWith("(") ? `(${cleanValue})` : `[${cleanValue}]`;
133
+ } else finalCleanValue = value;
134
+ const finalValue = this.processValue(finalCleanValue, unit, type);
135
+ const finalSecValue = this.processValue(secondValue, secondUnit, type);
136
+ if (type.startsWith("[") && type.endsWith("]")) {
137
+ const items = type.slice(1, -1).split(",").map((item) => item.trim());
138
+ const cssRules = items.map((item) => {
139
+ const prop = this.property[item] || item;
140
+ const finalProperty = typeof prop === "string" && prop.startsWith("--") ? String(prop) : this.toKebabCase(String(prop));
141
+ return `${finalProperty}: ${finalValue}`;
142
+ }).join("; ");
143
+ return {
144
+ className: `${`[${type.slice(1, -1)}]${isHyphen ? "-" : ""}${value}${unit}`}`,
145
+ cssRules,
146
+ // return css rules directly
147
+ value: null,
148
+ // and set value to null to prevent value duplication
149
+ prefix
150
+ };
151
+ }
152
+ if (properties) {
153
+ if (typeof properties === "object" && "property" in properties && "value" in properties) {
154
+ const groupValue = properties.group && this.values[properties.group] ? this.values[properties.group][finalValue] : unit ? value : finalValue;
155
+ const property = typeof properties.property === "function" ? properties.property({
156
+ value: groupValue,
157
+ unit,
158
+ secondValue: secondUnit ? secondValue : finalSecValue,
159
+ secondUnit,
160
+ key: extractedFor
161
+ }) : properties.property;
162
+ const template = properties.value;
163
+ let processedValue;
164
+ if (typeof template === "function") {
165
+ processedValue = template({
166
+ value: groupValue,
167
+ unit,
168
+ secondValue: secondUnit ? secondValue : finalSecValue,
169
+ secondUnit,
170
+ key: extractedFor,
171
+ property
172
+ });
173
+ } else if (template && typeof template === "string") {
174
+ const valuesGroup = properties.group || type;
175
+ const newValue = this.processValue(finalCleanValue, unit, valuesGroup);
176
+ processedValue = this.values[finalCleanValue] || this.values[valuesGroup][finalCleanValue] || finalCleanValue.includes("{") || template.includes("{") ? this.parseValuePattern(valuesGroup, template, newValue, "", finalSecValue, "") : finalValue;
177
+ } else processedValue = null;
178
+ const className = `${type}${value ? `${isHyphen ? isHyphen ? "-" : "" : ""}${value}${unit}` : ""}${secondValue ? `/${secondValue}${secondUnit}` : ""}`;
179
+ return {
180
+ className,
181
+ cssRules: Array.isArray(property) ? property : typeof property === "string" && property.includes(":") ? property : this.toKebabCase(String(property)),
182
+ value: template === null ? null : value.startsWith("[") ? finalValue : processedValue,
183
+ prefix
184
+ };
185
+ }
186
+ const finalRegProperty = typeof properties === "function" ? properties({
187
+ value: unit ? value : finalValue,
188
+ unit,
189
+ secondValue: secondUnit ? secondValue : finalSecValue,
190
+ secondUnit,
191
+ key: extractedFor
192
+ }) : properties;
193
+ return {
194
+ className: `${type}${value ? (isHyphen ? "-" : "") + value + unit : ""}`,
195
+ cssRules: Array.isArray(properties) ? finalRegProperty : typeof finalRegProperty === "string" && finalRegProperty.startsWith("value:") ? finalRegProperty.slice(6) : this.toKebabCase(String(finalRegProperty)),
196
+ value: typeof finalRegProperty === "string" && finalRegProperty.startsWith("value:") ? null : finalValue,
197
+ prefix
198
+ };
199
+ }
200
+ return null;
201
+ }
202
+ parseValuePattern(group, pattern, inputValue, inputUnit, inputSecValue, inputSecUnit) {
203
+ if (!pattern.includes("{0}") && !pattern.includes("{1") && !pattern.includes("||"))
204
+ return pattern;
205
+ const [value, defaultValue] = pattern.split("||").map((s) => s.trim());
206
+ const finalValue = this.processValue(inputValue, inputUnit, group);
207
+ const finalSecValue = this.processValue(inputSecValue, inputSecUnit, group);
208
+ if (pattern.includes("{0}") && pattern.includes("{1") || pattern.includes("{1")) {
209
+ let computedValue = value;
210
+ if (inputValue) {
211
+ computedValue = computedValue.replace("{0}", finalValue);
212
+ }
213
+ if (pattern.includes("{1")) {
214
+ const match = computedValue.match(/{1([^}]*)}/);
215
+ if (pattern.includes("{1}")) {
216
+ if (inputSecValue) {
217
+ computedValue = inputSecValue.startsWith("[") ? finalSecValue : computedValue.replace("{1}", finalSecValue);
218
+ } else {
219
+ computedValue = defaultValue;
220
+ }
221
+ } else if (match) {
222
+ const fullMatch = match[0];
223
+ const innerContent = match[1].trim();
224
+ let replacementValue = finalSecValue;
225
+ if (!replacementValue && innerContent.includes("|")) {
226
+ replacementValue = innerContent.split("|")[1].trim();
227
+ } else if (!replacementValue) {
228
+ replacementValue = "";
229
+ }
230
+ computedValue = inputValue.startsWith("[") ? finalValue : computedValue.replace(fullMatch, replacementValue);
231
+ }
232
+ }
233
+ return inputValue ? computedValue : defaultValue || value;
234
+ } else {
235
+ return inputValue ? inputValue.startsWith("[") ? finalValue : value.replace("{0}", finalValue) : defaultValue || value;
236
+ }
237
+ }
238
+ getParentClass(className) {
239
+ return Object.keys(this.classes).filter(
240
+ (cssProperty) => Object.prototype.hasOwnProperty.call(
241
+ this.classes[cssProperty],
242
+ className
243
+ )
244
+ );
245
+ }
246
+ processCustomClass(className, value = "", unit = "", prefix = "", secValue = "", secUnit = "", isHyphen = true) {
247
+ if (!className) return null;
248
+ const properties = this.getParentClass(className);
249
+ if (properties.length > 0) {
250
+ const rules = properties.map((prop) => {
251
+ const classObj = this.classes[prop];
252
+ if (!classObj) return "";
253
+ const processedValue = this.parseValuePattern(
254
+ className,
255
+ classObj[className] || "",
256
+ value,
257
+ unit,
258
+ secValue,
259
+ secUnit
260
+ );
261
+ return `${this.toKebabCase(String(prop))}: ${processedValue}`;
262
+ }).filter(Boolean).join("; ");
263
+ const isValueType = className.slice(-(value + unit).length);
264
+ const finalClassName = `${className}${value ? `${isHyphen ? "-" : ""}${value}${unit}` : ""}${secValue ? `/${secValue}${secUnit}` : ""}`;
265
+ return {
266
+ className: value === isValueType ? className : finalClassName,
267
+ cssRules: rules,
268
+ value: null,
269
+ prefix
270
+ };
271
+ }
272
+ return null;
273
+ }
274
+ processAlias(className, prefix = "") {
275
+ const alias = this.aliases[className];
276
+ if (!alias) return null;
277
+ const aliasClasses = alias.split(" ");
278
+ const combinedRules = [];
279
+ aliasClasses.forEach((aliasClass) => {
280
+ const [rprefix, rtype] = aliasClass.split(":");
281
+ const getType = rtype || rprefix;
282
+ const getPrefix = rtype ? rprefix : void 0;
283
+ const parts = this.parse(aliasClass);
284
+ const parsed = parts ? parts : [getPrefix, getType, "", ""];
285
+ if (!parsed) return;
286
+ const [prefix2, type, value, unit, secValue, secUnit] = parsed;
287
+ const result = this.processShorthand(type, value, unit, void 0, secValue, secUnit);
288
+ const shouldClasses = this.processCustomClass(type, value, unit, prefix2, secValue, secUnit);
289
+ if (shouldClasses) {
290
+ const { cssRules } = shouldClasses;
291
+ combinedRules.push(cssRules);
292
+ return;
293
+ }
294
+ if (result) {
295
+ const value2 = result.value !== null ? `: ${result.value}` : "";
296
+ if (Array.isArray(result.cssRules)) {
297
+ result.cssRules.forEach((rule) => {
298
+ combinedRules.push(`${this.toKebabCase(rule)}${value2}`);
299
+ });
300
+ } else {
301
+ combinedRules.push(`${result.cssRules}${value2}`);
302
+ }
303
+ }
304
+ });
305
+ return {
306
+ className,
307
+ cssRules: combinedRules.join("; "),
308
+ value: null,
309
+ prefix
310
+ };
311
+ }
312
+ process(classNames) {
313
+ const classList = Array.isArray(classNames) ? classNames : classNames.split(/\s+/);
314
+ const results = [];
315
+ classList.forEach((className) => {
316
+ if (!className) return this;
317
+ const [rprefix, rtype] = className.split(":");
318
+ const getType = rtype || rprefix;
319
+ const getPrefix = rtype ? rprefix : void 0;
320
+ const aliasResult = this.processAlias(getType, getPrefix);
321
+ if (aliasResult) {
322
+ const { className: aliasClassName, cssRules } = aliasResult;
323
+ results.push({
324
+ className: aliasClassName,
325
+ cssRules,
326
+ value: null,
327
+ prefix: getPrefix
328
+ });
329
+ return;
330
+ }
331
+ const parts = this.parse(className);
332
+ const parsed = parts ? parts : [getPrefix, getType, "", ""];
333
+ if (!parsed) return this;
334
+ const [prefix, type, value, unit, secValue, secUnit] = parsed;
335
+ const isHyphen = !className.includes((type || "") + (value || ""));
336
+ const classFromClasses = this.getParentClass(`${type}${isHyphen ? "-" : ""}${value}`).length > 0 ? `${type}${isHyphen ? "-" : ""}${value}` : type;
337
+ const shouldClasses = this.processCustomClass(
338
+ classFromClasses,
339
+ value,
340
+ unit,
341
+ prefix,
342
+ secValue,
343
+ secUnit,
344
+ isHyphen
345
+ );
346
+ if (shouldClasses) {
347
+ const { className: className2, cssRules, prefix: prefix2 } = shouldClasses;
348
+ results.push({
349
+ className: className2,
350
+ cssRules,
351
+ value: null,
352
+ prefix: prefix2
353
+ });
354
+ return;
355
+ }
356
+ const result = this.processShorthand(type, value, unit, prefix, secValue, secUnit, isHyphen);
357
+ if (result) {
358
+ const { className: className2, cssRules, value: ruleValue, prefix: rulePrefix } = result;
359
+ results.push({
360
+ className: className2,
361
+ cssRules,
362
+ value: ruleValue,
363
+ prefix: rulePrefix
364
+ });
365
+ }
366
+ });
367
+ return results;
368
+ }
369
+ }
370
+ exports.TenoxUI = TenoxUI;
371
+ exports.default = TenoxUI;
2
372
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../src/index.ts"],"sourcesContent":["import type {\n Values,\n Aliases,\n Classes,\n CSSPropertyOrVariable,\n GetCSSProperty\n} from '@tenoxui/types'\nimport type { Property, Config, ProcessedStyle } from './types'\nexport * from './types'\nexport class TenoxUI {\n private property: Property\n private values: Values\n private classes: Classes\n private aliases: Aliases\n\n constructor({ property = {}, values = {}, classes = {}, aliases = {} }: Config = {}) {\n this.property = {\n moxie: ({ key }) => key as GetCSSProperty, // use moxie-* to access all properties and variables\n ...property\n }\n this.values = values\n this.classes = classes\n this.aliases = aliases\n }\n\n public toKebabCase(str: string): string {\n if (/^(webkit|moz|ms|o)[A-Z]/.test(str)) {\n const match = str.match(/^(webkit|moz|ms|o)/)\n if (match) {\n const prefix = match[0]\n return `-${prefix}${str\n .slice(prefix.length)\n .replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`)}`\n }\n }\n\n return str.replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`)\n }\n\n public escapeCSSSelector(str: string): string {\n return str.replace(/([ #{}.:;?%&,@+*~'\"!^$[\\]()=>|/])/g, '\\\\$1')\n }\n\n private getAllClassNames(classRegistry: Classes | undefined): string[] {\n if (!classRegistry) return []\n const classNames = new Set<string>()\n\n Object.entries(classRegistry).forEach(([property, classObj]) => {\n if (classObj && typeof classObj === 'object') {\n Object.keys(classObj).forEach((className) => {\n classNames.add(className)\n })\n }\n })\n\n return Array.from(classNames)\n }\n\n private getTypePrefixes(safelist: string[] = []): string {\n const styleAttribute = this.property\n const classRegistry = this.classes\n const propertyTypes = Object.keys(styleAttribute)\n\n if (!classRegistry) {\n return [...propertyTypes, ...safelist].sort((a, b) => b.length - a.length).join('|')\n }\n\n const classConfigs = this.getAllClassNames(classRegistry)\n const classPatterns = [...classConfigs]\n\n return [...propertyTypes, ...classPatterns, ...safelist]\n .sort((a, b) => b.length - a.length)\n .join('|')\n }\n\n private generateClassNameRegEx(safelist?: string[]): RegExp {\n const typePrefixes = this.getTypePrefixes(safelist)\n\n // Common pattern for handling complex nested structures\n const nestedBracketPattern = '\\\\[[^\\\\]]+\\\\]'\n const nestedParenPattern = '\\\\([^()]*(?:\\\\([^()]*\\\\)[^()]*)*\\\\)'\n const nestedBracePattern = '\\\\{[^{}]*(?:\\\\{[^{}]*\\\\}[^{}]*)*\\\\}'\n\n // 1. Prefix pattern - now allows for complex structures like nth-[...]\n const prefixPattern =\n '(?:(' +\n // Simple prefix (hover, md, focus, etc.)\n '[a-zA-Z0-9_-]+|' +\n // Prefix with nested structures like nth-[...]\n '[a-zA-Z0-9_-]+(?:-' +\n nestedBracketPattern +\n ')|' +\n // Direct bracket, parenthesis, or brace content\n nestedBracketPattern +\n '|' +\n nestedParenPattern +\n '|' +\n nestedBracePattern +\n '):)?'\n\n // 2. Type pattern\n const typePattern = `(${typePrefixes}|\\\\[[^\\\\]]+\\\\])`\n\n // 3. Separator (optional)\n const separator = '(?:-)?'\n\n // 4. Value pattern - modified to handle $ variables correctly\n const valuePattern =\n '(-?(?:\\\\d+(?:\\\\.\\\\d+)?)|' + // Numbers\n '(?:[a-zA-Z0-9_]+(?:-[a-zA-Z0-9_]+)*(?:-[a-zA-Z0-9_]+)*)|' + // Words with hyphens\n '(?:#[0-9a-fA-F]+)|' + // Hex colors\n nestedBracketPattern +\n '|' + // Bracket content\n nestedBracePattern +\n '|' + // Curly brace content\n nestedParenPattern +\n '|' + // Parentheses content\n '(?:\\\\$[^\\\\s\\\\/]+))' // Dollar sign content\n\n // 5. Unit pattern (optional)\n const unitPattern = '([a-zA-Z%]*)'\n\n // 6. Secondary value pattern (optional)\n const secondaryPattern =\n '(?:\\\\/(-?(?:\\\\d+(?:\\\\.\\\\d+)?)|' + // Same pattern as valuePattern\n '(?:[a-zA-Z0-9_]+(?:-[a-zA-Z0-9_]+)*(?:-[a-zA-Z0-9_]+)*)|' +\n '(?:#[0-9a-fA-F]+)|' +\n nestedBracketPattern +\n '|' +\n nestedBracePattern +\n '|' +\n nestedParenPattern +\n '|' +\n '(?:\\\\$[^\\\\s\\\\/]+))' +\n '([a-zA-Z%]*))?'\n\n return new RegExp(\n prefixPattern + typePattern + separator + valuePattern + unitPattern + secondaryPattern\n )\n }\n\n public parse(className: string, safelist?: string[]) {\n // Check if the className exists in any class object\n if (Object.values(this.classes).some((classObj) => classObj?.[className])) {\n return [undefined, className, '', '', undefined, undefined]\n }\n\n const classNameRegEx = this.generateClassNameRegEx(safelist)\n const match = (className + '-dummy').match(classNameRegEx)\n if (!match) return null\n\n const [, prefix, type, value, unit, secValue, secUnit] = match\n const finalValue = value === 'dummy' ? '' : value.replace('-dummy', '')\n\n return [prefix, type, finalValue, unit || '', secValue, secUnit]\n }\n\n // unique value parser\n public processValue(value: string, unit: string, group: string): string {\n if (!value) return ''\n\n // Replace values wrapped in {} with values from this.values\n const replaceWithValueRegistry = (text: string): string => {\n return text.replace(/\\{([^}]+)\\}/g, (match, key) => {\n const valueRegistry = this.values\n const val =\n valueRegistry !== null\n ? typeof valueRegistry[group] === 'object'\n ? (valueRegistry[group] as { [value: string]: string })[key]\n : valueRegistry[key]\n : undefined\n\n return typeof val === 'string' ? val : match\n })\n }\n\n if (\n typeof this.values === 'object' &&\n this.values !== null &&\n ((this.values[group] &&\n typeof this.values[group] === 'object' &&\n this.values[group][value]) ||\n this.values[value])\n ) {\n if (typeof this.values[group] === 'object' && this.values[group] !== null) {\n return this.values[group][value] as string\n }\n\n return this.values[value] as string\n } else if (value.startsWith('$')) {\n return `var(--${value.slice(1)})` //? [color]-$my-color => color: var(--my-color)\n } else if (\n (value.startsWith('[') && value.endsWith(']')) ||\n (value.startsWith('(') && value.endsWith(')'))\n ) {\n const cleanValue = value.slice(1, -1).replace(/_/g, ' ') //? replace '_' with ' '\n\n if (cleanValue.includes('{')) {\n return replaceWithValueRegistry(cleanValue)\n }\n return cleanValue.startsWith('--') ? `var(${cleanValue})` : cleanValue\n }\n\n return value + (unit || '') //? [padding]-4px => padding: 4px\n }\n\n public processShorthand(\n type: string = '',\n value: string | undefined = '',\n unit: string | undefined = '',\n prefix: string | undefined,\n secondValue: string | undefined = '',\n secondUnit: string | undefined = '',\n isHyphen: boolean = true\n ): ProcessedStyle | null {\n const properties = this.property[type]\n // Extract \"for\" from (color:red) => { for: 'color', cleanValue: 'red' }\n // Pattern that matches both (label:value) and [label:value] formats\n const pattern = /^(?:\\(|\\[)([^:]+):(.+)(?:\\)|\\])$/\n let extractedFor: string | null = null\n let cleanValue = value || ''\n const matchValue = cleanValue.match(pattern)\n if (matchValue) {\n extractedFor = matchValue[1].trim()\n cleanValue = matchValue[2].trim()\n }\n\n let finalCleanValue\n\n if (value.includes(extractedFor + ':')) {\n finalCleanValue = value.startsWith('(') ? `(${cleanValue})` : `[${cleanValue}]`\n } else finalCleanValue = value\n\n // process input value\n const finalValue = this.processValue(finalCleanValue, unit, type)\n // process second value\n const finalSecValue = this.processValue(secondValue, secondUnit, type)\n\n // if the type started with square bracket\n // e.g. [--my-color], [color,borderColor] ...\n if (type.startsWith('[') && type.endsWith(']')) {\n const items = type\n .slice(1, -1)\n .split(',')\n .map((item) => item.trim())\n\n const cssRules = items\n .map((item) => {\n const prop = this.property[item] || item\n const finalProperty =\n typeof prop === 'string' && prop.startsWith('--')\n ? String(prop)\n : this.toKebabCase(String(prop))\n return `${finalProperty}: ${finalValue}`\n })\n .join('; ')\n\n return {\n className: `${`[${type.slice(1, -1)}]${isHyphen ? '-' : ''}${value}${unit}`}`,\n cssRules, // return css rules directly\n value: null, // and set value to null to prevent value duplication\n prefix\n }\n }\n\n // if type matched property's key\n // e.g. { property: { bg: 'background' } }\n // the `bg` is the type\n if (properties) {\n if (typeof properties === 'object' && 'property' in properties && 'value' in properties) {\n const valuesGroup = properties.group || type\n const groupValue = (this.values[valuesGroup] as { [value: string]: string })[finalValue]\n ? (this.values[valuesGroup] as { [value: string]: string })[finalValue]\n : unit\n ? value\n : finalValue\n\n const property =\n typeof properties.property === 'function'\n ? properties.property({\n value: groupValue,\n unit,\n secondValue: secondUnit ? secondValue : finalSecValue,\n secondUnit,\n key: extractedFor\n })\n : properties.property\n\n const template = properties.value\n\n let processedValue\n\n if (typeof template === 'function') {\n processedValue = template({\n value: groupValue,\n unit,\n secondValue: secondUnit ? secondValue : finalSecValue,\n secondUnit,\n key: extractedFor,\n property\n })\n } else if (template && typeof template === 'string') {\n const newValue = this.processValue(finalCleanValue, unit, valuesGroup)\n\n processedValue =\n this.values[finalCleanValue] ||\n (this.values[valuesGroup] as { [value: string]: string })[finalCleanValue] ||\n finalCleanValue.includes('{') ||\n template.includes('{')\n ? this.parseValuePattern(valuesGroup, template, newValue, '', finalSecValue, '')\n : finalValue\n } else processedValue = null\n\n const className = `${type}${\n value ? `${isHyphen ? (isHyphen ? '-' : '') : ''}${value}${unit}` : ''\n }${secondValue ? `/${secondValue}${secondUnit}` : ''}`\n\n return {\n className,\n cssRules: Array.isArray(property)\n ? (property as string[])\n : typeof property === 'string' && (property as string).includes(':')\n ? (property as string)\n : (this.toKebabCase(String(property)) as string),\n value: template === null ? null : value.startsWith('[') ? finalValue : processedValue,\n prefix\n }\n }\n\n const finalRegProperty =\n typeof properties === 'function'\n ? properties({\n value: unit ? value : finalValue,\n unit,\n secondValue: secondUnit ? secondValue : finalSecValue,\n secondUnit,\n key: extractedFor\n })\n : properties\n\n return {\n className: `${type}${value ? (isHyphen ? '-' : '') + value + unit : ''}`,\n cssRules: Array.isArray(properties)\n ? (finalRegProperty as string[])\n : typeof finalRegProperty === 'string' && finalRegProperty.startsWith('value:')\n ? finalRegProperty.slice(6)\n : (this.toKebabCase(String(finalRegProperty)) as string),\n value:\n typeof finalRegProperty === 'string' && finalRegProperty.startsWith('value:')\n ? null\n : finalValue,\n prefix\n }\n }\n\n return null\n }\n\n private parseValuePattern(\n group: string,\n pattern: string,\n inputValue: string,\n inputUnit: string,\n inputSecValue: string,\n inputSecUnit: string\n ): string {\n if (!pattern.includes('{0}') && !pattern.includes('{1') && !pattern.includes('||'))\n return pattern\n\n const [value, defaultValue] = pattern.split('||').map((s) => s.trim())\n const finalValue = this.processValue(inputValue, inputUnit, group)\n const finalSecValue = this.processValue(inputSecValue, inputSecUnit, group)\n\n if ((pattern.includes('{0}') && pattern.includes('{1')) || pattern.includes('{1')) {\n let computedValue = value\n if (inputValue) {\n computedValue = computedValue.replace('{0}', finalValue)\n }\n if (pattern.includes('{1')) {\n // find {1 ... } pattern and extract default value if present\n const match = computedValue.match(/{1([^}]*)}/)\n if (pattern.includes('{1}')) {\n if (inputSecValue) {\n computedValue = inputSecValue.startsWith('[')\n ? finalSecValue\n : computedValue.replace('{1}', finalSecValue)\n } else {\n computedValue = defaultValue\n }\n } else if (match) {\n const fullMatch = match[0]\n const innerContent = match[1].trim()\n\n let replacementValue = finalSecValue\n if (!replacementValue && innerContent.includes('|')) {\n // use default value after | if second value isn provided\n replacementValue = innerContent.split('|')[1].trim()\n } else if (!replacementValue) {\n replacementValue = ''\n }\n computedValue = inputValue.startsWith('[')\n ? finalValue\n : computedValue.replace(fullMatch, replacementValue)\n }\n }\n return inputValue ? computedValue : defaultValue || value\n }\n // Handle only {0} replacement\n else {\n return inputValue\n ? inputValue.startsWith('[')\n ? finalValue\n : value.replace('{0}', finalValue)\n : defaultValue || value\n }\n }\n\n private getParentClass(className: string): CSSPropertyOrVariable[] {\n return Object.keys(this.classes).filter((cssProperty) =>\n Object.prototype.hasOwnProperty.call(\n this.classes[cssProperty as CSSPropertyOrVariable],\n className\n )\n ) as CSSPropertyOrVariable[]\n }\n\n public processCustomClass(\n className: string | undefined,\n value: string | undefined = '',\n unit: string | undefined = '',\n prefix: string | undefined = '',\n secValue: string | undefined = '',\n secUnit: string | undefined = '',\n isHyphen: boolean = true\n ): ProcessedStyle | null {\n if (!className) return null\n\n const properties = this.getParentClass(className)\n\n if (properties.length > 0) {\n const rules = properties\n .map((prop) => {\n const classObj = this.classes[prop]\n if (!classObj) return ''\n\n const processedValue = this.parseValuePattern(\n className,\n classObj[className] || '',\n value,\n unit,\n secValue,\n secUnit\n )\n\n return `${this.toKebabCase(String(prop))}: ${processedValue}`\n })\n .filter(Boolean)\n .join('; ')\n\n const isValueType = className.slice(-(value + unit).length)\n\n const finalClassName = `${className}${value ? `${isHyphen ? '-' : ''}${value}${unit}` : ''}${\n secValue ? `/${secValue}${secUnit}` : ''\n }`\n\n return {\n className: value === isValueType ? className : finalClassName,\n cssRules: rules,\n value: null,\n prefix\n }\n }\n\n return null\n }\n\n public processAlias(className: string, prefix: string = ''): ProcessedStyle | null {\n const alias = this.aliases[className]\n\n if (!alias) return null\n\n const aliasClasses = alias.split(' ')\n const combinedRules: string[] = []\n\n aliasClasses.forEach((aliasClass) => {\n const [rprefix, rtype] = aliasClass.split(':')\n const getType = rtype || rprefix\n const getPrefix = rtype ? rprefix : undefined\n const parts = this.parse(aliasClass)\n const parsed = parts ? parts : [getPrefix, getType, '', '']\n if (!parsed) return\n\n const [prefix, type, value, unit, secValue, secUnit] = parsed\n const result = this.processShorthand(type, value!, unit, undefined, secValue, secUnit)\n\n const shouldClasses = this.processCustomClass(type, value, unit, prefix, secValue, secUnit)\n if (shouldClasses) {\n const { cssRules } = shouldClasses\n combinedRules.push(cssRules as string)\n\n return\n }\n\n if (result) {\n const value = result.value !== null ? `: ${result.value}` : ''\n if (Array.isArray(result.cssRules)) {\n result.cssRules.forEach((rule) => {\n combinedRules.push(`${this.toKebabCase(rule)}${value}`)\n })\n } else {\n combinedRules.push(`${result.cssRules}${value}`)\n }\n }\n })\n\n return {\n className,\n cssRules: combinedRules.join('; '),\n value: null,\n prefix\n }\n }\n\n public process(classNames: string | string[]): ProcessedStyle[] {\n const classList = Array.isArray(classNames) ? classNames : classNames.split(/\\s+/)\n\n const results: ProcessedStyle[] = []\n\n classList.forEach((className) => {\n if (!className) return this\n // process prefix and actual class name\n const [rprefix, rtype] = className.split(':')\n const getType = rtype || rprefix\n const getPrefix = rtype ? rprefix : undefined\n\n // process class name aliases\n const aliasResult = this.processAlias(getType, getPrefix)\n if (aliasResult) {\n const { className: aliasClassName, cssRules } = aliasResult\n\n results.push({\n className: aliasClassName,\n cssRules,\n value: null,\n prefix: getPrefix\n })\n\n return\n }\n\n const parts = this.parse(className)\n const parsed = parts ? parts : [getPrefix, getType, '', '']\n if (!parsed) return this\n\n const [prefix, type, value, unit, secValue, secUnit] = parsed\n\n const isHyphen = !className.includes((type || '') + (value || ''))\n\n const classFromClasses =\n this.getParentClass(`${type}${isHyphen ? '-' : ''}${value}`).length > 0\n ? `${type}${isHyphen ? '-' : ''}${value}`\n : type\n\n const shouldClasses = this.processCustomClass(\n classFromClasses,\n value,\n unit,\n prefix,\n secValue,\n secUnit,\n isHyphen\n )\n\n if (shouldClasses) {\n const { className, cssRules, prefix } = shouldClasses\n\n results.push({\n className,\n cssRules,\n value: null,\n prefix\n })\n\n return\n }\n\n const result = this.processShorthand(type, value!, unit, prefix, secValue, secUnit, isHyphen)\n\n if (result) {\n const { className, cssRules, value: ruleValue, prefix: rulePrefix } = result\n\n results.push({\n className,\n cssRules,\n value: ruleValue,\n prefix: rulePrefix\n })\n }\n })\n\n return results\n }\n}\n\nexport default TenoxUI\n"],"names":["TenoxUI","property","values","classes","aliases","__spreadValues","key","str","match","prefix","letter","classRegistry","classNames","classObj","className","safelist","styleAttribute","propertyTypes","a","b","classPatterns","typePrefixes","nestedBracketPattern","nestedParenPattern","nestedBracePattern","prefixPattern","typePattern","separator","valuePattern","unitPattern","secondaryPattern","classNameRegEx","type","value","unit","secValue","secUnit","finalValue","group","replaceWithValueRegistry","text","valueRegistry","val","cleanValue","secondValue","secondUnit","isHyphen","properties","pattern","extractedFor","matchValue","finalCleanValue","finalSecValue","cssRules","item","prop","valuesGroup","groupValue","template","processedValue","newValue","finalRegProperty","inputValue","inputUnit","inputSecValue","inputSecUnit","defaultValue","s","computedValue","fullMatch","innerContent","replacementValue","cssProperty","rules","isValueType","finalClassName","alias","aliasClasses","combinedRules","aliasClass","rprefix","rtype","getType","getPrefix","parts","parsed","result","shouldClasses","rule","classList","results","aliasResult","aliasClassName","classFromClasses","ruleValue","rulePrefix"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs","sources":["../src/index.ts"],"sourcesContent":["import type {\n Values,\n Aliases,\n Classes,\n CSSPropertyOrVariable,\n GetCSSProperty\n} from '@tenoxui/types'\nimport type { Property, Config, ProcessedStyle } from './types'\nexport * from './types'\nexport class TenoxUI {\n private property: Property\n private values: Values\n private classes: Classes\n private aliases: Aliases\n\n constructor({ property = {}, values = {}, classes = {}, aliases = {} }: Config = {}) {\n this.property = {\n moxie: ({ key }) => key as GetCSSProperty, // use moxie-* to access all properties and variables\n ...property\n }\n this.values = values\n this.classes = classes\n this.aliases = aliases\n }\n\n public toKebabCase(str: string): string {\n if (/^(webkit|moz|ms|o)[A-Z]/.test(str)) {\n const match = str.match(/^(webkit|moz|ms|o)/)\n if (match) {\n const prefix = match[0]\n return `-${prefix}${str\n .slice(prefix.length)\n .replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`)}`\n }\n }\n\n return str.replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`)\n }\n\n public escapeCSSSelector(str: string): string {\n return str.replace(/([ #{}.:;?%&,@+*~'\"!^$[\\]()=>|/])/g, '\\\\$1')\n }\n\n private getAllClassNames(classRegistry: Classes | undefined): string[] {\n if (!classRegistry) return []\n const classNames = new Set<string>()\n\n Object.entries(classRegistry).forEach(([property, classObj]) => {\n if (classObj && typeof classObj === 'object') {\n Object.keys(classObj).forEach((className) => {\n classNames.add(className)\n })\n }\n })\n\n return Array.from(classNames)\n }\n\n private getTypePrefixes(safelist: string[] = []): string {\n const styleAttribute = this.property\n const classRegistry = this.classes\n const propertyTypes = Object.keys(styleAttribute)\n\n if (!classRegistry) {\n return [...propertyTypes, ...safelist].sort((a, b) => b.length - a.length).join('|')\n }\n\n const classConfigs = this.getAllClassNames(classRegistry)\n const classPatterns = [...classConfigs]\n\n return [...propertyTypes, ...classPatterns, ...safelist]\n .sort((a, b) => b.length - a.length)\n .join('|')\n }\n\n private generateClassNameRegEx(safelist?: string[]): RegExp {\n const typePrefixes = this.getTypePrefixes(safelist)\n\n // Common pattern for handling complex nested structures\n const nestedBracketPattern = '\\\\[[^\\\\]]+\\\\]'\n const nestedParenPattern = '\\\\([^()]*(?:\\\\([^()]*\\\\)[^()]*)*\\\\)'\n const nestedBracePattern = '\\\\{[^{}]*(?:\\\\{[^{}]*\\\\}[^{}]*)*\\\\}'\n\n // 1. Prefix pattern - now allows for complex structures like nth-[...]\n const prefixPattern =\n '(?:(' +\n // Simple prefix (hover, md, focus, etc.)\n '[a-zA-Z0-9_-]+|' +\n // Prefix with nested structures like nth-[...]\n '[a-zA-Z0-9_-]+(?:-' +\n nestedBracketPattern +\n ')|' +\n // Direct bracket, parenthesis, or brace content\n nestedBracketPattern +\n '|' +\n nestedParenPattern +\n '|' +\n nestedBracePattern +\n '):)?'\n\n // 2. Type pattern\n const typePattern = `(${typePrefixes}|\\\\[[^\\\\]]+\\\\])`\n\n // 3. Separator (optional)\n const separator = '(?:-)?'\n\n // 4. Value pattern - modified to handle $ variables correctly\n const valuePattern =\n '(-?(?:\\\\d+(?:\\\\.\\\\d+)?)|' + // Numbers\n '(?:[a-zA-Z0-9_]+(?:-[a-zA-Z0-9_]+)*(?:-[a-zA-Z0-9_]+)*)|' + // Words with hyphens\n '(?:#[0-9a-fA-F]+)|' + // Hex colors\n nestedBracketPattern +\n '|' + // Bracket content\n nestedBracePattern +\n '|' + // Curly brace content\n nestedParenPattern +\n '|' + // Parentheses content\n '(?:\\\\$[^\\\\s\\\\/]+))' // Dollar sign content\n\n // 5. Unit pattern (optional)\n const unitPattern = '([a-zA-Z%]*)'\n\n // 6. Secondary value pattern (optional)\n const secondaryPattern =\n '(?:\\\\/(-?(?:\\\\d+(?:\\\\.\\\\d+)?)|' + // Same pattern as valuePattern\n '(?:[a-zA-Z0-9_]+(?:-[a-zA-Z0-9_]+)*(?:-[a-zA-Z0-9_]+)*)|' +\n '(?:#[0-9a-fA-F]+)|' +\n nestedBracketPattern +\n '|' +\n nestedBracePattern +\n '|' +\n nestedParenPattern +\n '|' +\n '(?:\\\\$[^\\\\s\\\\/]+))' +\n '([a-zA-Z%]*))?'\n\n return new RegExp(\n prefixPattern + typePattern + separator + valuePattern + unitPattern + secondaryPattern\n )\n }\n\n public parse(className: string, safelist?: string[]) {\n // Check if the className exists in any class object\n if (Object.values(this.classes).some((classObj) => classObj?.[className])) {\n return [undefined, className, '', '', undefined, undefined]\n }\n\n const classNameRegEx = this.generateClassNameRegEx(safelist)\n const match = (className + '-dummy').match(classNameRegEx)\n if (!match) return null\n\n const [, prefix, type, value, unit, secValue, secUnit] = match\n const finalValue = value === 'dummy' ? '' : value.replace('-dummy', '')\n\n return [prefix, type, finalValue, unit || '', secValue, secUnit]\n }\n\n // unique value parser\n public processValue(value: string, unit: string, group: string): string {\n if (!value) return ''\n\n // Replace values wrapped in {} with values from this.values\n const replaceWithValueRegistry = (text: string): string => {\n return text.replace(/\\{([^}]+)\\}/g, (match, key) => {\n const valueRegistry = this.values\n const val =\n valueRegistry !== null\n ? typeof valueRegistry[group] === 'object'\n ? (valueRegistry[group] as { [value: string]: string })[key]\n : valueRegistry[key]\n : undefined\n\n return typeof val === 'string' ? val : match\n })\n }\n\n if (\n typeof this.values === 'object' &&\n this.values !== null &&\n ((this.values[group] &&\n typeof this.values[group] === 'object' &&\n this.values[group][value]) ||\n this.values[value])\n ) {\n if (typeof this.values[group] === 'object' && this.values[group] !== null) {\n return this.values[group][value] as string\n }\n\n return this.values[value] as string\n } else if (value.startsWith('$')) {\n return `var(--${value.slice(1)})` //? [color]-$my-color => color: var(--my-color)\n } else if (\n (value.startsWith('[') && value.endsWith(']')) ||\n (value.startsWith('(') && value.endsWith(')'))\n ) {\n const cleanValue = value.slice(1, -1).replace(/_/g, ' ') //? replace '_' with ' '\n\n if (cleanValue.includes('{')) {\n return replaceWithValueRegistry(cleanValue)\n }\n return cleanValue.startsWith('--') ? `var(${cleanValue})` : cleanValue\n }\n\n return value + (unit || '') //? [padding]-4px => padding: 4px\n }\n\n public processShorthand(\n type: string = '',\n value: string | undefined = '',\n unit: string | undefined = '',\n prefix: string | undefined,\n secondValue: string | undefined = '',\n secondUnit: string | undefined = '',\n isHyphen: boolean = true\n ): ProcessedStyle | null {\n const properties = this.property[type]\n // Extract \"for\" from (color:red) => { for: 'color', cleanValue: 'red' }\n // Pattern that matches both (label:value) and [label:value] formats\n const pattern = /^(?:\\(|\\[)([^:]+):(.+)(?:\\)|\\])$/\n let extractedFor: string | null = null\n let cleanValue = value || ''\n const matchValue = cleanValue.match(pattern)\n if (matchValue) {\n extractedFor = matchValue[1].trim()\n cleanValue = matchValue[2].trim()\n }\n\n let finalCleanValue\n\n if (value.includes(extractedFor + ':')) {\n finalCleanValue = value.startsWith('(') ? `(${cleanValue})` : `[${cleanValue}]`\n } else finalCleanValue = value\n\n // process input value\n const finalValue = this.processValue(finalCleanValue, unit, type)\n // process second value\n const finalSecValue = this.processValue(secondValue, secondUnit, type)\n\n // if the type started with square bracket\n // e.g. [--my-color], [color,borderColor] ...\n if (type.startsWith('[') && type.endsWith(']')) {\n const items = type\n .slice(1, -1)\n .split(',')\n .map((item) => item.trim())\n\n const cssRules = items\n .map((item) => {\n const prop = this.property[item] || item\n const finalProperty =\n typeof prop === 'string' && prop.startsWith('--')\n ? String(prop)\n : this.toKebabCase(String(prop))\n return `${finalProperty}: ${finalValue}`\n })\n .join('; ')\n\n return {\n className: `${`[${type.slice(1, -1)}]${isHyphen ? '-' : ''}${value}${unit}`}`,\n cssRules, // return css rules directly\n value: null, // and set value to null to prevent value duplication\n prefix\n }\n }\n\n // if type matched property's key\n // e.g. { property: { bg: 'background' } }\n // the `bg` is the type\n if (properties) {\n if (typeof properties === 'object' && 'property' in properties && 'value' in properties) {\n const groupValue =\n properties.group && this.values[properties.group]\n ? (this.values[properties.group] as { [value: string]: string })[finalValue]\n : unit\n ? value\n : finalValue\n\n const property =\n typeof properties.property === 'function'\n ? properties.property({\n value: groupValue,\n unit,\n secondValue: secondUnit ? secondValue : finalSecValue,\n secondUnit,\n key: extractedFor\n })\n : properties.property\n\n const template = properties.value\n\n let processedValue\n\n if (typeof template === 'function') {\n processedValue = template({\n value: groupValue,\n unit,\n secondValue: secondUnit ? secondValue : finalSecValue,\n secondUnit,\n key: extractedFor,\n property\n })\n } else if (template && typeof template === 'string') {\n const valuesGroup = properties.group || type\n const newValue = this.processValue(finalCleanValue, unit, valuesGroup)\n\n processedValue =\n this.values[finalCleanValue] ||\n (this.values[valuesGroup] as { [value: string]: string })[finalCleanValue] ||\n finalCleanValue.includes('{') ||\n template.includes('{')\n ? this.parseValuePattern(valuesGroup, template, newValue, '', finalSecValue, '')\n : finalValue\n } else processedValue = null\n\n const className = `${type}${\n value ? `${isHyphen ? (isHyphen ? '-' : '') : ''}${value}${unit}` : ''\n }${secondValue ? `/${secondValue}${secondUnit}` : ''}`\n\n return {\n className,\n cssRules: Array.isArray(property)\n ? (property as string[])\n : typeof property === 'string' && (property as string).includes(':')\n ? (property as string)\n : (this.toKebabCase(String(property)) as string),\n value: template === null ? null : value.startsWith('[') ? finalValue : processedValue,\n prefix\n }\n }\n\n const finalRegProperty =\n typeof properties === 'function'\n ? properties({\n value: unit ? value : finalValue,\n unit,\n secondValue: secondUnit ? secondValue : finalSecValue,\n secondUnit,\n key: extractedFor\n })\n : properties\n\n return {\n className: `${type}${value ? (isHyphen ? '-' : '') + value + unit : ''}`,\n cssRules: Array.isArray(properties)\n ? (finalRegProperty as string[])\n : typeof finalRegProperty === 'string' && finalRegProperty.startsWith('value:')\n ? finalRegProperty.slice(6)\n : (this.toKebabCase(String(finalRegProperty)) as string),\n value:\n typeof finalRegProperty === 'string' && finalRegProperty.startsWith('value:')\n ? null\n : finalValue,\n prefix\n }\n }\n\n return null\n }\n\n private parseValuePattern(\n group: string,\n pattern: string,\n inputValue: string,\n inputUnit: string,\n inputSecValue: string,\n inputSecUnit: string\n ): string {\n if (!pattern.includes('{0}') && !pattern.includes('{1') && !pattern.includes('||'))\n return pattern\n\n const [value, defaultValue] = pattern.split('||').map((s) => s.trim())\n const finalValue = this.processValue(inputValue, inputUnit, group)\n const finalSecValue = this.processValue(inputSecValue, inputSecUnit, group)\n\n if ((pattern.includes('{0}') && pattern.includes('{1')) || pattern.includes('{1')) {\n let computedValue = value\n if (inputValue) {\n computedValue = computedValue.replace('{0}', finalValue)\n }\n if (pattern.includes('{1')) {\n // find {1 ... } pattern and extract default value if present\n const match = computedValue.match(/{1([^}]*)}/)\n if (pattern.includes('{1}')) {\n if (inputSecValue) {\n computedValue = inputSecValue.startsWith('[')\n ? finalSecValue\n : computedValue.replace('{1}', finalSecValue)\n } else {\n computedValue = defaultValue\n }\n } else if (match) {\n const fullMatch = match[0]\n const innerContent = match[1].trim()\n\n let replacementValue = finalSecValue\n if (!replacementValue && innerContent.includes('|')) {\n // use default value after | if second value isn provided\n replacementValue = innerContent.split('|')[1].trim()\n } else if (!replacementValue) {\n replacementValue = ''\n }\n computedValue = inputValue.startsWith('[')\n ? finalValue\n : computedValue.replace(fullMatch, replacementValue)\n }\n }\n return inputValue ? computedValue : defaultValue || value\n }\n // Handle only {0} replacement\n else {\n return inputValue\n ? inputValue.startsWith('[')\n ? finalValue\n : value.replace('{0}', finalValue)\n : defaultValue || value\n }\n }\n\n private getParentClass(className: string): CSSPropertyOrVariable[] {\n return Object.keys(this.classes).filter((cssProperty) =>\n Object.prototype.hasOwnProperty.call(\n this.classes[cssProperty as CSSPropertyOrVariable],\n className\n )\n ) as CSSPropertyOrVariable[]\n }\n\n public processCustomClass(\n className: string | undefined,\n value: string | undefined = '',\n unit: string | undefined = '',\n prefix: string | undefined = '',\n secValue: string | undefined = '',\n secUnit: string | undefined = '',\n isHyphen: boolean = true\n ): ProcessedStyle | null {\n if (!className) return null\n\n const properties = this.getParentClass(className)\n\n if (properties.length > 0) {\n const rules = properties\n .map((prop) => {\n const classObj = this.classes[prop]\n if (!classObj) return ''\n\n const processedValue = this.parseValuePattern(\n className,\n classObj[className] || '',\n value,\n unit,\n secValue,\n secUnit\n )\n\n return `${this.toKebabCase(String(prop))}: ${processedValue}`\n })\n .filter(Boolean)\n .join('; ')\n\n const isValueType = className.slice(-(value + unit).length)\n\n const finalClassName = `${className}${value ? `${isHyphen ? '-' : ''}${value}${unit}` : ''}${\n secValue ? `/${secValue}${secUnit}` : ''\n }`\n\n return {\n className: value === isValueType ? className : finalClassName,\n cssRules: rules,\n value: null,\n prefix\n }\n }\n\n return null\n }\n\n public processAlias(className: string, prefix: string = ''): ProcessedStyle | null {\n const alias = this.aliases[className]\n\n if (!alias) return null\n\n const aliasClasses = alias.split(' ')\n const combinedRules: string[] = []\n\n aliasClasses.forEach((aliasClass) => {\n const [rprefix, rtype] = aliasClass.split(':')\n const getType = rtype || rprefix\n const getPrefix = rtype ? rprefix : undefined\n const parts = this.parse(aliasClass)\n const parsed = parts ? parts : [getPrefix, getType, '', '']\n if (!parsed) return\n\n const [prefix, type, value, unit, secValue, secUnit] = parsed\n const result = this.processShorthand(type, value!, unit, undefined, secValue, secUnit)\n\n const shouldClasses = this.processCustomClass(type, value, unit, prefix, secValue, secUnit)\n if (shouldClasses) {\n const { cssRules } = shouldClasses\n combinedRules.push(cssRules as string)\n\n return\n }\n\n if (result) {\n const value = result.value !== null ? `: ${result.value}` : ''\n if (Array.isArray(result.cssRules)) {\n result.cssRules.forEach((rule) => {\n combinedRules.push(`${this.toKebabCase(rule)}${value}`)\n })\n } else {\n combinedRules.push(`${result.cssRules}${value}`)\n }\n }\n })\n\n return {\n className,\n cssRules: combinedRules.join('; '),\n value: null,\n prefix\n }\n }\n\n public process(classNames: string | string[]): ProcessedStyle[] {\n const classList = Array.isArray(classNames) ? classNames : classNames.split(/\\s+/)\n\n const results: ProcessedStyle[] = []\n\n classList.forEach((className) => {\n if (!className) return this\n // process prefix and actual class name\n const [rprefix, rtype] = className.split(':')\n const getType = rtype || rprefix\n const getPrefix = rtype ? rprefix : undefined\n\n // process class name aliases\n const aliasResult = this.processAlias(getType, getPrefix)\n if (aliasResult) {\n const { className: aliasClassName, cssRules } = aliasResult\n\n results.push({\n className: aliasClassName,\n cssRules,\n value: null,\n prefix: getPrefix\n })\n\n return\n }\n\n const parts = this.parse(className)\n const parsed = parts ? parts : [getPrefix, getType, '', '']\n if (!parsed) return this\n\n const [prefix, type, value, unit, secValue, secUnit] = parsed\n\n const isHyphen = !className.includes((type || '') + (value || ''))\n\n const classFromClasses =\n this.getParentClass(`${type}${isHyphen ? '-' : ''}${value}`).length > 0\n ? `${type}${isHyphen ? '-' : ''}${value}`\n : type\n\n const shouldClasses = this.processCustomClass(\n classFromClasses,\n value,\n unit,\n prefix,\n secValue,\n secUnit,\n isHyphen\n )\n\n if (shouldClasses) {\n const { className, cssRules, prefix } = shouldClasses\n\n results.push({\n className,\n cssRules,\n value: null,\n prefix\n })\n\n return\n }\n\n const result = this.processShorthand(type, value!, unit, prefix, secValue, secUnit, isHyphen)\n\n if (result) {\n const { className, cssRules, value: ruleValue, prefix: rulePrefix } = result\n\n results.push({\n className,\n cssRules,\n value: ruleValue,\n prefix: rulePrefix\n })\n }\n })\n\n return results\n }\n}\n\nexport default TenoxUI\n"],"names":["prefix","value","className"],"mappings":"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"}