@canopy-iiif/app 0.10.8 → 0.10.10

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.
@@ -6,7 +6,6 @@
6
6
  * Tailwind theme.extend values to those variables for easy use in utilities.
7
7
  */
8
8
  const plugin = require("tailwindcss/plugin");
9
- const path = require("path");
10
9
  const {loadCanopyTheme} = require("./theme");
11
10
 
12
11
  function compileVarsCss() {
@@ -17,91 +16,9 @@ function compileVarsCss() {
17
16
  }
18
17
  return theme.css;
19
18
  }
20
- try {
21
- const sass = require("sass");
22
- const entry = path.join(__dirname, "styles", "variables.emit.scss");
23
- const out = sass.compile(entry, {style: "expanded"});
24
- return out && out.css ? out.css : "";
25
- } catch (_) {
26
- return "";
27
- }
28
19
  }
29
20
 
30
21
  module.exports = {
31
- theme: {
32
- container: {center: true, padding: "1rem"},
33
- extend: {
34
- colors: {
35
- brand: {
36
- DEFAULT: "var(--color-brand-default)",
37
- 50: "var(--color-brand-50)",
38
- 100: "var(--color-brand-100)",
39
- 200: "var(--color-brand-200)",
40
- 300: "var(--color-brand-300)",
41
- 400: "var(--color-brand-400)",
42
- 500: "var(--color-brand-500)",
43
- 600: "var(--color-brand-600)",
44
- 700: "var(--color-brand-700)",
45
- 800: "var(--color-brand-800)",
46
- 900: "var(--color-brand-900)",
47
- },
48
- gray: {
49
- DEFAULT: "var(--color-gray-default)",
50
- 50: "var(--color-gray-50)",
51
- 100: "var(--color-gray-100)",
52
- 200: "var(--color-gray-200)",
53
- 300: "var(--color-gray-300)",
54
- 400: "var(--color-gray-400)",
55
- 500: "var(--color-gray-500)",
56
- 600: "var(--color-gray-600)",
57
- 700: "var(--color-gray-700)",
58
- 800: "var(--color-gray-800)",
59
- 900: "var(--color-gray-900)",
60
- },
61
- muted: "var(--color-gray-muted)",
62
- white: "#ffffff",
63
- black: "#000000",
64
- },
65
- fontFamily: {
66
- mono: ["var(--font-mono)"],
67
- sans: ["var(--font-sans)"],
68
- serif: ["var(--font-serif)"],
69
- },
70
- maxWidth: {
71
- content: "var(--max-w-content)",
72
- wide: "var(--max-w-wide)",
73
- },
74
- fontSize: {
75
- xs: ["var(--font-size-xs)", {lineHeight: "var(--line-height-xs)"}],
76
- sm: ["var(--font-size-sm)", {lineHeight: "var(--line-height-sm)"}],
77
- base: [
78
- "var(--font-size-base)",
79
- {lineHeight: "var(--line-height-base)"},
80
- ],
81
- lg: ["var(--font-size-lg)", {lineHeight: "var(--line-height-lg)"}],
82
- xl: ["var(--font-size-xl)", {lineHeight: "var(--line-height-xl)"}],
83
- "2xl": ["var(--font-size-2xl)", {lineHeight: "var(--line-height-2xl)"}],
84
- "3xl": ["var(--font-size-3xl)", {lineHeight: "var(--line-height-3xl)"}],
85
- },
86
- borderRadius: {
87
- sm: "var(--radius-sm)",
88
- DEFAULT: "var(--radius-default)",
89
- md: "var(--radius-md)",
90
- },
91
- boxShadow: {
92
- sm: "var(--shadow-sm)",
93
- DEFAULT: "var(--shadow)",
94
- md: "var(--shadow-md)",
95
- lg: "var(--shadow-lg)",
96
- },
97
- transitionDuration: {
98
- canopyFast: "var(--duration-fast)",
99
- },
100
- transitionTimingFunction: {
101
- canopy: "var(--easing-standard)",
102
- },
103
- },
104
- },
105
22
  plugins: [
106
23
  // Inject CSS variables (tokens) derived from Sass variables
107
24
  plugin(function ({addBase, postcss}) {
package/ui/theme.js CHANGED
@@ -8,8 +8,6 @@ const DEFAULT_GRAY = "slate";
8
8
  const DEFAULT_APPEARANCE = "light";
9
9
  const DEBUG_FLAG_RAW = String(process.env.CANOPY_DEBUG_THEME || "");
10
10
  const DEBUG_ENABLED = /^(1|true|yes|on)$/i.test(DEBUG_FLAG_RAW.trim());
11
- const SASS_STYLES_DIR = path.join(__dirname, "styles");
12
- const SASS_VARIABLES_ENTRY = path.join(SASS_STYLES_DIR, "_variables.scss");
13
11
 
14
12
  function debugLog(...args) {
15
13
  if (!DEBUG_ENABLED) return;
@@ -18,31 +16,6 @@ function debugLog(...args) {
18
16
  } catch (_) {}
19
17
  }
20
18
 
21
- function loadSassVariableTokens() {
22
- try {
23
- if (!fs.existsSync(SASS_VARIABLES_ENTRY)) return {map: {}, css: ""};
24
- const sass = require("sass");
25
- const source = `@use 'sass:meta';\n@use 'sass:string';\n@use 'variables';\n$__canopy_tokens: meta.module-variables('variables');\n@function canopy-token-name($name) {\n $identifier: #{$name};\n @if $identifier == null or $identifier == '' {\n @return null;\n }\n @if string.slice($identifier, 1, 1) == '_' {\n @return null;\n }\n @return '--#{$identifier}';\n}\n@mixin canopy-emit-tokens() {\n @each $name, $value in $__canopy_tokens {\n $css-name: canopy-token-name($name);\n @if $css-name {\n #{$css-name}: #{meta.inspect($value)};\n }\n }\n}\n:root {\n @include canopy-emit-tokens();\n}\n:host {\n @include canopy-emit-tokens();\n}\n`;
26
- const result = sass.compileString(source, {
27
- loadPaths: [SASS_STYLES_DIR],
28
- style: "expanded",
29
- });
30
- const css = (result && result.css ? result.css : "").trim();
31
- const vars = {};
32
- const regex = /--([A-Za-z0-9_-]+)\s*:\s*([^;]+);/g;
33
- let match;
34
- while ((match = regex.exec(css))) {
35
- vars[`--${match[1]}`] = match[2].trim();
36
- }
37
- return {map: vars, css};
38
- } catch (error) {
39
- debugLog(
40
- "failed to compile Sass variables",
41
- error && error.message ? error.message : error
42
- );
43
- return {map: {}, css: ""};
44
- }
45
- }
46
19
  const LEVELS = [
47
20
  "50",
48
21
  "100",
@@ -267,12 +240,8 @@ function loadCanopyTheme(options = {}) {
267
240
  });
268
241
  }
269
242
 
270
- const sassTokens = loadSassVariableTokens();
271
243
  const dynamicVars = buildVariablesMap(accentScale, grayScale, {appearance});
272
- const mergedVars = {
273
- ...(sassTokens && sassTokens.map ? sassTokens.map : {}),
274
- ...dynamicVars,
275
- };
244
+ const mergedVars = dynamicVars;
276
245
  const css = variablesToCss(mergedVars);
277
246
  const sassConfig = buildSassConfig(accentScale, grayScale);
278
247