x-app-sdk 1.0.4 → 1.0.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/dist/index.es.js CHANGED
@@ -1,64 +1,80 @@
1
- var Ze = Object.defineProperty;
2
- var Le = (e, r, t) => r in e ? Ze(e, r, { enumerable: !0, configurable: !0, writable: !0, value: t }) : e[r] = t;
3
- var k = (e, r, t) => Le(e, typeof r != "symbol" ? r + "" : r, t);
4
- import { jsx as Ie } from "react/jsx-runtime";
5
- import * as ue from "react";
6
- class ze {
1
+ var a = Object.defineProperty;
2
+ var d = (A, g, I) => g in A ? a(A, g, { enumerable: !0, configurable: !0, writable: !0, value: I }) : A[g] = I;
3
+ var n = (A, g, I) => d(A, typeof g != "symbol" ? g + "" : g, I);
4
+ var t = /* @__PURE__ */ ((A) => (A.RequestConfigUIApp = "requestConfigUIApp", A.RequestInfo = "requestInfo", A.RequestCloseApp = "requestCloseApp", A.RequestPickerImage = "requestPickerImage", A.RequestVibrate = "requestVibrate", A))(t || {}), o = /* @__PURE__ */ ((A) => (A.ResponseConfigApp = "responseConfigUIApp", A.ResponseInfo = "responseInfo", A.ResponsePickerImage = "responsePickerImage", A.ResponseVibrate = "responseVibrate", A.ResponseCloseApp = "responseCloseApp", A.ResponsePremission = "responsePremission", A))(o || {}), i = /* @__PURE__ */ ((A) => (A.SUCCESS = "success", A.ERROR = "error", A.PREMISSION_ERROR = "premissionError", A))(i || {}), l = /* @__PURE__ */ ((A) => (A.USER = "user", A))(l || {});
5
+ class h {
7
6
  constructor() {
8
- k(this, "handlers");
9
- k(this, "isInitialized");
10
- k(this, "isBrowserMode");
11
- k(this, "cachedInfo");
12
- k(this, "infoRequests");
13
- this.handlers = /* @__PURE__ */ new Map(), this.isInitialized = !1, this.isBrowserMode = !1, this.cachedInfo = /* @__PURE__ */ new Map(), this.infoRequests = /* @__PURE__ */ new Map(), this.initialize();
7
+ n(this, "premissions");
8
+ n(this, "getPremissions", () => ({
9
+ [t.RequestInfo]: !0,
10
+ [t.RequestCloseApp]: !0,
11
+ [t.RequestPickerImage]: !0,
12
+ [t.RequestVibrate]: !0
13
+ }));
14
+ n(this, "checkPremission", (g) => this.premissions[g]);
15
+ this.premissions = {}, this.initialize();
14
16
  }
15
17
  initialize() {
16
- window.Flutter ? (this.setupMessageHandler(), this.isInitialized = !0, this.isBrowserMode = !1, this.send("requestInitialInfo", {})) : (this.isInitialized = !0, this.isBrowserMode = !0, console.warn("Flutter channel not found. Running in browser mode."));
18
+ window.Flutter || (this.premissions = this.getPremissions());
19
+ }
20
+ }
21
+ class p {
22
+ constructor() {
23
+ n(this, "handlers");
24
+ n(this, "isInitialized");
25
+ n(this, "isBrowserMode");
26
+ n(this, "cachedInfo");
27
+ n(this, "infoRequests");
28
+ n(this, "premissionEvent");
29
+ this.handlers = /* @__PURE__ */ new Map(), this.isInitialized = !1, this.isBrowserMode = !1, this.cachedInfo = /* @__PURE__ */ new Map(), this.infoRequests = /* @__PURE__ */ new Map(), this.premissionEvent = new h(), this.initialize();
30
+ }
31
+ initialize() {
32
+ window.Flutter ? (this.setupMessageHandler(), this.isInitialized = !0, this.isBrowserMode = !1, this.send(t.RequestInfo, {})) : (this.isInitialized = !0, this.isBrowserMode = !0, console.warn("Flutter channel not found. Running in browser mode."));
17
33
  }
18
34
  setupMessageHandler() {
19
- window.receiveFromFlutter = (r) => {
35
+ window.receiveFromFlutter = (g) => {
20
36
  try {
21
- const t = JSON.parse(r);
22
- if (t.type === "infoUpdate") {
23
- this.handleInfoUpdate(t.data);
37
+ const I = JSON.parse(g);
38
+ if (I.type === o.ResponseInfo) {
39
+ this.handleInfoUpdate(I.data);
24
40
  return;
25
41
  }
26
- this.handleMessage(t);
27
- } catch (t) {
28
- console.error("Error parsing message from Flutter:", t);
42
+ this.handleMessage(I);
43
+ } catch (I) {
44
+ console.error("Error parsing message from Flutter:", I);
29
45
  }
30
46
  };
31
47
  }
32
- handleInfoUpdate(r) {
33
- r && Object.entries(r).forEach(([t, s]) => {
34
- this.cachedInfo.set(t, s), (this.infoRequests.get(t) || []).forEach((d) => d(s)), this.infoRequests.delete(t);
48
+ handleInfoUpdate(g) {
49
+ g && Object.entries(g).forEach(([I, C]) => {
50
+ this.cachedInfo.set(I, C), (this.infoRequests.get(I) || []).forEach((r) => r(C)), this.infoRequests.delete(I);
35
51
  });
36
52
  }
37
- handleMessage(r) {
38
- (this.handlers.get(r.type) || []).forEach((s) => {
53
+ handleMessage(g) {
54
+ (this.handlers.get(g.type) || []).forEach((C) => {
39
55
  try {
40
- s(r);
41
- } catch (i) {
42
- console.error("Error in message handler:", i);
56
+ C(g);
57
+ } catch (s) {
58
+ console.error("Error in message handler:", s);
43
59
  }
44
60
  });
45
61
  }
46
- send(r, t) {
47
- var i;
62
+ send(g, I) {
63
+ var s;
48
64
  if (!this.isInitialized) {
49
- console.warn("SDK not initialized");
65
+ console.error("SDK not initialized");
50
66
  return;
51
67
  }
52
- const s = { type: r, data: t };
53
- (i = window.Flutter) == null || i.postMessage(JSON.stringify(s));
68
+ const C = { type: g, data: I };
69
+ (s = window.Flutter) == null || s.postMessage(JSON.stringify(C));
54
70
  }
55
- on(r, t) {
56
- const s = this.handlers.get(r) || [];
57
- s.push(t), this.handlers.set(r, s);
71
+ on(g, I) {
72
+ const C = this.handlers.get(g) || [];
73
+ C.push(I), this.handlers.set(g, C);
58
74
  }
59
- off(r, t) {
60
- const s = this.handlers.get(r) || [], i = s.indexOf(t);
61
- i > -1 && (s.splice(i, 1), this.handlers.set(r, s));
75
+ off(g, I) {
76
+ const C = this.handlers.get(g) || [], s = C.indexOf(I);
77
+ s > -1 && (C.splice(s, 1), this.handlers.set(g, C));
62
78
  }
63
79
  getBrowserMode() {
64
80
  return this.isBrowserMode;
@@ -66,2618 +82,125 @@ class ze {
66
82
  getInitialized() {
67
83
  return this.isInitialized;
68
84
  }
69
- getCachedInfo(r) {
70
- return this.cachedInfo.get(r);
85
+ getCachedInfo(g) {
86
+ return this.cachedInfo.get(g);
71
87
  }
72
88
  getInfoRequests() {
73
89
  return this.infoRequests;
74
90
  }
75
- setInfoRequest(r, t) {
76
- this.infoRequests.set(r, t);
91
+ setInfoRequest(g, I) {
92
+ this.infoRequests.set(g, I);
93
+ }
94
+ checkPremissionEvent(g) {
95
+ return this.premissionEvent.checkPremission(g);
77
96
  }
78
97
  }
79
- const P = new ze();
80
- var C = /* @__PURE__ */ ((e) => (e.SUCCESS = "success", e.ERROR = "error", e))(C || {}), je = /* @__PURE__ */ ((e) => (e.RequestInfo = "requestInfo", e.RequestCloseApp = "requestCloseApp", e.RequestPickerImage = "requestPickerImage", e))(je || {}), Ee = /* @__PURE__ */ ((e) => e)(Ee || {}), Re = /* @__PURE__ */ ((e) => (e.USER = "user", e))(Re || {});
81
- const Xe = {
98
+ const e = new p();
99
+ e.getBrowserMode();
100
+ const R = {
82
101
  user: {
83
102
  name: "Pham Hong Son"
84
103
  }
85
- }, Ge = {
86
- path: "/hello.png",
87
- base64: ""
88
- }, Zt = async (e) => {
89
- if (P.getBrowserMode()) {
90
- const t = {
91
- type: "",
92
- status: C.SUCCESS,
93
- data: Xe[e]
104
+ }, m = async (A) => {
105
+ if (e.getBrowserMode()) {
106
+ if (!e.checkPremissionEvent(t.RequestInfo)) {
107
+ const C = {
108
+ type: o.ResponseInfo,
109
+ status: i.PREMISSION_ERROR
110
+ };
111
+ return Promise.resolve(C);
112
+ }
113
+ const I = {
114
+ type: o.ResponseInfo,
115
+ status: i.SUCCESS,
116
+ data: R[A]
94
117
  };
95
- return Promise.resolve(t);
96
- }
97
- const r = P.getCachedInfo(e);
98
- if (r !== void 0) {
99
- const t = {
100
- type: "",
101
- status: C.SUCCESS,
102
- data: r
118
+ return Promise.resolve(I);
119
+ }
120
+ const g = e.getCachedInfo(A);
121
+ if (g !== void 0) {
122
+ const I = {
123
+ type: o.ResponseInfo,
124
+ status: i.SUCCESS,
125
+ data: g
103
126
  };
104
- return Promise.resolve(t);
105
- }
106
- return new Promise((t) => {
107
- const i = P.getInfoRequests().get(e) || [];
108
- i.push((d) => {
109
- const l = {
110
- type: "",
111
- status: C.SUCCESS,
112
- data: d
127
+ return Promise.resolve(I);
128
+ }
129
+ return new Promise((I) => {
130
+ const s = e.getInfoRequests().get(A) || [];
131
+ s.push((r) => {
132
+ const c = {
133
+ type: o.ResponseInfo,
134
+ status: i.SUCCESS,
135
+ data: r
113
136
  };
114
- t(l);
115
- }), P.setInfoRequest(e, i), P.send("requestInfo", { key: e });
137
+ I(c);
138
+ }), e.setInfoRequest(A, s), e.send(t.RequestInfo, { key: A });
116
139
  });
117
- }, Lt = async () => {
118
- if (!P.getInitialized())
140
+ }, u = {
141
+ path: "/hello.png",
142
+ base64: ""
143
+ }, f = async () => {
144
+ if (!e.getInitialized())
119
145
  throw new Error("SDK not initialized");
120
- if (P.getBrowserMode()) {
121
- const e = {
122
- type: "",
123
- status: C.SUCCESS,
124
- data: Ge
146
+ if (e.getBrowserMode()) {
147
+ if (!e.checkPremissionEvent(t.RequestPickerImage)) {
148
+ const g = {
149
+ type: o.ResponsePickerImage,
150
+ status: i.PREMISSION_ERROR
151
+ };
152
+ return Promise.resolve(g);
153
+ }
154
+ const A = {
155
+ type: o.ResponsePickerImage,
156
+ status: i.SUCCESS,
157
+ data: u
125
158
  };
126
- return Promise.resolve(e);
159
+ return Promise.resolve(A);
127
160
  }
128
- return new Promise((e, r) => {
129
- const t = (s) => {
130
- s.status === C.ERROR ? r(s) : e(s), P.off("camera_result", t);
161
+ return new Promise((A, g) => {
162
+ const I = (C) => {
163
+ C.status === i.ERROR ? g(C) : A(C), e.off(o.ResponsePickerImage, I);
131
164
  };
132
- P.on("camera_result", t), P.send("requestPickerImage", void 0);
165
+ e.on(o.ResponsePickerImage, I), e.send(t.RequestPickerImage, void 0);
133
166
  });
134
- }, It = (e) => {
135
- P.send("requestCloseApp", e);
136
- };
137
- function he(e) {
138
- var r, t, s = "";
139
- if (typeof e == "string" || typeof e == "number") s += e;
140
- else if (typeof e == "object") if (Array.isArray(e)) {
141
- var i = e.length;
142
- for (r = 0; r < i; r++) e[r] && (t = he(e[r])) && (s && (s += " "), s += t);
143
- } else for (t in e) e[t] && (s && (s += " "), s += t);
144
- return s;
145
- }
146
- function ke() {
147
- for (var e, r, t = 0, s = "", i = arguments.length; t < i; t++) (e = arguments[t]) && (r = he(e)) && (s && (s += " "), s += r);
148
- return s;
149
- }
150
- const se = "-", He = (e) => {
151
- const r = Ce(e), {
152
- conflictingClassGroups: t,
153
- conflictingClassGroupModifiers: s
154
- } = e;
155
- return {
156
- getClassGroupId: (l) => {
157
- const b = l.split(se);
158
- return b[0] === "" && b.length !== 1 && b.shift(), me(b, r) || De(l);
159
- },
160
- getConflictingClassGroupIds: (l, b) => {
161
- const u = t[l] || [];
162
- return b && s[l] ? [...u, ...s[l]] : u;
163
- }
164
- };
165
- }, me = (e, r) => {
166
- var l;
167
- if (e.length === 0)
168
- return r.classGroupId;
169
- const t = e[0], s = r.nextPart.get(t), i = s ? me(e.slice(1), s) : void 0;
170
- if (i)
171
- return i;
172
- if (r.validators.length === 0)
173
- return;
174
- const d = e.join(se);
175
- return (l = r.validators.find(({
176
- validator: b
177
- }) => b(d))) == null ? void 0 : l.classGroupId;
178
- }, xe = /^\[(.+)\]$/, De = (e) => {
179
- if (xe.test(e)) {
180
- const r = xe.exec(e)[1], t = r == null ? void 0 : r.substring(0, r.indexOf(":"));
181
- if (t)
182
- return "arbitrary.." + t;
183
- }
184
- }, Ce = (e) => {
185
- const {
186
- theme: r,
187
- classGroups: t
188
- } = e, s = {
189
- nextPart: /* @__PURE__ */ new Map(),
190
- validators: []
191
- };
192
- for (const i in t)
193
- ee(t[i], s, i, r);
194
- return s;
195
- }, ee = (e, r, t, s) => {
196
- e.forEach((i) => {
197
- if (typeof i == "string") {
198
- const d = i === "" ? r : be(r, i);
199
- d.classGroupId = t;
200
- return;
201
- }
202
- if (typeof i == "function") {
203
- if (Ye(i)) {
204
- ee(i(s), r, t, s);
205
- return;
206
- }
207
- r.validators.push({
208
- validator: i,
209
- classGroupId: t
210
- });
211
- return;
212
- }
213
- Object.entries(i).forEach(([d, l]) => {
214
- ee(l, be(r, d), t, s);
215
- });
216
- });
217
- }, be = (e, r) => {
218
- let t = e;
219
- return r.split(se).forEach((s) => {
220
- t.nextPart.has(s) || t.nextPart.set(s, {
221
- nextPart: /* @__PURE__ */ new Map(),
222
- validators: []
223
- }), t = t.nextPart.get(s);
224
- }), t;
225
- }, Ye = (e) => e.isThemeGetter, qe = (e) => {
226
- if (e < 1)
227
- return {
228
- get: () => {
229
- },
230
- set: () => {
231
- }
167
+ }, G = (A) => {
168
+ e.send(t.RequestCloseApp, A);
169
+ }, B = async () => {
170
+ if (!e.checkPremissionEvent(t.RequestPickerImage)) {
171
+ const A = {
172
+ type: o.ResponseVibrate,
173
+ status: i.PREMISSION_ERROR
232
174
  };
233
- let r = 0, t = /* @__PURE__ */ new Map(), s = /* @__PURE__ */ new Map();
234
- const i = (d, l) => {
235
- t.set(d, l), r++, r > e && (r = 0, s = t, t = /* @__PURE__ */ new Map());
236
- };
237
- return {
238
- get(d) {
239
- let l = t.get(d);
240
- if (l !== void 0)
241
- return l;
242
- if ((l = s.get(d)) !== void 0)
243
- return i(d, l), l;
244
- },
245
- set(d, l) {
246
- t.has(d) ? t.set(d, l) : i(d, l);
247
- }
248
- };
249
- }, te = "!", re = ":", Je = re.length, Be = (e) => {
250
- const {
251
- prefix: r,
252
- experimentalParseClassName: t
253
- } = e;
254
- let s = (i) => {
255
- const d = [];
256
- let l = 0, b = 0, u = 0, g;
257
- for (let y = 0; y < i.length; y++) {
258
- let w = i[y];
259
- if (l === 0 && b === 0) {
260
- if (w === re) {
261
- d.push(i.slice(u, y)), u = y + Je;
262
- continue;
263
- }
264
- if (w === "/") {
265
- g = y;
266
- continue;
267
- }
268
- }
269
- w === "[" ? l++ : w === "]" ? l-- : w === "(" ? b++ : w === ")" && b--;
270
- }
271
- const h = d.length === 0 ? i : i.substring(u), M = We(h), J = M !== h, B = g && g > u ? g - u : void 0;
272
- return {
273
- modifiers: d,
274
- hasImportantModifier: J,
275
- baseClassName: M,
276
- maybePostfixModifierPosition: B
277
- };
278
- };
279
- if (r) {
280
- const i = r + re, d = s;
281
- s = (l) => l.startsWith(i) ? d(l.substring(i.length)) : {
282
- isExternal: !0,
283
- modifiers: [],
284
- hasImportantModifier: !1,
285
- baseClassName: l,
286
- maybePostfixModifierPosition: void 0
287
- };
288
- }
289
- if (t) {
290
- const i = s;
291
- s = (d) => t({
292
- className: d,
293
- parseClassName: i
294
- });
175
+ return Promise.resolve(A);
295
176
  }
296
- return s;
297
- }, We = (e) => e.endsWith(te) ? e.substring(0, e.length - 1) : e.startsWith(te) ? e.substring(1) : e, Oe = (e) => {
298
- const r = Object.fromEntries(e.orderSensitiveModifiers.map((s) => [s, !0]));
299
- return (s) => {
300
- if (s.length <= 1)
301
- return s;
302
- const i = [];
303
- let d = [];
304
- return s.forEach((l) => {
305
- l[0] === "[" || r[l] ? (i.push(...d.sort(), l), d = []) : d.push(l);
306
- }), i.push(...d.sort()), i;
307
- };
308
- }, Se = (e) => ({
309
- cache: qe(e.cacheSize),
310
- parseClassName: Be(e),
311
- sortModifiers: Oe(e),
312
- ...He(e)
313
- }), Te = /\s+/, Qe = (e, r) => {
314
- const {
315
- parseClassName: t,
316
- getClassGroupId: s,
317
- getConflictingClassGroupIds: i,
318
- sortModifiers: d
319
- } = r, l = [], b = e.trim().split(Te);
320
- let u = "";
321
- for (let g = b.length - 1; g >= 0; g -= 1) {
322
- const h = b[g], {
323
- isExternal: M,
324
- modifiers: J,
325
- hasImportantModifier: B,
326
- baseClassName: y,
327
- maybePostfixModifierPosition: w
328
- } = t(h);
329
- if (M) {
330
- u = h + (u.length > 0 ? " " + u : u);
331
- continue;
332
- }
333
- let E = !!w, I = s(E ? y.substring(0, w) : y);
334
- if (!I) {
335
- if (!E) {
336
- u = h + (u.length > 0 ? " " + u : u);
337
- continue;
338
- }
339
- if (I = s(y), !I) {
340
- u = h + (u.length > 0 ? " " + u : u);
341
- continue;
342
- }
343
- E = !1;
344
- }
345
- const W = d(J).join(":"), O = B ? W + te : W, R = O + I;
346
- if (l.includes(R))
347
- continue;
348
- l.push(R);
349
- const X = i(I, E);
350
- for (let a = 0; a < X.length; ++a) {
351
- const v = X[a];
352
- l.push(O + v);
353
- }
354
- u = h + (u.length > 0 ? " " + u : u);
177
+ e.send(t.RequestVibrate);
178
+ }, y = async (A) => {
179
+ if (!e.getInitialized())
180
+ throw new Error("SDK not initialized");
181
+ if (e.getBrowserMode()) {
182
+ const g = {
183
+ type: o.ResponseConfigApp,
184
+ status: i.SUCCESS
185
+ };
186
+ return Promise.resolve(g);
355
187
  }
356
- return u;
357
- };
358
- function Ve() {
359
- let e = 0, r, t, s = "";
360
- for (; e < arguments.length; )
361
- (r = arguments[e++]) && (t = pe(r)) && (s && (s += " "), s += t);
362
- return s;
363
- }
364
- const pe = (e) => {
365
- if (typeof e == "string")
366
- return e;
367
- let r, t = "";
368
- for (let s = 0; s < e.length; s++)
369
- e[s] && (r = pe(e[s])) && (t && (t += " "), t += r);
370
- return t;
188
+ return new Promise((g, I) => {
189
+ const C = (s) => {
190
+ s.status === i.ERROR ? I(s) : g(s), e.off(o.ResponseConfigApp, C);
191
+ };
192
+ e.on(o.ResponseConfigApp, C), e.send(t.RequestConfigUIApp, A);
193
+ });
371
194
  };
372
- function Ne(e, ...r) {
373
- let t, s, i, d = l;
374
- function l(u) {
375
- const g = r.reduce((h, M) => M(h), e());
376
- return t = Se(g), s = t.cache.get, i = t.cache.set, d = b, b(u);
377
- }
378
- function b(u) {
379
- const g = s(u);
380
- if (g)
381
- return g;
382
- const h = Qe(u, t);
383
- return i(u, h), h;
384
- }
385
- return function() {
386
- return d(Ve.apply(null, arguments));
387
- };
388
- }
389
- const f = (e) => {
390
- const r = (t) => t[e] || [];
391
- return r.isThemeGetter = !0, r;
392
- }, ye = /^\[(?:(\w[\w-]*):)?(.+)\]$/i, we = /^\((?:(\w[\w-]*):)?(.+)\)$/i, Fe = /^\d+\/\d+$/, Ue = /^(\d+(\.\d+)?)?(xs|sm|md|lg|xl)$/, Ke = /\d+(%|px|r?em|[sdl]?v([hwib]|min|max)|pt|pc|in|cm|mm|cap|ch|ex|r?lh|cq(w|h|i|b|min|max))|\b(calc|min|max|clamp)\(.+\)|^0$/, _e = /^(rgba?|hsla?|hwb|(ok)?(lab|lch))\(.+\)$/, $e = /^(inset_)?-?((\d+)?\.?(\d+)[a-z]+|0)_-?((\d+)?\.?(\d+)[a-z]+|0)/, et = /^(url|image|image-set|cross-fade|element|(repeating-)?(linear|radial|conic)-gradient)\(.+\)$/, H = (e) => Fe.test(e), c = (e) => !!e && !Number.isNaN(Number(e)), Z = (e) => !!e && Number.isInteger(Number(e)), fe = (e) => e.endsWith("%") && c(e.slice(0, -1)), L = (e) => Ue.test(e), tt = () => !0, rt = (e) => (
393
- // `colorFunctionRegex` check is necessary because color functions can have percentages in them which which would be incorrectly classified as lengths.
394
- // For example, `hsl(0 0% 0%)` would be classified as a length without this check.
395
- // I could also use lookbehind assertion in `lengthUnitRegex` but that isn't supported widely enough.
396
- Ke.test(e) && !_e.test(e)
397
- ), ne = () => !1, st = (e) => $e.test(e), nt = (e) => et.test(e), ot = (e) => !n(e) && !o(e), it = (e) => Y(e, Ae, ne), n = (e) => ye.test(e), j = (e) => Y(e, Me, rt), $ = (e) => Y(e, mt, c), at = (e) => Y(e, ve, ne), lt = (e) => Y(e, Pe, nt), dt = (e) => Y(e, ne, st), o = (e) => we.test(e), S = (e) => q(e, Me), ct = (e) => q(e, pt), ut = (e) => q(e, ve), xt = (e) => q(e, Ae), bt = (e) => q(e, Pe), ft = (e) => q(e, yt, !0), Y = (e, r, t) => {
398
- const s = ye.exec(e);
399
- return s ? s[1] ? r(s[1]) : t(s[2]) : !1;
400
- }, q = (e, r, t = !1) => {
401
- const s = we.exec(e);
402
- return s ? s[1] ? r(s[1]) : t : !1;
403
- }, ve = (e) => e === "position", gt = /* @__PURE__ */ new Set(["image", "url"]), Pe = (e) => gt.has(e), ht = /* @__PURE__ */ new Set(["length", "size", "percentage"]), Ae = (e) => ht.has(e), Me = (e) => e === "length", mt = (e) => e === "number", pt = (e) => e === "family-name", yt = (e) => e === "shadow", wt = () => {
404
- const e = f("color"), r = f("font"), t = f("text"), s = f("font-weight"), i = f("tracking"), d = f("leading"), l = f("breakpoint"), b = f("container"), u = f("spacing"), g = f("radius"), h = f("shadow"), M = f("inset-shadow"), J = f("drop-shadow"), B = f("blur"), y = f("perspective"), w = f("aspect"), E = f("ease"), I = f("animate"), W = () => ["auto", "avoid", "all", "avoid-page", "page", "left", "right", "column"], O = () => ["bottom", "center", "left", "left-bottom", "left-top", "right", "right-bottom", "right-top", "top"], R = () => ["auto", "hidden", "clip", "visible", "scroll"], X = () => ["auto", "contain", "none"], a = () => [o, n, u], v = () => [H, "full", "auto", ...a()], oe = () => [Z, "none", "subgrid", o, n], ie = () => ["auto", {
405
- span: ["full", Z, o, n]
406
- }, Z, o, n], T = () => [Z, "auto", o, n], ae = () => ["auto", "min", "max", "fr", o, n], U = () => ["start", "end", "center", "between", "around", "evenly", "stretch", "baseline"], G = () => ["start", "end", "center", "stretch"], A = () => ["auto", ...a()], z = () => [H, "auto", "full", "dvw", "dvh", "lvw", "lvh", "svw", "svh", "min", "max", "fit", ...a()], x = () => [e, o, n], K = () => [fe, S, j], m = () => [
407
- // Deprecated since Tailwind CSS v4.0.0
408
- "",
409
- "none",
410
- "full",
411
- g,
412
- o,
413
- n
414
- ], p = () => ["", c, S, j], Q = () => ["solid", "dashed", "dotted", "double"], le = () => ["normal", "multiply", "screen", "overlay", "darken", "lighten", "color-dodge", "color-burn", "hard-light", "soft-light", "difference", "exclusion", "hue", "saturation", "color", "luminosity"], de = () => [
415
- // Deprecated since Tailwind CSS v4.0.0
416
- "",
417
- "none",
418
- B,
419
- o,
420
- n
421
- ], ce = () => ["center", "top", "top-right", "right", "bottom-right", "bottom", "bottom-left", "left", "top-left", o, n], V = () => ["none", c, o, n], N = () => ["none", c, o, n], _ = () => [c, o, n], F = () => [H, "full", ...a()];
422
- return {
423
- cacheSize: 500,
424
- theme: {
425
- animate: ["spin", "ping", "pulse", "bounce"],
426
- aspect: ["video"],
427
- blur: [L],
428
- breakpoint: [L],
429
- color: [tt],
430
- container: [L],
431
- "drop-shadow": [L],
432
- ease: ["in", "out", "in-out"],
433
- font: [ot],
434
- "font-weight": ["thin", "extralight", "light", "normal", "medium", "semibold", "bold", "extrabold", "black"],
435
- "inset-shadow": [L],
436
- leading: ["none", "tight", "snug", "normal", "relaxed", "loose"],
437
- perspective: ["dramatic", "near", "normal", "midrange", "distant", "none"],
438
- radius: [L],
439
- shadow: [L],
440
- spacing: ["px", c],
441
- text: [L],
442
- tracking: ["tighter", "tight", "normal", "wide", "wider", "widest"]
443
- },
444
- classGroups: {
445
- // --------------
446
- // --- Layout ---
447
- // --------------
448
- /**
449
- * Aspect Ratio
450
- * @see https://tailwindcss.com/docs/aspect-ratio
451
- */
452
- aspect: [{
453
- aspect: ["auto", "square", H, n, o, w]
454
- }],
455
- /**
456
- * Container
457
- * @see https://tailwindcss.com/docs/container
458
- * @deprecated since Tailwind CSS v4.0.0
459
- */
460
- container: ["container"],
461
- /**
462
- * Columns
463
- * @see https://tailwindcss.com/docs/columns
464
- */
465
- columns: [{
466
- columns: [c, n, o, b]
467
- }],
468
- /**
469
- * Break After
470
- * @see https://tailwindcss.com/docs/break-after
471
- */
472
- "break-after": [{
473
- "break-after": W()
474
- }],
475
- /**
476
- * Break Before
477
- * @see https://tailwindcss.com/docs/break-before
478
- */
479
- "break-before": [{
480
- "break-before": W()
481
- }],
482
- /**
483
- * Break Inside
484
- * @see https://tailwindcss.com/docs/break-inside
485
- */
486
- "break-inside": [{
487
- "break-inside": ["auto", "avoid", "avoid-page", "avoid-column"]
488
- }],
489
- /**
490
- * Box Decoration Break
491
- * @see https://tailwindcss.com/docs/box-decoration-break
492
- */
493
- "box-decoration": [{
494
- "box-decoration": ["slice", "clone"]
495
- }],
496
- /**
497
- * Box Sizing
498
- * @see https://tailwindcss.com/docs/box-sizing
499
- */
500
- box: [{
501
- box: ["border", "content"]
502
- }],
503
- /**
504
- * Display
505
- * @see https://tailwindcss.com/docs/display
506
- */
507
- display: ["block", "inline-block", "inline", "flex", "inline-flex", "table", "inline-table", "table-caption", "table-cell", "table-column", "table-column-group", "table-footer-group", "table-header-group", "table-row-group", "table-row", "flow-root", "grid", "inline-grid", "contents", "list-item", "hidden"],
508
- /**
509
- * Screen Reader Only
510
- * @see https://tailwindcss.com/docs/display#screen-reader-only
511
- */
512
- sr: ["sr-only", "not-sr-only"],
513
- /**
514
- * Floats
515
- * @see https://tailwindcss.com/docs/float
516
- */
517
- float: [{
518
- float: ["right", "left", "none", "start", "end"]
519
- }],
520
- /**
521
- * Clear
522
- * @see https://tailwindcss.com/docs/clear
523
- */
524
- clear: [{
525
- clear: ["left", "right", "both", "none", "start", "end"]
526
- }],
527
- /**
528
- * Isolation
529
- * @see https://tailwindcss.com/docs/isolation
530
- */
531
- isolation: ["isolate", "isolation-auto"],
532
- /**
533
- * Object Fit
534
- * @see https://tailwindcss.com/docs/object-fit
535
- */
536
- "object-fit": [{
537
- object: ["contain", "cover", "fill", "none", "scale-down"]
538
- }],
539
- /**
540
- * Object Position
541
- * @see https://tailwindcss.com/docs/object-position
542
- */
543
- "object-position": [{
544
- object: [...O(), n, o]
545
- }],
546
- /**
547
- * Overflow
548
- * @see https://tailwindcss.com/docs/overflow
549
- */
550
- overflow: [{
551
- overflow: R()
552
- }],
553
- /**
554
- * Overflow X
555
- * @see https://tailwindcss.com/docs/overflow
556
- */
557
- "overflow-x": [{
558
- "overflow-x": R()
559
- }],
560
- /**
561
- * Overflow Y
562
- * @see https://tailwindcss.com/docs/overflow
563
- */
564
- "overflow-y": [{
565
- "overflow-y": R()
566
- }],
567
- /**
568
- * Overscroll Behavior
569
- * @see https://tailwindcss.com/docs/overscroll-behavior
570
- */
571
- overscroll: [{
572
- overscroll: X()
573
- }],
574
- /**
575
- * Overscroll Behavior X
576
- * @see https://tailwindcss.com/docs/overscroll-behavior
577
- */
578
- "overscroll-x": [{
579
- "overscroll-x": X()
580
- }],
581
- /**
582
- * Overscroll Behavior Y
583
- * @see https://tailwindcss.com/docs/overscroll-behavior
584
- */
585
- "overscroll-y": [{
586
- "overscroll-y": X()
587
- }],
588
- /**
589
- * Position
590
- * @see https://tailwindcss.com/docs/position
591
- */
592
- position: ["static", "fixed", "absolute", "relative", "sticky"],
593
- /**
594
- * Top / Right / Bottom / Left
595
- * @see https://tailwindcss.com/docs/top-right-bottom-left
596
- */
597
- inset: [{
598
- inset: v()
599
- }],
600
- /**
601
- * Right / Left
602
- * @see https://tailwindcss.com/docs/top-right-bottom-left
603
- */
604
- "inset-x": [{
605
- "inset-x": v()
606
- }],
607
- /**
608
- * Top / Bottom
609
- * @see https://tailwindcss.com/docs/top-right-bottom-left
610
- */
611
- "inset-y": [{
612
- "inset-y": v()
613
- }],
614
- /**
615
- * Start
616
- * @see https://tailwindcss.com/docs/top-right-bottom-left
617
- */
618
- start: [{
619
- start: v()
620
- }],
621
- /**
622
- * End
623
- * @see https://tailwindcss.com/docs/top-right-bottom-left
624
- */
625
- end: [{
626
- end: v()
627
- }],
628
- /**
629
- * Top
630
- * @see https://tailwindcss.com/docs/top-right-bottom-left
631
- */
632
- top: [{
633
- top: v()
634
- }],
635
- /**
636
- * Right
637
- * @see https://tailwindcss.com/docs/top-right-bottom-left
638
- */
639
- right: [{
640
- right: v()
641
- }],
642
- /**
643
- * Bottom
644
- * @see https://tailwindcss.com/docs/top-right-bottom-left
645
- */
646
- bottom: [{
647
- bottom: v()
648
- }],
649
- /**
650
- * Left
651
- * @see https://tailwindcss.com/docs/top-right-bottom-left
652
- */
653
- left: [{
654
- left: v()
655
- }],
656
- /**
657
- * Visibility
658
- * @see https://tailwindcss.com/docs/visibility
659
- */
660
- visibility: ["visible", "invisible", "collapse"],
661
- /**
662
- * Z-Index
663
- * @see https://tailwindcss.com/docs/z-index
664
- */
665
- z: [{
666
- z: [Z, "auto", o, n]
667
- }],
668
- // ------------------------
669
- // --- Flexbox and Grid ---
670
- // ------------------------
671
- /**
672
- * Flex Basis
673
- * @see https://tailwindcss.com/docs/flex-basis
674
- */
675
- basis: [{
676
- basis: [H, "full", "auto", b, ...a()]
677
- }],
678
- /**
679
- * Flex Direction
680
- * @see https://tailwindcss.com/docs/flex-direction
681
- */
682
- "flex-direction": [{
683
- flex: ["row", "row-reverse", "col", "col-reverse"]
684
- }],
685
- /**
686
- * Flex Wrap
687
- * @see https://tailwindcss.com/docs/flex-wrap
688
- */
689
- "flex-wrap": [{
690
- flex: ["nowrap", "wrap", "wrap-reverse"]
691
- }],
692
- /**
693
- * Flex
694
- * @see https://tailwindcss.com/docs/flex
695
- */
696
- flex: [{
697
- flex: [c, H, "auto", "initial", "none", n]
698
- }],
699
- /**
700
- * Flex Grow
701
- * @see https://tailwindcss.com/docs/flex-grow
702
- */
703
- grow: [{
704
- grow: ["", c, o, n]
705
- }],
706
- /**
707
- * Flex Shrink
708
- * @see https://tailwindcss.com/docs/flex-shrink
709
- */
710
- shrink: [{
711
- shrink: ["", c, o, n]
712
- }],
713
- /**
714
- * Order
715
- * @see https://tailwindcss.com/docs/order
716
- */
717
- order: [{
718
- order: [Z, "first", "last", "none", o, n]
719
- }],
720
- /**
721
- * Grid Template Columns
722
- * @see https://tailwindcss.com/docs/grid-template-columns
723
- */
724
- "grid-cols": [{
725
- "grid-cols": oe()
726
- }],
727
- /**
728
- * Grid Column Start / End
729
- * @see https://tailwindcss.com/docs/grid-column
730
- */
731
- "col-start-end": [{
732
- col: ie()
733
- }],
734
- /**
735
- * Grid Column Start
736
- * @see https://tailwindcss.com/docs/grid-column
737
- */
738
- "col-start": [{
739
- "col-start": T()
740
- }],
741
- /**
742
- * Grid Column End
743
- * @see https://tailwindcss.com/docs/grid-column
744
- */
745
- "col-end": [{
746
- "col-end": T()
747
- }],
748
- /**
749
- * Grid Template Rows
750
- * @see https://tailwindcss.com/docs/grid-template-rows
751
- */
752
- "grid-rows": [{
753
- "grid-rows": oe()
754
- }],
755
- /**
756
- * Grid Row Start / End
757
- * @see https://tailwindcss.com/docs/grid-row
758
- */
759
- "row-start-end": [{
760
- row: ie()
761
- }],
762
- /**
763
- * Grid Row Start
764
- * @see https://tailwindcss.com/docs/grid-row
765
- */
766
- "row-start": [{
767
- "row-start": T()
768
- }],
769
- /**
770
- * Grid Row End
771
- * @see https://tailwindcss.com/docs/grid-row
772
- */
773
- "row-end": [{
774
- "row-end": T()
775
- }],
776
- /**
777
- * Grid Auto Flow
778
- * @see https://tailwindcss.com/docs/grid-auto-flow
779
- */
780
- "grid-flow": [{
781
- "grid-flow": ["row", "col", "dense", "row-dense", "col-dense"]
782
- }],
783
- /**
784
- * Grid Auto Columns
785
- * @see https://tailwindcss.com/docs/grid-auto-columns
786
- */
787
- "auto-cols": [{
788
- "auto-cols": ae()
789
- }],
790
- /**
791
- * Grid Auto Rows
792
- * @see https://tailwindcss.com/docs/grid-auto-rows
793
- */
794
- "auto-rows": [{
795
- "auto-rows": ae()
796
- }],
797
- /**
798
- * Gap
799
- * @see https://tailwindcss.com/docs/gap
800
- */
801
- gap: [{
802
- gap: a()
803
- }],
804
- /**
805
- * Gap X
806
- * @see https://tailwindcss.com/docs/gap
807
- */
808
- "gap-x": [{
809
- "gap-x": a()
810
- }],
811
- /**
812
- * Gap Y
813
- * @see https://tailwindcss.com/docs/gap
814
- */
815
- "gap-y": [{
816
- "gap-y": a()
817
- }],
818
- /**
819
- * Justify Content
820
- * @see https://tailwindcss.com/docs/justify-content
821
- */
822
- "justify-content": [{
823
- justify: [...U(), "normal"]
824
- }],
825
- /**
826
- * Justify Items
827
- * @see https://tailwindcss.com/docs/justify-items
828
- */
829
- "justify-items": [{
830
- "justify-items": [...G(), "normal"]
831
- }],
832
- /**
833
- * Justify Self
834
- * @see https://tailwindcss.com/docs/justify-self
835
- */
836
- "justify-self": [{
837
- "justify-self": ["auto", ...G()]
838
- }],
839
- /**
840
- * Align Content
841
- * @see https://tailwindcss.com/docs/align-content
842
- */
843
- "align-content": [{
844
- content: ["normal", ...U()]
845
- }],
846
- /**
847
- * Align Items
848
- * @see https://tailwindcss.com/docs/align-items
849
- */
850
- "align-items": [{
851
- items: [...G(), "baseline"]
852
- }],
853
- /**
854
- * Align Self
855
- * @see https://tailwindcss.com/docs/align-self
856
- */
857
- "align-self": [{
858
- self: ["auto", ...G(), "baseline"]
859
- }],
860
- /**
861
- * Place Content
862
- * @see https://tailwindcss.com/docs/place-content
863
- */
864
- "place-content": [{
865
- "place-content": U()
866
- }],
867
- /**
868
- * Place Items
869
- * @see https://tailwindcss.com/docs/place-items
870
- */
871
- "place-items": [{
872
- "place-items": [...G(), "baseline"]
873
- }],
874
- /**
875
- * Place Self
876
- * @see https://tailwindcss.com/docs/place-self
877
- */
878
- "place-self": [{
879
- "place-self": ["auto", ...G()]
880
- }],
881
- // Spacing
882
- /**
883
- * Padding
884
- * @see https://tailwindcss.com/docs/padding
885
- */
886
- p: [{
887
- p: a()
888
- }],
889
- /**
890
- * Padding X
891
- * @see https://tailwindcss.com/docs/padding
892
- */
893
- px: [{
894
- px: a()
895
- }],
896
- /**
897
- * Padding Y
898
- * @see https://tailwindcss.com/docs/padding
899
- */
900
- py: [{
901
- py: a()
902
- }],
903
- /**
904
- * Padding Start
905
- * @see https://tailwindcss.com/docs/padding
906
- */
907
- ps: [{
908
- ps: a()
909
- }],
910
- /**
911
- * Padding End
912
- * @see https://tailwindcss.com/docs/padding
913
- */
914
- pe: [{
915
- pe: a()
916
- }],
917
- /**
918
- * Padding Top
919
- * @see https://tailwindcss.com/docs/padding
920
- */
921
- pt: [{
922
- pt: a()
923
- }],
924
- /**
925
- * Padding Right
926
- * @see https://tailwindcss.com/docs/padding
927
- */
928
- pr: [{
929
- pr: a()
930
- }],
931
- /**
932
- * Padding Bottom
933
- * @see https://tailwindcss.com/docs/padding
934
- */
935
- pb: [{
936
- pb: a()
937
- }],
938
- /**
939
- * Padding Left
940
- * @see https://tailwindcss.com/docs/padding
941
- */
942
- pl: [{
943
- pl: a()
944
- }],
945
- /**
946
- * Margin
947
- * @see https://tailwindcss.com/docs/margin
948
- */
949
- m: [{
950
- m: A()
951
- }],
952
- /**
953
- * Margin X
954
- * @see https://tailwindcss.com/docs/margin
955
- */
956
- mx: [{
957
- mx: A()
958
- }],
959
- /**
960
- * Margin Y
961
- * @see https://tailwindcss.com/docs/margin
962
- */
963
- my: [{
964
- my: A()
965
- }],
966
- /**
967
- * Margin Start
968
- * @see https://tailwindcss.com/docs/margin
969
- */
970
- ms: [{
971
- ms: A()
972
- }],
973
- /**
974
- * Margin End
975
- * @see https://tailwindcss.com/docs/margin
976
- */
977
- me: [{
978
- me: A()
979
- }],
980
- /**
981
- * Margin Top
982
- * @see https://tailwindcss.com/docs/margin
983
- */
984
- mt: [{
985
- mt: A()
986
- }],
987
- /**
988
- * Margin Right
989
- * @see https://tailwindcss.com/docs/margin
990
- */
991
- mr: [{
992
- mr: A()
993
- }],
994
- /**
995
- * Margin Bottom
996
- * @see https://tailwindcss.com/docs/margin
997
- */
998
- mb: [{
999
- mb: A()
1000
- }],
1001
- /**
1002
- * Margin Left
1003
- * @see https://tailwindcss.com/docs/margin
1004
- */
1005
- ml: [{
1006
- ml: A()
1007
- }],
1008
- /**
1009
- * Space Between X
1010
- * @see https://tailwindcss.com/docs/margin#adding-space-between-children
1011
- */
1012
- "space-x": [{
1013
- "space-x": a()
1014
- }],
1015
- /**
1016
- * Space Between X Reverse
1017
- * @see https://tailwindcss.com/docs/margin#adding-space-between-children
1018
- */
1019
- "space-x-reverse": ["space-x-reverse"],
1020
- /**
1021
- * Space Between Y
1022
- * @see https://tailwindcss.com/docs/margin#adding-space-between-children
1023
- */
1024
- "space-y": [{
1025
- "space-y": a()
1026
- }],
1027
- /**
1028
- * Space Between Y Reverse
1029
- * @see https://tailwindcss.com/docs/margin#adding-space-between-children
1030
- */
1031
- "space-y-reverse": ["space-y-reverse"],
1032
- // --------------
1033
- // --- Sizing ---
1034
- // --------------
1035
- /**
1036
- * Size
1037
- * @see https://tailwindcss.com/docs/width#setting-both-width-and-height
1038
- */
1039
- size: [{
1040
- size: z()
1041
- }],
1042
- /**
1043
- * Width
1044
- * @see https://tailwindcss.com/docs/width
1045
- */
1046
- w: [{
1047
- w: [b, "screen", ...z()]
1048
- }],
1049
- /**
1050
- * Min-Width
1051
- * @see https://tailwindcss.com/docs/min-width
1052
- */
1053
- "min-w": [{
1054
- "min-w": [
1055
- b,
1056
- "screen",
1057
- /** Deprecated. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */
1058
- "none",
1059
- ...z()
1060
- ]
1061
- }],
1062
- /**
1063
- * Max-Width
1064
- * @see https://tailwindcss.com/docs/max-width
1065
- */
1066
- "max-w": [{
1067
- "max-w": [
1068
- b,
1069
- "screen",
1070
- "none",
1071
- /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */
1072
- "prose",
1073
- /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */
1074
- {
1075
- screen: [l]
1076
- },
1077
- ...z()
1078
- ]
1079
- }],
1080
- /**
1081
- * Height
1082
- * @see https://tailwindcss.com/docs/height
1083
- */
1084
- h: [{
1085
- h: ["screen", ...z()]
1086
- }],
1087
- /**
1088
- * Min-Height
1089
- * @see https://tailwindcss.com/docs/min-height
1090
- */
1091
- "min-h": [{
1092
- "min-h": ["screen", "none", ...z()]
1093
- }],
1094
- /**
1095
- * Max-Height
1096
- * @see https://tailwindcss.com/docs/max-height
1097
- */
1098
- "max-h": [{
1099
- "max-h": ["screen", ...z()]
1100
- }],
1101
- // ------------------
1102
- // --- Typography ---
1103
- // ------------------
1104
- /**
1105
- * Font Size
1106
- * @see https://tailwindcss.com/docs/font-size
1107
- */
1108
- "font-size": [{
1109
- text: ["base", t, S, j]
1110
- }],
1111
- /**
1112
- * Font Smoothing
1113
- * @see https://tailwindcss.com/docs/font-smoothing
1114
- */
1115
- "font-smoothing": ["antialiased", "subpixel-antialiased"],
1116
- /**
1117
- * Font Style
1118
- * @see https://tailwindcss.com/docs/font-style
1119
- */
1120
- "font-style": ["italic", "not-italic"],
1121
- /**
1122
- * Font Weight
1123
- * @see https://tailwindcss.com/docs/font-weight
1124
- */
1125
- "font-weight": [{
1126
- font: [s, o, $]
1127
- }],
1128
- /**
1129
- * Font Stretch
1130
- * @see https://tailwindcss.com/docs/font-stretch
1131
- */
1132
- "font-stretch": [{
1133
- "font-stretch": ["ultra-condensed", "extra-condensed", "condensed", "semi-condensed", "normal", "semi-expanded", "expanded", "extra-expanded", "ultra-expanded", fe, n]
1134
- }],
1135
- /**
1136
- * Font Family
1137
- * @see https://tailwindcss.com/docs/font-family
1138
- */
1139
- "font-family": [{
1140
- font: [ct, n, r]
1141
- }],
1142
- /**
1143
- * Font Variant Numeric
1144
- * @see https://tailwindcss.com/docs/font-variant-numeric
1145
- */
1146
- "fvn-normal": ["normal-nums"],
1147
- /**
1148
- * Font Variant Numeric
1149
- * @see https://tailwindcss.com/docs/font-variant-numeric
1150
- */
1151
- "fvn-ordinal": ["ordinal"],
1152
- /**
1153
- * Font Variant Numeric
1154
- * @see https://tailwindcss.com/docs/font-variant-numeric
1155
- */
1156
- "fvn-slashed-zero": ["slashed-zero"],
1157
- /**
1158
- * Font Variant Numeric
1159
- * @see https://tailwindcss.com/docs/font-variant-numeric
1160
- */
1161
- "fvn-figure": ["lining-nums", "oldstyle-nums"],
1162
- /**
1163
- * Font Variant Numeric
1164
- * @see https://tailwindcss.com/docs/font-variant-numeric
1165
- */
1166
- "fvn-spacing": ["proportional-nums", "tabular-nums"],
1167
- /**
1168
- * Font Variant Numeric
1169
- * @see https://tailwindcss.com/docs/font-variant-numeric
1170
- */
1171
- "fvn-fraction": ["diagonal-fractions", "stacked-fractions"],
1172
- /**
1173
- * Letter Spacing
1174
- * @see https://tailwindcss.com/docs/letter-spacing
1175
- */
1176
- tracking: [{
1177
- tracking: [i, o, n]
1178
- }],
1179
- /**
1180
- * Line Clamp
1181
- * @see https://tailwindcss.com/docs/line-clamp
1182
- */
1183
- "line-clamp": [{
1184
- "line-clamp": [c, "none", o, $]
1185
- }],
1186
- /**
1187
- * Line Height
1188
- * @see https://tailwindcss.com/docs/line-height
1189
- */
1190
- leading: [{
1191
- leading: [
1192
- /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */
1193
- d,
1194
- ...a()
1195
- ]
1196
- }],
1197
- /**
1198
- * List Style Image
1199
- * @see https://tailwindcss.com/docs/list-style-image
1200
- */
1201
- "list-image": [{
1202
- "list-image": ["none", o, n]
1203
- }],
1204
- /**
1205
- * List Style Position
1206
- * @see https://tailwindcss.com/docs/list-style-position
1207
- */
1208
- "list-style-position": [{
1209
- list: ["inside", "outside"]
1210
- }],
1211
- /**
1212
- * List Style Type
1213
- * @see https://tailwindcss.com/docs/list-style-type
1214
- */
1215
- "list-style-type": [{
1216
- list: ["disc", "decimal", "none", o, n]
1217
- }],
1218
- /**
1219
- * Text Alignment
1220
- * @see https://tailwindcss.com/docs/text-align
1221
- */
1222
- "text-alignment": [{
1223
- text: ["left", "center", "right", "justify", "start", "end"]
1224
- }],
1225
- /**
1226
- * Placeholder Color
1227
- * @deprecated since Tailwind CSS v3.0.0
1228
- * @see https://v3.tailwindcss.com/docs/placeholder-color
1229
- */
1230
- "placeholder-color": [{
1231
- placeholder: x()
1232
- }],
1233
- /**
1234
- * Text Color
1235
- * @see https://tailwindcss.com/docs/text-color
1236
- */
1237
- "text-color": [{
1238
- text: x()
1239
- }],
1240
- /**
1241
- * Text Decoration
1242
- * @see https://tailwindcss.com/docs/text-decoration
1243
- */
1244
- "text-decoration": ["underline", "overline", "line-through", "no-underline"],
1245
- /**
1246
- * Text Decoration Style
1247
- * @see https://tailwindcss.com/docs/text-decoration-style
1248
- */
1249
- "text-decoration-style": [{
1250
- decoration: [...Q(), "wavy"]
1251
- }],
1252
- /**
1253
- * Text Decoration Thickness
1254
- * @see https://tailwindcss.com/docs/text-decoration-thickness
1255
- */
1256
- "text-decoration-thickness": [{
1257
- decoration: [c, "from-font", "auto", o, j]
1258
- }],
1259
- /**
1260
- * Text Decoration Color
1261
- * @see https://tailwindcss.com/docs/text-decoration-color
1262
- */
1263
- "text-decoration-color": [{
1264
- decoration: x()
1265
- }],
1266
- /**
1267
- * Text Underline Offset
1268
- * @see https://tailwindcss.com/docs/text-underline-offset
1269
- */
1270
- "underline-offset": [{
1271
- "underline-offset": [c, "auto", o, n]
1272
- }],
1273
- /**
1274
- * Text Transform
1275
- * @see https://tailwindcss.com/docs/text-transform
1276
- */
1277
- "text-transform": ["uppercase", "lowercase", "capitalize", "normal-case"],
1278
- /**
1279
- * Text Overflow
1280
- * @see https://tailwindcss.com/docs/text-overflow
1281
- */
1282
- "text-overflow": ["truncate", "text-ellipsis", "text-clip"],
1283
- /**
1284
- * Text Wrap
1285
- * @see https://tailwindcss.com/docs/text-wrap
1286
- */
1287
- "text-wrap": [{
1288
- text: ["wrap", "nowrap", "balance", "pretty"]
1289
- }],
1290
- /**
1291
- * Text Indent
1292
- * @see https://tailwindcss.com/docs/text-indent
1293
- */
1294
- indent: [{
1295
- indent: a()
1296
- }],
1297
- /**
1298
- * Vertical Alignment
1299
- * @see https://tailwindcss.com/docs/vertical-align
1300
- */
1301
- "vertical-align": [{
1302
- align: ["baseline", "top", "middle", "bottom", "text-top", "text-bottom", "sub", "super", o, n]
1303
- }],
1304
- /**
1305
- * Whitespace
1306
- * @see https://tailwindcss.com/docs/whitespace
1307
- */
1308
- whitespace: [{
1309
- whitespace: ["normal", "nowrap", "pre", "pre-line", "pre-wrap", "break-spaces"]
1310
- }],
1311
- /**
1312
- * Word Break
1313
- * @see https://tailwindcss.com/docs/word-break
1314
- */
1315
- break: [{
1316
- break: ["normal", "words", "all", "keep"]
1317
- }],
1318
- /**
1319
- * Hyphens
1320
- * @see https://tailwindcss.com/docs/hyphens
1321
- */
1322
- hyphens: [{
1323
- hyphens: ["none", "manual", "auto"]
1324
- }],
1325
- /**
1326
- * Content
1327
- * @see https://tailwindcss.com/docs/content
1328
- */
1329
- content: [{
1330
- content: ["none", o, n]
1331
- }],
1332
- // -------------------
1333
- // --- Backgrounds ---
1334
- // -------------------
1335
- /**
1336
- * Background Attachment
1337
- * @see https://tailwindcss.com/docs/background-attachment
1338
- */
1339
- "bg-attachment": [{
1340
- bg: ["fixed", "local", "scroll"]
1341
- }],
1342
- /**
1343
- * Background Clip
1344
- * @see https://tailwindcss.com/docs/background-clip
1345
- */
1346
- "bg-clip": [{
1347
- "bg-clip": ["border", "padding", "content", "text"]
1348
- }],
1349
- /**
1350
- * Background Origin
1351
- * @see https://tailwindcss.com/docs/background-origin
1352
- */
1353
- "bg-origin": [{
1354
- "bg-origin": ["border", "padding", "content"]
1355
- }],
1356
- /**
1357
- * Background Position
1358
- * @see https://tailwindcss.com/docs/background-position
1359
- */
1360
- "bg-position": [{
1361
- bg: [...O(), ut, at]
1362
- }],
1363
- /**
1364
- * Background Repeat
1365
- * @see https://tailwindcss.com/docs/background-repeat
1366
- */
1367
- "bg-repeat": [{
1368
- bg: ["no-repeat", {
1369
- repeat: ["", "x", "y", "space", "round"]
1370
- }]
1371
- }],
1372
- /**
1373
- * Background Size
1374
- * @see https://tailwindcss.com/docs/background-size
1375
- */
1376
- "bg-size": [{
1377
- bg: ["auto", "cover", "contain", xt, it]
1378
- }],
1379
- /**
1380
- * Background Image
1381
- * @see https://tailwindcss.com/docs/background-image
1382
- */
1383
- "bg-image": [{
1384
- bg: ["none", {
1385
- linear: [{
1386
- to: ["t", "tr", "r", "br", "b", "bl", "l", "tl"]
1387
- }, Z, o, n],
1388
- radial: ["", o, n],
1389
- conic: [Z, o, n]
1390
- }, bt, lt]
1391
- }],
1392
- /**
1393
- * Background Color
1394
- * @see https://tailwindcss.com/docs/background-color
1395
- */
1396
- "bg-color": [{
1397
- bg: x()
1398
- }],
1399
- /**
1400
- * Gradient Color Stops From Position
1401
- * @see https://tailwindcss.com/docs/gradient-color-stops
1402
- */
1403
- "gradient-from-pos": [{
1404
- from: K()
1405
- }],
1406
- /**
1407
- * Gradient Color Stops Via Position
1408
- * @see https://tailwindcss.com/docs/gradient-color-stops
1409
- */
1410
- "gradient-via-pos": [{
1411
- via: K()
1412
- }],
1413
- /**
1414
- * Gradient Color Stops To Position
1415
- * @see https://tailwindcss.com/docs/gradient-color-stops
1416
- */
1417
- "gradient-to-pos": [{
1418
- to: K()
1419
- }],
1420
- /**
1421
- * Gradient Color Stops From
1422
- * @see https://tailwindcss.com/docs/gradient-color-stops
1423
- */
1424
- "gradient-from": [{
1425
- from: x()
1426
- }],
1427
- /**
1428
- * Gradient Color Stops Via
1429
- * @see https://tailwindcss.com/docs/gradient-color-stops
1430
- */
1431
- "gradient-via": [{
1432
- via: x()
1433
- }],
1434
- /**
1435
- * Gradient Color Stops To
1436
- * @see https://tailwindcss.com/docs/gradient-color-stops
1437
- */
1438
- "gradient-to": [{
1439
- to: x()
1440
- }],
1441
- // ---------------
1442
- // --- Borders ---
1443
- // ---------------
1444
- /**
1445
- * Border Radius
1446
- * @see https://tailwindcss.com/docs/border-radius
1447
- */
1448
- rounded: [{
1449
- rounded: m()
1450
- }],
1451
- /**
1452
- * Border Radius Start
1453
- * @see https://tailwindcss.com/docs/border-radius
1454
- */
1455
- "rounded-s": [{
1456
- "rounded-s": m()
1457
- }],
1458
- /**
1459
- * Border Radius End
1460
- * @see https://tailwindcss.com/docs/border-radius
1461
- */
1462
- "rounded-e": [{
1463
- "rounded-e": m()
1464
- }],
1465
- /**
1466
- * Border Radius Top
1467
- * @see https://tailwindcss.com/docs/border-radius
1468
- */
1469
- "rounded-t": [{
1470
- "rounded-t": m()
1471
- }],
1472
- /**
1473
- * Border Radius Right
1474
- * @see https://tailwindcss.com/docs/border-radius
1475
- */
1476
- "rounded-r": [{
1477
- "rounded-r": m()
1478
- }],
1479
- /**
1480
- * Border Radius Bottom
1481
- * @see https://tailwindcss.com/docs/border-radius
1482
- */
1483
- "rounded-b": [{
1484
- "rounded-b": m()
1485
- }],
1486
- /**
1487
- * Border Radius Left
1488
- * @see https://tailwindcss.com/docs/border-radius
1489
- */
1490
- "rounded-l": [{
1491
- "rounded-l": m()
1492
- }],
1493
- /**
1494
- * Border Radius Start Start
1495
- * @see https://tailwindcss.com/docs/border-radius
1496
- */
1497
- "rounded-ss": [{
1498
- "rounded-ss": m()
1499
- }],
1500
- /**
1501
- * Border Radius Start End
1502
- * @see https://tailwindcss.com/docs/border-radius
1503
- */
1504
- "rounded-se": [{
1505
- "rounded-se": m()
1506
- }],
1507
- /**
1508
- * Border Radius End End
1509
- * @see https://tailwindcss.com/docs/border-radius
1510
- */
1511
- "rounded-ee": [{
1512
- "rounded-ee": m()
1513
- }],
1514
- /**
1515
- * Border Radius End Start
1516
- * @see https://tailwindcss.com/docs/border-radius
1517
- */
1518
- "rounded-es": [{
1519
- "rounded-es": m()
1520
- }],
1521
- /**
1522
- * Border Radius Top Left
1523
- * @see https://tailwindcss.com/docs/border-radius
1524
- */
1525
- "rounded-tl": [{
1526
- "rounded-tl": m()
1527
- }],
1528
- /**
1529
- * Border Radius Top Right
1530
- * @see https://tailwindcss.com/docs/border-radius
1531
- */
1532
- "rounded-tr": [{
1533
- "rounded-tr": m()
1534
- }],
1535
- /**
1536
- * Border Radius Bottom Right
1537
- * @see https://tailwindcss.com/docs/border-radius
1538
- */
1539
- "rounded-br": [{
1540
- "rounded-br": m()
1541
- }],
1542
- /**
1543
- * Border Radius Bottom Left
1544
- * @see https://tailwindcss.com/docs/border-radius
1545
- */
1546
- "rounded-bl": [{
1547
- "rounded-bl": m()
1548
- }],
1549
- /**
1550
- * Border Width
1551
- * @see https://tailwindcss.com/docs/border-width
1552
- */
1553
- "border-w": [{
1554
- border: p()
1555
- }],
1556
- /**
1557
- * Border Width X
1558
- * @see https://tailwindcss.com/docs/border-width
1559
- */
1560
- "border-w-x": [{
1561
- "border-x": p()
1562
- }],
1563
- /**
1564
- * Border Width Y
1565
- * @see https://tailwindcss.com/docs/border-width
1566
- */
1567
- "border-w-y": [{
1568
- "border-y": p()
1569
- }],
1570
- /**
1571
- * Border Width Start
1572
- * @see https://tailwindcss.com/docs/border-width
1573
- */
1574
- "border-w-s": [{
1575
- "border-s": p()
1576
- }],
1577
- /**
1578
- * Border Width End
1579
- * @see https://tailwindcss.com/docs/border-width
1580
- */
1581
- "border-w-e": [{
1582
- "border-e": p()
1583
- }],
1584
- /**
1585
- * Border Width Top
1586
- * @see https://tailwindcss.com/docs/border-width
1587
- */
1588
- "border-w-t": [{
1589
- "border-t": p()
1590
- }],
1591
- /**
1592
- * Border Width Right
1593
- * @see https://tailwindcss.com/docs/border-width
1594
- */
1595
- "border-w-r": [{
1596
- "border-r": p()
1597
- }],
1598
- /**
1599
- * Border Width Bottom
1600
- * @see https://tailwindcss.com/docs/border-width
1601
- */
1602
- "border-w-b": [{
1603
- "border-b": p()
1604
- }],
1605
- /**
1606
- * Border Width Left
1607
- * @see https://tailwindcss.com/docs/border-width
1608
- */
1609
- "border-w-l": [{
1610
- "border-l": p()
1611
- }],
1612
- /**
1613
- * Divide Width X
1614
- * @see https://tailwindcss.com/docs/border-width#between-children
1615
- */
1616
- "divide-x": [{
1617
- "divide-x": p()
1618
- }],
1619
- /**
1620
- * Divide Width X Reverse
1621
- * @see https://tailwindcss.com/docs/border-width#between-children
1622
- */
1623
- "divide-x-reverse": ["divide-x-reverse"],
1624
- /**
1625
- * Divide Width Y
1626
- * @see https://tailwindcss.com/docs/border-width#between-children
1627
- */
1628
- "divide-y": [{
1629
- "divide-y": p()
1630
- }],
1631
- /**
1632
- * Divide Width Y Reverse
1633
- * @see https://tailwindcss.com/docs/border-width#between-children
1634
- */
1635
- "divide-y-reverse": ["divide-y-reverse"],
1636
- /**
1637
- * Border Style
1638
- * @see https://tailwindcss.com/docs/border-style
1639
- */
1640
- "border-style": [{
1641
- border: [...Q(), "hidden", "none"]
1642
- }],
1643
- /**
1644
- * Divide Style
1645
- * @see https://tailwindcss.com/docs/border-style#setting-the-divider-style
1646
- */
1647
- "divide-style": [{
1648
- divide: [...Q(), "hidden", "none"]
1649
- }],
1650
- /**
1651
- * Border Color
1652
- * @see https://tailwindcss.com/docs/border-color
1653
- */
1654
- "border-color": [{
1655
- border: x()
1656
- }],
1657
- /**
1658
- * Border Color X
1659
- * @see https://tailwindcss.com/docs/border-color
1660
- */
1661
- "border-color-x": [{
1662
- "border-x": x()
1663
- }],
1664
- /**
1665
- * Border Color Y
1666
- * @see https://tailwindcss.com/docs/border-color
1667
- */
1668
- "border-color-y": [{
1669
- "border-y": x()
1670
- }],
1671
- /**
1672
- * Border Color S
1673
- * @see https://tailwindcss.com/docs/border-color
1674
- */
1675
- "border-color-s": [{
1676
- "border-s": x()
1677
- }],
1678
- /**
1679
- * Border Color E
1680
- * @see https://tailwindcss.com/docs/border-color
1681
- */
1682
- "border-color-e": [{
1683
- "border-e": x()
1684
- }],
1685
- /**
1686
- * Border Color Top
1687
- * @see https://tailwindcss.com/docs/border-color
1688
- */
1689
- "border-color-t": [{
1690
- "border-t": x()
1691
- }],
1692
- /**
1693
- * Border Color Right
1694
- * @see https://tailwindcss.com/docs/border-color
1695
- */
1696
- "border-color-r": [{
1697
- "border-r": x()
1698
- }],
1699
- /**
1700
- * Border Color Bottom
1701
- * @see https://tailwindcss.com/docs/border-color
1702
- */
1703
- "border-color-b": [{
1704
- "border-b": x()
1705
- }],
1706
- /**
1707
- * Border Color Left
1708
- * @see https://tailwindcss.com/docs/border-color
1709
- */
1710
- "border-color-l": [{
1711
- "border-l": x()
1712
- }],
1713
- /**
1714
- * Divide Color
1715
- * @see https://tailwindcss.com/docs/divide-color
1716
- */
1717
- "divide-color": [{
1718
- divide: x()
1719
- }],
1720
- /**
1721
- * Outline Style
1722
- * @see https://tailwindcss.com/docs/outline-style
1723
- */
1724
- "outline-style": [{
1725
- outline: [...Q(), "none", "hidden"]
1726
- }],
1727
- /**
1728
- * Outline Offset
1729
- * @see https://tailwindcss.com/docs/outline-offset
1730
- */
1731
- "outline-offset": [{
1732
- "outline-offset": [c, o, n]
1733
- }],
1734
- /**
1735
- * Outline Width
1736
- * @see https://tailwindcss.com/docs/outline-width
1737
- */
1738
- "outline-w": [{
1739
- outline: ["", c, S, j]
1740
- }],
1741
- /**
1742
- * Outline Color
1743
- * @see https://tailwindcss.com/docs/outline-color
1744
- */
1745
- "outline-color": [{
1746
- outline: [e]
1747
- }],
1748
- // ---------------
1749
- // --- Effects ---
1750
- // ---------------
1751
- /**
1752
- * Box Shadow
1753
- * @see https://tailwindcss.com/docs/box-shadow
1754
- */
1755
- shadow: [{
1756
- shadow: [
1757
- // Deprecated since Tailwind CSS v4.0.0
1758
- "",
1759
- "none",
1760
- h,
1761
- ft,
1762
- dt
1763
- ]
1764
- }],
1765
- /**
1766
- * Box Shadow Color
1767
- * @see https://tailwindcss.com/docs/box-shadow#setting-the-shadow-color
1768
- */
1769
- "shadow-color": [{
1770
- shadow: x()
1771
- }],
1772
- /**
1773
- * Inset Box Shadow
1774
- * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-shadow
1775
- */
1776
- "inset-shadow": [{
1777
- "inset-shadow": ["none", o, n, M]
1778
- }],
1779
- /**
1780
- * Inset Box Shadow Color
1781
- * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-shadow-color
1782
- */
1783
- "inset-shadow-color": [{
1784
- "inset-shadow": x()
1785
- }],
1786
- /**
1787
- * Ring Width
1788
- * @see https://tailwindcss.com/docs/box-shadow#adding-a-ring
1789
- */
1790
- "ring-w": [{
1791
- ring: p()
1792
- }],
1793
- /**
1794
- * Ring Width Inset
1795
- * @see https://v3.tailwindcss.com/docs/ring-width#inset-rings
1796
- * @deprecated since Tailwind CSS v4.0.0
1797
- * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158
1798
- */
1799
- "ring-w-inset": ["ring-inset"],
1800
- /**
1801
- * Ring Color
1802
- * @see https://tailwindcss.com/docs/box-shadow#setting-the-ring-color
1803
- */
1804
- "ring-color": [{
1805
- ring: x()
1806
- }],
1807
- /**
1808
- * Ring Offset Width
1809
- * @see https://v3.tailwindcss.com/docs/ring-offset-width
1810
- * @deprecated since Tailwind CSS v4.0.0
1811
- * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158
1812
- */
1813
- "ring-offset-w": [{
1814
- "ring-offset": [c, j]
1815
- }],
1816
- /**
1817
- * Ring Offset Color
1818
- * @see https://v3.tailwindcss.com/docs/ring-offset-color
1819
- * @deprecated since Tailwind CSS v4.0.0
1820
- * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158
1821
- */
1822
- "ring-offset-color": [{
1823
- "ring-offset": x()
1824
- }],
1825
- /**
1826
- * Inset Ring Width
1827
- * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-ring
1828
- */
1829
- "inset-ring-w": [{
1830
- "inset-ring": p()
1831
- }],
1832
- /**
1833
- * Inset Ring Color
1834
- * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-ring-color
1835
- */
1836
- "inset-ring-color": [{
1837
- "inset-ring": x()
1838
- }],
1839
- /**
1840
- * Opacity
1841
- * @see https://tailwindcss.com/docs/opacity
1842
- */
1843
- opacity: [{
1844
- opacity: [c, o, n]
1845
- }],
1846
- /**
1847
- * Mix Blend Mode
1848
- * @see https://tailwindcss.com/docs/mix-blend-mode
1849
- */
1850
- "mix-blend": [{
1851
- "mix-blend": [...le(), "plus-darker", "plus-lighter"]
1852
- }],
1853
- /**
1854
- * Background Blend Mode
1855
- * @see https://tailwindcss.com/docs/background-blend-mode
1856
- */
1857
- "bg-blend": [{
1858
- "bg-blend": le()
1859
- }],
1860
- // ---------------
1861
- // --- Filters ---
1862
- // ---------------
1863
- /**
1864
- * Filter
1865
- * @see https://tailwindcss.com/docs/filter
1866
- */
1867
- filter: [{
1868
- filter: [
1869
- // Deprecated since Tailwind CSS v3.0.0
1870
- "",
1871
- "none",
1872
- o,
1873
- n
1874
- ]
1875
- }],
1876
- /**
1877
- * Blur
1878
- * @see https://tailwindcss.com/docs/blur
1879
- */
1880
- blur: [{
1881
- blur: de()
1882
- }],
1883
- /**
1884
- * Brightness
1885
- * @see https://tailwindcss.com/docs/brightness
1886
- */
1887
- brightness: [{
1888
- brightness: [c, o, n]
1889
- }],
1890
- /**
1891
- * Contrast
1892
- * @see https://tailwindcss.com/docs/contrast
1893
- */
1894
- contrast: [{
1895
- contrast: [c, o, n]
1896
- }],
1897
- /**
1898
- * Drop Shadow
1899
- * @see https://tailwindcss.com/docs/drop-shadow
1900
- */
1901
- "drop-shadow": [{
1902
- "drop-shadow": [
1903
- // Deprecated since Tailwind CSS v4.0.0
1904
- "",
1905
- "none",
1906
- J,
1907
- o,
1908
- n
1909
- ]
1910
- }],
1911
- /**
1912
- * Grayscale
1913
- * @see https://tailwindcss.com/docs/grayscale
1914
- */
1915
- grayscale: [{
1916
- grayscale: ["", c, o, n]
1917
- }],
1918
- /**
1919
- * Hue Rotate
1920
- * @see https://tailwindcss.com/docs/hue-rotate
1921
- */
1922
- "hue-rotate": [{
1923
- "hue-rotate": [c, o, n]
1924
- }],
1925
- /**
1926
- * Invert
1927
- * @see https://tailwindcss.com/docs/invert
1928
- */
1929
- invert: [{
1930
- invert: ["", c, o, n]
1931
- }],
1932
- /**
1933
- * Saturate
1934
- * @see https://tailwindcss.com/docs/saturate
1935
- */
1936
- saturate: [{
1937
- saturate: [c, o, n]
1938
- }],
1939
- /**
1940
- * Sepia
1941
- * @see https://tailwindcss.com/docs/sepia
1942
- */
1943
- sepia: [{
1944
- sepia: ["", c, o, n]
1945
- }],
1946
- /**
1947
- * Backdrop Filter
1948
- * @see https://tailwindcss.com/docs/backdrop-filter
1949
- */
1950
- "backdrop-filter": [{
1951
- "backdrop-filter": [
1952
- // Deprecated since Tailwind CSS v3.0.0
1953
- "",
1954
- "none",
1955
- o,
1956
- n
1957
- ]
1958
- }],
1959
- /**
1960
- * Backdrop Blur
1961
- * @see https://tailwindcss.com/docs/backdrop-blur
1962
- */
1963
- "backdrop-blur": [{
1964
- "backdrop-blur": de()
1965
- }],
1966
- /**
1967
- * Backdrop Brightness
1968
- * @see https://tailwindcss.com/docs/backdrop-brightness
1969
- */
1970
- "backdrop-brightness": [{
1971
- "backdrop-brightness": [c, o, n]
1972
- }],
1973
- /**
1974
- * Backdrop Contrast
1975
- * @see https://tailwindcss.com/docs/backdrop-contrast
1976
- */
1977
- "backdrop-contrast": [{
1978
- "backdrop-contrast": [c, o, n]
1979
- }],
1980
- /**
1981
- * Backdrop Grayscale
1982
- * @see https://tailwindcss.com/docs/backdrop-grayscale
1983
- */
1984
- "backdrop-grayscale": [{
1985
- "backdrop-grayscale": ["", c, o, n]
1986
- }],
1987
- /**
1988
- * Backdrop Hue Rotate
1989
- * @see https://tailwindcss.com/docs/backdrop-hue-rotate
1990
- */
1991
- "backdrop-hue-rotate": [{
1992
- "backdrop-hue-rotate": [c, o, n]
1993
- }],
1994
- /**
1995
- * Backdrop Invert
1996
- * @see https://tailwindcss.com/docs/backdrop-invert
1997
- */
1998
- "backdrop-invert": [{
1999
- "backdrop-invert": ["", c, o, n]
2000
- }],
2001
- /**
2002
- * Backdrop Opacity
2003
- * @see https://tailwindcss.com/docs/backdrop-opacity
2004
- */
2005
- "backdrop-opacity": [{
2006
- "backdrop-opacity": [c, o, n]
2007
- }],
2008
- /**
2009
- * Backdrop Saturate
2010
- * @see https://tailwindcss.com/docs/backdrop-saturate
2011
- */
2012
- "backdrop-saturate": [{
2013
- "backdrop-saturate": [c, o, n]
2014
- }],
2015
- /**
2016
- * Backdrop Sepia
2017
- * @see https://tailwindcss.com/docs/backdrop-sepia
2018
- */
2019
- "backdrop-sepia": [{
2020
- "backdrop-sepia": ["", c, o, n]
2021
- }],
2022
- // --------------
2023
- // --- Tables ---
2024
- // --------------
2025
- /**
2026
- * Border Collapse
2027
- * @see https://tailwindcss.com/docs/border-collapse
2028
- */
2029
- "border-collapse": [{
2030
- border: ["collapse", "separate"]
2031
- }],
2032
- /**
2033
- * Border Spacing
2034
- * @see https://tailwindcss.com/docs/border-spacing
2035
- */
2036
- "border-spacing": [{
2037
- "border-spacing": a()
2038
- }],
2039
- /**
2040
- * Border Spacing X
2041
- * @see https://tailwindcss.com/docs/border-spacing
2042
- */
2043
- "border-spacing-x": [{
2044
- "border-spacing-x": a()
2045
- }],
2046
- /**
2047
- * Border Spacing Y
2048
- * @see https://tailwindcss.com/docs/border-spacing
2049
- */
2050
- "border-spacing-y": [{
2051
- "border-spacing-y": a()
2052
- }],
2053
- /**
2054
- * Table Layout
2055
- * @see https://tailwindcss.com/docs/table-layout
2056
- */
2057
- "table-layout": [{
2058
- table: ["auto", "fixed"]
2059
- }],
2060
- /**
2061
- * Caption Side
2062
- * @see https://tailwindcss.com/docs/caption-side
2063
- */
2064
- caption: [{
2065
- caption: ["top", "bottom"]
2066
- }],
2067
- // ---------------------------------
2068
- // --- Transitions and Animation ---
2069
- // ---------------------------------
2070
- /**
2071
- * Transition Property
2072
- * @see https://tailwindcss.com/docs/transition-property
2073
- */
2074
- transition: [{
2075
- transition: ["", "all", "colors", "opacity", "shadow", "transform", "none", o, n]
2076
- }],
2077
- /**
2078
- * Transition Behavior
2079
- * @see https://tailwindcss.com/docs/transition-behavior
2080
- */
2081
- "transition-behavior": [{
2082
- transition: ["normal", "discrete"]
2083
- }],
2084
- /**
2085
- * Transition Duration
2086
- * @see https://tailwindcss.com/docs/transition-duration
2087
- */
2088
- duration: [{
2089
- duration: [c, "initial", o, n]
2090
- }],
2091
- /**
2092
- * Transition Timing Function
2093
- * @see https://tailwindcss.com/docs/transition-timing-function
2094
- */
2095
- ease: [{
2096
- ease: ["linear", "initial", E, o, n]
2097
- }],
2098
- /**
2099
- * Transition Delay
2100
- * @see https://tailwindcss.com/docs/transition-delay
2101
- */
2102
- delay: [{
2103
- delay: [c, o, n]
2104
- }],
2105
- /**
2106
- * Animation
2107
- * @see https://tailwindcss.com/docs/animation
2108
- */
2109
- animate: [{
2110
- animate: ["none", I, o, n]
2111
- }],
2112
- // ------------------
2113
- // --- Transforms ---
2114
- // ------------------
2115
- /**
2116
- * Backface Visibility
2117
- * @see https://tailwindcss.com/docs/backface-visibility
2118
- */
2119
- backface: [{
2120
- backface: ["hidden", "visible"]
2121
- }],
2122
- /**
2123
- * Perspective
2124
- * @see https://tailwindcss.com/docs/perspective
2125
- */
2126
- perspective: [{
2127
- perspective: [y, o, n]
2128
- }],
2129
- /**
2130
- * Perspective Origin
2131
- * @see https://tailwindcss.com/docs/perspective-origin
2132
- */
2133
- "perspective-origin": [{
2134
- "perspective-origin": ce()
2135
- }],
2136
- /**
2137
- * Rotate
2138
- * @see https://tailwindcss.com/docs/rotate
2139
- */
2140
- rotate: [{
2141
- rotate: V()
2142
- }],
2143
- /**
2144
- * Rotate X
2145
- * @see https://tailwindcss.com/docs/rotate
2146
- */
2147
- "rotate-x": [{
2148
- "rotate-x": V()
2149
- }],
2150
- /**
2151
- * Rotate Y
2152
- * @see https://tailwindcss.com/docs/rotate
2153
- */
2154
- "rotate-y": [{
2155
- "rotate-y": V()
2156
- }],
2157
- /**
2158
- * Rotate Z
2159
- * @see https://tailwindcss.com/docs/rotate
2160
- */
2161
- "rotate-z": [{
2162
- "rotate-z": V()
2163
- }],
2164
- /**
2165
- * Scale
2166
- * @see https://tailwindcss.com/docs/scale
2167
- */
2168
- scale: [{
2169
- scale: N()
2170
- }],
2171
- /**
2172
- * Scale X
2173
- * @see https://tailwindcss.com/docs/scale
2174
- */
2175
- "scale-x": [{
2176
- "scale-x": N()
2177
- }],
2178
- /**
2179
- * Scale Y
2180
- * @see https://tailwindcss.com/docs/scale
2181
- */
2182
- "scale-y": [{
2183
- "scale-y": N()
2184
- }],
2185
- /**
2186
- * Scale Z
2187
- * @see https://tailwindcss.com/docs/scale
2188
- */
2189
- "scale-z": [{
2190
- "scale-z": N()
2191
- }],
2192
- /**
2193
- * Scale 3D
2194
- * @see https://tailwindcss.com/docs/scale
2195
- */
2196
- "scale-3d": ["scale-3d"],
2197
- /**
2198
- * Skew
2199
- * @see https://tailwindcss.com/docs/skew
2200
- */
2201
- skew: [{
2202
- skew: _()
2203
- }],
2204
- /**
2205
- * Skew X
2206
- * @see https://tailwindcss.com/docs/skew
2207
- */
2208
- "skew-x": [{
2209
- "skew-x": _()
2210
- }],
2211
- /**
2212
- * Skew Y
2213
- * @see https://tailwindcss.com/docs/skew
2214
- */
2215
- "skew-y": [{
2216
- "skew-y": _()
2217
- }],
2218
- /**
2219
- * Transform
2220
- * @see https://tailwindcss.com/docs/transform
2221
- */
2222
- transform: [{
2223
- transform: [o, n, "", "none", "gpu", "cpu"]
2224
- }],
2225
- /**
2226
- * Transform Origin
2227
- * @see https://tailwindcss.com/docs/transform-origin
2228
- */
2229
- "transform-origin": [{
2230
- origin: ce()
2231
- }],
2232
- /**
2233
- * Transform Style
2234
- * @see https://tailwindcss.com/docs/transform-style
2235
- */
2236
- "transform-style": [{
2237
- transform: ["3d", "flat"]
2238
- }],
2239
- /**
2240
- * Translate
2241
- * @see https://tailwindcss.com/docs/translate
2242
- */
2243
- translate: [{
2244
- translate: F()
2245
- }],
2246
- /**
2247
- * Translate X
2248
- * @see https://tailwindcss.com/docs/translate
2249
- */
2250
- "translate-x": [{
2251
- "translate-x": F()
2252
- }],
2253
- /**
2254
- * Translate Y
2255
- * @see https://tailwindcss.com/docs/translate
2256
- */
2257
- "translate-y": [{
2258
- "translate-y": F()
2259
- }],
2260
- /**
2261
- * Translate Z
2262
- * @see https://tailwindcss.com/docs/translate
2263
- */
2264
- "translate-z": [{
2265
- "translate-z": F()
2266
- }],
2267
- /**
2268
- * Translate None
2269
- * @see https://tailwindcss.com/docs/translate
2270
- */
2271
- "translate-none": ["translate-none"],
2272
- // ---------------------
2273
- // --- Interactivity ---
2274
- // ---------------------
2275
- /**
2276
- * Accent Color
2277
- * @see https://tailwindcss.com/docs/accent-color
2278
- */
2279
- accent: [{
2280
- accent: x()
2281
- }],
2282
- /**
2283
- * Appearance
2284
- * @see https://tailwindcss.com/docs/appearance
2285
- */
2286
- appearance: [{
2287
- appearance: ["none", "auto"]
2288
- }],
2289
- /**
2290
- * Caret Color
2291
- * @see https://tailwindcss.com/docs/just-in-time-mode#caret-color-utilities
2292
- */
2293
- "caret-color": [{
2294
- caret: x()
2295
- }],
2296
- /**
2297
- * Color Scheme
2298
- * @see https://tailwindcss.com/docs/color-scheme
2299
- */
2300
- "color-scheme": [{
2301
- scheme: ["normal", "dark", "light", "light-dark", "only-dark", "only-light"]
2302
- }],
2303
- /**
2304
- * Cursor
2305
- * @see https://tailwindcss.com/docs/cursor
2306
- */
2307
- cursor: [{
2308
- cursor: ["auto", "default", "pointer", "wait", "text", "move", "help", "not-allowed", "none", "context-menu", "progress", "cell", "crosshair", "vertical-text", "alias", "copy", "no-drop", "grab", "grabbing", "all-scroll", "col-resize", "row-resize", "n-resize", "e-resize", "s-resize", "w-resize", "ne-resize", "nw-resize", "se-resize", "sw-resize", "ew-resize", "ns-resize", "nesw-resize", "nwse-resize", "zoom-in", "zoom-out", o, n]
2309
- }],
2310
- /**
2311
- * Field Sizing
2312
- * @see https://tailwindcss.com/docs/field-sizing
2313
- */
2314
- "field-sizing": [{
2315
- "field-sizing": ["fixed", "content"]
2316
- }],
2317
- /**
2318
- * Pointer Events
2319
- * @see https://tailwindcss.com/docs/pointer-events
2320
- */
2321
- "pointer-events": [{
2322
- "pointer-events": ["auto", "none"]
2323
- }],
2324
- /**
2325
- * Resize
2326
- * @see https://tailwindcss.com/docs/resize
2327
- */
2328
- resize: [{
2329
- resize: ["none", "", "y", "x"]
2330
- }],
2331
- /**
2332
- * Scroll Behavior
2333
- * @see https://tailwindcss.com/docs/scroll-behavior
2334
- */
2335
- "scroll-behavior": [{
2336
- scroll: ["auto", "smooth"]
2337
- }],
2338
- /**
2339
- * Scroll Margin
2340
- * @see https://tailwindcss.com/docs/scroll-margin
2341
- */
2342
- "scroll-m": [{
2343
- "scroll-m": a()
2344
- }],
2345
- /**
2346
- * Scroll Margin X
2347
- * @see https://tailwindcss.com/docs/scroll-margin
2348
- */
2349
- "scroll-mx": [{
2350
- "scroll-mx": a()
2351
- }],
2352
- /**
2353
- * Scroll Margin Y
2354
- * @see https://tailwindcss.com/docs/scroll-margin
2355
- */
2356
- "scroll-my": [{
2357
- "scroll-my": a()
2358
- }],
2359
- /**
2360
- * Scroll Margin Start
2361
- * @see https://tailwindcss.com/docs/scroll-margin
2362
- */
2363
- "scroll-ms": [{
2364
- "scroll-ms": a()
2365
- }],
2366
- /**
2367
- * Scroll Margin End
2368
- * @see https://tailwindcss.com/docs/scroll-margin
2369
- */
2370
- "scroll-me": [{
2371
- "scroll-me": a()
2372
- }],
2373
- /**
2374
- * Scroll Margin Top
2375
- * @see https://tailwindcss.com/docs/scroll-margin
2376
- */
2377
- "scroll-mt": [{
2378
- "scroll-mt": a()
2379
- }],
2380
- /**
2381
- * Scroll Margin Right
2382
- * @see https://tailwindcss.com/docs/scroll-margin
2383
- */
2384
- "scroll-mr": [{
2385
- "scroll-mr": a()
2386
- }],
2387
- /**
2388
- * Scroll Margin Bottom
2389
- * @see https://tailwindcss.com/docs/scroll-margin
2390
- */
2391
- "scroll-mb": [{
2392
- "scroll-mb": a()
2393
- }],
2394
- /**
2395
- * Scroll Margin Left
2396
- * @see https://tailwindcss.com/docs/scroll-margin
2397
- */
2398
- "scroll-ml": [{
2399
- "scroll-ml": a()
2400
- }],
2401
- /**
2402
- * Scroll Padding
2403
- * @see https://tailwindcss.com/docs/scroll-padding
2404
- */
2405
- "scroll-p": [{
2406
- "scroll-p": a()
2407
- }],
2408
- /**
2409
- * Scroll Padding X
2410
- * @see https://tailwindcss.com/docs/scroll-padding
2411
- */
2412
- "scroll-px": [{
2413
- "scroll-px": a()
2414
- }],
2415
- /**
2416
- * Scroll Padding Y
2417
- * @see https://tailwindcss.com/docs/scroll-padding
2418
- */
2419
- "scroll-py": [{
2420
- "scroll-py": a()
2421
- }],
2422
- /**
2423
- * Scroll Padding Start
2424
- * @see https://tailwindcss.com/docs/scroll-padding
2425
- */
2426
- "scroll-ps": [{
2427
- "scroll-ps": a()
2428
- }],
2429
- /**
2430
- * Scroll Padding End
2431
- * @see https://tailwindcss.com/docs/scroll-padding
2432
- */
2433
- "scroll-pe": [{
2434
- "scroll-pe": a()
2435
- }],
2436
- /**
2437
- * Scroll Padding Top
2438
- * @see https://tailwindcss.com/docs/scroll-padding
2439
- */
2440
- "scroll-pt": [{
2441
- "scroll-pt": a()
2442
- }],
2443
- /**
2444
- * Scroll Padding Right
2445
- * @see https://tailwindcss.com/docs/scroll-padding
2446
- */
2447
- "scroll-pr": [{
2448
- "scroll-pr": a()
2449
- }],
2450
- /**
2451
- * Scroll Padding Bottom
2452
- * @see https://tailwindcss.com/docs/scroll-padding
2453
- */
2454
- "scroll-pb": [{
2455
- "scroll-pb": a()
2456
- }],
2457
- /**
2458
- * Scroll Padding Left
2459
- * @see https://tailwindcss.com/docs/scroll-padding
2460
- */
2461
- "scroll-pl": [{
2462
- "scroll-pl": a()
2463
- }],
2464
- /**
2465
- * Scroll Snap Align
2466
- * @see https://tailwindcss.com/docs/scroll-snap-align
2467
- */
2468
- "snap-align": [{
2469
- snap: ["start", "end", "center", "align-none"]
2470
- }],
2471
- /**
2472
- * Scroll Snap Stop
2473
- * @see https://tailwindcss.com/docs/scroll-snap-stop
2474
- */
2475
- "snap-stop": [{
2476
- snap: ["normal", "always"]
2477
- }],
2478
- /**
2479
- * Scroll Snap Type
2480
- * @see https://tailwindcss.com/docs/scroll-snap-type
2481
- */
2482
- "snap-type": [{
2483
- snap: ["none", "x", "y", "both"]
2484
- }],
2485
- /**
2486
- * Scroll Snap Type Strictness
2487
- * @see https://tailwindcss.com/docs/scroll-snap-type
2488
- */
2489
- "snap-strictness": [{
2490
- snap: ["mandatory", "proximity"]
2491
- }],
2492
- /**
2493
- * Touch Action
2494
- * @see https://tailwindcss.com/docs/touch-action
2495
- */
2496
- touch: [{
2497
- touch: ["auto", "none", "manipulation"]
2498
- }],
2499
- /**
2500
- * Touch Action X
2501
- * @see https://tailwindcss.com/docs/touch-action
2502
- */
2503
- "touch-x": [{
2504
- "touch-pan": ["x", "left", "right"]
2505
- }],
2506
- /**
2507
- * Touch Action Y
2508
- * @see https://tailwindcss.com/docs/touch-action
2509
- */
2510
- "touch-y": [{
2511
- "touch-pan": ["y", "up", "down"]
2512
- }],
2513
- /**
2514
- * Touch Action Pinch Zoom
2515
- * @see https://tailwindcss.com/docs/touch-action
2516
- */
2517
- "touch-pz": ["touch-pinch-zoom"],
2518
- /**
2519
- * User Select
2520
- * @see https://tailwindcss.com/docs/user-select
2521
- */
2522
- select: [{
2523
- select: ["none", "text", "all", "auto"]
2524
- }],
2525
- /**
2526
- * Will Change
2527
- * @see https://tailwindcss.com/docs/will-change
2528
- */
2529
- "will-change": [{
2530
- "will-change": ["auto", "scroll", "contents", "transform", o, n]
2531
- }],
2532
- // -----------
2533
- // --- SVG ---
2534
- // -----------
2535
- /**
2536
- * Fill
2537
- * @see https://tailwindcss.com/docs/fill
2538
- */
2539
- fill: [{
2540
- fill: ["none", ...x()]
2541
- }],
2542
- /**
2543
- * Stroke Width
2544
- * @see https://tailwindcss.com/docs/stroke-width
2545
- */
2546
- "stroke-w": [{
2547
- stroke: [c, S, j, $]
2548
- }],
2549
- /**
2550
- * Stroke
2551
- * @see https://tailwindcss.com/docs/stroke
2552
- */
2553
- stroke: [{
2554
- stroke: ["none", ...x()]
2555
- }],
2556
- // ---------------------
2557
- // --- Accessibility ---
2558
- // ---------------------
2559
- /**
2560
- * Forced Color Adjust
2561
- * @see https://tailwindcss.com/docs/forced-color-adjust
2562
- */
2563
- "forced-color-adjust": [{
2564
- "forced-color-adjust": ["auto", "none"]
2565
- }]
2566
- },
2567
- conflictingClassGroups: {
2568
- overflow: ["overflow-x", "overflow-y"],
2569
- overscroll: ["overscroll-x", "overscroll-y"],
2570
- inset: ["inset-x", "inset-y", "start", "end", "top", "right", "bottom", "left"],
2571
- "inset-x": ["right", "left"],
2572
- "inset-y": ["top", "bottom"],
2573
- flex: ["basis", "grow", "shrink"],
2574
- gap: ["gap-x", "gap-y"],
2575
- p: ["px", "py", "ps", "pe", "pt", "pr", "pb", "pl"],
2576
- px: ["pr", "pl"],
2577
- py: ["pt", "pb"],
2578
- m: ["mx", "my", "ms", "me", "mt", "mr", "mb", "ml"],
2579
- mx: ["mr", "ml"],
2580
- my: ["mt", "mb"],
2581
- size: ["w", "h"],
2582
- "font-size": ["leading"],
2583
- "fvn-normal": ["fvn-ordinal", "fvn-slashed-zero", "fvn-figure", "fvn-spacing", "fvn-fraction"],
2584
- "fvn-ordinal": ["fvn-normal"],
2585
- "fvn-slashed-zero": ["fvn-normal"],
2586
- "fvn-figure": ["fvn-normal"],
2587
- "fvn-spacing": ["fvn-normal"],
2588
- "fvn-fraction": ["fvn-normal"],
2589
- "line-clamp": ["display", "overflow"],
2590
- rounded: ["rounded-s", "rounded-e", "rounded-t", "rounded-r", "rounded-b", "rounded-l", "rounded-ss", "rounded-se", "rounded-ee", "rounded-es", "rounded-tl", "rounded-tr", "rounded-br", "rounded-bl"],
2591
- "rounded-s": ["rounded-ss", "rounded-es"],
2592
- "rounded-e": ["rounded-se", "rounded-ee"],
2593
- "rounded-t": ["rounded-tl", "rounded-tr"],
2594
- "rounded-r": ["rounded-tr", "rounded-br"],
2595
- "rounded-b": ["rounded-br", "rounded-bl"],
2596
- "rounded-l": ["rounded-tl", "rounded-bl"],
2597
- "border-spacing": ["border-spacing-x", "border-spacing-y"],
2598
- "border-w": ["border-w-s", "border-w-e", "border-w-t", "border-w-r", "border-w-b", "border-w-l"],
2599
- "border-w-x": ["border-w-r", "border-w-l"],
2600
- "border-w-y": ["border-w-t", "border-w-b"],
2601
- "border-color": ["border-color-s", "border-color-e", "border-color-t", "border-color-r", "border-color-b", "border-color-l"],
2602
- "border-color-x": ["border-color-r", "border-color-l"],
2603
- "border-color-y": ["border-color-t", "border-color-b"],
2604
- translate: ["translate-x", "translate-y", "translate-none"],
2605
- "translate-none": ["translate", "translate-x", "translate-y", "translate-z"],
2606
- "scroll-m": ["scroll-mx", "scroll-my", "scroll-ms", "scroll-me", "scroll-mt", "scroll-mr", "scroll-mb", "scroll-ml"],
2607
- "scroll-mx": ["scroll-mr", "scroll-ml"],
2608
- "scroll-my": ["scroll-mt", "scroll-mb"],
2609
- "scroll-p": ["scroll-px", "scroll-py", "scroll-ps", "scroll-pe", "scroll-pt", "scroll-pr", "scroll-pb", "scroll-pl"],
2610
- "scroll-px": ["scroll-pr", "scroll-pl"],
2611
- "scroll-py": ["scroll-pt", "scroll-pb"],
2612
- touch: ["touch-x", "touch-y", "touch-pz"],
2613
- "touch-x": ["touch"],
2614
- "touch-y": ["touch"],
2615
- "touch-pz": ["touch"]
2616
- },
2617
- conflictingClassGroupModifiers: {
2618
- "font-size": ["leading"]
2619
- },
2620
- orderSensitiveModifiers: ["before", "after", "placeholder", "file", "marker", "selection", "first-line", "first-letter", "backdrop", "*", "**"]
2621
- };
2622
- }, vt = /* @__PURE__ */ Ne(wt);
2623
- function Pt(...e) {
2624
- return vt(ke(e));
2625
- }
2626
- const D = {
2627
- variant: {
2628
- default: "xa:inline-flex xa:items-center xa:justify-center xa:gap-2 xa:whitespace-nowrap xa:rounded-md xa:text-sm xa:font-medium xa:transition-all xa:disabled:pointer-events-none xa:disabled:opacity-50 xa:[&_svg]:pointer-events-none xa:[&_svg:not([class*='size-'])]:size-4 xa:shrink-0 xa:[&_svg]:shrink-0 xa:outline-none xa:focus-visible:border-ring xa:focus-visible:ring-ring/50 xa:focus-visible:ring-[3px] xa:aria-invalid:ring-destructive/20 xa:dark:aria-invalid:ring-destructive/40 xa:aria-invalid:border-destructive xa:bg-primary xa:text-primary-foreground xa:shadow-xs xa:hover:bg-primary/90",
2629
- destructive: "xa:inline-flex xa:items-center xa:justify-center xa:gap-2 xa:whitespace-nowrap xa:rounded-md xa:text-sm xa:font-medium xa:transition-all xa:disabled:pointer-events-none xa:disabled:opacity-50 xa:[&_svg]:pointer-events-none xa:[&_svg:not([class*='size-'])]:size-4 xa:shrink-0 xa:[&_svg]:shrink-0 xa:outline-none xa:focus-visible:border-ring xa:focus-visible:ring-ring/50 xa:focus-visible:ring-[3px] xa:aria-invalid:ring-destructive/20 xa:dark:aria-invalid:ring-destructive/40 xa:aria-invalid:border-destructive xa:bg-destructive xa:text-white xa:shadow-xs xa:hover:bg-destructive/90 xa:focus-visible:ring-destructive/20 xa:dark:focus-visible:ring-destructive/40 xa:dark:bg-destructive/60",
2630
- outline: "xa:inline-flex xa:items-center xa:justify-center xa:gap-2 xa:whitespace-nowrap xa:rounded-md xa:text-sm xa:font-medium xa:transition-all xa:disabled:pointer-events-none xa:disabled:opacity-50 xa:[&_svg]:pointer-events-none xa:[&_svg:not([class*='size-'])]:size-4 xa:shrink-0 xa:[&_svg]:shrink-0 xa:outline-none xa:focus-visible:border-ring xa:focus-visible:ring-ring/50 xa:focus-visible:ring-[3px] xa:aria-invalid:ring-destructive/20 xa:dark:aria-invalid:ring-destructive/40 xa:aria-invalid:border-destructive xa:border xa:bg-background xa:shadow-xs xa:hover:bg-accent xa:hover:text-accent-foreground xa:dark:bg-input/30 xa:dark:border-input xa:dark:hover:bg-input/50",
2631
- secondary: "xa:inline-flex xa:items-center xa:justify-center xa:gap-2 xa:whitespace-nowrap xa:rounded-md xa:text-sm xa:font-medium xa:transition-all xa:disabled:pointer-events-none xa:disabled:opacity-50 xa:[&_svg]:pointer-events-none xa:[&_svg:not([class*='size-'])]:size-4 xa:shrink-0 xa:[&_svg]:shrink-0 xa:outline-none xa:focus-visible:border-ring xa:focus-visible:ring-ring/50 xa:focus-visible:ring-[3px] xa:aria-invalid:ring-destructive/20 xa:dark:aria-invalid:ring-destructive/40 xa:aria-invalid:border-destructive xa:bg-secondary xa:text-secondary-foreground xa:shadow-xs xa:hover:bg-secondary/80",
2632
- ghost: "xa:inline-flex xa:items-center xa:justify-center xa:gap-2 xa:whitespace-nowrap xa:rounded-md xa:text-sm xa:font-medium xa:transition-all xa:disabled:pointer-events-none xa:disabled:opacity-50 xa:[&_svg]:pointer-events-none xa:[&_svg:not([class*='size-'])]:size-4 xa:shrink-0 xa:[&_svg]:shrink-0 xa:outline-none xa:focus-visible:border-ring xa:focus-visible:ring-ring/50 xa:focus-visible:ring-[3px] xa:aria-invalid:ring-destructive/20 xa:dark:aria-invalid:ring-destructive/40 xa:aria-invalid:border-destructive xa:hover:bg-accent xa:hover:text-accent-foreground xa:dark:hover:bg-accent/50",
2633
- link: "xa:inline-flex xa:items-center xa:justify-center xa:gap-2 xa:whitespace-nowrap xa:rounded-md xa:text-sm xa:font-medium xa:transition-all xa:disabled:pointer-events-none xa:disabled:opacity-50 xa:[&_svg]:pointer-events-none xa:[&_svg:not([class*='size-'])]:size-4 xa:shrink-0 xa:[&_svg]:shrink-0 xa:outline-none xa:focus-visible:border-ring xa:focus-visible:ring-ring/50 xa:focus-visible:ring-[3px] xa:aria-invalid:ring-destructive/20 xa:dark:aria-invalid:ring-destructive/40 xa:aria-invalid:border-destructive xa:text-primary xa:underline-offset-4 xa:hover:underline"
2634
- },
2635
- size: {
2636
- default: "xa:h-9 xa:px-4 xa:py-2 xa:has-[>svg]:px-3",
2637
- sm: "xa:h-8 xa:rounded-md xa:gap-1.5 xa:px-3 xa:has-[>svg]:px-2.5",
2638
- lg: "xa:h-10 xa:rounded-md xa:px-6 xa:has-[>svg]:px-4",
2639
- icon: "xa:size-9"
2640
- },
2641
- defaultVariant: "default",
2642
- defaultSize: "default"
2643
- }, ge = (e = D.defaultVariant, r = D.defaultSize, t) => Pt(
2644
- D.variant[e],
2645
- D.size[r],
2646
- t
2647
- );
2648
- function zt({
2649
- className: e,
2650
- variant: r = D.defaultVariant,
2651
- size: t = D.defaultSize,
2652
- asChild: s = !1,
2653
- ...i
2654
- }) {
2655
- if (s && i.children) {
2656
- const d = ue.Children.only(i.children);
2657
- return ue.cloneElement(d, {
2658
- className: ge(r, t, e),
2659
- "data-slot": "button",
2660
- ...i,
2661
- children: d.props.children
2662
- });
2663
- }
2664
- return /* @__PURE__ */ Ie(
2665
- "button",
2666
- {
2667
- "data-slot": "button",
2668
- className: ge(r, t, e),
2669
- ...i
2670
- }
2671
- );
2672
- }
2673
195
  export {
2674
- Re as EKeyInfor,
2675
- C as EStatus,
2676
- je as ETypeRequest,
2677
- Ee as ETypeResponse,
2678
- zt as XButton,
2679
- It as closeApp,
2680
- P as fltSDK,
2681
- Lt as openPickerImage,
2682
- Zt as requestInfo
196
+ l as EKeyInfor,
197
+ i as EStatus,
198
+ t as ETypeRequest,
199
+ o as ETypeResponse,
200
+ G as closeApp,
201
+ y as configUIApp,
202
+ e as fltSDK,
203
+ m as getInfo,
204
+ f as openPickerImage,
205
+ B as vibrate
2683
206
  };