@tamagui/create-theme 1.74.3 → 1.74.4
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/esm/applyMask.native.js +40 -0
- package/dist/esm/applyMask.native.js.map +6 -0
- package/dist/esm/combineMasks.native.js +25 -0
- package/dist/esm/combineMasks.native.js.map +6 -0
- package/dist/esm/createTheme.native.js +35 -0
- package/dist/esm/createTheme.native.js.map +6 -0
- package/dist/esm/createThemeTypes.native.js +1 -0
- package/dist/esm/createThemeTypes.native.js.map +6 -0
- package/dist/esm/helpers.native.js +13 -0
- package/dist/esm/helpers.native.js.map +6 -0
- package/dist/esm/index.native.js +7 -0
- package/dist/esm/index.native.js.map +6 -0
- package/dist/esm/isMinusZero.native.js +7 -0
- package/dist/esm/isMinusZero.native.js.map +6 -0
- package/dist/esm/masks.native.js +83 -0
- package/dist/esm/masks.native.js.map +6 -0
- package/dist/esm/tests.native.js +18 -0
- package/dist/esm/tests.native.js.map +6 -0
- package/dist/esm/themeInfo.native.js +12 -0
- package/dist/esm/themeInfo.native.js.map +6 -0
- package/package.json +3 -3
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { createTheme } from "./createTheme";
|
|
2
|
+
import { getThemeInfo, setThemeInfo } from "./themeInfo";
|
|
3
|
+
function applyMask(theme, mask, options = {}, parentName, nextName) {
|
|
4
|
+
const info = getThemeInfo(theme, parentName);
|
|
5
|
+
if (!info)
|
|
6
|
+
throw new Error(
|
|
7
|
+
process.env.NODE_ENV !== "production" ? "No info found for theme, you must pass the theme created by createThemeFromPalette directly to extendTheme" : "\u274C Err2"
|
|
8
|
+
);
|
|
9
|
+
const next = applyMaskStateless(info, mask, options, parentName);
|
|
10
|
+
return setThemeInfo(next.theme, {
|
|
11
|
+
definition: next.definition,
|
|
12
|
+
palette: info.palette,
|
|
13
|
+
name: nextName
|
|
14
|
+
}), next.theme;
|
|
15
|
+
}
|
|
16
|
+
function applyMaskStateless(info, mask, options = {}, parentName) {
|
|
17
|
+
const skip = {
|
|
18
|
+
...options.skip
|
|
19
|
+
};
|
|
20
|
+
if (info.options?.nonInheritedValues)
|
|
21
|
+
for (const key in info.options.nonInheritedValues)
|
|
22
|
+
skip[key] = 1;
|
|
23
|
+
const maskOptions = {
|
|
24
|
+
parentName,
|
|
25
|
+
palette: info.palette,
|
|
26
|
+
...options,
|
|
27
|
+
skip
|
|
28
|
+
}, template = mask.mask(info.definition, maskOptions), theme = createTheme(info.palette, template);
|
|
29
|
+
return {
|
|
30
|
+
...info,
|
|
31
|
+
cache: /* @__PURE__ */ new Map(),
|
|
32
|
+
definition: template,
|
|
33
|
+
theme
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
export {
|
|
37
|
+
applyMask,
|
|
38
|
+
applyMaskStateless
|
|
39
|
+
};
|
|
40
|
+
//# sourceMappingURL=applyMask.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/applyMask.tsx"],
|
|
4
|
+
"mappings": "AAAA,SAAS,mBAAmB;AAE5B,SAAoB,cAAc,oBAAoB;AAE/C,SAAS,UACd,OACA,MACA,UAAuB,CAAC,GACxB,YACA,UACO;AACP,QAAM,OAAO,aAAa,OAAO,UAAU;AAC3C,MAAI,CAAC;AACH,UAAM,IAAI;AAAA,MACR,QAAQ,IAAI,aAAa,eACrB,+GACA;AAAA,IACN;AAGF,QAAM,OAAO,mBAAmB,MAAM,MAAM,SAAS,UAAU;AAE/D,sBAAa,KAAK,OAAO;AAAA,IACvB,YAAY,KAAK;AAAA,IACjB,SAAS,KAAK;AAAA,IACd,MAAM;AAAA,EACR,CAAC,GAEM,KAAK;AACd;AAEO,SAAS,mBACd,MACA,MACA,UAAuB,CAAC,GACxB,YAGA;AACA,QAAM,OAAO;AAAA,IACX,GAAG,QAAQ;AAAA,EACb;AAGA,MAAI,KAAK,SAAS;AAChB,eAAW,OAAO,KAAK,QAAQ;AAC7B,WAAK,GAAG,IAAI;AAKhB,QAAM,cAAc;AAAA,IAClB;AAAA,IACA,SAAS,KAAK;AAAA,IACd,GAAG;AAAA,IACH;AAAA,EACF,GAEM,WAAW,KAAK,KAAK,KAAK,YAAY,WAAW,GACjD,QAAQ,YAAY,KAAK,SAAS,QAAQ;AAEhD,SAAO;AAAA,IACL,GAAG;AAAA,IACH,OAAO,oBAAI,IAAI;AAAA,IACf,YAAY;AAAA,IACZ;AAAA,EACF;AACF;",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { applyMaskStateless } from "./applyMask";
|
|
2
|
+
import { getThemeInfo } from "./themeInfo";
|
|
3
|
+
const combineMasks = (...masks) => ({
|
|
4
|
+
name: "combine-mask",
|
|
5
|
+
mask: (template, opts) => {
|
|
6
|
+
let current = getThemeInfo(template, opts.parentName), theme;
|
|
7
|
+
for (const mask2 of masks) {
|
|
8
|
+
if (!current)
|
|
9
|
+
throw process.env.NODE_ENV === "development" ? new Error(
|
|
10
|
+
`After applying mask, nothing returned: ${current}, for template: ${template} and mask: ${mask2.toString()}, given opts ${JSON.stringify(
|
|
11
|
+
opts,
|
|
12
|
+
null,
|
|
13
|
+
2
|
|
14
|
+
)}`
|
|
15
|
+
) : "\u274C";
|
|
16
|
+
const next = applyMaskStateless(current, mask2, opts);
|
|
17
|
+
current = next, theme = next.theme;
|
|
18
|
+
}
|
|
19
|
+
return theme;
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
export {
|
|
23
|
+
combineMasks
|
|
24
|
+
};
|
|
25
|
+
//# sourceMappingURL=combineMasks.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/combineMasks.tsx"],
|
|
4
|
+
"mappings": "AAAA,SAAS,0BAA0B;AAEnC,SAAS,oBAAoB;AAEtB,MAAM,eAAe,IAAI,WACL;AAAA,EACvB,MAAM;AAAA,EACN,MAAM,CAAC,UAAU,SAAS;AACxB,QAAI,UAAU,aAAa,UAAU,KAAK,UAAU,GAChD;AACJ,eAAWA,SAAQ,OAAO;AACxB,UAAI,CAAC;AACH,cAAI,QAAQ,IAAI,aAAa,gBACrB,IAAI;AAAA,UACR,0CAA0C,OAAO,mBAAmB,QAAQ,cAAcA,MAAK,SAAS,CAAC,gBAAgB,KAAK;AAAA,YAC5H;AAAA,YACA;AAAA,YACA;AAAA,UACF,CAAC;AAAA,QACH,IAEM;AAEV,YAAM,OAAO,mBAAmB,SAASA,OAAM,IAAI;AACnD,gBAAU,MACV,QAAQ,KAAK;AAAA,IACf;AACA,WAAO;AAAA,EACT;AACF;",
|
|
5
|
+
"names": ["mask"]
|
|
6
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { isMinusZero } from "./isMinusZero";
|
|
2
|
+
import { setThemeInfo } from "./themeInfo";
|
|
3
|
+
const identityCache = /* @__PURE__ */ new Map();
|
|
4
|
+
function createTheme(palette, definition, options, name, skipCache = !1) {
|
|
5
|
+
const cacheKey = skipCache ? "" : JSON.stringify([name, palette, definition, options]);
|
|
6
|
+
if (!skipCache && identityCache.has(cacheKey))
|
|
7
|
+
return identityCache.get(cacheKey);
|
|
8
|
+
const theme = {
|
|
9
|
+
...Object.fromEntries(
|
|
10
|
+
Object.entries(definition).map(([key, offset]) => [key, getValue(palette, offset)])
|
|
11
|
+
),
|
|
12
|
+
...options?.nonInheritedValues
|
|
13
|
+
};
|
|
14
|
+
return cacheKey && (setThemeInfo(theme, { palette, definition, options, name }), identityCache.set(cacheKey, theme)), theme;
|
|
15
|
+
}
|
|
16
|
+
const getValue = (palette, value) => {
|
|
17
|
+
if (typeof value == "string")
|
|
18
|
+
return value;
|
|
19
|
+
const max = palette.length - 1, next = (value === 0 ? !isMinusZero(value) : value >= 0) ? value : max + value, index = Math.min(Math.max(0, next), max);
|
|
20
|
+
return palette[index];
|
|
21
|
+
};
|
|
22
|
+
function addChildren(themes, getChildren) {
|
|
23
|
+
const out = { ...themes };
|
|
24
|
+
for (const key in themes) {
|
|
25
|
+
const subThemes = getChildren(key, themes[key]);
|
|
26
|
+
for (const sKey in subThemes)
|
|
27
|
+
out[`${key}_${sKey}`] = subThemes[sKey];
|
|
28
|
+
}
|
|
29
|
+
return out;
|
|
30
|
+
}
|
|
31
|
+
export {
|
|
32
|
+
addChildren,
|
|
33
|
+
createTheme
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=createTheme.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/createTheme.tsx"],
|
|
4
|
+
"mappings": "AAMA,SAAS,mBAAmB;AAC5B,SAAS,oBAAoB;AAE7B,MAAM,gBAAgB,oBAAI,IAAI;AAEvB,SAAS,YAId,SACA,YACA,SACA,MACA,YAAY,IAGZ;AACA,QAAM,WAAW,YAAY,KAAK,KAAK,UAAU,CAAC,MAAM,SAAS,YAAY,OAAO,CAAC;AACrF,MAAI,CAAC,aACC,cAAc,IAAI,QAAQ;AAC5B,WAAO,cAAc,IAAI,QAAQ;AAIrC,QAAM,QAAQ;AAAA,IACZ,GAAI,OAAO;AAAA,MACT,OAAO,QAAQ,UAAU,EAAE,IAAI,CAAC,CAAC,KAAK,MAAM,MACnC,CAAC,KAAK,SAAS,SAAS,MAAM,CAAC,CACvC;AAAA,IACH;AAAA,IACA,GAAG,SAAS;AAAA,EACd;AAEA,SAAI,aACF,aAAa,OAAO,EAAE,SAAS,YAAY,SAAS,KAAK,CAAC,GAC1D,cAAc,IAAI,UAAU,KAAK,IAG5B;AACT;AAEA,MAAM,WAAW,CAAC,SAA6B,UAA2B;AACxE,MAAI,OAAO,SAAU;AAAU,WAAO;AACtC,QAAM,MAAM,QAAQ,SAAS,GAEvB,QADa,UAAU,IAAI,CAAC,YAAY,KAAK,IAAI,SAAS,KACtC,QAAQ,MAAM,OAClC,QAAQ,KAAK,IAAI,KAAK,IAAI,GAAG,IAAI,GAAG,GAAG;AAC7C,SAAO,QAAQ,KAAK;AACtB;AAWO,SAAS,YAId,QACA,aAGA;AACA,QAAM,MAAM,EAAE,GAAG,OAAO;AACxB,aAAW,OAAO,QAAQ;AACxB,UAAM,YAAY,YAAY,KAAK,OAAO,GAAG,CAAC;AAC9C,eAAW,QAAQ;AACjB,UAAI,GAAG,GAAG,IAAI,IAAI,EAAE,IAAI,UAAU,IAAI;AAAA,EAE1C;AACA,SAAO;AACT;",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=createThemeTypes.js.map
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
const objectKeys = (obj) => Object.keys(obj);
|
|
2
|
+
function objectEntries(obj) {
|
|
3
|
+
return Object.entries(obj);
|
|
4
|
+
}
|
|
5
|
+
function objectFromEntries(arr) {
|
|
6
|
+
return Object.fromEntries(arr);
|
|
7
|
+
}
|
|
8
|
+
export {
|
|
9
|
+
objectEntries,
|
|
10
|
+
objectFromEntries,
|
|
11
|
+
objectKeys
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=helpers.js.map
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { objectEntries, objectFromEntries } from "./helpers";
|
|
2
|
+
import { isMinusZero } from "./isMinusZero";
|
|
3
|
+
const createMask = (createMask2) => typeof createMask2 == "function" ? { name: createMask2.name || "unnamed", mask: createMask2 } : createMask2, skipMask = {
|
|
4
|
+
name: "skip-mask",
|
|
5
|
+
mask: (template, opts) => {
|
|
6
|
+
const { skip } = opts;
|
|
7
|
+
return Object.fromEntries(
|
|
8
|
+
Object.entries(template).filter(([k]) => !skip || !(k in skip)).map(([k, v]) => [k, applyOverrides(k, v, opts)])
|
|
9
|
+
);
|
|
10
|
+
}
|
|
11
|
+
};
|
|
12
|
+
function applyOverrides(key, value, opts) {
|
|
13
|
+
let override, strategy = opts.overrideStrategy;
|
|
14
|
+
const overrideSwap = opts.overrideSwap?.[key];
|
|
15
|
+
if (typeof overrideSwap < "u")
|
|
16
|
+
override = overrideSwap, strategy = "swap";
|
|
17
|
+
else {
|
|
18
|
+
const overrideShift = opts.overrideShift?.[key];
|
|
19
|
+
if (typeof overrideShift < "u")
|
|
20
|
+
override = overrideShift, strategy = "shift";
|
|
21
|
+
else {
|
|
22
|
+
const overrideDefault = opts.override?.[key];
|
|
23
|
+
typeof overrideDefault < "u" && (override = overrideDefault, strategy = opts.overrideStrategy);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
return typeof override > "u" || typeof override == "string" ? value : strategy === "swap" ? override : value;
|
|
27
|
+
}
|
|
28
|
+
const createIdentityMask = () => ({
|
|
29
|
+
name: "identity-mask",
|
|
30
|
+
mask: (template) => template
|
|
31
|
+
}), createInverseMask = () => ({
|
|
32
|
+
name: "inverse-mask",
|
|
33
|
+
mask: (template, opts) => {
|
|
34
|
+
const inversed = objectFromEntries(
|
|
35
|
+
objectEntries(template).map(([k, v]) => [k, -v])
|
|
36
|
+
);
|
|
37
|
+
return skipMask.mask(inversed, opts);
|
|
38
|
+
}
|
|
39
|
+
}), createShiftMask = ({ inverse } = {}, defaultOptions) => ({
|
|
40
|
+
name: "shift-mask",
|
|
41
|
+
mask: (template, opts) => {
|
|
42
|
+
const {
|
|
43
|
+
override,
|
|
44
|
+
overrideStrategy = "shift",
|
|
45
|
+
max: maxIn,
|
|
46
|
+
palette,
|
|
47
|
+
min = 0,
|
|
48
|
+
strength = 1
|
|
49
|
+
} = { ...defaultOptions, ...opts }, values = Object.entries(template), max = maxIn ?? (palette ? Object.values(palette).length - 1 : 1 / 0), out = {};
|
|
50
|
+
for (const [key, value] of values) {
|
|
51
|
+
if (typeof value == "string")
|
|
52
|
+
continue;
|
|
53
|
+
if (typeof override?.[key] == "number") {
|
|
54
|
+
const overrideVal = override[key];
|
|
55
|
+
out[key] = overrideStrategy === "shift" ? value + overrideVal : overrideVal;
|
|
56
|
+
continue;
|
|
57
|
+
} else if (typeof override?.[key] == "string") {
|
|
58
|
+
out[key] = override[key];
|
|
59
|
+
continue;
|
|
60
|
+
}
|
|
61
|
+
const isPositive = value === 0 ? !isMinusZero(value) : value >= 0, direction = isPositive ? 1 : -1, invert = inverse ? -1 : 1, next = value + strength * direction * invert, clamped = isPositive ? Math.max(min, Math.min(max, next)) : Math.min(-min, Math.max(-max, next));
|
|
62
|
+
out[key] = clamped;
|
|
63
|
+
}
|
|
64
|
+
return skipMask.mask(out, opts);
|
|
65
|
+
}
|
|
66
|
+
}), createWeakenMask = (defaultOptions) => ({
|
|
67
|
+
name: "soften-mask",
|
|
68
|
+
mask: createShiftMask({}, defaultOptions).mask
|
|
69
|
+
}), createSoftenMask = createWeakenMask, createStrengthenMask = (defaultOptions) => ({
|
|
70
|
+
name: "strengthen-mask",
|
|
71
|
+
mask: createShiftMask({ inverse: !0 }, defaultOptions).mask
|
|
72
|
+
});
|
|
73
|
+
export {
|
|
74
|
+
createIdentityMask,
|
|
75
|
+
createInverseMask,
|
|
76
|
+
createMask,
|
|
77
|
+
createShiftMask,
|
|
78
|
+
createSoftenMask,
|
|
79
|
+
createStrengthenMask,
|
|
80
|
+
createWeakenMask,
|
|
81
|
+
skipMask
|
|
82
|
+
};
|
|
83
|
+
//# sourceMappingURL=masks.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/masks.tsx"],
|
|
4
|
+
"mappings": "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",
|
|
5
|
+
"names": ["createMask"]
|
|
6
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { applyMask } from "./applyMask";
|
|
2
|
+
import { createTheme } from "./createTheme";
|
|
3
|
+
import { createStrengthenMask, createWeakenMask } from "./masks";
|
|
4
|
+
if (process.env.NODE_ENV === "development") {
|
|
5
|
+
const palette = ["0", "1", "2", "3", "-3", "-2", "-1", "-0"], template = { bg: 1, fg: -1 }, stongerMask = createStrengthenMask(), weakerMask = createWeakenMask(), theme = createTheme(palette, template);
|
|
6
|
+
if (theme.bg !== "1" || theme.fg !== "-1")
|
|
7
|
+
throw "\u274C";
|
|
8
|
+
const str = applyMask(theme, stongerMask);
|
|
9
|
+
if (str.bg !== "0" || str.fg !== "-0")
|
|
10
|
+
throw "\u274C";
|
|
11
|
+
const weak = applyMask(theme, weakerMask);
|
|
12
|
+
if (weak.bg !== "2" || weak.fg !== "-2")
|
|
13
|
+
throw "\u274C";
|
|
14
|
+
const weak2 = applyMask(theme, weakerMask, { strength: 2 });
|
|
15
|
+
if (weak2.bg !== "3" || weak2.fg !== "-3")
|
|
16
|
+
throw "\u274C";
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=tests.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/tests.tsx"],
|
|
4
|
+
"mappings": "AAAA,SAAS,iBAAiB;AAC1B,SAAS,mBAAmB;AAC5B,SAAS,sBAAsB,wBAAwB;AAGvD,IAAI,QAAQ,IAAI,aAAa,eAAe;AAC1C,QAAM,UAAU,CAAC,KAAK,KAAK,KAAK,KAAK,MAAM,MAAM,MAAM,IAAI,GACrD,WAAW,EAAE,IAAI,GAAG,IAAI,GAAG,GAE3B,cAAc,qBAAqB,GACnC,aAAa,iBAAiB,GAE9B,QAAQ,YAAY,SAAS,QAAQ;AAE3C,MADI,MAAM,OAAO,OACb,MAAM,OAAO;AAAM,UAAM;AAE7B,QAAM,MAAM,UAAU,OAAO,WAAW;AAExC,MADI,IAAI,OAAO,OACX,IAAI,OAAO;AAAM,UAAM;AAE3B,QAAM,OAAO,UAAU,OAAO,UAAU;AAExC,MADI,KAAK,OAAO,OACZ,KAAK,OAAO;AAAM,UAAM;AAE5B,QAAM,QAAQ,UAAU,OAAO,YAAY,EAAE,UAAU,EAAE,CAAC;AAE1D,MADI,MAAM,OAAO,OACb,MAAM,OAAO;AAAM,UAAM;AAC/B;",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
const THEME_INFO = /* @__PURE__ */ new Map(), getThemeInfo = (theme, name) => THEME_INFO.get(name || JSON.stringify(theme)), setThemeInfo = (theme, info) => {
|
|
2
|
+
const next = {
|
|
3
|
+
...info,
|
|
4
|
+
cache: /* @__PURE__ */ new Map()
|
|
5
|
+
};
|
|
6
|
+
THEME_INFO.set(info.name || JSON.stringify(theme), next), THEME_INFO.set(JSON.stringify(info.definition), next);
|
|
7
|
+
};
|
|
8
|
+
export {
|
|
9
|
+
getThemeInfo,
|
|
10
|
+
setThemeInfo
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=themeInfo.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/themeInfo.tsx"],
|
|
4
|
+
"mappings": "AAcA,MAAM,aAAa,oBAAI,IAAuB,GAEjC,eAAe,CAC1B,OACA,SAEO,WAAW,IAAI,QAAQ,KAAK,UAAU,KAAK,CAAC,GAGxC,eAAe,CAC1B,OACA,SAGG;AACH,QAAM,OAAO;AAAA,IACX,GAAG;AAAA,IACH,OAAO,oBAAI,IAAI;AAAA,EACjB;AACA,aAAW,IAAI,KAAK,QAAQ,KAAK,UAAU,KAAK,GAAG,IAAI,GACvD,WAAW,IAAI,KAAK,UAAU,KAAK,UAAU,GAAG,IAAI;AACtD;",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tamagui/create-theme",
|
|
3
|
-
"version": "1.74.
|
|
3
|
+
"version": "1.74.4",
|
|
4
4
|
"types": "./types/index.d.ts",
|
|
5
5
|
"main": "dist/cjs",
|
|
6
6
|
"module": "dist/esm",
|
|
@@ -28,10 +28,10 @@
|
|
|
28
28
|
}
|
|
29
29
|
},
|
|
30
30
|
"dependencies": {
|
|
31
|
-
"@tamagui/web": "1.74.
|
|
31
|
+
"@tamagui/web": "1.74.4"
|
|
32
32
|
},
|
|
33
33
|
"devDependencies": {
|
|
34
|
-
"@tamagui/build": "1.74.
|
|
34
|
+
"@tamagui/build": "1.74.4"
|
|
35
35
|
},
|
|
36
36
|
"publishConfig": {
|
|
37
37
|
"access": "public"
|