@tamagui/create-theme 1.38.1 → 1.38.3
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/cjs/ThemeBuilder.js +2 -1
- package/dist/cjs/ThemeBuilder.js.map +1 -1
- package/dist/cjs/applyMask.js +72 -0
- package/dist/cjs/applyMask.js.map +6 -0
- package/dist/cjs/applyMaskStateless.js +72 -0
- package/dist/cjs/applyMaskStateless.js.map +6 -0
- package/dist/cjs/combineMasks.js +48 -0
- package/dist/cjs/combineMasks.js.map +6 -0
- package/dist/cjs/createTheme.js.map +1 -1
- package/dist/cjs/createThemeTypes.js +17 -0
- package/dist/cjs/createThemeTypes.js.map +6 -0
- package/dist/cjs/index.js +6 -2
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/isMinusZero.js.map +1 -1
- package/dist/cjs/masks.js +0 -66
- package/dist/cjs/masks.js.map +2 -2
- package/dist/cjs/tests.js +4 -3
- package/dist/cjs/tests.js.map +1 -1
- package/dist/cjs/themeInfo.js.map +1 -1
- package/dist/esm/ThemeBuilder.js +2 -1
- package/dist/esm/ThemeBuilder.js.map +1 -1
- package/dist/esm/applyMask.js +47 -0
- package/dist/esm/applyMask.js.map +6 -0
- package/dist/esm/applyMaskStateless.js +47 -0
- package/dist/esm/applyMaskStateless.js.map +6 -0
- package/dist/esm/combineMasks.js +24 -0
- package/dist/esm/combineMasks.js.map +6 -0
- package/dist/esm/createTheme.js.map +1 -1
- package/dist/esm/createThemeTypes.js +1 -0
- package/dist/esm/createThemeTypes.js.map +6 -0
- package/dist/esm/index.js +3 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/isMinusZero.js.map +1 -1
- package/dist/esm/masks.js +0 -63
- package/dist/esm/masks.js.map +2 -2
- package/dist/esm/tests.js +2 -1
- package/dist/esm/tests.js.map +1 -1
- package/dist/esm/themeInfo.js.map +1 -1
- package/package.json +3 -3
- package/src/ThemeBuilder.tsx +4 -3
- package/src/applyMask.tsx +68 -0
- package/src/combineMasks.tsx +21 -0
- package/src/createTheme.tsx +6 -1
- package/src/index.tsx +3 -1
- package/src/isMinusZero.tsx +1 -1
- package/src/masks.tsx +1 -86
- package/src/tests.tsx +2 -1
- package/src/themeInfo.tsx +6 -1
- package/types/ThemeBuilder.d.ts +2 -2
- package/types/ThemeBuilder.d.ts.map +1 -1
- package/types/applyMask.d.ts +7 -0
- package/types/applyMask.d.ts.map +1 -0
- package/types/applyMaskStateless.d.ts +7 -0
- package/types/applyMaskStateless.d.ts.map +1 -0
- package/types/combineMasks.d.ts +3 -0
- package/types/combineMasks.d.ts.map +1 -0
- package/types/createTheme.d.ts +1 -1
- package/types/createTheme.d.ts.map +1 -1
- package/types/createThemeTypes.d.ts +24 -0
- package/types/createThemeTypes.d.ts.map +1 -0
- package/types/index.d.ts +3 -1
- package/types/index.d.ts.map +1 -1
- package/types/isMinusZero.d.ts +1 -1
- package/types/isMinusZero.d.ts.map +1 -1
- package/types/masks.d.ts +1 -7
- package/types/masks.d.ts.map +1 -1
- package/types/themeInfo.d.ts +1 -1
- package/types/themeInfo.d.ts.map +1 -1
- /package/src/{types.tsx → createThemeTypes.tsx} +0 -0
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { applyMaskStateless } from "./applyMask";
|
|
2
|
+
import { getThemeInfo } from "./themeInfo";
|
|
3
|
+
const combineMasks = (...masks) => {
|
|
4
|
+
const mask = {
|
|
5
|
+
name: "combine-mask",
|
|
6
|
+
mask: (template, opts) => {
|
|
7
|
+
let current = getThemeInfo(template, opts.parentName);
|
|
8
|
+
let theme;
|
|
9
|
+
for (const mask2 of masks) {
|
|
10
|
+
if (!current)
|
|
11
|
+
throw `\u274C`;
|
|
12
|
+
const next = applyMaskStateless(current, mask2, opts);
|
|
13
|
+
current = next;
|
|
14
|
+
theme = next.theme;
|
|
15
|
+
}
|
|
16
|
+
return theme;
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
return mask;
|
|
20
|
+
};
|
|
21
|
+
export {
|
|
22
|
+
combineMasks
|
|
23
|
+
};
|
|
24
|
+
//# 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,UAAwB;AACtD,QAAM,OAAmB;AAAA,IACvB,MAAM;AAAA,IACN,MAAM,CAAC,UAAU,SAAS;AACxB,UAAI,UAAU,aAAa,UAAU,KAAK,UAAU;AACpD,UAAI;AACJ,iBAAWA,SAAQ,OAAO;AACxB,YAAI,CAAC;AAAS,gBAAM;AACpB,cAAM,OAAO,mBAAmB,SAASA,OAAM,IAAI;AACnD,kBAAU;AACV,gBAAQ,KAAK;AAAA,MACf;AACA,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAO;AACT;",
|
|
5
|
+
"names": ["mask"]
|
|
6
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/createTheme.tsx"],
|
|
4
|
-
"mappings": "
|
|
4
|
+
"mappings": "AAMA,SAAS,mBAAmB;AAC5B,SAAS,oBAAoB;AAE7B,MAAM,gBAAgB,oBAAI,IAAI;AAEvB,SAAS,YAId,SACA,YACA,SACA,MACA,YAAY,OAGZ;AACA,QAAM,WAAW,YAAY,KAAK,KAAK,UAAU,CAAC,MAAM,SAAS,YAAY,OAAO,CAAC;AACrF,MAAI,CAAC,WAAW;AACd,QAAI,cAAc,IAAI,QAAQ,GAAG;AAC/B,aAAO,cAAc,IAAI,QAAQ;AAAA,IACnC;AAAA,EACF;AAEA,QAAM,QAAQ;AAAA,IACZ,GAAI,OAAO;AAAA,MACT,OAAO,QAAQ,UAAU,EAAE,IAAI,CAAC,CAAC,KAAK,MAAM,MAAM;AAChD,eAAO,CAAC,KAAK,SAAS,SAAS,MAAM,CAAC;AAAA,MACxC,CAAC;AAAA,IACH;AAAA,IACA,GAAG,mCAAS;AAAA,EACd;AAEA,MAAI,UAAU;AACZ,iBAAa,OAAO,EAAE,SAAS,YAAY,SAAS,KAAK,CAAC;AAC1D,kBAAc,IAAI,UAAU,KAAK;AAAA,EACnC;AAEA,SAAO;AACT;AAEA,MAAM,WAAW,CAAC,SAA6B,UAA2B;AACxE,MAAI,OAAO,UAAU;AAAU,WAAO;AACtC,QAAM,MAAM,QAAQ,SAAS;AAC7B,QAAM,aAAa,UAAU,IAAI,CAAC,YAAY,KAAK,IAAI,SAAS;AAChE,QAAM,OAAO,aAAa,QAAQ,MAAM;AACxC,QAAM,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,WAAW;AAC5B,UAAI,GAAG,OAAO,MAAM,IAAI,UAAU,IAAI;AAAA,IACxC;AAAA,EACF;AACA,SAAO;AACT;",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=createThemeTypes.js.map
|
package/dist/esm/index.js
CHANGED
package/dist/esm/index.js.map
CHANGED
package/dist/esm/masks.js
CHANGED
|
@@ -1,26 +1,6 @@
|
|
|
1
|
-
import { createTheme } from "./createTheme";
|
|
2
1
|
import { objectEntries, objectFromEntries } from "./helpers";
|
|
3
2
|
import { isMinusZero } from "./isMinusZero";
|
|
4
|
-
import { getThemeInfo, setThemeInfo } from "./themeInfo";
|
|
5
3
|
const createMask = (createMask2) => typeof createMask2 === "function" ? { name: createMask2.name || "unnamed", mask: createMask2 } : createMask2;
|
|
6
|
-
const combineMasks = (...masks) => {
|
|
7
|
-
const mask = {
|
|
8
|
-
name: "combine-mask",
|
|
9
|
-
mask: (template, opts) => {
|
|
10
|
-
let current = getThemeInfo(template, opts.parentName);
|
|
11
|
-
let theme;
|
|
12
|
-
for (const mask2 of masks) {
|
|
13
|
-
if (!current)
|
|
14
|
-
throw `\u274C`;
|
|
15
|
-
const next = applyMaskStateless(current, mask2, opts);
|
|
16
|
-
current = next;
|
|
17
|
-
theme = next.theme;
|
|
18
|
-
}
|
|
19
|
-
return theme;
|
|
20
|
-
}
|
|
21
|
-
};
|
|
22
|
-
return mask;
|
|
23
|
-
};
|
|
24
4
|
const skipMask = {
|
|
25
5
|
name: "skip-mask",
|
|
26
6
|
mask: (template, { skip }) => {
|
|
@@ -93,50 +73,7 @@ const createStrengthenMask = (defaultOptions) => ({
|
|
|
93
73
|
name: "strengthen-mask",
|
|
94
74
|
mask: createShiftMask({ inverse: true }, defaultOptions).mask
|
|
95
75
|
});
|
|
96
|
-
function applyMaskStateless(info, mask, options = {}, parentName) {
|
|
97
|
-
var _a;
|
|
98
|
-
const skip = {
|
|
99
|
-
...options.skip
|
|
100
|
-
};
|
|
101
|
-
if ((_a = info.options) == null ? void 0 : _a.nonInheritedValues) {
|
|
102
|
-
for (const key in info.options.nonInheritedValues) {
|
|
103
|
-
skip[key] = 1;
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
const maskOptions = {
|
|
107
|
-
parentName,
|
|
108
|
-
palette: info.palette,
|
|
109
|
-
...options,
|
|
110
|
-
skip
|
|
111
|
-
};
|
|
112
|
-
const template = mask.mask(info.definition, maskOptions);
|
|
113
|
-
const theme = createTheme(info.palette, template);
|
|
114
|
-
return {
|
|
115
|
-
...info,
|
|
116
|
-
cache: /* @__PURE__ */ new Map(),
|
|
117
|
-
definition: template,
|
|
118
|
-
theme
|
|
119
|
-
};
|
|
120
|
-
}
|
|
121
|
-
function applyMask(theme, mask, options = {}, parentName, nextName) {
|
|
122
|
-
const info = getThemeInfo(theme, parentName);
|
|
123
|
-
if (!info) {
|
|
124
|
-
throw new Error(
|
|
125
|
-
process.env.NODE_ENV !== "production" ? `No info found for theme, you must pass the theme created by createThemeFromPalette directly to extendTheme` : `\u274C Err2`
|
|
126
|
-
);
|
|
127
|
-
}
|
|
128
|
-
const next = applyMaskStateless(info, mask, options, parentName);
|
|
129
|
-
setThemeInfo(next.theme, {
|
|
130
|
-
definition: next.definition,
|
|
131
|
-
palette: info.palette,
|
|
132
|
-
name: nextName
|
|
133
|
-
});
|
|
134
|
-
return next.theme;
|
|
135
|
-
}
|
|
136
76
|
export {
|
|
137
|
-
applyMask,
|
|
138
|
-
applyMaskStateless,
|
|
139
|
-
combineMasks,
|
|
140
77
|
createIdentityMask,
|
|
141
78
|
createInverseMask,
|
|
142
79
|
createMask,
|
package/dist/esm/masks.js.map
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/masks.tsx"],
|
|
4
|
-
"mappings": "
|
|
5
|
-
"names": ["createMask"
|
|
4
|
+
"mappings": "AACA,SAAS,eAAe,yBAAyB;AACjD,SAAS,mBAAmB;AAErB,MAAM,aAAa,CACxBA,gBAEA,OAAOA,gBAAe,aAClB,EAAE,MAAMA,YAAW,QAAQ,WAAW,MAAMA,YAAW,IACvDA;AAEC,MAAM,WAAuB;AAAA,EAClC,MAAM;AAAA,EACN,MAAM,CAAC,UAAU,EAAE,KAAK,MAAM;AAC5B,QAAI,CAAC;AAAM,aAAO;AAClB,WAAO,OAAO;AAAA,MACZ,OAAO,QAAQ,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC,MAAM,EAAE,KAAK,KAAK;AAAA,IACvD;AAAA,EACF;AACF;AAEO,MAAM,qBAAqB,OAAmB;AAAA,EACnD,MAAM;AAAA,EACN,MAAM,CAAC,aAAa;AACtB;AAEO,MAAM,oBAAoB,MAAM;AACrC,QAAM,OAAmB;AAAA,IACvB,MAAM;AAAA,IACN,MAAM,CAAC,UAAU,SAAS;AACxB,YAAM,WAAW;AAAA,QACf,cAAc,QAAQ,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;AAAA,MACjD;AACA,aAAO,SAAS,KAAK,UAAU,IAAI;AAAA,IACrC;AAAA,EACF;AACA,SAAO;AACT;AAIO,MAAM,kBAAkB,CAC7B,EAAE,QAAQ,IAAsB,CAAC,GACjC,mBACG;AACH,QAAM,OAAmB;AAAA,IACvB,MAAM;AAAA,IACN,MAAM,CAAC,UAAU,SAAS;AACxB,YAAM;AAAA,QACJ;AAAA,QACA,KAAK;AAAA,QACL;AAAA,QACA,MAAM;AAAA,QACN,WAAW;AAAA,MACb,IAAI,EAAE,GAAG,gBAAgB,GAAG,KAAK;AACjC,YAAM,SAAS,OAAO,QAAQ,QAAQ;AACtC,YAAM,MAAM,UAAU,UAAU,OAAO,OAAO,OAAO,EAAE,SAAS,IAAI;AACpE,YAAM,MAAM,CAAC;AACb,iBAAW,CAAC,KAAK,KAAK,KAAK,QAAQ;AACjC,YAAI,OAAO,UAAU;AAAU;AAC/B,YAAI,QAAO,qCAAW,UAAS,UAAU;AACvC,gBAAM,gBAAgB,SAAS,GAAG;AAClC,cAAI,GAAG,IAAI,QAAQ;AACnB;AAAA,QACF,WAAW,QAAO,qCAAW,UAAS,UAAU;AAC9C,cAAI,GAAG,IAAI,SAAS,GAAG;AACvB;AAAA,QACF;AACA,cAAM,aAAa,UAAU,IAAI,CAAC,YAAY,KAAK,IAAI,SAAS;AAChE,cAAM,YAAY,aAAa,IAAI;AACnC,cAAM,SAAS,UAAU,KAAK;AAC9B,cAAM,OAAO,QAAQ,WAAW,YAAY;AAC5C,cAAM,UAAU,aACZ,KAAK,IAAI,KAAK,KAAK,IAAI,KAAK,IAAI,CAAC,IACjC,KAAK,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,IAAI,CAAC;AAEvC,YAAI,GAAG,IAAI;AAAA,MACb;AAEA,aAAO,SAAS,KAAK,KAAK,IAAI;AAAA,IAChC;AAAA,EACF;AACA,SAAO;AACT;AAEO,MAAM,mBAAmB,CAAC,oBAA8C;AAAA,EAC7E,MAAM;AAAA,EACN,MAAM,gBAAgB,CAAC,GAAG,cAAc,EAAE;AAC5C;AAEO,MAAM,mBAAmB;AAEzB,MAAM,uBAAuB,CAAC,oBAA8C;AAAA,EACjF,MAAM;AAAA,EACN,MAAM,gBAAgB,EAAE,SAAS,KAAK,GAAG,cAAc,EAAE;AAC3D;",
|
|
5
|
+
"names": ["createMask"]
|
|
6
6
|
}
|
package/dist/esm/tests.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { applyMask } from "./applyMask";
|
|
1
2
|
import { createTheme } from "./createTheme";
|
|
2
|
-
import {
|
|
3
|
+
import { createStrengthenMask, createWeakenMask } from "./masks";
|
|
3
4
|
if (process.env.NODE_ENV === "development") {
|
|
4
5
|
const palette = ["0", "1", "2", "3", "-3", "-2", "-1", "-0"];
|
|
5
6
|
const template = { bg: 1, fg: -1 };
|
package/dist/esm/tests.js.map
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/tests.tsx"],
|
|
4
|
-
"mappings": "AAAA,SAAS,mBAAmB;AAC5B,SAAS,
|
|
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;AAC3D,QAAM,WAAW,EAAE,IAAI,GAAG,IAAI,GAAG;AAEjC,QAAM,cAAc,qBAAqB;AACzC,QAAM,aAAa,iBAAiB;AAEpC,QAAM,QAAQ,YAAY,SAAS,QAAQ;AAC3C,MAAI,MAAM,OAAO;AAAK,UAAM;AAC5B,MAAI,MAAM,OAAO;AAAM,UAAM;AAE7B,QAAM,MAAM,UAAU,OAAO,WAAW;AACxC,MAAI,IAAI,OAAO;AAAK,UAAM;AAC1B,MAAI,IAAI,OAAO;AAAM,UAAM;AAE3B,QAAM,OAAO,UAAU,OAAO,UAAU;AACxC,MAAI,KAAK,OAAO;AAAK,UAAM;AAC3B,MAAI,KAAK,OAAO;AAAM,UAAM;AAE5B,QAAM,QAAQ,UAAU,OAAO,YAAY,EAAE,UAAU,EAAE,CAAC;AAC1D,MAAI,MAAM,OAAO;AAAK,UAAM;AAC5B,MAAI,MAAM,OAAO;AAAM,UAAM;AAC/B;",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/themeInfo.tsx"],
|
|
4
|
-
"mappings": "
|
|
4
|
+
"mappings": "AAcA,MAAM,aAAa,oBAAI,IAAuB;AAEvC,MAAM,eAAe,CAC1B,OACA,SAC0B;AAC1B,SAAO,WAAW,IAAI,QAAQ,KAAK,UAAU,KAAK,CAAC;AACrD;AAEO,MAAM,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;AACvD,aAAW,IAAI,KAAK,UAAU,KAAK,UAAU,GAAG,IAAI;AACtD;",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tamagui/create-theme",
|
|
3
|
-
"version": "1.38.
|
|
3
|
+
"version": "1.38.3",
|
|
4
4
|
"types": "./types/index.d.ts",
|
|
5
5
|
"main": "dist/cjs",
|
|
6
6
|
"module": "dist/esm",
|
|
@@ -33,10 +33,10 @@
|
|
|
33
33
|
}
|
|
34
34
|
},
|
|
35
35
|
"dependencies": {
|
|
36
|
-
"@tamagui/web": "1.38.
|
|
36
|
+
"@tamagui/web": "1.38.3"
|
|
37
37
|
},
|
|
38
38
|
"devDependencies": {
|
|
39
|
-
"@tamagui/build": "1.38.
|
|
39
|
+
"@tamagui/build": "1.38.3"
|
|
40
40
|
},
|
|
41
41
|
"publishConfig": {
|
|
42
42
|
"access": "public"
|
package/src/ThemeBuilder.tsx
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { Narrow } from '@tamagui/web'
|
|
1
|
+
import type { Narrow } from '@tamagui/web'
|
|
2
2
|
|
|
3
|
+
import { applyMask } from './applyMask'
|
|
3
4
|
import { createTheme } from './createTheme'
|
|
5
|
+
import { CreateMask, CreateThemeOptions, MaskOptions } from './createThemeTypes'
|
|
4
6
|
import { objectEntries, objectFromEntries, objectKeys } from './helpers'
|
|
5
|
-
import {
|
|
6
|
-
import { CreateMask, CreateThemeOptions, MaskOptions } from './types'
|
|
7
|
+
import { createMask } from './masks'
|
|
7
8
|
|
|
8
9
|
export type Palette = string[]
|
|
9
10
|
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { createTheme } from './createTheme'
|
|
2
|
+
import { CreateMask, GenericTheme, MaskOptions, ThemeMask } from './createThemeTypes'
|
|
3
|
+
import { ThemeInfo, getThemeInfo, setThemeInfo } from './themeInfo'
|
|
4
|
+
|
|
5
|
+
export function applyMask<Theme extends GenericTheme | ThemeMask>(
|
|
6
|
+
theme: Theme,
|
|
7
|
+
mask: CreateMask,
|
|
8
|
+
options: MaskOptions = {},
|
|
9
|
+
parentName?: string,
|
|
10
|
+
nextName?: string
|
|
11
|
+
): Theme {
|
|
12
|
+
const info = getThemeInfo(theme, parentName)
|
|
13
|
+
if (!info) {
|
|
14
|
+
throw new Error(
|
|
15
|
+
process.env.NODE_ENV !== 'production'
|
|
16
|
+
? `No info found for theme, you must pass the theme created by createThemeFromPalette directly to extendTheme`
|
|
17
|
+
: `❌ Err2`
|
|
18
|
+
)
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
const next = applyMaskStateless(info, mask, options, parentName)
|
|
22
|
+
|
|
23
|
+
setThemeInfo(next.theme, {
|
|
24
|
+
definition: next.definition,
|
|
25
|
+
palette: info.palette,
|
|
26
|
+
name: nextName,
|
|
27
|
+
})
|
|
28
|
+
|
|
29
|
+
return next.theme as Theme
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export function applyMaskStateless<Theme extends GenericTheme | ThemeMask>(
|
|
33
|
+
info: ThemeInfo,
|
|
34
|
+
mask: CreateMask,
|
|
35
|
+
options: MaskOptions = {},
|
|
36
|
+
parentName?: string
|
|
37
|
+
): ThemeInfo & {
|
|
38
|
+
theme: Theme
|
|
39
|
+
} {
|
|
40
|
+
const skip = {
|
|
41
|
+
...options.skip,
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
// skip nonInheritedValues from parent theme
|
|
45
|
+
if (info.options?.nonInheritedValues) {
|
|
46
|
+
for (const key in info.options.nonInheritedValues) {
|
|
47
|
+
skip[key] = 1
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// convert theme back to template first
|
|
52
|
+
const maskOptions = {
|
|
53
|
+
parentName,
|
|
54
|
+
palette: info.palette,
|
|
55
|
+
...options,
|
|
56
|
+
skip,
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
const template = mask.mask(info.definition, maskOptions)
|
|
60
|
+
const theme = createTheme(info.palette, template) as Theme
|
|
61
|
+
|
|
62
|
+
return {
|
|
63
|
+
...info,
|
|
64
|
+
cache: new Map(),
|
|
65
|
+
definition: template,
|
|
66
|
+
theme,
|
|
67
|
+
}
|
|
68
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { applyMaskStateless } from './applyMask'
|
|
2
|
+
import { CreateMask } from './createThemeTypes'
|
|
3
|
+
import { getThemeInfo } from './themeInfo'
|
|
4
|
+
|
|
5
|
+
export const combineMasks = (...masks: CreateMask[]) => {
|
|
6
|
+
const mask: CreateMask = {
|
|
7
|
+
name: 'combine-mask',
|
|
8
|
+
mask: (template, opts) => {
|
|
9
|
+
let current = getThemeInfo(template, opts.parentName)
|
|
10
|
+
let theme: any
|
|
11
|
+
for (const mask of masks) {
|
|
12
|
+
if (!current) throw `❌`
|
|
13
|
+
const next = applyMaskStateless(current, mask, opts)
|
|
14
|
+
current = next
|
|
15
|
+
theme = next.theme
|
|
16
|
+
}
|
|
17
|
+
return theme
|
|
18
|
+
},
|
|
19
|
+
}
|
|
20
|
+
return mask
|
|
21
|
+
}
|
package/src/createTheme.tsx
CHANGED
|
@@ -1,6 +1,11 @@
|
|
|
1
|
+
import {
|
|
2
|
+
CreateThemeOptions,
|
|
3
|
+
CreateThemePalette,
|
|
4
|
+
GenericTheme,
|
|
5
|
+
ThemeMask,
|
|
6
|
+
} from './createThemeTypes'
|
|
1
7
|
import { isMinusZero } from './isMinusZero'
|
|
2
8
|
import { setThemeInfo } from './themeInfo'
|
|
3
|
-
import { CreateThemeOptions, CreateThemePalette, GenericTheme, ThemeMask } from './types'
|
|
4
9
|
|
|
5
10
|
const identityCache = new Map()
|
|
6
11
|
|
package/src/index.tsx
CHANGED
package/src/isMinusZero.tsx
CHANGED
package/src/masks.tsx
CHANGED
|
@@ -1,8 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { CreateMask, MaskFunction, MaskOptions } from './createThemeTypes'
|
|
2
2
|
import { objectEntries, objectFromEntries } from './helpers'
|
|
3
3
|
import { isMinusZero } from './isMinusZero'
|
|
4
|
-
import { ThemeInfo, getThemeInfo, setThemeInfo } from './themeInfo'
|
|
5
|
-
import { CreateMask, GenericTheme, MaskFunction, MaskOptions, ThemeMask } from './types'
|
|
6
4
|
|
|
7
5
|
export const createMask = <C extends CreateMask | MaskFunction>(
|
|
8
6
|
createMask: C
|
|
@@ -11,24 +9,6 @@ export const createMask = <C extends CreateMask | MaskFunction>(
|
|
|
11
9
|
? { name: createMask.name || 'unnamed', mask: createMask }
|
|
12
10
|
: createMask
|
|
13
11
|
|
|
14
|
-
export const combineMasks = (...masks: CreateMask[]) => {
|
|
15
|
-
const mask: CreateMask = {
|
|
16
|
-
name: 'combine-mask',
|
|
17
|
-
mask: (template, opts) => {
|
|
18
|
-
let current = getThemeInfo(template, opts.parentName)
|
|
19
|
-
let theme: any
|
|
20
|
-
for (const mask of masks) {
|
|
21
|
-
if (!current) throw `❌`
|
|
22
|
-
const next = applyMaskStateless(current, mask, opts)
|
|
23
|
-
current = next
|
|
24
|
-
theme = next.theme
|
|
25
|
-
}
|
|
26
|
-
return theme
|
|
27
|
-
},
|
|
28
|
-
}
|
|
29
|
-
return mask
|
|
30
|
-
}
|
|
31
|
-
|
|
32
12
|
export const skipMask: CreateMask = {
|
|
33
13
|
name: 'skip-mask',
|
|
34
14
|
mask: (template, { skip }) => {
|
|
@@ -114,68 +94,3 @@ export const createStrengthenMask = (defaultOptions?: MaskOptions): CreateMask =
|
|
|
114
94
|
name: 'strengthen-mask',
|
|
115
95
|
mask: createShiftMask({ inverse: true }, defaultOptions).mask,
|
|
116
96
|
})
|
|
117
|
-
|
|
118
|
-
export function applyMaskStateless<Theme extends GenericTheme | ThemeMask>(
|
|
119
|
-
info: ThemeInfo,
|
|
120
|
-
mask: CreateMask,
|
|
121
|
-
options: MaskOptions = {},
|
|
122
|
-
parentName?: string
|
|
123
|
-
): ThemeInfo & {
|
|
124
|
-
theme: Theme
|
|
125
|
-
} {
|
|
126
|
-
const skip = {
|
|
127
|
-
...options.skip,
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
// skip nonInheritedValues from parent theme
|
|
131
|
-
if (info.options?.nonInheritedValues) {
|
|
132
|
-
for (const key in info.options.nonInheritedValues) {
|
|
133
|
-
skip[key] = 1
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
// convert theme back to template first
|
|
138
|
-
const maskOptions = {
|
|
139
|
-
parentName,
|
|
140
|
-
palette: info.palette,
|
|
141
|
-
...options,
|
|
142
|
-
skip,
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
const template = mask.mask(info.definition, maskOptions)
|
|
146
|
-
const theme = createTheme(info.palette, template) as Theme
|
|
147
|
-
|
|
148
|
-
return {
|
|
149
|
-
...info,
|
|
150
|
-
cache: new Map(),
|
|
151
|
-
definition: template,
|
|
152
|
-
theme,
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
export function applyMask<Theme extends GenericTheme | ThemeMask>(
|
|
157
|
-
theme: Theme,
|
|
158
|
-
mask: CreateMask,
|
|
159
|
-
options: MaskOptions = {},
|
|
160
|
-
parentName?: string,
|
|
161
|
-
nextName?: string
|
|
162
|
-
): Theme {
|
|
163
|
-
const info = getThemeInfo(theme, parentName)
|
|
164
|
-
if (!info) {
|
|
165
|
-
throw new Error(
|
|
166
|
-
process.env.NODE_ENV !== 'production'
|
|
167
|
-
? `No info found for theme, you must pass the theme created by createThemeFromPalette directly to extendTheme`
|
|
168
|
-
: `❌ Err2`
|
|
169
|
-
)
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
const next = applyMaskStateless(info, mask, options, parentName)
|
|
173
|
-
|
|
174
|
-
setThemeInfo(next.theme, {
|
|
175
|
-
definition: next.definition,
|
|
176
|
-
palette: info.palette,
|
|
177
|
-
name: nextName,
|
|
178
|
-
})
|
|
179
|
-
|
|
180
|
-
return next.theme as Theme
|
|
181
|
-
}
|
package/src/tests.tsx
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { applyMask } from './applyMask'
|
|
1
2
|
import { createTheme } from './createTheme'
|
|
2
|
-
import {
|
|
3
|
+
import { createStrengthenMask, createWeakenMask } from './masks'
|
|
3
4
|
|
|
4
5
|
// --- tests ---
|
|
5
6
|
if (process.env.NODE_ENV === 'development') {
|
package/src/themeInfo.tsx
CHANGED
|
@@ -1,4 +1,9 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import {
|
|
2
|
+
CreateThemeOptions,
|
|
3
|
+
CreateThemePalette,
|
|
4
|
+
GenericTheme,
|
|
5
|
+
ThemeMask,
|
|
6
|
+
} from './createThemeTypes'
|
|
2
7
|
|
|
3
8
|
export type ThemeInfo = {
|
|
4
9
|
palette: CreateThemePalette
|
package/types/ThemeBuilder.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Narrow } from '@tamagui/web';
|
|
2
|
-
import { CreateMask, CreateThemeOptions, MaskOptions } from './
|
|
1
|
+
import type { Narrow } from '@tamagui/web';
|
|
2
|
+
import { CreateMask, CreateThemeOptions, MaskOptions } from './createThemeTypes';
|
|
3
3
|
export type Palette = string[];
|
|
4
4
|
type GenericTheme = {
|
|
5
5
|
[key: string]: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ThemeBuilder.d.ts","sourceRoot":"","sources":["../src/ThemeBuilder.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;
|
|
1
|
+
{"version":3,"file":"ThemeBuilder.d.ts","sourceRoot":"","sources":["../src/ThemeBuilder.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AAI1C,OAAO,EAAE,UAAU,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAA;AAIhF,MAAM,MAAM,OAAO,GAAG,MAAM,EAAE,CAAA;AAE9B,KAAK,YAAY,GAAG;IAClB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;CACtB,CAAA;AAED,MAAM,MAAM,QAAQ,GAAG;IACrB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;CACtB,CAAA;AAED,KAAK,cAAc,CAAC,KAAK,GAAG,MAAM,IAAI,WAAW,GAAG;IAClD,IAAI,EAAE,KAAK,CAAA;CACZ,CAAA;AAED,KAAK,kBAAkB,GAAG,kBAAkB,GAAG;IAC7C,OAAO,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,MAAM,CAAA;CACjB,CAAA;AAED,KAAK,eAAe,GAAG;IACrB,KAAK,EAAE,YAAY,CAAA;CACpB,CAAA;AAED,MAAM,MAAM,KAAK,CAAC,KAAK,GAAG,MAAM,IAC5B,eAAe,GACf,kBAAkB,GAClB,cAAc,CAAC,KAAK,CAAC,CAAA;AAEzB,KAAK,eAAe,CAAC,KAAK,GAAG,MAAM,IAAI,KAAK,CAAC,KAAK,CAAC,GAAG;IACpD,MAAM,EAAE,MAAM,CAAA;CACf,CAAA;AAED,KAAK,kBAAkB,GAAG;IACxB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;CACvB,CAAA;AAED,MAAM,MAAM,eAAe,CAAC,KAAK,SAAS,MAAM,GAAG,MAAM,IACrD,KAAK,CAAC,KAAK,CAAC,GACZ,eAAe,CAAC,KAAK,CAAC,EAAE,CAAA;AAE5B,KAAK,eAAe,GAAG,MAAM,GAAG,EAAE,CAAA;AAElC,KAAK,gBAAgB,CAAC,KAAK,SAAS,MAAM,GAAG,MAAM,IAAI;IACrD,CAAC,GAAG,EAAE,MAAM,GAAG,eAAe,CAAC,KAAK,GAAG,eAAe,CAAC,CAAA;CACxD,CAAA;AAED,KAAK,mBAAmB,GAAG;IACzB,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,CAAA;CACxB,CAAA;AAED,KAAK,eAAe,GAAG;IACrB,CAAC,GAAG,EAAE,MAAM,GAAG,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC,CAAA;CAC/C,CAAA;AAED,KAAK,iBAAiB,GAAG;IACvB,QAAQ,CAAC,EAAE,kBAAkB,CAAA;IAC7B,SAAS,CAAC,EAAE,mBAAmB,CAAA;IAC/B,MAAM,CAAC,EAAE,gBAAgB,CAAA;IACzB,KAAK,CAAC,EAAE,eAAe,CAAA;CACxB,CAAA;AAED,KAAK,gBAAgB,CAAC,CAAC,SAAS,MAAM,GAAG,SAAS,IAAI,CAAC,SAAS,MAAM,GAClE,OAAO,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,GACjC,KAAK,CAAA;AAET,KAAK,6BAA6B,CAAC,QAAQ,IAAI;KAC5C,GAAG,IAAI,MAAM,QAAQ,GAAG,MAAM;CAChC,CAAA;AAED,KAAK,cAAc,CAAC,CAAC,EAAE,MAAM,SAAS,gBAAgB,GAAG,SAAS,IAAI,CAAC,SAAS,MAAM,GAClF,CAAC,SAAS,MAAM,MAAM,GACpB,MAAM,CAAC,CAAC,CAAC,GACT,aAAa,CAAC,CAAC,CAAC,SAAS,MAAM,MAAM,GACrC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,GACxB,aAAa,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,SAAS,MAAM,MAAM,GACpD,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,GACvC,aAAa,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,MAAM,MAAM,GACnE,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GACtD,KAAK,GACP,KAAK,CAAA;AAET,KAAK,iBAAiB,CAAC,EAAE,SAAS,GAAG,EAAE,CAAC,SAAS,iBAAiB,IAAI,EAAE,SAAS;IAC/E,KAAK,EAAE,MAAM,CAAC,CAAA;CACf,GACG,CAAC,GACD,EAAE,SAAS;IAAE,MAAM,EAAE,MAAM,CAAC,CAAA;CAAE,GAE9B,iBAAiB,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,GACpD,EAAE,SAAS;IAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;CAAE,GAChC,CAAC,SAAS,MAAM,CAAC,CAAC,WAAW,CAAC,GAC5B,6BAA6B,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,GAChD,EAAE,GACJ,EAAE,CAAA;AAEN,KAAK,uBAAuB,CAAC,CAAC,SAAS,iBAAiB,IAAI;KACzD,GAAG,IAAI,MAAM,CAAC,CAAC,QAAQ,CAAC,GAAG,iBAAiB,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;CACnE,CAAA;AAED,KAAK,aAAa,CAAC,CAAC,SAAS,MAAM,IACjC,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,MAAM,EAAE,GAC7D,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,GACrB,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,MAAM,EAAE,GACtD,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,GAChB,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,MAAM,EAAE,GAC3C,GAAG,CAAC,IAAI,CAAC,EAAE,GACX,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,MAAM,EAAE,GAChC,GAAG,CAAC,EAAE,GACN,KAAK,CAAA;AAEX,qBAAa,YAAY,CAAC,KAAK,SAAS,iBAAiB;IACpC,KAAK,EAAE,KAAK;gBAAZ,KAAK,EAAE,KAAK;IAE/B,WAAW,CAAC,KAAK,CAAC,CAAC,SAAS,kBAAkB,EAAE,QAAQ,EAAE,CAAC;kBAQ3C,CAAC;;IAKjB,YAAY,CAAC,KAAK,CAAC,CAAC,SAAS,mBAAmB,EAAE,SAAS,EAAE,CAAC;mBAQ7C,CAAC;;IAKlB,QAAQ,CAAC,KAAK,CAAC,CAAC,SAAS,eAAe,EAAE,KAAK,EAAE,CAAC;eAUrC,CAAC;;IAKd,SAAS,CAAC,KAAK,CAAC,CAAC,SAAS,gBAAgB,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAC1E,MAAM,EAAE,CAAC;gBASG,CAAC;;IAKf,cAAc,CACZ,GAAG,SAAS,MAAM,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EACtE,KAAK,CAAC,kBAAkB,SAAS,MAAM,EAAE,GAAG,EAAE,EAE9C,oBAAoB,EAAE,GAAG,EACzB,OAAO,CAAC,EAAE;QACR,kBAAkB,CAAC,EAAE,kBAAkB,CAAA;KACxC;;;;;IA0DH,KAAK,IAAI,uBAAuB,CAAC,KAAK,CAAC;CA4FxC;AAED,wBAAgB,kBAAkB,qBAEjC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { CreateMask, GenericTheme, MaskOptions, ThemeMask } from './createThemeTypes';
|
|
2
|
+
import { ThemeInfo } from './themeInfo';
|
|
3
|
+
export declare function applyMask<Theme extends GenericTheme | ThemeMask>(theme: Theme, mask: CreateMask, options?: MaskOptions, parentName?: string, nextName?: string): Theme;
|
|
4
|
+
export declare function applyMaskStateless<Theme extends GenericTheme | ThemeMask>(info: ThemeInfo, mask: CreateMask, options?: MaskOptions, parentName?: string): ThemeInfo & {
|
|
5
|
+
theme: Theme;
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=applyMask.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"applyMask.d.ts","sourceRoot":"","sources":["../src/applyMask.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAA;AACrF,OAAO,EAAE,SAAS,EAA8B,MAAM,aAAa,CAAA;AAEnE,wBAAgB,SAAS,CAAC,KAAK,SAAS,YAAY,GAAG,SAAS,EAC9D,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,UAAU,EAChB,OAAO,GAAE,WAAgB,EACzB,UAAU,CAAC,EAAE,MAAM,EACnB,QAAQ,CAAC,EAAE,MAAM,GAChB,KAAK,CAmBP;AAED,wBAAgB,kBAAkB,CAAC,KAAK,SAAS,YAAY,GAAG,SAAS,EACvE,IAAI,EAAE,SAAS,EACf,IAAI,EAAE,UAAU,EAChB,OAAO,GAAE,WAAgB,EACzB,UAAU,CAAC,EAAE,MAAM,GAClB,SAAS,GAAG;IACb,KAAK,EAAE,KAAK,CAAA;CACb,CA6BA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { CreateMask, GenericTheme, MaskOptions, ThemeMask } from './createThemeTypes';
|
|
2
|
+
import { ThemeInfo } from './themeInfo';
|
|
3
|
+
export declare function applyMask<Theme extends GenericTheme | ThemeMask>(theme: Theme, mask: CreateMask, options?: MaskOptions, parentName?: string, nextName?: string): Theme;
|
|
4
|
+
export declare function applyMaskStateless<Theme extends GenericTheme | ThemeMask>(info: ThemeInfo, mask: CreateMask, options?: MaskOptions, parentName?: string): ThemeInfo & {
|
|
5
|
+
theme: Theme;
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=applyMaskStateless.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"applyMaskStateless.d.ts","sourceRoot":"","sources":["../src/applyMaskStateless.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAA;AACrF,OAAO,EAAE,SAAS,EAA8B,MAAM,aAAa,CAAA;AAEnE,wBAAgB,SAAS,CAAC,KAAK,SAAS,YAAY,GAAG,SAAS,EAC9D,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,UAAU,EAChB,OAAO,GAAE,WAAgB,EACzB,UAAU,CAAC,EAAE,MAAM,EACnB,QAAQ,CAAC,EAAE,MAAM,GAChB,KAAK,CAmBP;AAED,wBAAgB,kBAAkB,CAAC,KAAK,SAAS,YAAY,GAAG,SAAS,EACvE,IAAI,EAAE,SAAS,EACf,IAAI,EAAE,UAAU,EAChB,OAAO,GAAE,WAAgB,EACzB,UAAU,CAAC,EAAE,MAAM,GAClB,SAAS,GAAG;IACb,KAAK,EAAE,KAAK,CAAA;CACb,CA6BA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"combineMasks.d.ts","sourceRoot":"","sources":["../src/combineMasks.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAG/C,eAAO,MAAM,YAAY,aAAc,UAAU,EAAE,eAgBlD,CAAA"}
|
package/types/createTheme.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CreateThemeOptions, CreateThemePalette, GenericTheme, ThemeMask } from './
|
|
1
|
+
import { CreateThemeOptions, CreateThemePalette, GenericTheme, ThemeMask } from './createThemeTypes';
|
|
2
2
|
export declare function createTheme<Definition extends ThemeMask, Extras extends GenericTheme = {}>(palette: CreateThemePalette, definition: Definition, options?: CreateThemeOptions, name?: string, skipCache?: boolean): {
|
|
3
3
|
[key in keyof Definition | keyof Extras]: string;
|
|
4
4
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createTheme.d.ts","sourceRoot":"","sources":["../src/createTheme.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"createTheme.d.ts","sourceRoot":"","sources":["../src/createTheme.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAClB,YAAY,EACZ,SAAS,EACV,MAAM,oBAAoB,CAAA;AAM3B,wBAAgB,WAAW,CACzB,UAAU,SAAS,SAAS,EAC5B,MAAM,SAAS,YAAY,GAAG,EAAE,EAEhC,OAAO,EAAE,kBAAkB,EAC3B,UAAU,EAAE,UAAU,EACtB,OAAO,CAAC,EAAE,kBAAkB,EAC5B,IAAI,CAAC,EAAE,MAAM,EACb,SAAS,UAAQ,GAChB;KACA,GAAG,IAAI,MAAM,UAAU,GAAG,MAAM,MAAM,GAAG,MAAM;CACjD,CAuBA;AAWD,KAAK,YAAY,CAAC,UAAU,EAAE,SAAS,IAAI,GAAG,UAAU,SAAS,MAAM,GACnE,UAAU,GACV,KAAK,IAAI,SAAS,SAAS,MAAM,GAAG,SAAS,GAAG,KAAK,EAAE,CAAA;AAE3D,KAAK,WAAW,CAAC,IAAI,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,KAAK,SAAS,YAAY,IAAI,CACpF,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,KAAK,KACT;IAAE,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,CAAA;CAAE,CAAA;AAE7B,wBAAgB,WAAW,CACzB,MAAM,SAAS;IAAE,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,CAAA;CAAE,EAC9C,WAAW,SAAS,WAAW,CAAC,MAAM,MAAM,EAAE,MAAM,CAAC,MAAM,MAAM,CAAC,CAAC,EAEnE,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,WAAW,GACvB,MAAM,GAAG;KACT,GAAG,IAAI,YAAY,CAAC,MAAM,MAAM,EAAE,MAAM,UAAU,CAAC,WAAW,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,MAAM,CAAC;CACzF,CASA"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { Variable } from '@tamagui/web';
|
|
2
|
+
export type CreateThemePalette = (string | Variable)[];
|
|
3
|
+
export type ThemeMask = Record<string, string | number>;
|
|
4
|
+
export type MaskOptions = {
|
|
5
|
+
palette?: CreateThemePalette;
|
|
6
|
+
override?: Partial<ThemeMask>;
|
|
7
|
+
skip?: Partial<ThemeMask>;
|
|
8
|
+
strength?: number;
|
|
9
|
+
max?: number;
|
|
10
|
+
min?: number;
|
|
11
|
+
parentName?: string;
|
|
12
|
+
};
|
|
13
|
+
export type GenericTheme = {
|
|
14
|
+
[key: string]: string | Variable;
|
|
15
|
+
};
|
|
16
|
+
export type MaskFunction = <A extends ThemeMask>(template: A, options: MaskOptions) => A;
|
|
17
|
+
export type CreateMask = {
|
|
18
|
+
name: string;
|
|
19
|
+
mask: MaskFunction;
|
|
20
|
+
};
|
|
21
|
+
export type CreateThemeOptions = {
|
|
22
|
+
nonInheritedValues?: GenericTheme;
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=createThemeTypes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createThemeTypes.d.ts","sourceRoot":"","sources":["../src/createThemeTypes.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAA;AAE5C,MAAM,MAAM,kBAAkB,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,EAAE,CAAA;AAEtD,MAAM,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,CAAA;AAEvD,MAAM,MAAM,WAAW,GAAG;IACxB,OAAO,CAAC,EAAE,kBAAkB,CAAA;IAC5B,QAAQ,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,CAAA;IAC7B,IAAI,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,CAAA;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB,CAAA;AAED,MAAM,MAAM,YAAY,GAAG;IAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,QAAQ,CAAA;CAAE,CAAA;AAE/D,MAAM,MAAM,YAAY,GAAG,CAAC,CAAC,SAAS,SAAS,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,WAAW,KAAK,CAAC,CAAA;AAExF,MAAM,MAAM,UAAU,GAAG;IACvB,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,YAAY,CAAA;CACnB,CAAA;AAED,MAAM,MAAM,kBAAkB,GAAG;IAC/B,kBAAkB,CAAC,EAAE,YAAY,CAAA;CAClC,CAAA"}
|
package/types/index.d.ts
CHANGED
package/types/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.tsx"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAA;AAC7B,cAAc,SAAS,CAAA;AACvB,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.tsx"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAA;AAC7B,cAAc,SAAS,CAAA;AACvB,cAAc,gBAAgB,CAAA;AAC9B,cAAc,aAAa,CAAA;AAC3B,cAAc,oBAAoB,CAAA"}
|
package/types/isMinusZero.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export declare function isMinusZero(value:
|
|
1
|
+
export declare function isMinusZero(value: number): boolean;
|
|
2
2
|
//# sourceMappingURL=isMinusZero.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isMinusZero.d.ts","sourceRoot":"","sources":["../src/isMinusZero.tsx"],"names":[],"mappings":"AAAA,wBAAgB,WAAW,CAAC,KAAK,
|
|
1
|
+
{"version":3,"file":"isMinusZero.d.ts","sourceRoot":"","sources":["../src/isMinusZero.tsx"],"names":[],"mappings":"AAAA,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,WAExC"}
|