@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.cjs +19 -20
- package/index.mjs +544 -560
- package/modules/utilities/types.d.ts +10 -6
- package/modules/utilities/types.d.ts.map +1 -1
- package/modules/utilities/utils.d.ts +4 -3
- package/modules/utilities/utils.d.ts.map +1 -1
- package/package.json +1 -1
package/index.mjs
CHANGED
|
@@ -1,78 +1,78 @@
|
|
|
1
|
-
var
|
|
2
|
-
var
|
|
3
|
-
var
|
|
4
|
-
import
|
|
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
|
|
7
|
-
import { readFile as
|
|
8
|
-
import { resolve as
|
|
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
|
|
13
|
+
return V(p.baseDir, e);
|
|
14
14
|
}
|
|
15
|
-
static resolveWritePath(e,
|
|
16
|
-
const r =
|
|
15
|
+
static resolveWritePath(e, o) {
|
|
16
|
+
const r = V(p.baseDir, o ?? "");
|
|
17
17
|
return {
|
|
18
18
|
targetDir: r,
|
|
19
|
-
targetPath:
|
|
19
|
+
targetPath: V(r, e)
|
|
20
20
|
};
|
|
21
21
|
}
|
|
22
|
-
static handleReadError(e,
|
|
23
|
-
throw e.code === "ENOENT" ? new Error(`File not found: ${
|
|
24
|
-
`Failed to read file "${
|
|
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,
|
|
27
|
+
static async read(e, o = "utf8") {
|
|
28
28
|
const r = p.resolveReadPath(e);
|
|
29
29
|
try {
|
|
30
|
-
return await
|
|
31
|
-
} catch (
|
|
32
|
-
p.handleReadError(
|
|
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
|
|
36
|
+
const o = p.resolveReadPath(e);
|
|
37
37
|
try {
|
|
38
|
-
return await
|
|
38
|
+
return await N(o);
|
|
39
39
|
} catch (r) {
|
|
40
|
-
p.handleReadError(r,
|
|
40
|
+
p.handleReadError(r, o);
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
43
|
static async readJson(e) {
|
|
44
|
-
const
|
|
44
|
+
const o = p.resolveReadPath(e);
|
|
45
45
|
try {
|
|
46
|
-
const r = await
|
|
46
|
+
const r = await N(o, { encoding: "utf8" });
|
|
47
47
|
try {
|
|
48
48
|
return JSON.parse(r);
|
|
49
|
-
} catch (
|
|
50
|
-
throw new Error(`Failed to parse JSON from "${
|
|
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,
|
|
53
|
+
p.handleReadError(r, o);
|
|
54
54
|
}
|
|
55
55
|
}
|
|
56
|
-
static async write(e,
|
|
57
|
-
const { directory:
|
|
58
|
-
if (!n &&
|
|
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
|
|
60
|
+
return await ge(a, { recursive: !0 }), await pe(i, o, { encoding: "utf8" }), i;
|
|
61
61
|
}
|
|
62
|
-
static async writeWithExtension(e,
|
|
63
|
-
const n =
|
|
64
|
-
return p.write(a, r,
|
|
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
|
|
68
|
-
return
|
|
67
|
+
const o = p.resolveReadPath(e);
|
|
68
|
+
return C(o);
|
|
69
69
|
}
|
|
70
|
-
static async delete(e,
|
|
71
|
-
const { targetPath: r } = p.resolveWritePath(e,
|
|
72
|
-
|
|
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
|
-
|
|
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
|
-
`${
|
|
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
|
-
|
|
97
|
-
let
|
|
98
|
-
const
|
|
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((
|
|
101
|
-
Array.isArray(t[
|
|
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
|
-
},
|
|
104
|
-
const
|
|
103
|
+
}, me = (t, e = 50) => {
|
|
104
|
+
const o = [];
|
|
105
105
|
for (let r = 0; r < t.length; r += e)
|
|
106
|
-
|
|
107
|
-
return
|
|
106
|
+
o.push(t.slice(r, r + e));
|
|
107
|
+
return o;
|
|
108
108
|
};
|
|
109
109
|
class P {
|
|
110
|
-
constructor(e,
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
this.figmaToken = e, this.fileId =
|
|
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
|
|
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
|
|
125
|
+
return o;
|
|
126
126
|
}
|
|
127
|
-
async performControlledRequest(e, { params:
|
|
128
|
-
var
|
|
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(
|
|
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(() =>
|
|
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:
|
|
140
|
-
}, u = performance.now(),
|
|
139
|
+
signal: s.signal
|
|
140
|
+
}, u = performance.now(), f = await fetch(`${a}`, c);
|
|
141
141
|
clearTimeout(i);
|
|
142
|
-
const
|
|
143
|
-
return (
|
|
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,
|
|
146
|
-
var
|
|
145
|
+
async request(e, o) {
|
|
146
|
+
var s;
|
|
147
147
|
const r = await this.performControlledRequest(e, {
|
|
148
|
-
...
|
|
148
|
+
...o
|
|
149
149
|
});
|
|
150
|
-
return (
|
|
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
|
|
159
|
+
const o = me(e).map(
|
|
160
160
|
(n) => this.request(`/files/${this.fileId}/nodes`, { params: { ids: n.join(",") } })
|
|
161
|
-
), r = await Promise.all(
|
|
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
|
|
169
|
-
const
|
|
168
|
+
const q = (t, e) => {
|
|
169
|
+
const o = Array.isArray(e) ? e : e.split(".");
|
|
170
170
|
let r = t;
|
|
171
|
-
for (const
|
|
171
|
+
for (const s of o) {
|
|
172
172
|
if (r == null || typeof r != "object") return;
|
|
173
|
-
r = r[
|
|
173
|
+
r = r[s];
|
|
174
174
|
}
|
|
175
175
|
return r;
|
|
176
|
-
},
|
|
176
|
+
}, H = (t, e) => {
|
|
177
177
|
if (!e || typeof e != "object") return t;
|
|
178
178
|
if (!t || typeof t != "object") return e;
|
|
179
|
-
const
|
|
179
|
+
const o = { ...t };
|
|
180
180
|
for (const r in e)
|
|
181
|
-
e.hasOwnProperty(r) && (typeof e[r] == "object" && e[r] !== null && typeof
|
|
182
|
-
return
|
|
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
|
|
199
|
-
if (!x(t[
|
|
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
|
|
205
|
-
if (
|
|
204
|
+
const o = Object.keys(t), r = Object.keys(e);
|
|
205
|
+
if (o.length !== r.length)
|
|
206
206
|
return !1;
|
|
207
|
-
for (const
|
|
208
|
-
if (!r.includes(
|
|
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
|
|
214
|
+
const R = {
|
|
215
215
|
color: {},
|
|
216
216
|
effect: {},
|
|
217
217
|
text: {},
|
|
218
218
|
grid: {}
|
|
219
219
|
};
|
|
220
|
-
class
|
|
220
|
+
class we {
|
|
221
221
|
constructor(e) {
|
|
222
222
|
// files
|
|
223
|
-
|
|
224
|
-
|
|
223
|
+
w(this, "tokensDir");
|
|
224
|
+
w(this, "manifestPath");
|
|
225
225
|
// result data
|
|
226
|
-
|
|
227
|
-
|
|
226
|
+
w(this, "variables");
|
|
227
|
+
w(this, "styles");
|
|
228
228
|
// flags
|
|
229
|
-
|
|
230
|
-
this.tokensDir = e || "", this.manifestPath =
|
|
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
|
|
238
|
-
return
|
|
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
|
|
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
|
|
248
|
+
const o = /^\{(.+)\}$/, r = e.match(o);
|
|
249
249
|
if (r) {
|
|
250
|
-
const
|
|
251
|
-
return `{${this.normalizeKey(
|
|
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
|
-
([
|
|
261
|
-
([
|
|
260
|
+
([o, r]) => Object.entries(r.modes).flatMap(
|
|
261
|
+
([s, n]) => n.map((a) => ({
|
|
262
262
|
fileName: a,
|
|
263
|
-
modeName: this.normalizeKey(
|
|
264
|
-
collectionName:
|
|
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((
|
|
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,
|
|
273
|
-
return Object.entries(e).reduce((r, [
|
|
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(
|
|
275
|
+
[this.normalizeKey(s)]: {
|
|
276
276
|
type: n.$type,
|
|
277
277
|
description: n.$description,
|
|
278
|
-
value:
|
|
278
|
+
value: o ? { [this.normalizeKey(o)]: this.parseValue(n.$value) } : this.parseValue(n.$value)
|
|
279
279
|
}
|
|
280
|
-
} : { ...r, [this.normalizeKey(
|
|
280
|
+
} : { ...r, [this.normalizeKey(s)]: this.getTokensFromFile(n, o) }, {});
|
|
281
281
|
}
|
|
282
|
-
processTokensFile(e,
|
|
283
|
-
const
|
|
284
|
-
return { [
|
|
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:
|
|
291
|
+
e.map(async ({ fileName: o, modeName: r, collectionName: s }) => {
|
|
292
292
|
try {
|
|
293
|
-
const n =
|
|
294
|
-
return this.processTokensFile(a, r,
|
|
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: ${
|
|
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((
|
|
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
|
|
309
|
+
const o = this.createVariableFileList(e), r = await this.loadVariableFiles(o);
|
|
310
310
|
return this.mergeVariables(r);
|
|
311
|
-
} catch (
|
|
312
|
-
throw new Error(`Failed to load token variables from ${this.tokensDir}: ${
|
|
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
|
-
([
|
|
321
|
-
styleType:
|
|
322
|
-
fileName:
|
|
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:
|
|
331
|
+
e.map(async ({ styleType: r, fileName: s }) => {
|
|
332
332
|
try {
|
|
333
|
-
const 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: ${
|
|
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,
|
|
340
|
+
(r, s) => ({ ...r, [s.styleType]: this.getTokensFromFile(s.styleTokens, "") }),
|
|
341
341
|
{
|
|
342
|
-
...
|
|
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 { ...
|
|
351
|
-
const
|
|
352
|
-
return await this.loadStyleFiles(
|
|
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((
|
|
402
|
-
const
|
|
403
|
-
return n && (
|
|
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,
|
|
412
|
+
resolveVariableValueString(e, o) {
|
|
413
413
|
if (!this.isVariableReference(e)) return e;
|
|
414
|
-
const r = this.getVariablePath(e),
|
|
415
|
-
if (
|
|
416
|
-
return this.resolveVariableValueString(
|
|
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,
|
|
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
|
|
428
|
-
if (
|
|
429
|
-
if (
|
|
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(
|
|
432
|
-
return
|
|
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
|
|
439
|
-
const e = await new
|
|
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:
|
|
445
|
-
n && d.exists(n) && await i.load(), await Promise.all(
|
|
446
|
-
},
|
|
447
|
-
await
|
|
448
|
-
}, ke = ["xxxl", "xxl", "xl", "lg", "md", "sm", "xs", "xxs", "xxxs"],
|
|
449
|
-
(e,
|
|
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
|
-
[
|
|
451
|
+
[o.name]: $e(o)
|
|
452
452
|
}),
|
|
453
453
|
{}
|
|
454
454
|
), Te = async (t, e) => {
|
|
455
455
|
await d.delete(t, e);
|
|
456
|
-
},
|
|
457
|
-
await d.write(t, e, { directory:
|
|
458
|
-
}, F = async (t, e,
|
|
459
|
-
await Te(t,
|
|
460
|
-
},
|
|
461
|
-
const e = t.map(({ name:
|
|
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
|
-
},
|
|
467
|
+
}, Me = (t) => {
|
|
468
468
|
var r;
|
|
469
|
-
const e = t.map(({ name:
|
|
470
|
-
return !e.length || !
|
|
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: '${
|
|
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
|
-
`),
|
|
490
|
-
const
|
|
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",
|
|
493
|
+
F("styles.scss", s, e),
|
|
494
494
|
F("index.ts", n, e)
|
|
495
495
|
]);
|
|
496
496
|
}, Ve = (t, e) => {
|
|
497
|
-
const
|
|
498
|
-
if (
|
|
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 ${
|
|
500
|
+
`Not enough breakpoint names provided. Found ${o.length} breakpoints in data, but only ${e.length} names specified: ${e.join(", ")}`
|
|
501
501
|
);
|
|
502
|
-
const
|
|
503
|
-
if (
|
|
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: ${
|
|
505
|
+
`Found non-numeric breakpoint keys in grid data: ${s.join(", ")}. All breakpoint keys must be numeric values.`
|
|
506
506
|
);
|
|
507
|
-
return
|
|
507
|
+
return o.map((n, a) => ({
|
|
508
508
|
name: e[e.length - 1 - a] || `bp-${n}`,
|
|
509
509
|
value: n
|
|
510
510
|
}));
|
|
511
|
-
},
|
|
511
|
+
}, It = ({
|
|
512
512
|
input: t = {},
|
|
513
513
|
output: { dir: e }
|
|
514
514
|
}) => ({
|
|
515
515
|
name: "breakpoints/tokenManager",
|
|
516
|
-
executor: async ({ tokenManagerClient:
|
|
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 (!
|
|
520
|
+
if (!o.isLoaded())
|
|
521
521
|
throw new Error("TokenManager is not loaded. Tokens must be loaded before using this module.");
|
|
522
|
-
const
|
|
523
|
-
if (!
|
|
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(
|
|
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
|
|
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
|
|
539
|
-
throw console.error("[breakpoints/tokenManager] ❌ Failed to generate breakpoints:",
|
|
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
|
-
}),
|
|
542
|
+
}), Fe = "styles.css", xe = "index.ts", A = (t, e) => {
|
|
543
543
|
if (!e.length) return "";
|
|
544
|
-
const
|
|
544
|
+
const o = e.map((r) => ` ${r}`).join(`
|
|
545
545
|
`);
|
|
546
546
|
return `${t} {
|
|
547
|
-
${
|
|
547
|
+
${o}
|
|
548
548
|
}`;
|
|
549
|
-
},
|
|
550
|
-
(e,
|
|
551
|
-
const r =
|
|
552
|
-
return typeof
|
|
553
|
-
e[
|
|
554
|
-
}) : e.root.push(`${r}: ${
|
|
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
|
-
),
|
|
558
|
-
const e = A(".color-variables", t.root),
|
|
559
|
-
if (
|
|
560
|
-
const a = A(
|
|
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,
|
|
565
|
+
return [e, o].filter(Boolean).join(`
|
|
566
566
|
|
|
567
567
|
`);
|
|
568
|
-
},
|
|
569
|
-
${t.map((r) => ` '${r.name}': 'var(${
|
|
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
|
-
`,
|
|
576
|
+
`, Re = async ({
|
|
577
577
|
tsContent: t,
|
|
578
578
|
cssContent: e,
|
|
579
|
-
dir:
|
|
579
|
+
dir: o
|
|
580
580
|
}) => {
|
|
581
|
-
await d.delete(
|
|
582
|
-
const r = d.write(
|
|
583
|
-
await Promise.all([r,
|
|
584
|
-
},
|
|
585
|
-
const
|
|
586
|
-
await
|
|
587
|
-
},
|
|
588
|
-
const r = Number((
|
|
589
|
-
return [...e, `${
|
|
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 =
|
|
591
|
+
const e = M(t.stops);
|
|
592
592
|
return `linear-gradient(${t.angle}deg, ${e})`;
|
|
593
|
-
},
|
|
594
|
-
const e =
|
|
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
|
-
},
|
|
597
|
-
const e =
|
|
596
|
+
}, Ue = (t) => {
|
|
597
|
+
const e = M(t.stops);
|
|
598
598
|
return `linear-gradient(${t.angle}deg, ${e})`;
|
|
599
|
-
},
|
|
600
|
-
(
|
|
601
|
-
const
|
|
602
|
-
if (
|
|
603
|
-
const i = Object.keys(
|
|
604
|
-
(
|
|
605
|
-
...
|
|
606
|
-
[
|
|
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
|
-
) :
|
|
610
|
-
return { ...
|
|
609
|
+
) : K(l), u = { [n]: c };
|
|
610
|
+
return { ...o, ...u };
|
|
611
611
|
}
|
|
612
|
-
const a =
|
|
613
|
-
return { ...
|
|
612
|
+
const a = Z(s, n);
|
|
613
|
+
return { ...o, ...a };
|
|
614
614
|
},
|
|
615
615
|
{}
|
|
616
|
-
),
|
|
617
|
-
const
|
|
618
|
-
if (
|
|
619
|
-
if (
|
|
620
|
-
const a = typeof
|
|
621
|
-
return a ? { ...
|
|
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 =
|
|
624
|
-
return n ? { ...
|
|
625
|
-
}, {}),
|
|
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:
|
|
627
|
+
executor: async ({ tokenManagerClient: o }) => {
|
|
628
628
|
try {
|
|
629
629
|
console.log("[colors/tokenManager] Generating colors from TokenManager...");
|
|
630
|
-
const { includeVariables: r, includeStyles:
|
|
631
|
-
if (!(r != null && r.length) && !
|
|
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 (!
|
|
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 =
|
|
636
|
-
if (
|
|
637
|
-
const l =
|
|
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) =>
|
|
646
|
-
(l) => Object.entries(
|
|
647
|
-
(c, [u,
|
|
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
|
|
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
|
|
661
|
-
throw console.error("[colors/tokenManager] ❌ Failed to generate colors:",
|
|
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
|
-
}),
|
|
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
|
-
}`,
|
|
675
|
-
const
|
|
674
|
+
}`, ze = (t, e) => {
|
|
675
|
+
const o = e || "components", r = t.map((s) => We(s)).join(`
|
|
676
676
|
|
|
677
677
|
`);
|
|
678
|
-
return `@layer ${
|
|
678
|
+
return `@layer ${o} {
|
|
679
679
|
${r}
|
|
680
680
|
}`;
|
|
681
|
-
},
|
|
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,
|
|
686
|
-
await d.delete(t,
|
|
687
|
-
},
|
|
688
|
-
const r =
|
|
689
|
-
await D("styles.module.css", r, e), await D("index.ts",
|
|
690
|
-
},
|
|
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
|
-
},
|
|
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" ||
|
|
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
|
-
}, []),
|
|
711
|
+
}, []), Jt = ({
|
|
712
712
|
input: t = {},
|
|
713
713
|
output: { dir: e }
|
|
714
714
|
}) => ({
|
|
715
715
|
name: "container/tokenManager",
|
|
716
|
-
executor: async ({ tokenManagerClient:
|
|
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 (!
|
|
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
|
|
724
|
-
if (!
|
|
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 =
|
|
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
|
|
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
|
|
740
|
-
throw console.error("[container/tokenManager] ❌ Failed to generate container:",
|
|
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
|
-
}),
|
|
743
|
+
}), He = "styles.css", Qe = "index.ts", L = (t, e) => {
|
|
744
744
|
if (!e.length) return "";
|
|
745
|
-
const
|
|
745
|
+
const o = e.map((r) => ` ${r}`).join(`
|
|
746
746
|
`);
|
|
747
747
|
return `${t} {
|
|
748
|
-
${
|
|
748
|
+
${o}
|
|
749
749
|
}`;
|
|
750
|
-
},
|
|
751
|
-
(e,
|
|
752
|
-
const r =
|
|
753
|
-
return typeof
|
|
754
|
-
const i =
|
|
755
|
-
return { ...
|
|
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
|
-
),
|
|
760
|
-
const e = L(".shadow-variables", t.root),
|
|
761
|
-
if (
|
|
762
|
-
const a = L(
|
|
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,
|
|
767
|
+
return [e, o].filter(Boolean).join(`
|
|
768
768
|
|
|
769
769
|
`);
|
|
770
|
-
},
|
|
771
|
-
${t.map((r) => ` '${r.name}': 'var(${
|
|
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
|
-
`,
|
|
778
|
+
`, tt = async ({
|
|
779
779
|
tsContent: t,
|
|
780
780
|
cssContent: e,
|
|
781
|
-
dir:
|
|
781
|
+
dir: o
|
|
782
782
|
}) => {
|
|
783
|
-
await d.delete(
|
|
784
|
-
const r = d.write(
|
|
785
|
-
await Promise.all([r,
|
|
786
|
-
},
|
|
787
|
-
const
|
|
788
|
-
await
|
|
789
|
-
},
|
|
790
|
-
(
|
|
791
|
-
const
|
|
792
|
-
if (
|
|
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]:
|
|
794
|
+
[n]: s.value.map(Xe).join(", ")
|
|
795
795
|
};
|
|
796
|
-
return { ...
|
|
796
|
+
return { ...o, ...i };
|
|
797
797
|
}
|
|
798
|
-
const a =
|
|
799
|
-
return { ...
|
|
798
|
+
const a = _(s, n);
|
|
799
|
+
return { ...o, ...a };
|
|
800
800
|
},
|
|
801
801
|
{}
|
|
802
|
-
),
|
|
802
|
+
), qt = ({ input: t = {}, output: { dir: e } }) => ({
|
|
803
803
|
name: "shadows/tokenManager",
|
|
804
|
-
executor: async ({ tokenManagerClient:
|
|
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 (!
|
|
810
|
+
if (!o.isLoaded())
|
|
811
811
|
throw new Error("TokenManager is not loaded. Tokens must be loaded before using this module.");
|
|
812
|
-
const
|
|
812
|
+
const s = [];
|
|
813
813
|
if (r) {
|
|
814
|
-
const a =
|
|
815
|
-
console.log("[shadows/tokenManager] Processing styles for shadows..."), 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 =
|
|
818
|
-
(a) => Object.entries(
|
|
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
|
|
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
|
|
833
|
-
throw console.error("[shadows/tokenManager] ❌ Failed to generate shadows:",
|
|
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
|
-
}),
|
|
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
|
|
838
|
+
const o = e.map((r) => ` ${r}`).join(`
|
|
839
839
|
`);
|
|
840
840
|
return `${t} {
|
|
841
|
-
${
|
|
841
|
+
${o}
|
|
842
842
|
}`;
|
|
843
|
-
},
|
|
843
|
+
}, ee = (t, e) => {
|
|
844
844
|
if (typeof t != "string") return t;
|
|
845
|
-
const
|
|
846
|
-
return
|
|
847
|
-
},
|
|
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:
|
|
849
|
+
fontFamily: ee(t.fontFamily, e)
|
|
850
850
|
}, T = (t, e) => {
|
|
851
|
-
const
|
|
852
|
-
return Object.entries(t).forEach(([r,
|
|
853
|
-
const n = r === "fontFamily" ?
|
|
854
|
-
|
|
855
|
-
}),
|
|
856
|
-
},
|
|
857
|
-
const r = Object.keys(t.breakpoints),
|
|
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],
|
|
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
|
-
...
|
|
865
|
+
...s,
|
|
866
866
|
...l
|
|
867
867
|
}
|
|
868
868
|
}
|
|
@@ -871,93 +871,93 @@ ${s}
|
|
|
871
871
|
[
|
|
872
872
|
{
|
|
873
873
|
breakpoint: null,
|
|
874
|
-
css:
|
|
874
|
+
css: s
|
|
875
875
|
}
|
|
876
876
|
]
|
|
877
877
|
);
|
|
878
|
-
},
|
|
878
|
+
}, te = () => ({
|
|
879
879
|
base: {},
|
|
880
880
|
breakpoints: {}
|
|
881
|
-
}), O = (t, e,
|
|
882
|
-
Object.keys(r).length && (t.breakpoints[e] || (t.breakpoints[e] = {}), t.breakpoints[e][
|
|
883
|
-
...t.breakpoints[e][
|
|
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
|
-
},
|
|
887
|
-
|
|
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
|
-
},
|
|
895
|
-
const e =
|
|
896
|
-
const n = t.breakpoints[
|
|
897
|
-
return r + `@media (max-width: ${
|
|
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 +
|
|
900
|
-
},
|
|
901
|
-
const r = t.reduce((
|
|
902
|
-
return
|
|
903
|
-
},
|
|
904
|
-
const r = t[
|
|
905
|
-
return e + `.typo-${
|
|
906
|
-
}, ""),
|
|
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
|
-
},
|
|
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
|
|
913
|
+
if (e.endsWith("rem")) return G(e);
|
|
914
914
|
if (e.endsWith("px")) {
|
|
915
|
-
const
|
|
916
|
-
return
|
|
915
|
+
const o = G(e);
|
|
916
|
+
return o === null ? null : o / 16;
|
|
917
917
|
}
|
|
918
918
|
return null;
|
|
919
|
-
},
|
|
920
|
-
const { minValueRem: e, maxValueRem:
|
|
921
|
-
return `calc(${e}rem + ((100vw - ${r}rem) / (${
|
|
922
|
-
},
|
|
923
|
-
const
|
|
924
|
-
const
|
|
925
|
-
return { breakpointName:
|
|
926
|
-
}).filter((
|
|
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
|
-
|
|
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
|
-
|
|
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),
|
|
937
|
-
if (
|
|
938
|
-
|
|
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
|
|
946
|
-
const
|
|
947
|
-
if (
|
|
948
|
-
return
|
|
949
|
-
const
|
|
950
|
-
return
|
|
951
|
-
...
|
|
952
|
-
[
|
|
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,
|
|
956
|
-
},
|
|
957
|
-
if (!r) return
|
|
958
|
-
const
|
|
959
|
-
return
|
|
960
|
-
},
|
|
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
|
-
` : "",
|
|
968
|
+
` : "", ft = (t, e) => t.length ? `const typography = {
|
|
969
969
|
${t.map((r) => {
|
|
970
|
-
const
|
|
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]:
|
|
973
|
+
[i]: z(l, e)
|
|
974
974
|
}),
|
|
975
975
|
{}
|
|
976
976
|
);
|
|
977
977
|
return ` '${r.name}': {
|
|
978
|
-
base: ${JSON.stringify(
|
|
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:
|
|
991
|
+
cssContent: o,
|
|
992
992
|
dir: r
|
|
993
993
|
}) => {
|
|
994
994
|
await d.delete(r);
|
|
995
|
-
const
|
|
996
|
-
await Promise.all([
|
|
997
|
-
},
|
|
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:
|
|
1000
|
+
breakpoints: o,
|
|
1001
1001
|
fontFamily: r,
|
|
1002
|
-
fluid:
|
|
1002
|
+
fluid: s
|
|
1003
1003
|
}) => {
|
|
1004
|
-
const n =
|
|
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,
|
|
1007
|
-
const n = t[
|
|
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, [
|
|
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
|
|
1015
|
-
if (
|
|
1016
|
-
|
|
1017
|
-
const
|
|
1018
|
-
|
|
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
|
|
1022
|
-
|
|
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, [
|
|
1029
|
-
}, {}),
|
|
1030
|
-
const
|
|
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 { ...
|
|
1032
|
+
return { ...o, ...se(n, s) };
|
|
1033
1033
|
const a = n.value;
|
|
1034
|
-
return { ...
|
|
1035
|
-
}, {}),
|
|
1034
|
+
return { ...o, [s]: a };
|
|
1035
|
+
}, {}), Ht = ({ input: t, output: { dir: e } }) => ({
|
|
1036
1036
|
name: "typography/tokenManager",
|
|
1037
|
-
executor: async ({ tokenManagerClient:
|
|
1037
|
+
executor: async ({ tokenManagerClient: o }) => {
|
|
1038
1038
|
try {
|
|
1039
1039
|
console.log("[typography/tokenManager] Generating typography from TokenManager...");
|
|
1040
|
-
const { breakpoints: r, fontFamily:
|
|
1041
|
-
if (!
|
|
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 =
|
|
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,
|
|
1046
|
+
(u, f) => ({
|
|
1047
1047
|
...u,
|
|
1048
|
-
...oe(
|
|
1048
|
+
...oe(f, o, { breakpoints: t.breakpoints })
|
|
1049
1049
|
}),
|
|
1050
1050
|
{}
|
|
1051
|
-
), c = Object.entries(
|
|
1052
|
-
([u,
|
|
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
|
|
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:
|
|
1062
|
+
fontFamily: s || {},
|
|
1063
1063
|
fluid: n
|
|
1064
1064
|
}), console.log("[typography/tokenManager] ✅ Successfully generated typography files");
|
|
1065
1065
|
} catch (r) {
|
|
1066
|
-
const
|
|
1067
|
-
throw console.error("[typography/tokenManager] ❌ Failed to generate typography:",
|
|
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
|
-
}),
|
|
1071
|
-
const
|
|
1072
|
-
if (!
|
|
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 =
|
|
1074
|
+
const r = q(t, o);
|
|
1075
1075
|
if (r === void 0)
|
|
1076
|
-
throw new Error(`Variables subtree not found at path: ${
|
|
1076
|
+
throw new Error(`Variables subtree not found at path: ${o.join(".")}`);
|
|
1077
1077
|
return r;
|
|
1078
|
-
},
|
|
1078
|
+
}, ae = (t, e, o) => {
|
|
1079
1079
|
if (!t) return [];
|
|
1080
|
-
if (
|
|
1080
|
+
if (pt(t)) {
|
|
1081
1081
|
if (t.type !== "dimension") return [];
|
|
1082
|
-
const r = t.value,
|
|
1083
|
-
const i = r[a], l =
|
|
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:
|
|
1086
|
+
return [{ flatName: e, resolvedByMode: s }];
|
|
1087
1087
|
}
|
|
1088
|
-
return
|
|
1089
|
-
const
|
|
1090
|
-
return
|
|
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
|
-
},
|
|
1093
|
-
(
|
|
1094
|
-
) : t,
|
|
1095
|
-
const e =
|
|
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
|
|
1098
|
+
const o = e[e.length - 1];
|
|
1099
1099
|
return {
|
|
1100
|
-
variablesClassName: `${
|
|
1101
|
-
variableNamePrefix:
|
|
1100
|
+
variablesClassName: `${o}-variables`,
|
|
1101
|
+
variableNamePrefix: o
|
|
1102
1102
|
};
|
|
1103
|
-
},
|
|
1104
|
-
const
|
|
1103
|
+
}, $t = (t, e) => {
|
|
1104
|
+
const r = le(t.variablePath).variableNamePrefix, s = e.variablesClassName ?? `${r}-variables`;
|
|
1105
1105
|
return {
|
|
1106
|
-
variableNamePrefix:
|
|
1107
|
-
variablesClassName:
|
|
1106
|
+
variableNamePrefix: r,
|
|
1107
|
+
variablesClassName: s
|
|
1108
1108
|
};
|
|
1109
|
-
}, ce = (t, e,
|
|
1110
|
-
const r =
|
|
1111
|
-
|
|
1112
|
-
|
|
1113
|
-
|
|
1114
|
-
|
|
1115
|
-
|
|
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
|
-
),
|
|
1119
|
-
const
|
|
1120
|
-
if (Object.keys(
|
|
1121
|
-
const
|
|
1122
|
-
return { base: { [
|
|
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
|
|
1125
|
-
if (
|
|
1126
|
-
const
|
|
1127
|
-
return { base: { [
|
|
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 (
|
|
1130
|
-
const
|
|
1131
|
-
return { base: { [
|
|
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
|
|
1134
|
-
const
|
|
1135
|
-
if (
|
|
1136
|
-
const
|
|
1137
|
-
return { ...
|
|
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: { [
|
|
1140
|
-
},
|
|
1141
|
-
(
|
|
1142
|
-
const { base:
|
|
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: { ...
|
|
1150
|
-
breakpoints: Tt(
|
|
1151
|
+
base: { ...r.base, ...n },
|
|
1152
|
+
breakpoints: Tt(r.breakpoints, a)
|
|
1151
1153
|
};
|
|
1152
1154
|
},
|
|
1153
1155
|
{ base: {}, breakpoints: {} }
|
|
1154
|
-
),
|
|
1156
|
+
), Mt = (t, e, o) => {
|
|
1155
1157
|
if (!t.length) return "";
|
|
1156
|
-
const {
|
|
1157
|
-
const
|
|
1158
|
-
return `@media (max-width: ${
|
|
1159
|
-
${
|
|
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
|
|
1166
|
+
return i ? `${a}
|
|
1165
1167
|
|
|
1166
|
-
${
|
|
1168
|
+
${i}` : a;
|
|
1167
1169
|
}, Ct = (t, e) => {
|
|
1168
|
-
const
|
|
1170
|
+
const o = t.resolvedByMode, r = ie(e), s = Object.keys(e).length > 0 && r.length > 0;
|
|
1169
1171
|
return { breakpoints: (() => {
|
|
1170
|
-
if (!
|
|
1171
|
-
return Object.keys(
|
|
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
|
|
1175
|
-
}), Object.keys(
|
|
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 =
|
|
1181
|
+
const c = o[l];
|
|
1180
1182
|
return c === void 0 ? i : { ...i, [l]: c };
|
|
1181
1183
|
}, {}) };
|
|
1182
|
-
},
|
|
1183
|
-
const { breakpoints:
|
|
1184
|
+
}, Nt = (t, e) => {
|
|
1185
|
+
const { breakpoints: o } = e;
|
|
1184
1186
|
return t.length ? `const utilities = {
|
|
1185
|
-
${t.map((
|
|
1186
|
-
const n = Ct(
|
|
1187
|
-
return ` '${
|
|
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,
|
|
1199
|
-
(r,
|
|
1200
|
+
}, Vt = (t, e, o) => t.reduce(
|
|
1201
|
+
(r, s) => ({
|
|
1200
1202
|
...r,
|
|
1201
|
-
[
|
|
1203
|
+
[s.flatName]: ue(e, o, s.flatName)
|
|
1202
1204
|
}),
|
|
1203
1205
|
{}
|
|
1204
|
-
),
|
|
1205
|
-
const r =
|
|
1206
|
-
return
|
|
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 = ${
|
|
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
|
-
},
|
|
1230
|
+
}, xt = "styles.css", Ot = "utilities.ts", Pt = "index.ts", Et = async ({
|
|
1248
1231
|
dir: t,
|
|
1249
1232
|
globalCss: e,
|
|
1250
|
-
utilitiesTs:
|
|
1233
|
+
utilitiesTs: o,
|
|
1251
1234
|
indexTs: r
|
|
1252
1235
|
}) => {
|
|
1253
1236
|
await d.delete(t), await Promise.all([
|
|
1254
|
-
d.write(
|
|
1255
|
-
d.write(
|
|
1256
|
-
d.write(
|
|
1237
|
+
d.write(xt, e, { directory: t }),
|
|
1238
|
+
d.write(Ot, o, { directory: t }),
|
|
1239
|
+
d.write(Pt, r, { directory: t })
|
|
1257
1240
|
]);
|
|
1258
|
-
},
|
|
1241
|
+
}, Bt = async ({
|
|
1259
1242
|
tokens: t,
|
|
1260
1243
|
input: e,
|
|
1261
|
-
output:
|
|
1244
|
+
output: o
|
|
1262
1245
|
}) => {
|
|
1263
|
-
const { dir: r } =
|
|
1264
|
-
await
|
|
1265
|
-
},
|
|
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:
|
|
1250
|
+
executor: async ({ tokenManagerClient: o }) => {
|
|
1268
1251
|
var r;
|
|
1269
1252
|
try {
|
|
1270
|
-
if (console.log("[utilities/tokenManager] Generating utility classes from TokenManager..."), !
|
|
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
|
|
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
|
|
1280
|
-
} catch (
|
|
1281
|
-
const n =
|
|
1282
|
-
throw console.error("[utilities/tokenManager] ❌ Failed to generate utilities:", 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;
|
|
1283
1266
|
}
|
|
1284
1267
|
}
|
|
1285
1268
|
});
|
|
1286
1269
|
export {
|
|
1287
1270
|
ke as BREAKPOINTS_NAMES,
|
|
1288
|
-
|
|
1289
|
-
|
|
1290
|
-
|
|
1291
|
-
|
|
1292
|
-
|
|
1293
|
-
|
|
1294
|
-
|
|
1295
|
-
|
|
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
|
-
|
|
1298
|
-
|
|
1299
|
-
|
|
1300
|
-
|
|
1280
|
+
Wt as generate,
|
|
1281
|
+
Bt as generateUtilitiesFiles,
|
|
1282
|
+
ie as getSortedBreakpointModes,
|
|
1283
|
+
Qt as getUtilityCssVariableName,
|
|
1301
1284
|
ce as getUtilityCssVariableNameWithoutDashes,
|
|
1302
|
-
|
|
1303
|
-
|
|
1304
|
-
|
|
1305
|
-
|
|
1306
|
-
|
|
1307
|
-
|
|
1308
|
-
|
|
1309
|
-
Ht as
|
|
1310
|
-
|
|
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
|
-
|
|
1296
|
+
Et as writeUtilitiesFiles
|
|
1313
1297
|
};
|