UNPKG

@tldraw/tlschema

Version:

tldraw infinite canvas SDK (schema).

88 lines (87 loc) 2.98 kB
"use strict"; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var TLColorStyle_exports = {}; __export(TLColorStyle_exports, { DefaultColorStyle: () => DefaultColorStyle, DefaultLabelColorStyle: () => DefaultLabelColorStyle, registerColorsFromThemes: () => registerColorsFromThemes }); module.exports = __toCommonJS(TLColorStyle_exports); var import_StyleProp = require("./StyleProp"); const defaultColorNames = [ "black", "grey", "light-violet", "violet", "blue", "light-blue", "yellow", "orange", "green", "light-green", "light-red", "red", "white" ]; const DefaultColorStyle = import_StyleProp.StyleProp.defineEnum("tldraw:color", { defaultValue: "black", values: defaultColorNames }); const DefaultLabelColorStyle = import_StyleProp.StyleProp.defineEnum("tldraw:labelColor", { defaultValue: "black", values: defaultColorNames }); function registerColorsFromThemes(definitions) { const colorNames = /* @__PURE__ */ new Set(); for (const def of Object.values(definitions)) { for (const colorPalette of [def.colors.light, def.colors.dark]) { for (const [key, value] of Object.entries(colorPalette)) { if (typeof value === "object" && value !== null) { colorNames.add(key); } } } } if (colorNames.size > 0) { DefaultColorStyle.addValues(...colorNames); DefaultLabelColorStyle.addValues(...colorNames); } const toRemove = DefaultColorStyle.values.filter((v) => !colorNames.has(v)); if (toRemove.length > 0) { DefaultColorStyle.removeValues(...toRemove); DefaultLabelColorStyle.removeValues(...toRemove); } if (process.env.NODE_ENV !== "production") { for (const def of Object.values(definitions)) { for (const color of colorNames) { if (!(color in def.colors.light)) { console.warn( `Theme '${def.id}' light palette is missing color '${color}'. Shapes using this color won't render correctly.` ); } if (!(color in def.colors.dark)) { console.warn( `Theme '${def.id}' dark palette is missing color '${color}'. Shapes using this color won't render correctly.` ); } } } } } //# sourceMappingURL=TLColorStyle.js.map