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