@tamagui/create-theme 1.116.0 → 1.116.2

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.
@@ -0,0 +1,55 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: !0 });
8
+ }, __copyProps = (to, from, except, desc) => {
9
+ if (from && typeof from == "object" || typeof from == "function")
10
+ for (let key of __getOwnPropNames(from))
11
+ !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
12
+ return to;
13
+ };
14
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
15
+ var applyMask_exports = {};
16
+ __export(applyMask_exports, {
17
+ applyMask: () => applyMask,
18
+ applyMaskStateless: () => applyMaskStateless
19
+ });
20
+ module.exports = __toCommonJS(applyMask_exports);
21
+ var import_createTheme = require("./createTheme"), import_themeInfo = require("./themeInfo");
22
+ function applyMask(theme, mask, options = {}, parentName, nextName) {
23
+ const info = (0, import_themeInfo.getThemeInfo)(theme, parentName);
24
+ if (!info)
25
+ throw new Error(
26
+ process.env.NODE_ENV !== "production" ? "No info found for theme, you must pass the theme created by createThemeFromPalette directly to extendTheme" : "\u274C Err2"
27
+ );
28
+ const next = applyMaskStateless(info, mask, options, parentName);
29
+ return (0, import_themeInfo.setThemeInfo)(next.theme, {
30
+ definition: next.definition,
31
+ palette: info.palette,
32
+ name: nextName
33
+ }), next.theme;
34
+ }
35
+ function applyMaskStateless(info, mask, options = {}, parentName) {
36
+ const skip = {
37
+ ...options.skip
38
+ };
39
+ if (info.options?.nonInheritedValues)
40
+ for (const key in info.options.nonInheritedValues)
41
+ skip[key] = 1;
42
+ const maskOptions = {
43
+ parentName,
44
+ palette: info.palette,
45
+ ...options,
46
+ skip
47
+ }, template = mask.mask(info.definition, maskOptions), theme = (0, import_createTheme.createTheme)(info.palette, template);
48
+ return {
49
+ ...info,
50
+ cache: /* @__PURE__ */ new Map(),
51
+ definition: template,
52
+ theme
53
+ };
54
+ }
55
+ //# sourceMappingURL=applyMask.js.map
@@ -0,0 +1,40 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: !0 });
8
+ }, __copyProps = (to, from, except, desc) => {
9
+ if (from && typeof from == "object" || typeof from == "function")
10
+ for (let key of __getOwnPropNames(from))
11
+ !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
12
+ return to;
13
+ };
14
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
15
+ var combineMasks_exports = {};
16
+ __export(combineMasks_exports, {
17
+ combineMasks: () => combineMasks
18
+ });
19
+ module.exports = __toCommonJS(combineMasks_exports);
20
+ var import_applyMask = require("./applyMask"), import_themeInfo = require("./themeInfo");
21
+ const combineMasks = (...masks) => ({
22
+ name: "combine-mask",
23
+ mask: (template, opts) => {
24
+ let current = (0, import_themeInfo.getThemeInfo)(template, opts.parentName), theme;
25
+ for (const mask2 of masks) {
26
+ if (!current)
27
+ throw new Error(
28
+ `Nothing returned from mask: ${current}, for template: ${template} and mask: ${mask2.toString()}, given opts ${JSON.stringify(
29
+ opts,
30
+ null,
31
+ 2
32
+ )}`
33
+ );
34
+ const next = (0, import_applyMask.applyMaskStateless)(current, mask2, opts);
35
+ current = next, theme = next.theme;
36
+ }
37
+ return theme;
38
+ }
39
+ });
40
+ //# sourceMappingURL=combineMasks.js.map
@@ -0,0 +1,69 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: !0 });
8
+ }, __copyProps = (to, from, except, desc) => {
9
+ if (from && typeof from == "object" || typeof from == "function")
10
+ for (let key of __getOwnPropNames(from))
11
+ !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
12
+ return to;
13
+ };
14
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
15
+ var createTheme_exports = {};
16
+ __export(createTheme_exports, {
17
+ addChildren: () => addChildren,
18
+ createTheme: () => createTheme,
19
+ createThemeWithPalettes: () => createThemeWithPalettes
20
+ });
21
+ module.exports = __toCommonJS(createTheme_exports);
22
+ var import_isMinusZero = require("./isMinusZero"), import_themeInfo = require("./themeInfo");
23
+ const identityCache = /* @__PURE__ */ new Map();
24
+ function createThemeWithPalettes(palettes, defaultPalette, definition, options, name, skipCache = !1) {
25
+ if (!palettes[defaultPalette])
26
+ throw new Error(`No pallete: ${defaultPalette}`);
27
+ const newDef = { ...definition };
28
+ for (const key in definition) {
29
+ let val = definition[key];
30
+ if (typeof val == "string" && val[0] === "$") {
31
+ const [altPaletteName$, altPaletteIndex] = val.split("."), altPaletteName = altPaletteName$.slice(1), parentName = defaultPalette.split("_")[0], altPalette = palettes[altPaletteName] || palettes[`${parentName}_${altPaletteName}`];
32
+ if (altPalette) {
33
+ const next = getValue(altPalette, +altPaletteIndex);
34
+ typeof next < "u" && (newDef[key] = next);
35
+ }
36
+ }
37
+ }
38
+ return createTheme(palettes[defaultPalette], newDef, options, name, skipCache);
39
+ }
40
+ function createTheme(palette, definition, options, name, skipCache = !1) {
41
+ const cacheKey = skipCache ? "" : JSON.stringify([name, palette, definition, options]);
42
+ if (!skipCache && identityCache.has(cacheKey))
43
+ return identityCache.get(cacheKey);
44
+ const theme = {
45
+ ...Object.fromEntries(
46
+ Object.entries(definition).map(([key, offset]) => [key, getValue(palette, offset)])
47
+ ),
48
+ ...options?.nonInheritedValues
49
+ };
50
+ return (0, import_themeInfo.setThemeInfo)(theme, { palette, definition, options, name }), cacheKey && identityCache.set(cacheKey, theme), theme;
51
+ }
52
+ const getValue = (palette, value) => {
53
+ if (!palette)
54
+ throw new Error("No palette!");
55
+ if (typeof value == "string")
56
+ return value;
57
+ const max = palette.length - 1, next = (value === 0 ? !(0, import_isMinusZero.isMinusZero)(value) : value >= 0) ? value : max + value, index = Math.min(Math.max(0, next), max);
58
+ return palette[index];
59
+ };
60
+ function addChildren(themes, getChildren) {
61
+ const out = { ...themes };
62
+ for (const key in themes) {
63
+ const subThemes = getChildren(key, themes[key]);
64
+ for (const sKey in subThemes)
65
+ out[`${key}_${sKey}`] = subThemes[sKey];
66
+ }
67
+ return out;
68
+ }
69
+ //# sourceMappingURL=createTheme.js.map
@@ -0,0 +1,14 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __copyProps = (to, from, except, desc) => {
6
+ if (from && typeof from == "object" || typeof from == "function")
7
+ for (let key of __getOwnPropNames(from))
8
+ !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
9
+ return to;
10
+ };
11
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
12
+ var createThemeTypes_exports = {};
13
+ module.exports = __toCommonJS(createThemeTypes_exports);
14
+ //# sourceMappingURL=createThemeTypes.js.map
@@ -0,0 +1,29 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: !0 });
8
+ }, __copyProps = (to, from, except, desc) => {
9
+ if (from && typeof from == "object" || typeof from == "function")
10
+ for (let key of __getOwnPropNames(from))
11
+ !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
12
+ return to;
13
+ };
14
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
15
+ var helpers_exports = {};
16
+ __export(helpers_exports, {
17
+ objectEntries: () => objectEntries,
18
+ objectFromEntries: () => objectFromEntries,
19
+ objectKeys: () => objectKeys
20
+ });
21
+ module.exports = __toCommonJS(helpers_exports);
22
+ const objectKeys = (obj) => Object.keys(obj);
23
+ function objectEntries(obj) {
24
+ return Object.entries(obj);
25
+ }
26
+ function objectFromEntries(arr) {
27
+ return Object.fromEntries(arr);
28
+ }
29
+ //# sourceMappingURL=helpers.js.map
@@ -0,0 +1,20 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __copyProps = (to, from, except, desc) => {
6
+ if (from && typeof from == "object" || typeof from == "function")
7
+ for (let key of __getOwnPropNames(from))
8
+ !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
9
+ return to;
10
+ }, __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
11
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
12
+ var src_exports = {};
13
+ module.exports = __toCommonJS(src_exports);
14
+ __reExport(src_exports, require("./createTheme"), module.exports);
15
+ __reExport(src_exports, require("./masks"), module.exports);
16
+ __reExport(src_exports, require("./combineMasks"), module.exports);
17
+ __reExport(src_exports, require("./applyMask"), module.exports);
18
+ __reExport(src_exports, require("./createThemeTypes"), module.exports);
19
+ __reExport(src_exports, require("./helpers"), module.exports);
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,23 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: !0 });
8
+ }, __copyProps = (to, from, except, desc) => {
9
+ if (from && typeof from == "object" || typeof from == "function")
10
+ for (let key of __getOwnPropNames(from))
11
+ !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
12
+ return to;
13
+ };
14
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
15
+ var isMinusZero_exports = {};
16
+ __export(isMinusZero_exports, {
17
+ isMinusZero: () => isMinusZero
18
+ });
19
+ module.exports = __toCommonJS(isMinusZero_exports);
20
+ function isMinusZero(value) {
21
+ return 1 / value === Number.NEGATIVE_INFINITY;
22
+ }
23
+ //# sourceMappingURL=isMinusZero.js.map
@@ -0,0 +1,98 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: !0 });
8
+ }, __copyProps = (to, from, except, desc) => {
9
+ if (from && typeof from == "object" || typeof from == "function")
10
+ for (let key of __getOwnPropNames(from))
11
+ !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
12
+ return to;
13
+ };
14
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
15
+ var masks_exports = {};
16
+ __export(masks_exports, {
17
+ createIdentityMask: () => createIdentityMask,
18
+ createInverseMask: () => createInverseMask,
19
+ createMask: () => createMask,
20
+ createShiftMask: () => createShiftMask,
21
+ createSoftenMask: () => createSoftenMask,
22
+ createStrengthenMask: () => createStrengthenMask,
23
+ createWeakenMask: () => createWeakenMask,
24
+ skipMask: () => skipMask
25
+ });
26
+ module.exports = __toCommonJS(masks_exports);
27
+ var import_helpers = require("./helpers"), import_isMinusZero = require("./isMinusZero");
28
+ const createMask = (createMask2) => typeof createMask2 == "function" ? { name: createMask2.name || "unnamed", mask: createMask2 } : createMask2, skipMask = {
29
+ name: "skip-mask",
30
+ mask: (template, opts) => {
31
+ const { skip } = opts;
32
+ return Object.fromEntries(
33
+ Object.entries(template).filter(([k]) => !skip || !(k in skip)).map(([k, v]) => [k, applyOverrides(k, v, opts)])
34
+ );
35
+ }
36
+ };
37
+ function applyOverrides(key, value, opts) {
38
+ let override, strategy = opts.overrideStrategy;
39
+ const overrideSwap = opts.overrideSwap?.[key];
40
+ if (typeof overrideSwap < "u")
41
+ override = overrideSwap, strategy = "swap";
42
+ else {
43
+ const overrideShift = opts.overrideShift?.[key];
44
+ if (typeof overrideShift < "u")
45
+ override = overrideShift, strategy = "shift";
46
+ else {
47
+ const overrideDefault = opts.override?.[key];
48
+ typeof overrideDefault < "u" && (override = overrideDefault, strategy = opts.overrideStrategy);
49
+ }
50
+ }
51
+ return typeof override > "u" || typeof override == "string" ? value : strategy === "swap" ? override : value;
52
+ }
53
+ const createIdentityMask = () => ({
54
+ name: "identity-mask",
55
+ mask: (template, opts) => skipMask.mask(template, opts)
56
+ }), createInverseMask = () => ({
57
+ name: "inverse-mask",
58
+ mask: (template, opts) => {
59
+ const inversed = (0, import_helpers.objectFromEntries)(
60
+ (0, import_helpers.objectEntries)(template).map(([k, v]) => [k, -v])
61
+ );
62
+ return skipMask.mask(inversed, opts);
63
+ }
64
+ }), createShiftMask = ({ inverse } = {}, defaultOptions) => ({
65
+ name: "shift-mask",
66
+ mask: (template, opts) => {
67
+ const {
68
+ override,
69
+ overrideStrategy = "shift",
70
+ max: maxIn,
71
+ palette,
72
+ min = 0,
73
+ strength = 1
74
+ } = { ...defaultOptions, ...opts }, values = Object.entries(template), max = maxIn ?? (palette ? Object.values(palette).length - 1 : Number.POSITIVE_INFINITY), out = {};
75
+ for (const [key, value] of values) {
76
+ if (typeof value == "string") continue;
77
+ if (typeof override?.[key] == "number") {
78
+ const overrideVal = override[key];
79
+ out[key] = overrideStrategy === "shift" ? value + overrideVal : overrideVal;
80
+ continue;
81
+ }
82
+ if (typeof override?.[key] == "string") {
83
+ out[key] = override[key];
84
+ continue;
85
+ }
86
+ const isPositive = value === 0 ? !(0, import_isMinusZero.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));
87
+ out[key] = clamped;
88
+ }
89
+ return skipMask.mask(out, opts);
90
+ }
91
+ }), createWeakenMask = (defaultOptions) => ({
92
+ name: "soften-mask",
93
+ mask: createShiftMask({}, defaultOptions).mask
94
+ }), createSoftenMask = createWeakenMask, createStrengthenMask = (defaultOptions) => ({
95
+ name: "strengthen-mask",
96
+ mask: createShiftMask({ inverse: !0 }, defaultOptions).mask
97
+ });
98
+ //# sourceMappingURL=masks.js.map
@@ -0,0 +1,12 @@
1
+ var import_applyMask = require("./applyMask"), import_createTheme = require("./createTheme"), import_masks = require("./masks");
2
+ if (process.env.NODE_ENV === "development") {
3
+ const palette = ["0", "1", "2", "3", "-3", "-2", "-1", "-0"], template = { bg: 1, fg: -1 }, stongerMask = (0, import_masks.createStrengthenMask)(), weakerMask = (0, import_masks.createWeakenMask)(), theme = (0, import_createTheme.createTheme)(palette, template);
4
+ if (theme.bg !== "1" || theme.fg !== "-1") throw "\u274C";
5
+ const str = (0, import_applyMask.applyMask)(theme, stongerMask);
6
+ if (str.bg !== "0" || str.fg !== "-0") throw "\u274C";
7
+ const weak = (0, import_applyMask.applyMask)(theme, weakerMask);
8
+ if (weak.bg !== "2" || weak.fg !== "-2") throw "\u274C";
9
+ const weak2 = (0, import_applyMask.applyMask)(theme, weakerMask, { strength: 2 });
10
+ if (weak2.bg !== "3" || weak2.fg !== "-3") throw "\u274C";
11
+ }
12
+ //# sourceMappingURL=tests.js.map
@@ -0,0 +1,28 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: !0 });
8
+ }, __copyProps = (to, from, except, desc) => {
9
+ if (from && typeof from == "object" || typeof from == "function")
10
+ for (let key of __getOwnPropNames(from))
11
+ !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
12
+ return to;
13
+ };
14
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
15
+ var themeInfo_exports = {};
16
+ __export(themeInfo_exports, {
17
+ getThemeInfo: () => getThemeInfo,
18
+ setThemeInfo: () => setThemeInfo
19
+ });
20
+ module.exports = __toCommonJS(themeInfo_exports);
21
+ const THEME_INFO = /* @__PURE__ */ new Map(), getThemeInfo = (theme, name) => THEME_INFO.get(name || JSON.stringify(theme)), setThemeInfo = (theme, info) => {
22
+ const next = {
23
+ ...info,
24
+ cache: /* @__PURE__ */ new Map()
25
+ };
26
+ THEME_INFO.set(info.name || JSON.stringify(theme), next), THEME_INFO.set(JSON.stringify(info.definition), next);
27
+ };
28
+ //# sourceMappingURL=themeInfo.js.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tamagui/create-theme",
3
- "version": "1.116.0",
3
+ "version": "1.116.2",
4
4
  "types": "./types/index.d.ts",
5
5
  "main": "dist/cjs",
6
6
  "module": "dist/esm",
@@ -31,10 +31,10 @@
31
31
  }
32
32
  },
33
33
  "dependencies": {
34
- "@tamagui/web": "1.116.0"
34
+ "@tamagui/web": "1.116.2"
35
35
  },
36
36
  "devDependencies": {
37
- "@tamagui/build": "1.116.0"
37
+ "@tamagui/build": "1.116.2"
38
38
  },
39
39
  "publishConfig": {
40
40
  "access": "public"
File without changes
File without changes
File without changes
File without changes