@greensight/gts 1.0.0-beta.5 → 1.0.0-beta.6

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/index.mjs CHANGED
@@ -1,78 +1,78 @@
1
- var ue = Object.defineProperty;
2
- var de = (t, e, s) => e in t ? ue(t, e, { enumerable: !0, configurable: !0, writable: !0, value: s }) : t[e] = s;
3
- var m = (t, e, s) => de(t, typeof e != "symbol" ? e + "" : e, s);
4
- import w from "path";
1
+ var de = Object.defineProperty;
2
+ var fe = (t, e, o) => e in t ? de(t, e, { enumerable: !0, configurable: !0, writable: !0, value: o }) : t[e] = o;
3
+ var w = (t, e, o) => fe(t, typeof e != "symbol" ? e + "" : e, o);
4
+ import k from "path";
5
5
  import { tsImport as ye } from "ts-import";
6
- import { existsSync as M } from "node:fs";
7
- import { readFile as V, mkdir as fe, writeFile as ge, rm as pe } from "node:fs/promises";
8
- import { resolve as N } from "node:path";
6
+ import { existsSync as C } from "node:fs";
7
+ import { readFile as N, mkdir as ge, writeFile as pe, rm as he } from "node:fs/promises";
8
+ import { resolve as V } from "node:path";
9
9
  const p = class p {
10
10
  static resolveReadPath(e) {
11
11
  if (!e || !e.trim())
12
12
  throw new Error("File path must be a non-empty string");
13
- return N(p.baseDir, e);
13
+ return V(p.baseDir, e);
14
14
  }
15
- static resolveWritePath(e, s) {
16
- const r = N(p.baseDir, s ?? "");
15
+ static resolveWritePath(e, o) {
16
+ const r = V(p.baseDir, o ?? "");
17
17
  return {
18
18
  targetDir: r,
19
- targetPath: N(r, e)
19
+ targetPath: V(r, e)
20
20
  };
21
21
  }
22
- static handleReadError(e, s) {
23
- throw e.code === "ENOENT" ? new Error(`File not found: ${s}`) : new Error(
24
- `Failed to read file "${s}": ${e.message ?? String(e)}`
22
+ static handleReadError(e, o) {
23
+ throw e.code === "ENOENT" ? new Error(`File not found: ${o}`) : new Error(
24
+ `Failed to read file "${o}": ${e.message ?? String(e)}`
25
25
  );
26
26
  }
27
- static async read(e, s = "utf8") {
27
+ static async read(e, o = "utf8") {
28
28
  const r = p.resolveReadPath(e);
29
29
  try {
30
- return await V(r, { encoding: s });
31
- } catch (o) {
32
- p.handleReadError(o, r);
30
+ return await N(r, { encoding: o });
31
+ } catch (s) {
32
+ p.handleReadError(s, r);
33
33
  }
34
34
  }
35
35
  static async readBuffer(e) {
36
- const s = p.resolveReadPath(e);
36
+ const o = p.resolveReadPath(e);
37
37
  try {
38
- return await V(s);
38
+ return await N(o);
39
39
  } catch (r) {
40
- p.handleReadError(r, s);
40
+ p.handleReadError(r, o);
41
41
  }
42
42
  }
43
43
  static async readJson(e) {
44
- const s = p.resolveReadPath(e);
44
+ const o = p.resolveReadPath(e);
45
45
  try {
46
- const r = await V(s, { encoding: "utf8" });
46
+ const r = await N(o, { encoding: "utf8" });
47
47
  try {
48
48
  return JSON.parse(r);
49
- } catch (o) {
50
- throw new Error(`Failed to parse JSON from "${s}": ${o.message}`);
49
+ } catch (s) {
50
+ throw new Error(`Failed to parse JSON from "${o}": ${s.message}`);
51
51
  }
52
52
  } catch (r) {
53
- p.handleReadError(r, s);
53
+ p.handleReadError(r, o);
54
54
  }
55
55
  }
56
- static async write(e, s = "", r = {}) {
57
- const { directory: o, overwrite: n = !0 } = r, { targetDir: a, targetPath: i } = p.resolveWritePath(e, o);
58
- if (!n && M(i))
56
+ static async write(e, o = "", r = {}) {
57
+ const { directory: s, overwrite: n = !0 } = r, { targetDir: a, targetPath: i } = p.resolveWritePath(e, s);
58
+ if (!n && C(i))
59
59
  throw new Error(`File ${i} already exists`);
60
- return await fe(a, { recursive: !0 }), await ge(i, s, { encoding: "utf8" }), i;
60
+ return await ge(a, { recursive: !0 }), await pe(i, o, { encoding: "utf8" }), i;
61
61
  }
62
- static async writeWithExtension(e, s, r = "", o) {
63
- const n = s.startsWith(".") ? s : `.${s}`, a = `${e}${n}`;
64
- return p.write(a, r, o);
62
+ static async writeWithExtension(e, o, r = "", s) {
63
+ const n = o.startsWith(".") ? o : `.${o}`, a = `${e}${n}`;
64
+ return p.write(a, r, s);
65
65
  }
66
66
  static exists(e) {
67
- const s = p.resolveReadPath(e);
68
- return M(s);
67
+ const o = p.resolveReadPath(e);
68
+ return C(o);
69
69
  }
70
- static async delete(e, s) {
71
- const { targetPath: r } = p.resolveWritePath(e, s);
72
- M(r) && await pe(r, { recursive: !0, force: !0 });
70
+ static async delete(e, o) {
71
+ const { targetPath: r } = p.resolveWritePath(e, o);
72
+ C(r) && await he(r, { recursive: !0, force: !0 });
73
73
  }
74
74
  };
75
- m(p, "baseDir", process.cwd());
75
+ w(p, "baseDir", process.cwd());
76
76
  let d = p;
77
77
  const $ = class $ {
78
78
  static async create() {
@@ -83,7 +83,7 @@ const $ = class $ {
83
83
  async load() {
84
84
  try {
85
85
  const e = await ye.compile(
86
- `${w.resolve(process.cwd(), $.configFileName)}`
86
+ `${k.resolve(process.cwd(), $.configFileName)}`
87
87
  );
88
88
  if (!e)
89
89
  throw new Error("gts.config.ts must default-export a configuration object");
@@ -93,61 +93,61 @@ const $ = class $ {
93
93
  }
94
94
  }
95
95
  };
96
- m($, "configFileName", "gts.config.ts");
97
- let j = $;
98
- const he = (t) => {
96
+ w($, "configFileName", "gts.config.ts");
97
+ let v = $;
98
+ const be = (t) => {
99
99
  const e = new URLSearchParams();
100
- return Object.keys(t).forEach((s) => {
101
- Array.isArray(t[s]) ? t[s].forEach((r) => e.append(`${s}[]`, r)) : e.append(s, t[s]);
100
+ return Object.keys(t).forEach((o) => {
101
+ Array.isArray(t[o]) ? t[o].forEach((r) => e.append(`${o}[]`, r)) : e.append(o, t[o]);
102
102
  }), e;
103
- }, be = (t, e = 50) => {
104
- const s = [];
103
+ }, me = (t, e = 50) => {
104
+ const o = [];
105
105
  for (let r = 0; r < t.length; r += e)
106
- s.push(t.slice(r, r + e));
107
- return s;
106
+ o.push(t.slice(r, r + e));
107
+ return o;
108
108
  };
109
109
  class P {
110
- constructor(e, s) {
111
- m(this, "figmaToken");
112
- m(this, "fileId");
113
- m(this, "onTimeMeasureHandler");
114
- this.figmaToken = e, this.fileId = s;
110
+ constructor(e, o) {
111
+ w(this, "figmaToken");
112
+ w(this, "fileId");
113
+ w(this, "onTimeMeasureHandler");
114
+ this.figmaToken = e, this.fileId = o;
115
115
  }
116
116
  setOnTimeMeasureHandler(e) {
117
117
  this.onTimeMeasureHandler = e;
118
118
  }
119
119
  static async returnJSON(e) {
120
- const s = await e.json();
120
+ const o = await e.json();
121
121
  if (!e.ok) {
122
122
  let r = "Request failed";
123
123
  throw new Error(r);
124
124
  }
125
- return s;
125
+ return o;
126
126
  }
127
- async performControlledRequest(e, { params: s = {}, timeout: r = 3e4, abortController: o = new AbortController() } = {}) {
128
- var h;
127
+ async performControlledRequest(e, { params: o = {}, timeout: r = 3e4, abortController: s = new AbortController() } = {}) {
128
+ var b;
129
129
  if (!this.figmaToken || !this.fileId)
130
130
  throw new Error("figmaToken and fileId are required in gts.config.ts");
131
- const n = Object.entries(s).reduce((f, [b, k]) => typeof k < "u" ? { ...f, [b]: k } : f, {}), a = `https://api.figma.com/v1${e}${n && Object.keys(n).length ? `?${he(n)}` : ""}`;
131
+ const n = Object.entries(o).reduce((g, [h, m]) => typeof m < "u" ? { ...g, [h]: m } : g, {}), a = `https://api.figma.com/v1${e}${n && Object.keys(n).length ? `?${be(n)}` : ""}`;
132
132
  console.log("endpoinWithParams=", a);
133
- const i = setTimeout(() => o.abort(), r), l = {
133
+ const i = setTimeout(() => s.abort(), r), l = {
134
134
  "Content-Type": "application/json",
135
135
  ...this.figmaToken && { "X-Figma-Token": this.figmaToken }
136
136
  }, c = {
137
137
  method: "GET",
138
138
  headers: l,
139
- signal: o.signal
140
- }, u = performance.now(), y = await fetch(`${a}`, c);
139
+ signal: s.signal
140
+ }, u = performance.now(), f = await fetch(`${a}`, c);
141
141
  clearTimeout(i);
142
- const g = performance.now() - u;
143
- return (h = this.onTimeMeasureHandler) == null || h.call(this, a, l, g), y;
142
+ const y = performance.now() - u;
143
+ return (b = this.onTimeMeasureHandler) == null || b.call(this, a, l, y), f;
144
144
  }
145
- async request(e, s) {
146
- var o;
145
+ async request(e, o) {
146
+ var s;
147
147
  const r = await this.performControlledRequest(e, {
148
- ...s
148
+ ...o
149
149
  });
150
- return (o = r.headers.get("content-type")) != null && o.includes("application/json") ? P.returnJSON(r) : r;
150
+ return (s = r.headers.get("content-type")) != null && s.includes("application/json") ? P.returnJSON(r) : r;
151
151
  }
152
152
  async getComponents() {
153
153
  return this.request(`/files/${this.fileId}/components`);
@@ -156,30 +156,30 @@ class P {
156
156
  return this.request(`/files/${this.fileId}/styles`);
157
157
  }
158
158
  async getNodes(e) {
159
- const s = be(e).map(
159
+ const o = me(e).map(
160
160
  (n) => this.request(`/files/${this.fileId}/nodes`, { params: { ids: n.join(",") } })
161
- ), r = await Promise.all(s);
161
+ ), r = await Promise.all(o);
162
162
  return {
163
163
  ...r[0],
164
164
  nodes: r.reduce((n, a) => ({ ...n, ...a.nodes }), {})
165
165
  };
166
166
  }
167
167
  }
168
- const H = (t, e) => {
169
- const s = Array.isArray(e) ? e : e.split(".");
168
+ const q = (t, e) => {
169
+ const o = Array.isArray(e) ? e : e.split(".");
170
170
  let r = t;
171
- for (const o of s) {
171
+ for (const s of o) {
172
172
  if (r == null || typeof r != "object") return;
173
- r = r[o];
173
+ r = r[s];
174
174
  }
175
175
  return r;
176
- }, Q = (t, e) => {
176
+ }, H = (t, e) => {
177
177
  if (!e || typeof e != "object") return t;
178
178
  if (!t || typeof t != "object") return e;
179
- const s = { ...t };
179
+ const o = { ...t };
180
180
  for (const r in e)
181
- e.hasOwnProperty(r) && (typeof e[r] == "object" && e[r] !== null && typeof s[r] == "object" && s[r] !== null ? s[r] = Q(s[r], e[r]) : s[r] = e[r]);
182
- return s;
181
+ e.hasOwnProperty(r) && (typeof e[r] == "object" && e[r] !== null && typeof o[r] == "object" && o[r] !== null ? o[r] = H(o[r], e[r]) : o[r] = e[r]);
182
+ return o;
183
183
  };
184
184
  function x(t, e) {
185
185
  if (t === e)
@@ -195,49 +195,49 @@ function x(t, e) {
195
195
  if (Array.isArray(t) && Array.isArray(e)) {
196
196
  if (t.length !== e.length)
197
197
  return !1;
198
- for (let s = 0; s < t.length; s++)
199
- if (!x(t[s], e[s]))
198
+ for (let o = 0; o < t.length; o++)
199
+ if (!x(t[o], e[o]))
200
200
  return !1;
201
201
  return !0;
202
202
  }
203
203
  if (typeof t == "object" && typeof e == "object") {
204
- const s = Object.keys(t), r = Object.keys(e);
205
- if (s.length !== r.length)
204
+ const o = Object.keys(t), r = Object.keys(e);
205
+ if (o.length !== r.length)
206
206
  return !1;
207
- for (const o of s)
208
- if (!r.includes(o) || !x(t[o], e[o]))
207
+ for (const s of o)
208
+ if (!r.includes(s) || !x(t[s], e[s]))
209
209
  return !1;
210
210
  return !0;
211
211
  }
212
212
  return !1;
213
213
  }
214
- const K = {
214
+ const R = {
215
215
  color: {},
216
216
  effect: {},
217
217
  text: {},
218
218
  grid: {}
219
219
  };
220
- class me {
220
+ class we {
221
221
  constructor(e) {
222
222
  // files
223
- m(this, "tokensDir");
224
- m(this, "manifestPath");
223
+ w(this, "tokensDir");
224
+ w(this, "manifestPath");
225
225
  // result data
226
- m(this, "variables");
227
- m(this, "styles");
226
+ w(this, "variables");
227
+ w(this, "styles");
228
228
  // flags
229
- m(this, "loaded", !1);
230
- this.tokensDir = e || "", this.manifestPath = w.join(this.tokensDir, "manifest.json");
229
+ w(this, "loaded", !1);
230
+ this.tokensDir = e || "", this.manifestPath = k.join(this.tokensDir, "manifest.json");
231
231
  }
232
232
  isLoaded() {
233
233
  return this.loaded && !!this.variables && !!this.styles;
234
234
  }
235
235
  /** to camelCase */
236
236
  normalizeKey(e) {
237
- const s = e.trim();
238
- return s && s.replace(/[-_\s]+/g, " ").split(" ").filter((r) => r.length).map((r, o) => {
237
+ const o = e.trim();
238
+ return o && o.replace(/[-_\s]+/g, " ").split(" ").filter((r) => r.length).map((r, s) => {
239
239
  const n = r.charAt(0), a = r.slice(1);
240
- return o === 0 ? r.toLowerCase() : n.toUpperCase() + a;
240
+ return s === 0 ? r.toLowerCase() : n.toUpperCase() + a;
241
241
  }).join("");
242
242
  }
243
243
  /**
@@ -245,10 +245,10 @@ class me {
245
245
  */
246
246
  parseVariableString(e) {
247
247
  if (typeof e != "string") return e;
248
- const s = /^\{(.+)\}$/, r = e.match(s);
248
+ const o = /^\{(.+)\}$/, r = e.match(o);
249
249
  if (r) {
250
- const o = r[1].trim();
251
- return `{${this.normalizeKey(o)}}`;
250
+ const s = r[1].trim();
251
+ return `{${this.normalizeKey(s)}}`;
252
252
  }
253
253
  return e;
254
254
  }
@@ -257,59 +257,59 @@ class me {
257
257
  */
258
258
  createVariableFileList(e) {
259
259
  return Object.entries(e).flatMap(
260
- ([s, r]) => Object.entries(r.modes).flatMap(
261
- ([o, n]) => n.map((a) => ({
260
+ ([o, r]) => Object.entries(r.modes).flatMap(
261
+ ([s, n]) => n.map((a) => ({
262
262
  fileName: a,
263
- modeName: this.normalizeKey(o.trim()),
264
- collectionName: s
263
+ modeName: this.normalizeKey(s.trim()),
264
+ collectionName: o
265
265
  }))
266
266
  )
267
267
  );
268
268
  }
269
269
  parseValue(e) {
270
- return e && (typeof e == "string" ? this.parseVariableString(e) : typeof e != "object" ? e : Array.isArray(e) ? e.map((s) => this.parseValue(s)) : Object.entries(e).reduce((s, [r, o]) => ({ ...s, [r]: this.parseValue(o) }), {}));
270
+ return e && (typeof e == "string" ? this.parseVariableString(e) : typeof e != "object" ? e : Array.isArray(e) ? e.map((o) => this.parseValue(o)) : Object.entries(e).reduce((o, [r, s]) => ({ ...o, [r]: this.parseValue(s) }), {}));
271
271
  }
272
- getTokensFromFile(e, s) {
273
- return Object.entries(e).reduce((r, [o, n]) => "$type" in n && "$value" in n ? {
272
+ getTokensFromFile(e, o) {
273
+ return Object.entries(e).reduce((r, [s, n]) => "$type" in n && "$value" in n ? {
274
274
  ...r,
275
- [this.normalizeKey(o)]: {
275
+ [this.normalizeKey(s)]: {
276
276
  type: n.$type,
277
277
  description: n.$description,
278
- value: s ? { [this.normalizeKey(s)]: this.parseValue(n.$value) } : this.parseValue(n.$value)
278
+ value: o ? { [this.normalizeKey(o)]: this.parseValue(n.$value) } : this.parseValue(n.$value)
279
279
  }
280
- } : { ...r, [this.normalizeKey(o)]: this.getTokensFromFile(n, s) }, {});
280
+ } : { ...r, [this.normalizeKey(s)]: this.getTokensFromFile(n, o) }, {});
281
281
  }
282
- processTokensFile(e, s, r) {
283
- const o = this.normalizeKey(r), n = this.getTokensFromFile(e, s);
284
- return { [o]: n };
282
+ processTokensFile(e, o, r) {
283
+ const s = this.normalizeKey(r), n = this.getTokensFromFile(e, o);
284
+ return { [s]: n };
285
285
  }
286
286
  /**
287
287
  * Loads all variable files in parallel and returns processed results
288
288
  */
289
289
  async loadVariableFiles(e) {
290
290
  return Promise.all(
291
- e.map(async ({ fileName: s, modeName: r, collectionName: o }) => {
291
+ e.map(async ({ fileName: o, modeName: r, collectionName: s }) => {
292
292
  try {
293
- const n = w.join(this.tokensDir, s), a = await d.readJson(n);
294
- return this.processTokensFile(a, r, o);
293
+ const n = k.join(this.tokensDir, o), a = await d.readJson(n);
294
+ return this.processTokensFile(a, r, s);
295
295
  } catch (n) {
296
- return console.warn(`Failed to load variable file: ${w.join(this.tokensDir, s)}`, n), {};
296
+ return console.warn(`Failed to load variable file: ${k.join(this.tokensDir, o)}`, n), {};
297
297
  }
298
298
  })
299
299
  );
300
300
  }
301
301
  mergeVariables(e) {
302
- return e.reduce((s, r) => Q(s, r), {});
302
+ return e.reduce((o, r) => H(o, r), {});
303
303
  }
304
304
  /**
305
305
  * Loads and processes all token variables from manifest collections
306
306
  */
307
307
  async loadTokenVariables(e) {
308
308
  try {
309
- const s = this.createVariableFileList(e), r = await this.loadVariableFiles(s);
309
+ const o = this.createVariableFileList(e), r = await this.loadVariableFiles(o);
310
310
  return this.mergeVariables(r);
311
- } catch (s) {
312
- throw new Error(`Failed to load token variables from ${this.tokensDir}: ${s}`);
311
+ } catch (o) {
312
+ throw new Error(`Failed to load token variables from ${this.tokensDir}: ${o}`);
313
313
  }
314
314
  }
315
315
  /**
@@ -317,9 +317,9 @@ class me {
317
317
  */
318
318
  createStyleFileList(e) {
319
319
  return Object.entries(e).flatMap(
320
- ([s, r]) => (r == null ? void 0 : r.map((o) => ({
321
- styleType: s,
322
- fileName: o
320
+ ([o, r]) => (r == null ? void 0 : r.map((s) => ({
321
+ styleType: o,
322
+ fileName: s
323
323
  }))) || []
324
324
  );
325
325
  }
@@ -328,18 +328,18 @@ class me {
328
328
  */
329
329
  async loadStyleFiles(e) {
330
330
  return (await Promise.all(
331
- e.map(async ({ styleType: r, fileName: o }) => {
331
+ e.map(async ({ styleType: r, fileName: s }) => {
332
332
  try {
333
- const n = w.join(this.tokensDir, o), a = await d.readJson(n);
333
+ const n = k.join(this.tokensDir, s), a = await d.readJson(n);
334
334
  return { styleType: r, styleTokens: a };
335
335
  } catch (n) {
336
- return console.warn(`Failed to load style file: ${w.join(this.tokensDir, o)}`, n), { styleType: r, styleTokens: {} };
336
+ return console.warn(`Failed to load style file: ${k.join(this.tokensDir, s)}`, n), { styleType: r, styleTokens: {} };
337
337
  }
338
338
  })
339
339
  )).reduce(
340
- (r, o) => ({ ...r, [o.styleType]: this.getTokensFromFile(o.styleTokens, "") }),
340
+ (r, s) => ({ ...r, [s.styleType]: this.getTokensFromFile(s.styleTokens, "") }),
341
341
  {
342
- ...K
342
+ ...R
343
343
  }
344
344
  );
345
345
  }
@@ -347,9 +347,9 @@ class me {
347
347
  * Loads and processes all style tokens from manifest
348
348
  */
349
349
  async loadStyles(e) {
350
- if (!e) return { ...K };
351
- const s = this.createStyleFileList(e);
352
- return await this.loadStyleFiles(s);
350
+ if (!e) return { ...R };
351
+ const o = this.createStyleFileList(e);
352
+ return await this.loadStyleFiles(o);
353
353
  }
354
354
  async load() {
355
355
  if (this.loaded) return;
@@ -398,9 +398,9 @@ class me {
398
398
  */
399
399
  resolveVariableValue(e) {
400
400
  if (typeof e == "object")
401
- return Object.keys(e).reduce((s, r) => {
402
- const o = e[r], n = this.resolveVariableValueString(o, r);
403
- return n && (s[r] = n), s;
401
+ return Object.keys(e).reduce((o, r) => {
402
+ const s = e[r], n = this.resolveVariableValueString(s, r);
403
+ return n && (o[r] = n), o;
404
404
  }, {});
405
405
  }
406
406
  /**
@@ -409,70 +409,70 @@ class me {
409
409
  * @param mode - Mode name to get value for (optional)
410
410
  * @returns resolved token variable or undefined if not found or invalid
411
411
  */
412
- resolveVariableValueString(e, s) {
412
+ resolveVariableValueString(e, o) {
413
413
  if (!this.isVariableReference(e)) return e;
414
- const r = this.getVariablePath(e), o = this.getToken(r, s);
415
- if (o)
416
- return this.resolveVariableValueString(o, s);
414
+ const r = this.getVariablePath(e), s = this.getToken(r, o);
415
+ if (s)
416
+ return this.resolveVariableValueString(s, o);
417
417
  }
418
418
  /**
419
419
  * Gets a nested token value by path, similar to lodash.get
420
420
  * @param variablePath - Dot-separated string path or array of path segments
421
421
  * @param mode - Mode name to get value for (optional)
422
422
  */
423
- getToken(e, s) {
423
+ getToken(e, o) {
424
424
  if (!this.loaded || !this.variables)
425
425
  throw new Error("Tokens not loaded. Call load() first.");
426
426
  for (const r of Object.values(this.variables)) {
427
- const o = H(r, e);
428
- if (o != null && o.value && typeof o.value == "object") {
429
- if (s) return o.value[s];
427
+ const s = q(r, e);
428
+ if (s != null && s.value && typeof s.value == "object") {
429
+ if (o) return s.value[o];
430
430
  {
431
- const n = Object.keys(o.value)[0];
432
- return o.value[n];
431
+ const n = Object.keys(s.value)[0];
432
+ return s.value[n];
433
433
  }
434
434
  }
435
435
  }
436
436
  }
437
437
  }
438
- const Lt = async () => {
439
- const e = await new j().load();
438
+ const Wt = async () => {
439
+ const e = await new v().load();
440
440
  if (!e)
441
441
  throw new Error(
442
442
  'Failed to load gts.config.ts. Run "npx gts-init" to create it, or ensure the file exists and default-exports a valid configuration.'
443
443
  );
444
- const { figmaToken: s, fileId: r, modules: o, manifest: n } = e, a = new P(s, r), i = new me(n);
445
- n && d.exists(n) && await i.load(), await Promise.all(o.map((l) => l.executor({ figmaApiClient: a, tokenManagerClient: i })));
446
- }, Wt = async () => {
447
- await j.create(), console.log("\x1B[32m%s\x1B[0m", "✔️ Configuration file created gts.config.ts");
448
- }, ke = ["xxxl", "xxl", "xl", "lg", "md", "sm", "xs", "xxs", "xxxs"], we = (t) => parseInt(t.value, 10), $e = (t) => t.reduce(
449
- (e, s) => ({
444
+ const { figmaToken: o, fileId: r, modules: s, manifest: n } = e, a = new P(o, r), i = new we(n);
445
+ n && d.exists(n) && await i.load(), await Promise.all(s.map((l) => l.executor({ figmaApiClient: a, tokenManagerClient: i })));
446
+ }, zt = async () => {
447
+ await v.create(), console.log("\x1B[32m%s\x1B[0m", "✔️ Configuration file created gts.config.ts");
448
+ }, ke = ["xxxl", "xxl", "xl", "lg", "md", "sm", "xs", "xxs", "xxxs"], $e = (t) => parseInt(t.value, 10), Se = (t) => t.reduce(
449
+ (e, o) => ({
450
450
  ...e,
451
- [s.name]: we(s)
451
+ [o.name]: $e(o)
452
452
  }),
453
453
  {}
454
454
  ), Te = async (t, e) => {
455
455
  await d.delete(t, e);
456
- }, Se = async (t, e, s) => {
457
- await d.write(t, e, { directory: s });
458
- }, F = async (t, e, s) => {
459
- await Te(t, s), await Se(t, e, s);
460
- }, je = (t) => {
461
- const e = t.map(({ name: s, value: r }) => ` --${s}: ${r};`);
456
+ }, je = async (t, e, o) => {
457
+ await d.write(t, e, { directory: o });
458
+ }, F = async (t, e, o) => {
459
+ await Te(t, o), await je(t, e, o);
460
+ }, ve = (t) => {
461
+ const e = t.map(({ name: o, value: r }) => ` --${o}: ${r};`);
462
462
  return e.length ? `.breakpoint-variables {
463
463
  ${e.join(`
464
464
  `)}
465
465
  }
466
466
  ` : "";
467
- }, ve = (t) => {
467
+ }, Me = (t) => {
468
468
  var r;
469
- const e = t.map(({ name: o, value: n }) => ` ${o}: ${n}`), s = (r = t.at(-1)) == null ? void 0 : r.name;
470
- return !e.length || !s ? "" : `$breakpointList: (
469
+ const e = t.map(({ name: s, value: n }) => ` ${s}: ${n}`), o = (r = t.at(-1)) == null ? void 0 : r.name;
470
+ return !e.length || !o ? "" : `$breakpointList: (
471
471
  ${e.join(`,
472
472
  `)}
473
473
  );
474
474
 
475
- $defaultBreakpoint: '${s}';
475
+ $defaultBreakpoint: '${o}';
476
476
  `;
477
477
  }, Ce = (t) => [
478
478
  `const breakpoints = ${JSON.stringify(t, null, 4)} as const;`,
@@ -486,155 +486,155 @@ $defaultBreakpoint: '${s}';
486
486
  "export type { BreakpointsKeysType, AllowMedia };",
487
487
  ""
488
488
  ].join(`
489
- `), Me = async ({ breakpointTokens: t, dir: e }) => {
490
- const s = $e(t), r = je(t), o = ve(t), n = Ce(s);
489
+ `), Ne = async ({ breakpointTokens: t, dir: e }) => {
490
+ const o = Se(t), r = ve(t), s = Me(t), n = Ce(o);
491
491
  await Promise.all([
492
492
  F("styles.css", r, e),
493
- F("styles.scss", o, e),
493
+ F("styles.scss", s, e),
494
494
  F("index.ts", n, e)
495
495
  ]);
496
496
  }, Ve = (t, e) => {
497
- const s = Object.keys(t).filter((n) => !isNaN(Number(n))).sort((n, a) => Number(n) - Number(a));
498
- if (s.length > e.length)
497
+ const o = Object.keys(t).filter((n) => !isNaN(Number(n))).sort((n, a) => Number(n) - Number(a));
498
+ if (o.length > e.length)
499
499
  throw new Error(
500
- `Not enough breakpoint names provided. Found ${s.length} breakpoints in data, but only ${e.length} names specified: ${e.join(", ")}`
500
+ `Not enough breakpoint names provided. Found ${o.length} breakpoints in data, but only ${e.length} names specified: ${e.join(", ")}`
501
501
  );
502
- const o = Object.keys(t).filter((n) => isNaN(Number(n)));
503
- if (o.length > 0)
502
+ const s = Object.keys(t).filter((n) => isNaN(Number(n)));
503
+ if (s.length > 0)
504
504
  throw new Error(
505
- `Found non-numeric breakpoint keys in grid data: ${o.join(", ")}. All breakpoint keys must be numeric values.`
505
+ `Found non-numeric breakpoint keys in grid data: ${s.join(", ")}. All breakpoint keys must be numeric values.`
506
506
  );
507
- return s.map((n, a) => ({
507
+ return o.map((n, a) => ({
508
508
  name: e[e.length - 1 - a] || `bp-${n}`,
509
509
  value: n
510
510
  }));
511
- }, zt = ({
511
+ }, It = ({
512
512
  input: t = {},
513
513
  output: { dir: e }
514
514
  }) => ({
515
515
  name: "breakpoints/tokenManager",
516
- executor: async ({ tokenManagerClient: s }) => {
516
+ executor: async ({ tokenManagerClient: o }) => {
517
517
  try {
518
518
  console.log("[breakpoints/tokenManager] Generating breakpoints from TokenManager...");
519
519
  const { names: r = ke } = t;
520
- if (!s.isLoaded())
520
+ if (!o.isLoaded())
521
521
  throw new Error("TokenManager is not loaded. Tokens must be loaded before using this module.");
522
- const o = s.getStyles();
523
- if (!o.grid)
522
+ const s = o.getStyles();
523
+ if (!s.grid)
524
524
  throw new Error("No grid styles found in TokenManager. Grid tokens must be loaded.");
525
525
  console.log("[breakpoints/tokenManager] Extracting breakpoints from grid styles...");
526
- const n = Ve(o.grid, r);
526
+ const n = Ve(s.grid, r);
527
527
  if (!n.length) {
528
528
  console.warn("[breakpoints/tokenManager] No breakpoints found in grid styles.");
529
529
  return;
530
530
  }
531
531
  console.log(
532
532
  `[breakpoints/tokenManager] Found ${n.length} breakpoints: ${n.map((a) => a.name).join(", ")}`
533
- ), console.log(`[breakpoints/tokenManager] Writing files to ${e}...`), await Me({
533
+ ), console.log(`[breakpoints/tokenManager] Writing files to ${e}...`), await Ne({
534
534
  breakpointTokens: n,
535
535
  dir: e
536
536
  }), console.log("[breakpoints/tokenManager] ✅ Successfully generated breakpoint files");
537
537
  } catch (r) {
538
- const o = r instanceof Error ? r.message : String(r);
539
- throw console.error("[breakpoints/tokenManager] ❌ Failed to generate breakpoints:", o), r instanceof Error && r.stack && console.error("[breakpoints/tokenManager] Stack trace:", r.stack), r;
538
+ const s = r instanceof Error ? r.message : String(r);
539
+ throw console.error("[breakpoints/tokenManager] ❌ Failed to generate breakpoints:", s), r instanceof Error && r.stack && console.error("[breakpoints/tokenManager] Stack trace:", r.stack), r;
540
540
  }
541
541
  }
542
- }), Ne = "styles.css", Fe = "index.ts", A = (t, e) => {
542
+ }), Fe = "styles.css", xe = "index.ts", A = (t, e) => {
543
543
  if (!e.length) return "";
544
- const s = e.map((r) => ` ${r}`).join(`
544
+ const o = e.map((r) => ` ${r}`).join(`
545
545
  `);
546
546
  return `${t} {
547
- ${s}
547
+ ${o}
548
548
  }`;
549
- }, xe = (t) => `.${t.replace(/\s+/g, "-").toLowerCase()}`, Z = (t) => `--cl-${t}`, Oe = (t) => t.reduce(
550
- (e, s) => {
551
- const r = Z(s.name);
552
- return typeof s.value == "object" ? Object.entries(s.value).forEach(([o, n]) => {
553
- e[o] || (e[o] = []), e[o].push(`${r}: ${n};`);
554
- }) : e.root.push(`${r}: ${s.value};`), e;
549
+ }, Oe = (t) => `.${t.replace(/\s+/g, "-").toLowerCase()}`, Q = (t) => `--cl-${t}`, Pe = (t) => t.reduce(
550
+ (e, o) => {
551
+ const r = Q(o.name);
552
+ return typeof o.value == "object" ? Object.entries(o.value).forEach(([s, n]) => {
553
+ e[s] || (e[s] = []), e[s].push(`${r}: ${n};`);
554
+ }) : e.root.push(`${r}: ${o.value};`), e;
555
555
  },
556
556
  { root: [] }
557
- ), Pe = (t) => {
558
- const e = A(".color-variables", t.root), s = Object.entries(t).reduce((r, [o, n]) => {
559
- if (o === "root" || !n.length) return r;
560
- const a = A(xe(`${o}-color-variables`), n);
557
+ ), Ee = (t) => {
558
+ const e = A(".color-variables", t.root), o = Object.entries(t).reduce((r, [s, n]) => {
559
+ if (s === "root" || !n.length) return r;
560
+ const a = A(Oe(`${s}-color-variables`), n);
561
561
  return a && r.push(a), r;
562
562
  }, []).join(`
563
563
 
564
564
  `);
565
- return [e, s].filter(Boolean).join(`
565
+ return [e, o].filter(Boolean).join(`
566
566
 
567
567
  `);
568
- }, Ee = (t) => `${`const colors = {
569
- ${t.map((r) => ` '${r.name}': 'var(${Z(r.name)})'`).join(`,
568
+ }, Be = (t) => `${`const colors = {
569
+ ${t.map((r) => ` '${r.name}': 'var(${Q(r.name)})'`).join(`,
570
570
  `)}
571
571
  } as const;`}
572
572
 
573
573
  type ColorsKeysType = keyof typeof colors;
574
574
 
575
575
  export { colors, type ColorsKeysType };
576
- `, Be = async ({
576
+ `, Re = async ({
577
577
  tsContent: t,
578
578
  cssContent: e,
579
- dir: s
579
+ dir: o
580
580
  }) => {
581
- await d.delete(s);
582
- const r = d.write(Fe, t, { directory: s }), o = d.write(Ne, e, { directory: s });
583
- await Promise.all([r, o]);
584
- }, Re = async ({ colorTokens: t, dir: e }) => {
585
- const s = Oe(t), r = Pe(s), o = Ee(t);
586
- await Be({ tsContent: o, cssContent: r, dir: e });
587
- }, v = (t) => t.reduce((e, s) => {
588
- const r = Number((s.position * 100).toFixed(1));
589
- return [...e, `${s.color}${r > 0 && r < 100 ? ` ${r}%` : ""}`];
581
+ await d.delete(o);
582
+ const r = d.write(xe, t, { directory: o }), s = d.write(Fe, e, { directory: o });
583
+ await Promise.all([r, s]);
584
+ }, Ae = async ({ colorTokens: t, dir: e }) => {
585
+ const o = Pe(t), r = Ee(o), s = Be(t);
586
+ await Re({ tsContent: s, cssContent: r, dir: e });
587
+ }, M = (t) => t.reduce((e, o) => {
588
+ const r = Number((o.position * 100).toFixed(1));
589
+ return [...e, `${o.color}${r > 0 && r < 100 ? ` ${r}%` : ""}`];
590
590
  }, []).join(", "), Ke = (t) => {
591
- const e = v(t.stops);
591
+ const e = M(t.stops);
592
592
  return `linear-gradient(${t.angle}deg, ${e})`;
593
- }, Ae = (t) => `radial-gradient(circle, ${v(t.stops)})`, Ue = (t) => {
594
- const e = v(t.stops);
593
+ }, De = (t) => `radial-gradient(circle, ${M(t.stops)})`, Le = (t) => {
594
+ const e = M(t.stops);
595
595
  return `conic-gradient(from ${t.angle}deg, ${e})`;
596
- }, De = (t) => {
597
- const e = v(t.stops);
596
+ }, Ue = (t) => {
597
+ const e = M(t.stops);
598
598
  return `linear-gradient(${t.angle}deg, ${e})`;
599
- }, U = (t) => typeof t == "string" ? t : t.type === "linear" ? Ke(t) : t.type === "radial" ? Ae(t) : t.type === "conic" ? Ue(t) : t.type === "diamond" ? De(t) : "", X = (t, e) => Object.keys(t).reduce(
600
- (s, r) => {
601
- const o = t[r], n = e ? `${e}-${r}` : r;
602
- if (o && typeof o == "object" && "type" in o && "value" in o) {
603
- const i = Object.keys(o.value), l = i.length > 1 ? o.value : o.value[i[0]], c = typeof l == "object" ? Object.keys(l).reduce(
604
- (y, g) => ({
605
- ...y,
606
- [g]: U(l[g])
599
+ }, K = (t) => typeof t == "string" ? t : t.type === "linear" ? Ke(t) : t.type === "radial" ? De(t) : t.type === "conic" ? Le(t) : t.type === "diamond" ? Ue(t) : "", Z = (t, e) => Object.keys(t).reduce(
600
+ (o, r) => {
601
+ const s = t[r], n = e ? `${e}-${r}` : r;
602
+ if (s && typeof s == "object" && "type" in s && "value" in s) {
603
+ const i = Object.keys(s.value), l = i.length > 1 ? s.value : s.value[i[0]], c = typeof l == "object" ? Object.keys(l).reduce(
604
+ (f, y) => ({
605
+ ...f,
606
+ [y]: K(l[y])
607
607
  }),
608
608
  {}
609
- ) : U(l), u = { [n]: c };
610
- return { ...s, ...u };
609
+ ) : K(l), u = { [n]: c };
610
+ return { ...o, ...u };
611
611
  }
612
- const a = X(o, n);
613
- return { ...s, ...a };
612
+ const a = Z(s, n);
613
+ return { ...o, ...a };
614
614
  },
615
615
  {}
616
- ), Y = (t, e) => Object.keys(t).reduce((s, r) => {
617
- const o = t[r];
618
- if (o.type && o.type !== "color") return s;
619
- if (o.type && o.value) {
620
- const a = typeof o.value == "string" ? e.resolveVariableValueString(o.value, r) : e.resolveVariableValue(o.value);
621
- return a ? { ...s, [r]: { ...o, value: a } } : s;
616
+ ), X = (t, e) => Object.keys(t).reduce((o, r) => {
617
+ const s = t[r];
618
+ if (s.type && s.type !== "color") return o;
619
+ if (s.type && s.value) {
620
+ const a = typeof s.value == "string" ? e.resolveVariableValueString(s.value, r) : e.resolveVariableValue(s.value);
621
+ return a ? { ...o, [r]: { ...s, value: a } } : o;
622
622
  }
623
- const n = Y(o, e);
624
- return n ? { ...s, [r]: n } : s;
625
- }, {}), It = ({ input: t = {}, output: { dir: e } }) => ({
623
+ const n = X(s, e);
624
+ return n ? { ...o, [r]: n } : o;
625
+ }, {}), Gt = ({ input: t = {}, output: { dir: e } }) => ({
626
626
  name: "colors/tokenManager",
627
- executor: async ({ tokenManagerClient: s }) => {
627
+ executor: async ({ tokenManagerClient: o }) => {
628
628
  try {
629
629
  console.log("[colors/tokenManager] Generating colors from TokenManager...");
630
- const { includeVariables: r, includeStyles: o = !0 } = t;
631
- if (!(r != null && r.length) && !o)
630
+ const { includeVariables: r, includeStyles: s = !0 } = t;
631
+ if (!(r != null && r.length) && !s)
632
632
  throw new Error("Either includeVariables or includeStyles must be enabled");
633
- if (!s.isLoaded())
633
+ if (!o.isLoaded())
634
634
  throw new Error("TokenManager is not loaded. Tokens must be loaded before using this module.");
635
- const n = [], a = s.getVariables();
636
- if (o) {
637
- const l = s.getStyles();
635
+ const n = [], a = o.getVariables();
636
+ if (s) {
637
+ const l = o.getStyles();
638
638
  console.log("[colors/tokenManager] Processing styles for colors..."), l.color && n.push(l.color);
639
639
  }
640
640
  if (r != null && r.length) {
@@ -642,9 +642,9 @@ export { colors, type ColorsKeysType };
642
642
  const l = r.map((c) => a[c]).filter(Boolean);
643
643
  n.push(...l);
644
644
  }
645
- const i = n.map((l) => Y(l, s)).flatMap(
646
- (l) => Object.entries(X(l, "")).reduce(
647
- (c, [u, y]) => [...c, { name: u, value: y }],
645
+ const i = n.map((l) => X(l, o)).flatMap(
646
+ (l) => Object.entries(Z(l, "")).reduce(
647
+ (c, [u, f]) => [...c, { name: u, value: f }],
648
648
  []
649
649
  )
650
650
  );
@@ -652,16 +652,16 @@ export { colors, type ColorsKeysType };
652
652
  console.warn("[colors/tokenManager] No color tokens generated");
653
653
  return;
654
654
  }
655
- console.log(`[colors/tokenManager] Generated ${i.length} color tokens`), console.log(`[colors/tokenManager] Writing files to ${e}...`), await Re({
655
+ console.log(`[colors/tokenManager] Generated ${i.length} color tokens`), console.log(`[colors/tokenManager] Writing files to ${e}...`), await Ae({
656
656
  colorTokens: i,
657
657
  dir: e
658
658
  }), console.log("[colors/tokenManager] ✅ Successfully generated color files");
659
659
  } catch (r) {
660
- const o = r instanceof Error ? r.message : String(r);
661
- throw console.error("[colors/tokenManager] ❌ Failed to generate colors:", o), r instanceof Error && r.stack && console.error("[colors/tokenManager] Stack trace:", r.stack), r;
660
+ const s = r instanceof Error ? r.message : String(r);
661
+ throw console.error("[colors/tokenManager] ❌ Failed to generate colors:", s), r instanceof Error && r.stack && console.error("[colors/tokenManager] Stack trace:", r.stack), r;
662
662
  }
663
663
  }
664
- }), Le = (t) => ` @media (width <= ${t.breakpoint}px) {
664
+ }), We = (t) => ` @media (width <= ${t.breakpoint}px) {
665
665
  .container {
666
666
  padding-left: ${t.offset};
667
667
  padding-right: ${t.offset};
@@ -671,26 +671,26 @@ export { colors, type ColorsKeysType };
671
671
  padding-left: ${t.offset};
672
672
  padding-right: ${t.offset};
673
673
  }
674
- }`, We = (t, e) => {
675
- const s = e || "components", r = t.map((o) => Le(o)).join(`
674
+ }`, ze = (t, e) => {
675
+ const o = e || "components", r = t.map((s) => We(s)).join(`
676
676
 
677
677
  `);
678
- return `@layer ${s} {
678
+ return `@layer ${o} {
679
679
  ${r}
680
680
  }`;
681
- }, ze = () => `import styles from './styles.module.css';
681
+ }, Ie = () => `import styles from './styles.module.css';
682
682
 
683
683
  export const conatinerClassName = styles.container;
684
684
  export const conatinerTabletClassName = styles.containerTablet;
685
- `, D = async (t, e, s) => {
686
- await d.delete(t, s), await d.write(t, e, { directory: s });
687
- }, Ie = async ({ containerTokens: t, dir: e, layer: s }) => {
688
- const r = We(t, s), o = ze();
689
- await D("styles.module.css", r, e), await D("index.ts", o, e);
690
- }, Ge = (t) => {
685
+ `, D = async (t, e, o) => {
686
+ await d.delete(t, o), await d.write(t, e, { directory: o });
687
+ }, Ge = async ({ containerTokens: t, dir: e, layer: o }) => {
688
+ const r = ze(t, o), s = Ie();
689
+ await D("styles.module.css", r, e), await D("index.ts", s, e);
690
+ }, Je = (t) => {
691
691
  const e = t.trim().toLowerCase();
692
692
  return e === "0" || e === "0px";
693
- }, Je = (t, e) => Object.keys(t).filter((n) => !isNaN(Number(n))).sort((n, a) => Number(a) - Number(n)).reduce((n, a) => {
693
+ }, qe = (t, e) => Object.keys(t).filter((n) => !isNaN(Number(n))).sort((n, a) => Number(a) - Number(n)).reduce((n, a) => {
694
694
  const i = t[a];
695
695
  if (!i || !("value" in i) || !Array.isArray(i.value))
696
696
  return n;
@@ -698,7 +698,7 @@ export const conatinerTabletClassName = styles.containerTablet;
698
698
  if (!(l != null && l.offset))
699
699
  return n;
700
700
  const c = e.resolveVariableValueString(l.offset);
701
- return !c || typeof c != "string" || Ge(c) ? n : [
701
+ return !c || typeof c != "string" || Je(c) ? n : [
702
702
  ...n,
703
703
  {
704
704
  breakpoint: Number(a),
@@ -708,114 +708,114 @@ export const conatinerTabletClassName = styles.containerTablet;
708
708
  }, []).reduce((n, a) => {
709
709
  const i = n[n.length - 1];
710
710
  return i && x(i.offset, a.offset) || n.push(a), n;
711
- }, []), Gt = ({
711
+ }, []), Jt = ({
712
712
  input: t = {},
713
713
  output: { dir: e }
714
714
  }) => ({
715
715
  name: "container/tokenManager",
716
- executor: async ({ tokenManagerClient: s }) => {
716
+ executor: async ({ tokenManagerClient: o }) => {
717
717
  try {
718
718
  console.log("[container/tokenManager] Generating container styles...");
719
719
  const { layer: r } = t;
720
- if (!s.isLoaded())
720
+ if (!o.isLoaded())
721
721
  throw new Error("TokenManager is not loaded. Tokens must be loaded before using this module.");
722
722
  console.log("[container/tokenManager] Extracting container tokens...");
723
- const o = s.getStyles();
724
- if (!o.grid)
723
+ const s = o.getStyles();
724
+ if (!s.grid)
725
725
  throw new Error("No grid styles found in TokenManager. Grid tokens must be loaded.");
726
- const n = Je(o.grid, s);
726
+ const n = qe(s.grid, o);
727
727
  if (!n.length) {
728
728
  console.warn("[container/tokenManager] No container tokens found.");
729
729
  return;
730
730
  }
731
731
  console.log(
732
732
  `[container/tokenManager] Found ${n.length} container tokens: ${n.map((a) => a.breakpoint).join(", ")}`
733
- ), console.log(`[container/tokenManager] Writing files to ${e}...`), await Ie({
733
+ ), console.log(`[container/tokenManager] Writing files to ${e}...`), await Ge({
734
734
  containerTokens: n,
735
735
  dir: e,
736
736
  layer: r
737
737
  }), console.log("[container/tokenManager] ✅ Successfully generated container files");
738
738
  } catch (r) {
739
- const o = r instanceof Error ? r.message : String(r);
740
- throw console.error("[container/tokenManager] ❌ Failed to generate container:", o), r instanceof Error && r.stack && console.error("[container/tokenManager] Stack trace:", r.stack), r;
739
+ const s = r instanceof Error ? r.message : String(r);
740
+ throw console.error("[container/tokenManager] ❌ Failed to generate container:", s), r instanceof Error && r.stack && console.error("[container/tokenManager] Stack trace:", r.stack), r;
741
741
  }
742
742
  }
743
- }), qe = "styles.css", He = "index.ts", L = (t, e) => {
743
+ }), He = "styles.css", Qe = "index.ts", L = (t, e) => {
744
744
  if (!e.length) return "";
745
- const s = e.map((r) => ` ${r}`).join(`
745
+ const o = e.map((r) => ` ${r}`).join(`
746
746
  `);
747
747
  return `${t} {
748
- ${s}
748
+ ${o}
749
749
  }`;
750
- }, Qe = (t) => `.${t.replace(/\s+/g, "-").toLowerCase()}`, _ = (t) => `--${t}`, Ze = ({ offsetX: t, offsetY: e, blur: s, spread: r, color: o }) => `${t} ${e} ${s} ${r} ${o}`, Xe = (t) => t.reduce(
751
- (e, s) => {
752
- const r = _(s.name);
753
- return typeof s.value != "object" ? (e.root.push(`${r}: ${s.value};`), e) : Object.entries(s.value).reduce((o, [n, a]) => {
754
- const i = o[n] ?? [];
755
- return { ...o, [n]: [...i, `${r}: ${a};`] };
750
+ }, Ze = (t) => `.${t.replace(/\s+/g, "-").toLowerCase()}`, Y = (t) => `--${t}`, Xe = ({ offsetX: t, offsetY: e, blur: o, spread: r, color: s }) => `${t} ${e} ${o} ${r} ${s}`, Ye = (t) => t.reduce(
751
+ (e, o) => {
752
+ const r = Y(o.name);
753
+ return typeof o.value != "object" ? (e.root.push(`${r}: ${o.value};`), e) : Object.entries(o.value).reduce((s, [n, a]) => {
754
+ const i = s[n] ?? [];
755
+ return { ...s, [n]: [...i, `${r}: ${a};`] };
756
756
  }, e);
757
757
  },
758
758
  { root: [] }
759
- ), Ye = (t) => {
760
- const e = L(".shadow-variables", t.root), s = Object.entries(t).reduce((r, [o, n]) => {
761
- if (o === "root" || !n.length) return r;
762
- const a = L(Qe(`${o}-shadow-variables`), n);
759
+ ), _e = (t) => {
760
+ const e = L(".shadow-variables", t.root), o = Object.entries(t).reduce((r, [s, n]) => {
761
+ if (s === "root" || !n.length) return r;
762
+ const a = L(Ze(`${s}-shadow-variables`), n);
763
763
  return a && r.push(a), r;
764
764
  }, []).join(`
765
765
 
766
766
  `);
767
- return [e, s].filter(Boolean).join(`
767
+ return [e, o].filter(Boolean).join(`
768
768
 
769
769
  `);
770
- }, _e = (t) => `${`const shadows = {
771
- ${t.map((r) => ` '${r.name}': 'var(${_(r.name)})'`).join(`,
770
+ }, et = (t) => `${`const shadows = {
771
+ ${t.map((r) => ` '${r.name}': 'var(${Y(r.name)})'`).join(`,
772
772
  `)}
773
773
  } as const;`}
774
774
 
775
775
  type ShadowsKeysType = keyof typeof shadows;
776
776
 
777
777
  export { shadows, type ShadowsKeysType };
778
- `, et = async ({
778
+ `, tt = async ({
779
779
  tsContent: t,
780
780
  cssContent: e,
781
- dir: s
781
+ dir: o
782
782
  }) => {
783
- await d.delete(s);
784
- const r = d.write(He, t, { directory: s }), o = d.write(qe, e, { directory: s });
785
- await Promise.all([r, o]);
786
- }, tt = async ({ shadowTokens: t, dir: e }) => {
787
- const s = Xe(t), r = Ye(s), o = _e(t);
788
- await et({ tsContent: o, cssContent: r, dir: e });
789
- }, ee = (t, e) => Object.keys(t).reduce(
790
- (s, r) => {
791
- const o = t[r], n = e ? `${e}-${r}` : r;
792
- if (o && typeof o == "object" && "type" in o && "value" in o) {
783
+ await d.delete(o);
784
+ const r = d.write(Qe, t, { directory: o }), s = d.write(He, e, { directory: o });
785
+ await Promise.all([r, s]);
786
+ }, rt = async ({ shadowTokens: t, dir: e }) => {
787
+ const o = Ye(t), r = _e(o), s = et(t);
788
+ await tt({ tsContent: s, cssContent: r, dir: e });
789
+ }, _ = (t, e) => Object.keys(t).reduce(
790
+ (o, r) => {
791
+ const s = t[r], n = e ? `${e}-${r}` : r;
792
+ if (s && typeof s == "object" && "type" in s && "value" in s) {
793
793
  const i = {
794
- [n]: o.value.map(Ze).join(", ")
794
+ [n]: s.value.map(Xe).join(", ")
795
795
  };
796
- return { ...s, ...i };
796
+ return { ...o, ...i };
797
797
  }
798
- const a = ee(o, n);
799
- return { ...s, ...a };
798
+ const a = _(s, n);
799
+ return { ...o, ...a };
800
800
  },
801
801
  {}
802
- ), Jt = ({ input: t = {}, output: { dir: e } }) => ({
802
+ ), qt = ({ input: t = {}, output: { dir: e } }) => ({
803
803
  name: "shadows/tokenManager",
804
- executor: async ({ tokenManagerClient: s }) => {
804
+ executor: async ({ tokenManagerClient: o }) => {
805
805
  try {
806
806
  console.log("[shadows/tokenManager] Generating shadows from TokenManager...");
807
807
  const { includeStyles: r = !0 } = t;
808
808
  if (!r)
809
809
  throw new Error("includeStyles must be enabled for shadows generation");
810
- if (!s.isLoaded())
810
+ if (!o.isLoaded())
811
811
  throw new Error("TokenManager is not loaded. Tokens must be loaded before using this module.");
812
- const o = [];
812
+ const s = [];
813
813
  if (r) {
814
- const a = s.getStyles();
815
- console.log("[shadows/tokenManager] Processing styles for shadows..."), a.effect && o.push(a.effect);
814
+ const a = o.getStyles();
815
+ console.log("[shadows/tokenManager] Processing styles for shadows..."), a.effect && s.push(a.effect);
816
816
  }
817
- const n = o.flatMap(
818
- (a) => Object.entries(ee(a, "")).reduce(
817
+ const n = s.flatMap(
818
+ (a) => Object.entries(_(a, "")).reduce(
819
819
  (i, [l, c]) => [...i, { name: l, value: c }],
820
820
  []
821
821
  )
@@ -824,45 +824,45 @@ export { shadows, type ShadowsKeysType };
824
824
  console.warn("[shadows/tokenManager] No shadow tokens generated");
825
825
  return;
826
826
  }
827
- console.log(`[shadows/tokenManager] Generated ${n.length} shadow tokens`), console.log(`[shadows/tokenManager] Writing files to ${e}...`), await tt({
827
+ console.log(`[shadows/tokenManager] Generated ${n.length} shadow tokens`), console.log(`[shadows/tokenManager] Writing files to ${e}...`), await rt({
828
828
  shadowTokens: n,
829
829
  dir: e
830
830
  }), console.log("[shadows/tokenManager] ✅ Successfully generated shadow files");
831
831
  } catch (r) {
832
- const o = r instanceof Error ? r.message : String(r);
833
- throw console.error("[shadows/tokenManager] ❌ Failed to generate shadows:", o), r instanceof Error && r.stack && console.error("[shadows/tokenManager] Stack trace:", r.stack), r;
832
+ const s = r instanceof Error ? r.message : String(r);
833
+ throw console.error("[shadows/tokenManager] ❌ Failed to generate shadows:", s), r instanceof Error && r.stack && console.error("[shadows/tokenManager] Stack trace:", r.stack), r;
834
834
  }
835
835
  }
836
- }), rt = "styles.module.css", st = "index.ts", ot = "typography.ts", W = "sans-serif", z = (t, e) => {
836
+ }), ot = "styles.module.css", st = "index.ts", nt = "typography.ts", U = "sans-serif", W = (t, e) => {
837
837
  if (!e.length) return "";
838
- const s = e.map((r) => ` ${r}`).join(`
838
+ const o = e.map((r) => ` ${r}`).join(`
839
839
  `);
840
840
  return `${t} {
841
- ${s}
841
+ ${o}
842
842
  }`;
843
- }, te = (t, e) => {
843
+ }, ee = (t, e) => {
844
844
  if (typeof t != "string") return t;
845
- const s = e[t] ?? t;
846
- return s.trim().toLowerCase().endsWith(W) ? s : `${s}, ${W}`;
847
- }, I = (t, e) => typeof t.fontFamily != "string" ? t : {
845
+ const o = e[t] ?? t;
846
+ return o.trim().toLowerCase().endsWith(U) ? o : `${o}, ${U}`;
847
+ }, z = (t, e) => typeof t.fontFamily != "string" ? t : {
848
848
  ...t,
849
- fontFamily: te(t.fontFamily, e)
849
+ fontFamily: ee(t.fontFamily, e)
850
850
  }, T = (t, e) => {
851
- const s = {};
852
- return Object.entries(t).forEach(([r, o]) => {
853
- const n = r === "fontFamily" ? te(o, e) : o, a = r.replace(/([A-Z])/g, "-$1").toLowerCase();
854
- s[a] = n;
855
- }), s;
856
- }, nt = (t, e, s) => {
857
- const r = Object.keys(t.breakpoints), o = T(t.base, s);
851
+ const o = {};
852
+ return Object.entries(t).forEach(([r, s]) => {
853
+ const n = r === "fontFamily" ? ee(s, e) : s, a = r.replace(/([A-Z])/g, "-$1").toLowerCase();
854
+ o[a] = n;
855
+ }), o;
856
+ }, at = (t, e, o) => {
857
+ const r = Object.keys(t.breakpoints), s = T(t.base, o);
858
858
  return r.reduce(
859
859
  (n, a, i) => {
860
- const l = T(t.breakpoints[a], s);
860
+ const l = T(t.breakpoints[a], o);
861
861
  return i ? [...n, { breakpoint: Number(e[a]), css: l }] : [
862
862
  {
863
863
  breakpoint: null,
864
864
  css: {
865
- ...o,
865
+ ...s,
866
866
  ...l
867
867
  }
868
868
  }
@@ -871,93 +871,93 @@ ${s}
871
871
  [
872
872
  {
873
873
  breakpoint: null,
874
- css: o
874
+ css: s
875
875
  }
876
876
  ]
877
877
  );
878
- }, re = () => ({
878
+ }, te = () => ({
879
879
  base: {},
880
880
  breakpoints: {}
881
- }), O = (t, e, s, r) => {
882
- Object.keys(r).length && (t.breakpoints[e] || (t.breakpoints[e] = {}), t.breakpoints[e][s] = {
883
- ...t.breakpoints[e][s],
881
+ }), O = (t, e, o, r) => {
882
+ Object.keys(r).length && (t.breakpoints[e] || (t.breakpoints[e] = {}), t.breakpoints[e][o] = {
883
+ ...t.breakpoints[e][o],
884
884
  ...r
885
885
  });
886
- }, S = (t, e, s, r) => {
887
- nt(e.value, s, r).forEach(({ breakpoint: n, css: a }) => {
886
+ }, j = (t, e, o, r) => {
887
+ at(e.value, o, r).forEach(({ breakpoint: n, css: a }) => {
888
888
  if (n === null) {
889
889
  t.base[e.name] = a;
890
890
  return;
891
891
  }
892
892
  O(t, n, e.name, a);
893
893
  });
894
- }, se = (t) => {
895
- const e = G(t.base), s = Object.keys(t.breakpoints).map(Number).sort((r, o) => o - r).reduce((r, o) => {
896
- const n = t.breakpoints[o];
897
- return r + `@media (max-width: ${o}px) { ${G(n)} }`;
894
+ }, re = (t) => {
895
+ const e = I(t.base), o = Object.keys(t.breakpoints).map(Number).sort((r, s) => s - r).reduce((r, s) => {
896
+ const n = t.breakpoints[s];
897
+ return r + `@media (max-width: ${s}px) { ${I(n)} }`;
898
898
  }, "");
899
- return e + s;
900
- }, at = (t, e, s) => {
901
- const r = t.reduce((o, n) => (S(o, n, e, s), o), re());
902
- return se(r);
903
- }, G = (t) => Object.keys(t).reduce((e, s) => {
904
- const r = t[s], o = Object.keys(r).map((n) => `${n}: ${r[n]}`).join(";");
905
- return e + `.typo-${s} { ${o} }`;
906
- }, ""), J = (t) => {
899
+ return e + o;
900
+ }, it = (t, e, o) => {
901
+ const r = t.reduce((s, n) => (j(s, n, e, o), s), te());
902
+ return re(r);
903
+ }, I = (t) => Object.keys(t).reduce((e, o) => {
904
+ const r = t[o], s = Object.keys(r).map((n) => `${n}: ${r[n]}`).join(";");
905
+ return e + `.typo-${o} { ${s} }`;
906
+ }, ""), G = (t) => {
907
907
  if (typeof t == "number") return Number.isFinite(t) ? t : null;
908
908
  const e = Number.parseFloat(t);
909
909
  return Number.isFinite(e) ? e : null;
910
- }, q = (t) => {
910
+ }, J = (t) => {
911
911
  if (typeof t == "number") return t / 16;
912
912
  const e = t.trim().toLowerCase();
913
- if (e.endsWith("rem")) return J(e);
913
+ if (e.endsWith("rem")) return G(e);
914
914
  if (e.endsWith("px")) {
915
- const s = J(e);
916
- return s === null ? null : s / 16;
915
+ const o = G(e);
916
+ return o === null ? null : o / 16;
917
917
  }
918
918
  return null;
919
- }, it = (t) => {
920
- const { minValueRem: e, maxValueRem: s, minVwRem: r, maxVwRem: o } = t, n = s - e;
921
- return `calc(${e}rem + ((100vw - ${r}rem) / (${o}rem - ${r}rem)) * ${n}rem)`;
922
- }, lt = (t, e, s, r) => {
923
- const o = ["font-size", "line-height"], n = Object.entries(e.value.breakpoints).map(([f, b]) => {
924
- const k = Number.parseInt(s[f], 10);
925
- return { breakpointName: f, width: k, typography: b };
926
- }).filter((f) => Number.isFinite(f.width)).sort((f, b) => b.width - f.width);
919
+ }, lt = (t) => {
920
+ const { minValueRem: e, maxValueRem: o, minVwRem: r, maxVwRem: s } = t, n = o - e;
921
+ return `calc(${e}rem + ((100vw - ${r}rem) / (${s}rem - ${r}rem)) * ${n}rem)`;
922
+ }, ct = (t, e, o, r) => {
923
+ const s = ["font-size", "line-height"], n = Object.entries(e.value.breakpoints).map(([g, h]) => {
924
+ const m = Number.parseInt(o[g], 10);
925
+ return { breakpointName: g, width: m, typography: h };
926
+ }).filter((g) => Number.isFinite(g.width)).sort((g, h) => h.width - g.width);
927
927
  if (n.length < 2) {
928
- S(t, e, s, r);
928
+ j(t, e, o, r);
929
929
  return;
930
930
  }
931
931
  const a = n[0], i = n[n.length - 1];
932
932
  if (a.width <= i.width) {
933
- S(t, e, s, r);
933
+ j(t, e, o, r);
934
934
  return;
935
935
  }
936
- const l = T(e.value.base, r), c = T(a.typography, r), u = T(i.typography, r), y = a.width / 16, g = i.width / 16;
937
- if (y === g) {
938
- S(t, e, s, r);
936
+ const l = T(e.value.base, r), c = T(a.typography, r), u = T(i.typography, r), f = a.width / 16, y = i.width / 16;
937
+ if (f === y) {
938
+ j(t, e, o, r);
939
939
  return;
940
940
  }
941
941
  t.base[e.name] = {
942
942
  ...l,
943
943
  ...c
944
944
  };
945
- const h = o.reduce((f, b) => {
946
- const k = c[b], C = u[b];
947
- if (k === void 0 || C === void 0 || k === C)
948
- return f;
949
- const B = q(k), R = q(C);
950
- return B === null || R === null ? f : {
951
- ...f,
952
- [b]: it({ minValueRem: R, maxValueRem: B, minVwRem: g, maxVwRem: y })
945
+ const b = s.reduce((g, h) => {
946
+ const m = c[h], S = u[h];
947
+ if (m === void 0 || S === void 0 || m === S)
948
+ return g;
949
+ const E = J(m), B = J(S);
950
+ return E === null || B === null ? g : {
951
+ ...g,
952
+ [h]: lt({ minValueRem: B, maxValueRem: E, minVwRem: y, maxVwRem: f })
953
953
  };
954
954
  }, {});
955
- O(t, a.width, e.name, h), O(t, i.width, e.name, u);
956
- }, ct = (t, e, s, r) => {
957
- if (!r) return at(t, e, s);
958
- const o = t.reduce((n, a) => (lt(n, a, e, s), n), re());
959
- return se(o);
960
- }, ut = (t) => t.length ? `import styles from './styles.module.css';
955
+ O(t, a.width, e.name, b), O(t, i.width, e.name, u);
956
+ }, ut = (t, e, o, r) => {
957
+ if (!r) return it(t, e, o);
958
+ const s = t.reduce((n, a) => (ct(n, a, e, o), n), te());
959
+ return re(s);
960
+ }, dt = (t) => t.length ? `import styles from './styles.module.css';
961
961
  import { typography } from './typography';
962
962
 
963
963
  type TypographyKeysType = keyof typeof typography;
@@ -965,17 +965,17 @@ type TypographyKeysType = keyof typeof typography;
965
965
  const getTypographyClass = (typographyKey: TypographyKeysType) => styles[\`typo-\${typographyKey}\`];
966
966
 
967
967
  export { typography, getTypographyClass, type TypographyKeysType };
968
- ` : "", dt = (t, e) => t.length ? `const typography = {
968
+ ` : "", ft = (t, e) => t.length ? `const typography = {
969
969
  ${t.map((r) => {
970
- const o = I(r.value.base, e), n = Object.entries(r.value.breakpoints).reduce(
970
+ const s = z(r.value.base, e), n = Object.entries(r.value.breakpoints).reduce(
971
971
  (a, [i, l]) => ({
972
972
  ...a,
973
- [i]: I(l, e)
973
+ [i]: z(l, e)
974
974
  }),
975
975
  {}
976
976
  );
977
977
  return ` '${r.name}': {
978
- base: ${JSON.stringify(o, null, 8).replace(/\n/g, `
978
+ base: ${JSON.stringify(s, null, 8).replace(/\n/g, `
979
979
  `)},
980
980
  breakpoints: ${JSON.stringify(n, null, 8).replace(/\n/g, `
981
981
  `)}
@@ -988,203 +988,205 @@ export { typography };
988
988
  ` : "", yt = async ({
989
989
  indexTSContent: t,
990
990
  typographyTSContent: e,
991
- cssContent: s,
991
+ cssContent: o,
992
992
  dir: r
993
993
  }) => {
994
994
  await d.delete(r);
995
- const o = d.write(st, t, { directory: r }), n = d.write(ot, e, { directory: r }), a = d.write(rt, s, { directory: r });
996
- await Promise.all([o, n, a]);
997
- }, ft = async ({
995
+ const s = d.write(st, t, { directory: r }), n = d.write(nt, e, { directory: r }), a = d.write(ot, o, { directory: r });
996
+ await Promise.all([s, n, a]);
997
+ }, gt = async ({
998
998
  typographyTokens: t,
999
999
  dir: e,
1000
- breakpoints: s,
1000
+ breakpoints: o,
1001
1001
  fontFamily: r,
1002
- fluid: o
1002
+ fluid: s
1003
1003
  }) => {
1004
- const n = ct(t, s, r, o), a = dt(t, r), i = ut(t);
1004
+ const n = ut(t, o, r, s), a = ft(t, r), i = dt(t);
1005
1005
  await yt({ indexTSContent: i, typographyTSContent: a, cssContent: n, dir: e });
1006
- }, oe = (t, e, s) => Object.keys(t).reduce((r, o) => {
1007
- const n = t[o];
1006
+ }, oe = (t, e, o) => Object.keys(t).reduce((r, s) => {
1007
+ const n = t[s];
1008
1008
  if (typeof n != "object" || Array.isArray(n)) return r;
1009
1009
  if (!("type" in n) || !("value" in n))
1010
- return { ...r, [o]: oe(n, e, s) };
1010
+ return { ...r, [s]: oe(n, e, o) };
1011
1011
  if (n.type !== "typography") return r;
1012
1012
  const a = n.value, i = Object.entries(a).reduce(
1013
1013
  (l, [c, u]) => {
1014
- const y = Object.keys(s.breakpoints);
1015
- if (y.length)
1016
- y.forEach((g) => {
1017
- const h = e.resolveVariableValueString(u, g);
1018
- h && (h === u ? l.base = { ...l.base, [c]: h } : l.breakpoints[g] = { ...l.breakpoints[g], [c]: h });
1014
+ const f = Object.keys(o.breakpoints);
1015
+ if (f.length)
1016
+ f.forEach((y) => {
1017
+ const b = e.resolveVariableValueString(u, y);
1018
+ b && (b === u ? l.base = { ...l.base, [c]: b } : l.breakpoints[y] = { ...l.breakpoints[y], [c]: b });
1019
1019
  });
1020
1020
  else {
1021
- const g = e.resolveVariableValueString(u);
1022
- g && (l.base = { ...l.base, [c]: g });
1021
+ const y = e.resolveVariableValueString(u);
1022
+ y && (l.base = { ...l.base, [c]: y });
1023
1023
  }
1024
1024
  return l;
1025
1025
  },
1026
1026
  { base: {}, breakpoints: {} }
1027
1027
  );
1028
- return { ...r, [o]: { type: "typography", value: i } };
1029
- }, {}), ne = (t, e) => Object.keys(t).reduce((s, r) => {
1030
- const o = e ? `${e}-${r}` : r, n = t[r];
1028
+ return { ...r, [s]: { type: "typography", value: i } };
1029
+ }, {}), se = (t, e) => Object.keys(t).reduce((o, r) => {
1030
+ const s = e ? `${e}-${r}` : r, n = t[r];
1031
1031
  if (!("type" in n) || !("value" in n))
1032
- return { ...s, ...ne(n, o) };
1032
+ return { ...o, ...se(n, s) };
1033
1033
  const a = n.value;
1034
- return { ...s, [o]: a };
1035
- }, {}), qt = ({ input: t, output: { dir: e } }) => ({
1034
+ return { ...o, [s]: a };
1035
+ }, {}), Ht = ({ input: t, output: { dir: e } }) => ({
1036
1036
  name: "typography/tokenManager",
1037
- executor: async ({ tokenManagerClient: s }) => {
1037
+ executor: async ({ tokenManagerClient: o }) => {
1038
1038
  try {
1039
1039
  console.log("[typography/tokenManager] Generating typography from TokenManager...");
1040
- const { breakpoints: r, fontFamily: o } = t, n = t.fluid ?? !0;
1041
- if (!s.isLoaded())
1040
+ const { breakpoints: r, fontFamily: s } = t, n = t.fluid ?? !0;
1041
+ if (!o.isLoaded())
1042
1042
  throw new Error("TokenManager is not loaded. Tokens must be loaded before using this module.");
1043
- const a = [], i = s.getStyles();
1043
+ const a = [], i = o.getStyles();
1044
1044
  console.log("[typography/tokenManager] Processing styles for typography..."), i.text && a.push(i.text);
1045
1045
  const l = a.reduce(
1046
- (u, y) => ({
1046
+ (u, f) => ({
1047
1047
  ...u,
1048
- ...oe(y, s, { breakpoints: t.breakpoints })
1048
+ ...oe(f, o, { breakpoints: t.breakpoints })
1049
1049
  }),
1050
1050
  {}
1051
- ), c = Object.entries(ne(l)).map(
1052
- ([u, y]) => ({ name: u, value: y })
1051
+ ), c = Object.entries(se(l)).map(
1052
+ ([u, f]) => ({ name: u, value: f })
1053
1053
  );
1054
1054
  if (c.length === 0) {
1055
1055
  console.warn("[typography/tokenManager] No typography tokens generated");
1056
1056
  return;
1057
1057
  }
1058
- console.log(`[typography/tokenManager] Generated ${c.length} typography tokens`), console.log(`[typography/tokenManager] Writing files to ${e}...`), await ft({
1058
+ console.log(`[typography/tokenManager] Generated ${c.length} typography tokens`), console.log(`[typography/tokenManager] Writing files to ${e}...`), await gt({
1059
1059
  typographyTokens: c,
1060
1060
  dir: e,
1061
1061
  breakpoints: r,
1062
- fontFamily: o || {},
1062
+ fontFamily: s || {},
1063
1063
  fluid: n
1064
1064
  }), console.log("[typography/tokenManager] ✅ Successfully generated typography files");
1065
1065
  } catch (r) {
1066
- const o = r instanceof Error ? r.message : String(r);
1067
- throw console.error("[typography/tokenManager] ❌ Failed to generate typography:", o), r instanceof Error && r.stack && console.error("[typography/tokenManager] Stack trace:", r.stack), r;
1066
+ const s = r instanceof Error ? r.message : String(r);
1067
+ throw console.error("[typography/tokenManager] ❌ Failed to generate typography:", s), r instanceof Error && r.stack && console.error("[typography/tokenManager] Stack trace:", r.stack), r;
1068
1068
  }
1069
1069
  }
1070
- }), gt = (t) => typeof t == "object" && t !== null && "type" in t && "value" in t, pt = (t) => typeof t == "object" && t !== null && !Array.isArray(t), ae = (t) => t.trim().split(".").map((e) => e.trim()).filter(Boolean), ht = (t, e) => {
1071
- const s = ae(e);
1072
- if (!s.length)
1070
+ }), pt = (t) => typeof t == "object" && t !== null && "type" in t && "value" in t, ht = (t) => typeof t == "object" && t !== null && !Array.isArray(t), ne = (t) => t.trim().split(".").map((e) => e.trim()).filter(Boolean), bt = (t, e) => {
1071
+ const o = ne(e);
1072
+ if (!o.length)
1073
1073
  throw new Error("variablePath must contain at least one segment");
1074
- const r = H(t, s);
1074
+ const r = q(t, o);
1075
1075
  if (r === void 0)
1076
- throw new Error(`Variables subtree not found at path: ${s.join(".")}`);
1076
+ throw new Error(`Variables subtree not found at path: ${o.join(".")}`);
1077
1077
  return r;
1078
- }, ie = (t, e, s) => {
1078
+ }, ae = (t, e, o) => {
1079
1079
  if (!t) return [];
1080
- if (gt(t)) {
1080
+ if (pt(t)) {
1081
1081
  if (t.type !== "dimension") return [];
1082
- const r = t.value, o = Object.keys(r).reduce((n, a) => {
1083
- const i = r[a], l = s.resolveVariableValueString(i, a);
1082
+ const r = t.value, s = Object.keys(r).reduce((n, a) => {
1083
+ const i = r[a], l = o.resolveVariableValueString(i, a);
1084
1084
  return { ...n, [a]: l ?? i };
1085
1085
  }, {});
1086
- return [{ flatName: e, resolvedByMode: o }];
1086
+ return [{ flatName: e, resolvedByMode: s }];
1087
1087
  }
1088
- return pt(t) ? Object.keys(t).flatMap((r) => {
1089
- const o = t[r], n = e ? `${e}-${r}` : r;
1090
- return ie(o, n, s);
1088
+ return ht(t) ? Object.keys(t).flatMap((r) => {
1089
+ const s = t[r], n = e ? `${e}-${r}` : r;
1090
+ return ae(s, n, o);
1091
1091
  }) : [];
1092
- }, bt = (t, e) => ie(t, "", e), mt = (t, e) => typeof e == "string" ? t === e : e.test(t), kt = (t, e) => e != null && e.length ? t.filter(
1093
- (s) => e.some((r) => mt(s.flatName, r))
1094
- ) : t, le = (t) => Object.keys(t).map((e) => ({ mode: e, widthPx: Number.parseInt(t[e], 10) })).filter((e) => Number.isFinite(e.widthPx)).sort((e, s) => s.widthPx - e.widthPx), E = (t) => {
1095
- const e = ae(t);
1092
+ }, mt = (t, e) => ae(t, "", e), wt = (t, e) => typeof e == "string" ? t === e : e.test(t), kt = (t, e) => e != null && e.length ? t.filter(
1093
+ (o) => e.some((r) => wt(o.flatName, r))
1094
+ ) : t, ie = (t) => Object.keys(t).map((e) => ({ mode: e, widthPx: Number.parseInt(t[e], 10) })).filter((e) => Number.isFinite(e.widthPx)).sort((e, o) => o.widthPx - e.widthPx), le = (t) => {
1095
+ const e = ne(t);
1096
1096
  if (!e.length)
1097
1097
  throw new Error("variablePath must contain at least one segment");
1098
- const s = e[e.length - 1];
1098
+ const o = e[e.length - 1];
1099
1099
  return {
1100
- variablesClassName: `${s}-variables`,
1101
- variableNamePrefix: s
1100
+ variablesClassName: `${o}-variables`,
1101
+ variableNamePrefix: o
1102
1102
  };
1103
- }, wt = (t, e) => {
1104
- const s = E(t.variablePath), r = e.variablesClassName ?? s.variablesClassName;
1103
+ }, $t = (t, e) => {
1104
+ const r = le(t.variablePath).variableNamePrefix, s = e.variablesClassName ?? `${r}-variables`;
1105
1105
  return {
1106
- variableNamePrefix: s.variableNamePrefix,
1107
- variablesClassName: r
1106
+ variableNamePrefix: r,
1107
+ variablesClassName: s
1108
1108
  };
1109
- }, ce = (t, e, s) => {
1110
- const r = E(t);
1111
- return (s == null ? void 0 : s(t, e)) ?? `${r.variableNamePrefix}-${e}`;
1112
- }, $t = (t, e, s) => `--${ce(t, e, s)}`, Tt = (t, e) => Object.keys(e).reduce(
1113
- (s, r) => {
1114
- const o = Number(r);
1115
- return { ...s, [o]: { ...s[o], ...e[o] } };
1109
+ }, ce = (t, e) => `${le(t).variableNamePrefix}-${e}`, Qt = (t, e) => `--${ce(t, e)}`, St = (t) => `--${t}`, ue = (t, e, o) => {
1110
+ const r = ce(t.variablePath, o);
1111
+ if (!e.parseCssVariableName)
1112
+ return r;
1113
+ const s = e.parseCssVariableName({
1114
+ variablePath: t.variablePath,
1115
+ flatName: o,
1116
+ defaultName: r
1117
+ });
1118
+ return s.trim() ? s : r;
1119
+ }, Tt = (t, e) => Object.keys(e).reduce(
1120
+ (o, r) => {
1121
+ const s = Number(r);
1122
+ return { ...o, [s]: { ...o[s], ...e[s] } };
1116
1123
  },
1117
1124
  { ...t }
1118
- ), St = (t, e, s, r) => {
1119
- const o = $t(s, t.flatName, r), n = le(e);
1120
- if (Object.keys(e).length === 0 || n.length === 0) {
1121
- const c = Object.values(t.resolvedByMode)[0] ?? "";
1122
- return { base: { [o]: c }, byBreakpoint: {} };
1125
+ ), jt = (t, e, o) => {
1126
+ const { breakpoints: r } = e, s = ue(e, o, t.flatName), n = St(s), a = ie(r);
1127
+ if (Object.keys(r).length === 0 || a.length === 0) {
1128
+ const u = Object.values(t.resolvedByMode)[0] ?? "";
1129
+ return { base: { [n]: u }, byBreakpoint: {} };
1123
1130
  }
1124
- const a = n.filter((c) => c.mode in t.resolvedByMode);
1125
- if (a.length === 0) {
1126
- const c = Object.values(t.resolvedByMode)[0] ?? "";
1127
- return { base: { [o]: c }, byBreakpoint: {} };
1131
+ const i = a.filter((u) => u.mode in t.resolvedByMode);
1132
+ if (i.length === 0) {
1133
+ const u = Object.values(t.resolvedByMode)[0] ?? "";
1134
+ return { base: { [n]: u }, byBreakpoint: {} };
1128
1135
  }
1129
- if (a.length === 1) {
1130
- const c = a[0], u = t.resolvedByMode[c.mode] ?? "";
1131
- return { base: { [o]: u }, byBreakpoint: {} };
1136
+ if (i.length === 1) {
1137
+ const u = i[0], f = t.resolvedByMode[u.mode] ?? "";
1138
+ return { base: { [n]: f }, byBreakpoint: {} };
1132
1139
  }
1133
- const i = t.resolvedByMode[a[0].mode] ?? "", l = a.slice(1).reduce((c, u, y) => {
1134
- const g = a[y].mode, h = t.resolvedByMode[g], f = t.resolvedByMode[u.mode];
1135
- if (f === void 0 || f === h) return c;
1136
- const b = u.widthPx, k = c[b] ?? {};
1137
- return { ...c, [b]: { ...k, [o]: f } };
1140
+ const l = t.resolvedByMode[i[0].mode] ?? "", c = i.slice(1).reduce((u, f, y) => {
1141
+ const b = i[y].mode, g = t.resolvedByMode[b], h = t.resolvedByMode[f.mode];
1142
+ if (h === void 0 || h === g) return u;
1143
+ const m = f.widthPx, S = u[m] ?? {};
1144
+ return { ...u, [m]: { ...S, [n]: h } };
1138
1145
  }, {});
1139
- return { base: { [o]: i }, byBreakpoint: l };
1140
- }, jt = (t, e, s, r) => t.reduce(
1141
- (o, n) => {
1142
- const { base: a, byBreakpoint: i } = St(
1143
- n,
1144
- e,
1145
- s,
1146
- r
1147
- );
1146
+ return { base: { [n]: l }, byBreakpoint: c };
1147
+ }, vt = (t, e, o) => t.reduce(
1148
+ (r, s) => {
1149
+ const { base: n, byBreakpoint: a } = jt(s, e, o);
1148
1150
  return {
1149
- base: { ...o.base, ...a },
1150
- breakpoints: Tt(o.breakpoints, i)
1151
+ base: { ...r.base, ...n },
1152
+ breakpoints: Tt(r.breakpoints, a)
1151
1153
  };
1152
1154
  },
1153
1155
  { base: {}, breakpoints: {} }
1154
- ), vt = (t, e, s) => {
1156
+ ), Mt = (t, e, o) => {
1155
1157
  if (!t.length) return "";
1156
- const { breakpoints: r, variablePath: o } = e, { variablesClassName: n } = wt(e, s), a = jt(t, r, o, s.parseVariableName), i = Object.keys(a.base).map((u) => ` ${u}: ${a.base[u]};`), l = z(`.${n}`, i), c = Object.keys(a.breakpoints).map(Number).sort((u, y) => y - u).map((u) => {
1157
- const y = a.breakpoints[u], g = Object.keys(y).map((f) => ` ${f}: ${y[f]};`), h = z(`.${n}`, g);
1158
- return `@media (max-width: ${u}px) {
1159
- ${h}
1158
+ const { variablesClassName: r } = $t(e, o), s = vt(t, e, o), n = Object.keys(s.base).map((l) => ` ${l}: ${s.base[l]};`), a = W(`.${r}`, n), i = Object.keys(s.breakpoints).map(Number).sort((l, c) => c - l).map((l) => {
1159
+ const c = s.breakpoints[l], u = Object.keys(c).map((y) => ` ${y}: ${c[y]};`), f = W(`.${r}`, u);
1160
+ return `@media (max-width: ${l}px) {
1161
+ ${f}
1160
1162
  }`;
1161
1163
  }).filter(Boolean).join(`
1162
1164
 
1163
1165
  `);
1164
- return c ? `${l}
1166
+ return i ? `${a}
1165
1167
 
1166
- ${c}` : l;
1168
+ ${i}` : a;
1167
1169
  }, Ct = (t, e) => {
1168
- const s = t.resolvedByMode, r = le(e), o = Object.keys(e).length > 0 && r.length > 0;
1170
+ const o = t.resolvedByMode, r = ie(e), s = Object.keys(e).length > 0 && r.length > 0;
1169
1171
  return { breakpoints: (() => {
1170
- if (!o)
1171
- return Object.keys(s);
1172
+ if (!s)
1173
+ return Object.keys(o);
1172
1174
  const i = [], l = /* @__PURE__ */ new Set();
1173
1175
  return r.forEach(({ mode: c }) => {
1174
- c in s && (i.push(c), l.add(c));
1175
- }), Object.keys(s).forEach((c) => {
1176
+ c in o && (i.push(c), l.add(c));
1177
+ }), Object.keys(o).forEach((c) => {
1176
1178
  l.has(c) || (i.push(c), l.add(c));
1177
1179
  }), i;
1178
1180
  })().reduce((i, l) => {
1179
- const c = s[l];
1181
+ const c = o[l];
1180
1182
  return c === void 0 ? i : { ...i, [l]: c };
1181
1183
  }, {}) };
1182
- }, Mt = (t, e) => {
1183
- const { breakpoints: s } = e;
1184
+ }, Nt = (t, e) => {
1185
+ const { breakpoints: o } = e;
1184
1186
  return t.length ? `const utilities = {
1185
- ${t.map((o) => {
1186
- const n = Ct(o, s), a = JSON.stringify(n, null, 8);
1187
- return ` '${o.flatName}': ${a.replace(/\n/g, `
1187
+ ${t.map((s) => {
1188
+ const n = Ct(s, o), a = JSON.stringify(n, null, 8);
1189
+ return ` '${s.flatName}': ${a.replace(/\n/g, `
1188
1190
  `)}`;
1189
1191
  }).join(`,
1190
1192
  `)}
@@ -1195,20 +1197,20 @@ export { utilities };
1195
1197
 
1196
1198
  export { utilities };
1197
1199
  `;
1198
- }, Vt = (t, e, s) => t.reduce(
1199
- (r, o) => ({
1200
+ }, Vt = (t, e, o) => t.reduce(
1201
+ (r, s) => ({
1200
1202
  ...r,
1201
- [o.flatName]: ce(e, o.flatName, s)
1203
+ [s.flatName]: ue(e, o, s.flatName)
1202
1204
  }),
1203
1205
  {}
1204
- ), Nt = (t, e, s) => {
1205
- const r = !!s.parseVariableName, o = Vt(t, e.variablePath, s.parseVariableName), n = JSON.stringify(o, null, 4), { variableNamePrefix: a } = E(e.variablePath);
1206
- return r ? [
1206
+ ), Ft = (t, e, o) => {
1207
+ const r = Vt(t, e, o);
1208
+ return [
1207
1209
  "import { utilities } from './utilities';",
1208
1210
  "",
1209
1211
  "type UtilitiesKeysType = keyof typeof utilities;",
1210
1212
  "",
1211
- `const utilityVariableNameByKey = ${n} as const;`,
1213
+ `const utilityVariableNameByKey = ${JSON.stringify(r, null, 4)} as const;`,
1212
1214
  "",
1213
1215
  "const getUtilityCssVariableName = (key: UtilitiesKeysType): string =>",
1214
1216
  " `--${utilityVariableNameByKey[key]}`;",
@@ -1224,90 +1226,72 @@ export { utilities };
1224
1226
  "};",
1225
1227
  ""
1226
1228
  ].join(`
1227
- `) : [
1228
- "import { utilities } from './utilities';",
1229
- "",
1230
- "type UtilitiesKeysType = keyof typeof utilities;",
1231
- "",
1232
- "const getUtilityCssVariableName = (key: UtilitiesKeysType): string =>",
1233
- ` \`--${a}-\${key}\`;`,
1234
- "",
1235
- "const getUtilityCssVar = (key: UtilitiesKeysType): string =>",
1236
- " `var(${getUtilityCssVariableName(key)})`;",
1237
- "",
1238
- "export {",
1239
- " utilities,",
1240
- " getUtilityCssVariableName,",
1241
- " getUtilityCssVar,",
1242
- " type UtilitiesKeysType,",
1243
- "};",
1244
- ""
1245
- ].join(`
1246
1229
  `);
1247
- }, Ft = "styles.css", xt = "utilities.ts", Ot = "index.ts", Pt = async ({
1230
+ }, xt = "styles.css", Ot = "utilities.ts", Pt = "index.ts", Et = async ({
1248
1231
  dir: t,
1249
1232
  globalCss: e,
1250
- utilitiesTs: s,
1233
+ utilitiesTs: o,
1251
1234
  indexTs: r
1252
1235
  }) => {
1253
1236
  await d.delete(t), await Promise.all([
1254
- d.write(Ft, e, { directory: t }),
1255
- d.write(xt, s, { directory: t }),
1256
- d.write(Ot, r, { directory: t })
1237
+ d.write(xt, e, { directory: t }),
1238
+ d.write(Ot, o, { directory: t }),
1239
+ d.write(Pt, r, { directory: t })
1257
1240
  ]);
1258
- }, Et = async ({
1241
+ }, Bt = async ({
1259
1242
  tokens: t,
1260
1243
  input: e,
1261
- output: s
1244
+ output: o
1262
1245
  }) => {
1263
- const { dir: r } = s, o = vt(t, e, s), n = Mt(t, e), a = Nt(t, e, s);
1264
- await Pt({ dir: r, globalCss: o, utilitiesTs: n, indexTs: a });
1265
- }, Ht = ({ input: t, output: e }) => ({
1246
+ const { dir: r } = o, s = Mt(t, e, o), n = Nt(t, e), a = Ft(t, e, o);
1247
+ await Et({ dir: r, globalCss: s, utilitiesTs: n, indexTs: a });
1248
+ }, Zt = ({ input: t, output: e }) => ({
1266
1249
  name: "utilities/tokenManager",
1267
- executor: async ({ tokenManagerClient: s }) => {
1250
+ executor: async ({ tokenManagerClient: o }) => {
1268
1251
  var r;
1269
1252
  try {
1270
- if (console.log("[utilities/tokenManager] Generating utility classes from TokenManager..."), !s.isLoaded())
1253
+ if (console.log("[utilities/tokenManager] Generating utility classes from TokenManager..."), !o.isLoaded())
1271
1254
  throw new Error("TokenManager is not loaded. Tokens must be loaded before using this module.");
1272
- const o = s.getVariables(), n = ht(o, t.variablePath), a = bt(n, s), i = kt(a, t.include);
1255
+ const s = o.getVariables(), n = bt(s, t.variablePath), a = mt(n, o), i = kt(a, t.include);
1273
1256
  if (!i.length) {
1274
1257
  a.length && ((r = t.include) != null && r.length) ? console.warn(
1275
1258
  `[utilities/tokenManager] No tokens left after include filter (${a.length} at path "${t.variablePath}")`
1276
1259
  ) : console.warn(`[utilities/tokenManager] No dimension tokens found at path "${t.variablePath}"`);
1277
1260
  return;
1278
1261
  }
1279
- console.log(`[utilities/tokenManager] Resolved ${i.length} utility token(s)`), console.log(`[utilities/tokenManager] Writing files to ${e.dir}...`), await Et({ tokens: i, input: t, output: e }), console.log("[utilities/tokenManager] ✅ Successfully generated utility files");
1280
- } catch (o) {
1281
- const n = o instanceof Error ? o.message : String(o);
1282
- throw console.error("[utilities/tokenManager] ❌ Failed to generate utilities:", n), o instanceof Error && o.stack && console.error("[utilities/tokenManager] Stack trace:", o.stack), o;
1262
+ console.log(`[utilities/tokenManager] Resolved ${i.length} utility token(s)`), console.log(`[utilities/tokenManager] Writing files to ${e.dir}...`), await Bt({ tokens: i, input: t, output: e }), console.log("[utilities/tokenManager] ✅ Successfully generated utility files");
1263
+ } catch (s) {
1264
+ const n = s instanceof Error ? s.message : String(s);
1265
+ throw console.error("[utilities/tokenManager] ❌ Failed to generate utilities:", n), s instanceof Error && s.stack && console.error("[utilities/tokenManager] Stack trace:", s.stack), s;
1283
1266
  }
1284
1267
  }
1285
1268
  });
1286
1269
  export {
1287
1270
  ke as BREAKPOINTS_NAMES,
1288
- me as TokenManager,
1289
- zt as breakpointsFromTokenManager,
1290
- Mt as buildUtilitiesDataTSContent,
1291
- vt as buildUtilitiesGlobalStylesCSS,
1292
- Nt as buildUtilitiesIndexTSContent,
1293
- It as colorsFromTokenManager,
1294
- Gt as containerFromTokenManager,
1295
- E as deriveUtilityNamingFromVariablePath,
1271
+ we as TokenManager,
1272
+ It as breakpointsFromTokenManager,
1273
+ Nt as buildUtilitiesDataTSContent,
1274
+ Mt as buildUtilitiesGlobalStylesCSS,
1275
+ Ft as buildUtilitiesIndexTSContent,
1276
+ Gt as colorsFromTokenManager,
1277
+ Jt as containerFromTokenManager,
1278
+ le as deriveUtilityNamingFromVariablePath,
1296
1279
  kt as filterResolvedUtilitiesByInclude,
1297
- Lt as generate,
1298
- Et as generateUtilitiesFiles,
1299
- le as getSortedBreakpointModes,
1300
- $t as getUtilityCssVariableName,
1280
+ Wt as generate,
1281
+ Bt as generateUtilitiesFiles,
1282
+ ie as getSortedBreakpointModes,
1283
+ Qt as getUtilityCssVariableName,
1301
1284
  ce as getUtilityCssVariableNameWithoutDashes,
1302
- ht as getVariablesSubtree,
1303
- Wt as init,
1304
- bt as resolveUtilitiesSubtree,
1305
- wt as resolveUtilityNaming,
1306
- Jt as shadowsFromTokenManager,
1307
- St as splitUtilityTokenForMedia,
1308
- qt as typographyFromTokenManager,
1309
- Ht as utilitiesFromTokenManager,
1310
- mt as utilityFlatNameMatchesIncludePattern,
1285
+ bt as getVariablesSubtree,
1286
+ zt as init,
1287
+ mt as resolveUtilitiesSubtree,
1288
+ ue as resolveUtilityCssVariableNameWithoutDashes,
1289
+ $t as resolveUtilityNaming,
1290
+ qt as shadowsFromTokenManager,
1291
+ jt as splitUtilityTokenForMedia,
1292
+ Ht as typographyFromTokenManager,
1293
+ Zt as utilitiesFromTokenManager,
1294
+ wt as utilityFlatNameMatchesIncludePattern,
1311
1295
  Ct as utilityTokenToSerializableData,
1312
- Pt as writeUtilitiesFiles
1296
+ Et as writeUtilitiesFiles
1313
1297
  };