@vueless/storybook 1.1.3-beta.4 → 1.1.3-beta.6

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,40 @@
1
+ import { create } from "storybook/theming/create";
2
+
3
+ export default create({
4
+ base: "light",
5
+ // Typography
6
+ fontBase: '"Roboto", sans-serif',
7
+ fontCode: "monospace",
8
+
9
+ // Main colors
10
+ colorPrimary: "#111827", // gray-900
11
+ colorSecondary: "#6b7280", // gray-500
12
+
13
+ // UI
14
+ appBg: "#f3f4f6", // gray-100
15
+ appPreviewBg: "#f9fafb", // gray-50
16
+ appBorderColor: "#e5e7eb", // gray-200
17
+ appContentBg: "#f9fafb", // gray-50
18
+ appBorderRadius: 8,
19
+
20
+ // Text colors
21
+ textColor: "#111827", // gray-900
22
+ textInverseColor: "#f9fafb", // gray-50
23
+
24
+ // Toolbar default and active colors
25
+ barTextColor: "#6b7280", // gray-500
26
+ barHoverColor: "#4b5563", // gray-600
27
+ barSelectedColor: "#374151", // gray-700
28
+ barBg: "#ffffff", // white
29
+
30
+ // Form colors
31
+ inputBg: "#ffffff", // white
32
+ inputBorder: "#d1d5db", // gray-300
33
+ inputTextColor: "#111827", // gray-900
34
+ inputBorderRadius: 4,
35
+
36
+ buttonBg: "#f3f4f6", // gray-100
37
+ buttonBorder: "#e5e7eb", // gray-200
38
+ booleanBg: "#f9fafb", // gray-50
39
+ booleanSelectedBg: "#e5e7eb", // gray-200
40
+ });
package/bin/index.js ADDED
@@ -0,0 +1,85 @@
1
+ #!/usr/bin/env node
2
+ /* eslint-disable no-console */
3
+
4
+ import path from "node:path";
5
+ import { cwd } from "node:process";
6
+ import { styleText } from "node:util";
7
+ import fs, { promises } from "node:fs";
8
+
9
+ const __dirname = path.dirname(new URL(import.meta.url).pathname);
10
+ const source = path.join(__dirname, "..", ".storybook");
11
+ const target = path.join(cwd(), ".storybook");
12
+
13
+ copyStorybookPreset(source, target);
14
+
15
+ await addStorybookCommands();
16
+
17
+ /**
18
+ * Copy Storybook preset to target directory.
19
+ * @param {string} source - Source directory.
20
+ * @param {string} target - Target directory.
21
+ * @param {Object} options - Options object.
22
+ * @param {boolean} options.consoles - Show console messages.
23
+ */
24
+ function copyStorybookPreset(source, target, { consoles = true } = {}) {
25
+ if (fs.existsSync(target)) {
26
+ const timestamp = new Date().valueOf();
27
+ const renamedTarget = `${target}-backup-${timestamp}`;
28
+
29
+ fs.renameSync(target, renamedTarget);
30
+
31
+ const warnMessage = styleText(
32
+ "yellow",
33
+ `Current Storybook preset backed into : '${path.basename(renamedTarget)}' folder. Remove it before commit.`,
34
+ );
35
+
36
+ console.log(warnMessage);
37
+ }
38
+
39
+ fs.mkdirSync(target, { recursive: true });
40
+
41
+ const files = fs.readdirSync(source);
42
+
43
+ files.forEach((file) => {
44
+ const srcFile = path.join(source, file);
45
+ const destFile = path.join(target, file);
46
+ const stat = fs.lstatSync(srcFile);
47
+
48
+ stat.isDirectory()
49
+ ? copyStorybookPreset(srcFile, destFile, { consoles: false })
50
+ : fs.copyFileSync(srcFile, destFile);
51
+ });
52
+
53
+ if (consoles) {
54
+ const successMessage = styleText(
55
+ "green",
56
+ `Storybook preset successfully saved into '${path.basename(target)}' folder.`,
57
+ );
58
+
59
+ console.log(successMessage);
60
+ }
61
+ }
62
+
63
+ /**
64
+ * Add Storybook commands to package.json.
65
+ */
66
+ async function addStorybookCommands() {
67
+ try {
68
+ const storybookCommands = {
69
+ "sb:dev": "storybook dev -p 6006 --no-open",
70
+ "sb:dev:docs": "storybook dev -p 6006 --docs --no-open",
71
+ "sb:build": "storybook build --docs",
72
+ "sb:preview": "vite preview --host --outDir=storybook-static",
73
+ };
74
+
75
+ const packageJsonPath = path.resolve(cwd(), "package.json");
76
+ const data = await promises.readFile(packageJsonPath, "utf8");
77
+ const packageJson = JSON.parse(data);
78
+
79
+ packageJson.scripts = { ...packageJson.scripts, ...storybookCommands };
80
+
81
+ await promises.writeFile(packageJsonPath, JSON.stringify(packageJson, null, 2) + "\n", "utf8");
82
+ } catch (error) {
83
+ console.error("Error:", error);
84
+ }
85
+ }
@@ -0,0 +1,37 @@
1
+ import { DecoratorHelpers } from "@storybook/addon-themes";
2
+ import { makeDecorator } from "storybook/preview-api";
3
+ import { setTheme } from "vueless";
4
+
5
+ /* Cache preview color mode. */
6
+ let previewColorMode = "";
7
+
8
+ /* Set Storybook color mode when system color mode changed. */
9
+ const prefersColorSchemeDark = window.matchMedia("(prefers-color-scheme: dark)");
10
+
11
+ prefersColorSchemeDark.addEventListener("change", (event) => {
12
+ const systemColorMode = event.matches ? "dark" : "light";
13
+
14
+ setTheme({ colorMode: previewColorMode || systemColorMode });
15
+ });
16
+
17
+ /* Define color mode decorator. */
18
+ export const storyDarkModeDecorator = makeDecorator({
19
+ name: "storyDarkModeDecorator",
20
+ wrapper: (storyFn, context) => {
21
+ const sbAddonThemesConfig = localStorage.getItem("sb-addon-themes-3") || "{}";
22
+ const storybookColorMode = JSON.parse(sbAddonThemesConfig).current || "light";
23
+ const systemColorMode = prefersColorSchemeDark.matches ? "dark" : "light";
24
+
25
+ DecoratorHelpers.initializeThemeState(["light", "dark"], storybookColorMode || systemColorMode);
26
+
27
+ previewColorMode = DecoratorHelpers.pluckThemeFromContext(context);
28
+
29
+ setTheme({ colorMode: previewColorMode || systemColorMode });
30
+
31
+ return {
32
+ components: { storyFn },
33
+ setup: () => ({ theme: previewColorMode }),
34
+ template: `<story />`,
35
+ };
36
+ },
37
+ });
package/index.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ export { storyDarkModeDecorator } from "./decorators/storyDarkModeDecorator";
2
+ export { vue3SourceDecorator } from "./decorators/vue3SourceDecorator";
package/index.js CHANGED
@@ -1,115 +1,2 @@
1
- #!/usr/bin/env node
2
- /* eslint-disable no-console */
3
-
4
- import fs, { promises } from "node:fs";
5
- import { styleText } from "node:util";
6
- import { cwd } from "node:process";
7
- import path from "node:path";
8
-
9
- // Get the command-line arguments
10
- const args = process.argv.slice(2);
11
- const parsedArgs = parseArgs(args);
12
-
13
- const __dirname = path.dirname(new URL(import.meta.url).pathname);
14
- const source = path.join(__dirname, ".storybook");
15
- const target = path.join(cwd(), ".storybook");
16
-
17
- copyStorybookPreset(source, target);
18
-
19
- await addStorybookCommands();
20
-
21
- if (parsedArgs.pnpm) {
22
- await createNpmrc();
23
- }
24
-
25
- function copyStorybookPreset(source, target, { consoles = true } = {}) {
26
- if (fs.existsSync(target)) {
27
- const timestamp = new Date().valueOf();
28
- const renamedTarget = `${target}-backup-${timestamp}`;
29
-
30
- fs.renameSync(target, renamedTarget);
31
-
32
- const warnMessage = styleText(
33
- "yellow",
34
- // eslint-disable-next-line vue/max-len
35
- `Current Storybook preset backed into : '${path.basename(renamedTarget)}' folder. Don't forget to remove it before commit.`,
36
- );
37
-
38
- console.log(warnMessage);
39
- }
40
-
41
- fs.mkdirSync(target, { recursive: true });
42
-
43
- const files = fs.readdirSync(source);
44
-
45
- files.forEach((file) => {
46
- const srcFile = path.join(source, file);
47
- const destFile = path.join(target, file);
48
- const stat = fs.lstatSync(srcFile);
49
-
50
- stat.isDirectory()
51
- ? copyStorybookPreset(srcFile, destFile, { consoles: false })
52
- : fs.copyFileSync(srcFile, destFile);
53
- });
54
-
55
- if (consoles) {
56
- const successMessage = styleText(
57
- "green",
58
- `Storybook preset successfully saved into '${path.basename(target)}' folder.`,
59
- );
60
-
61
- console.log(successMessage);
62
- }
63
- }
64
-
65
- async function addStorybookCommands() {
66
- try {
67
- const storybookCommands = {
68
- "sb:dev": "storybook dev -p 6006 --no-open",
69
- "sb:dev:docs": "storybook dev -p 6006 --docs --no-open",
70
- "sb:build": "storybook build --docs",
71
- "sb:preview": "vite preview --host --outDir=storybook-static",
72
- };
73
-
74
- const packageJsonPath = path.resolve(cwd(), "package.json");
75
- const data = await promises.readFile(packageJsonPath, "utf8");
76
- const packageJson = JSON.parse(data);
77
-
78
- packageJson.scripts = { ...packageJson.scripts, ...storybookCommands };
79
-
80
- await promises.writeFile(packageJsonPath, JSON.stringify(packageJson, null, 2) + "\n", "utf8");
81
- } catch (error) {
82
- console.error("Error:", error);
83
- }
84
- }
85
-
86
- async function createNpmrc() {
87
- const npmrcContent = [
88
- "# @vueless/storybook: pnpm: disable hoisting for the package related modules.",
89
- "public-hoist-pattern[] = *storybook*",
90
- "public-hoist-pattern[] = prettier2",
91
- ];
92
-
93
- const npmrcPath = path.join(cwd(), ".npmrc");
94
-
95
- try {
96
- await promises.writeFile(npmrcPath, npmrcContent.join("\n"));
97
- } catch (err) {
98
- console.error("Error writing .npmrc file:", err);
99
- }
100
- }
101
-
102
- function parseArgs(args) {
103
- const result = {};
104
-
105
- args.forEach((arg) => {
106
- if (arg.startsWith("--")) {
107
- const [key, value] = arg.split("=");
108
- const normalizedKey = key.substring(2);
109
-
110
- result[normalizedKey] = value !== undefined ? value : true;
111
- }
112
- });
113
-
114
- return result;
115
- }
1
+ export { storyDarkModeDecorator } from "./decorators/storyDarkModeDecorator";
2
+ export { vue3SourceDecorator } from "./decorators/vue3SourceDecorator";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vueless/storybook",
3
- "version": "1.1.3-beta.4",
3
+ "version": "1.1.3-beta.6",
4
4
  "description": "Simplifies Storybook configuration for Vueless UI library.",
5
5
  "author": "Johnny Grid <hello@vueless.com> (https://vueless.com)",
6
6
  "homepage": "https://vueless.com",
@@ -11,7 +11,7 @@
11
11
  "access": "public"
12
12
  },
13
13
  "bin": {
14
- "copy": "./index.js"
14
+ "copy": "./bin/index.js"
15
15
  },
16
16
  "scripts": {
17
17
  "lint": "eslint --no-fix src/",
@@ -24,17 +24,17 @@
24
24
  "release:major": "release-it major --ci --npm.publish --git.tag --github.release"
25
25
  },
26
26
  "dependencies": {
27
- "@storybook/addon-docs": "9.1.2",
28
- "@storybook/addon-links": "9.1.2",
29
- "@storybook/addon-themes": "9.1.2",
30
- "@storybook/vue3-vite": "9.1.2",
27
+ "@storybook/addon-docs": "9.1.3",
28
+ "@storybook/addon-links": "9.1.3",
29
+ "@storybook/addon-themes": "9.1.3",
30
+ "@storybook/vue3-vite": "9.1.3",
31
31
  "@vueless/storybook-dark-mode": "^9.0.7",
32
32
  "chokidar": "^4.0.3",
33
33
  "esbuild": "^0.25.9",
34
34
  "globby": "^14.1.0",
35
35
  "mkdirp": "^3.0.1",
36
36
  "prettier2": "npm:prettier@2.8.8",
37
- "storybook": "9.1.2",
37
+ "storybook": "9.1.3",
38
38
  "vue-docgen-api": "^4.79.2"
39
39
  },
40
40
  "devDependencies": {
@@ -45,13 +45,13 @@
45
45
  "eslint-config-prettier": "^10.1.8",
46
46
  "eslint-plugin-node": "^11.1.0",
47
47
  "eslint-plugin-prettier": "^5.5.4",
48
- "eslint-plugin-storybook": "9.1.2",
48
+ "eslint-plugin-storybook": "9.1.3",
49
49
  "prettier": "^3.6.2",
50
50
  "release-it": "^19.0.4",
51
51
  "tailwindcss": "^4.1.12",
52
52
  "vue": "latest",
53
53
  "vue-router": "latest",
54
- "vueless": "^1.1.1-beta.56"
54
+ "vueless": "^1.2.0"
55
55
  },
56
56
  "overrides": {
57
57
  "vue-docgen-api": {
package/webTypes/index.js CHANGED
File without changes
@@ -1,49 +0,0 @@
1
- import { DecoratorHelpers } from "@storybook/addon-themes";
2
- import { setTheme } from "vueless";
3
- import { COLOR_MODE_KEY } from "vueless/constants.js";
4
-
5
- const { initializeThemeState, pluckThemeFromContext } = DecoratorHelpers;
6
-
7
- const prefersColorSchemeDark = window.matchMedia("(prefers-color-scheme: dark)");
8
-
9
- prefersColorSchemeDark.addEventListener("change", (event) => {
10
- setTheme({ colorMode: event.matches ? "dark" : "light" });
11
- });
12
-
13
- export const storyDarkModeDecorator = () => {
14
- /* Set theme className to html tag before initialization (fix white blink issue). */
15
- const sbAddonThemesConfig = localStorage.getItem("sb-addon-themes-3") || "{}";
16
- const storybookTheme = JSON.parse(sbAddonThemesConfig).current || "light";
17
-
18
- // this fixing first load
19
- document.body.classList.add(storybookTheme);
20
-
21
- // this fixing white blink issue
22
- if (window.location.toString().includes("viewMode=docs")) {
23
- document.documentElement.classList.add(storybookTheme);
24
-
25
- setTimeout(() => {
26
- document.documentElement.classList.remove("light", "dark");
27
- }, 4000);
28
- }
29
-
30
- /* Initialize theme state. */
31
- const colorMode = prefersColorSchemeDark.matches ? "dark" : "light";
32
- const cachedColorMode = localStorage.getItem(COLOR_MODE_KEY) || colorMode;
33
-
34
- initializeThemeState(["light", "dark"], cachedColorMode);
35
-
36
- return (story, context) => {
37
- const theme = pluckThemeFromContext(context);
38
-
39
- setTheme({ colorMode: theme });
40
-
41
- return {
42
- components: { story },
43
- setup() {
44
- return { theme };
45
- },
46
- template: `<story />`,
47
- };
48
- };
49
- };
@@ -1,290 +0,0 @@
1
- /* Default tailwind colors */
2
- export const TAILWIND_COLORS = {
3
- white: "#ffffff",
4
- slate: {
5
- 50: "#f8fafc",
6
- 100: "#f1f5f9",
7
- 200: "#e2e8f0",
8
- 300: "#cbd5e1",
9
- 400: "#94a3b8",
10
- 500: "#64748b",
11
- 600: "#475569",
12
- 700: "#334155",
13
- 800: "#1e293b",
14
- 900: "#0f172a",
15
- 950: "#020617",
16
- },
17
- gray: {
18
- 50: "#f9fafb",
19
- 100: "#f3f4f6",
20
- 200: "#e5e7eb",
21
- 300: "#d1d5db",
22
- 400: "#9ca3af",
23
- 500: "#6b7280",
24
- 600: "#4b5563",
25
- 700: "#374151",
26
- 800: "#1f2937",
27
- 900: "#111827",
28
- 950: "#030712",
29
- },
30
- zinc: {
31
- 50: "#fafafa",
32
- 100: "#f4f4f5",
33
- 200: "#e4e4e7",
34
- 300: "#d4d4d8",
35
- 400: "#a1a1aa",
36
- 500: "#71717a",
37
- 600: "#52525b",
38
- 700: "#3f3f46",
39
- 800: "#27272a",
40
- 900: "#18181b",
41
- 950: "#09090b",
42
- },
43
- neutral: {
44
- 50: "#fafafa",
45
- 100: "#f5f5f5",
46
- 200: "#e5e5e5",
47
- 300: "#d4d4d4",
48
- 400: "#a3a3a3",
49
- 500: "#737373",
50
- 600: "#525252",
51
- 700: "#404040",
52
- 800: "#262626",
53
- 900: "#171717",
54
- 950: "#0a0a0a",
55
- },
56
- stone: {
57
- 50: "#fafaf9",
58
- 100: "#f5f5f4",
59
- 200: "#e7e5e4",
60
- 300: "#d6d3d1",
61
- 400: "#a8a29e",
62
- 500: "#78716c",
63
- 600: "#57534e",
64
- 700: "#44403c",
65
- 800: "#292524",
66
- 900: "#1c1917",
67
- 950: "#0c0a09",
68
- },
69
- red: {
70
- 50: "#fef2f2",
71
- 100: "#fee2e2",
72
- 200: "#fecaca",
73
- 300: "#fca5a5",
74
- 400: "#f87171",
75
- 500: "#ef4444",
76
- 600: "#dc2626",
77
- 700: "#b91c1c",
78
- 800: "#991b1b",
79
- 900: "#7f1d1d",
80
- 950: "#450a0a",
81
- },
82
- orange: {
83
- 50: "#fff7ed",
84
- 100: "#ffedd5",
85
- 200: "#fed7aa",
86
- 300: "#fdba74",
87
- 400: "#fb923c",
88
- 500: "#f97316",
89
- 600: "#ea580c",
90
- 700: "#c2410c",
91
- 800: "#9a3412",
92
- 900: "#7c2d12",
93
- 950: "#431407",
94
- },
95
- amber: {
96
- 50: "#fffbeb",
97
- 100: "#fef3c7",
98
- 200: "#fde68a",
99
- 300: "#fcd34d",
100
- 400: "#fbbf24",
101
- 500: "#f59e0b",
102
- 600: "#d97706",
103
- 700: "#b45309",
104
- 800: "#92400e",
105
- 900: "#78350f",
106
- 950: "#451a03",
107
- },
108
- yellow: {
109
- 50: "#fefce8",
110
- 100: "#fef9c3",
111
- 200: "#fef08a",
112
- 300: "#fde047",
113
- 400: "#facc15",
114
- 500: "#eab308",
115
- 600: "#ca8a04",
116
- 700: "#a16207",
117
- 800: "#854d0e",
118
- 900: "#713f12",
119
- 950: "#422006",
120
- },
121
- lime: {
122
- 50: "#f7fee7",
123
- 100: "#ecfccb",
124
- 200: "#d9f99d",
125
- 300: "#bef264",
126
- 400: "#a3e635",
127
- 500: "#84cc16",
128
- 600: "#65a30d",
129
- 700: "#4d7c0f",
130
- 800: "#3f6212",
131
- 900: "#365314",
132
- 950: "#1a2e05",
133
- },
134
- green: {
135
- 50: "#f0fdf4",
136
- 100: "#dcfce7",
137
- 200: "#bbf7d0",
138
- 300: "#86efac",
139
- 400: "#4ade80",
140
- 500: "#22c55e",
141
- 600: "#16a34a",
142
- 700: "#15803d",
143
- 800: "#166534",
144
- 900: "#14532d",
145
- 950: "#052e16",
146
- },
147
- emerald: {
148
- 50: "#ecfdf5",
149
- 100: "#d1fae5",
150
- 200: "#a7f3d0",
151
- 300: "#6ee7b7",
152
- 400: "#34d399",
153
- 500: "#10b981",
154
- 600: "#059669",
155
- 700: "#047857",
156
- 800: "#065f46",
157
- 900: "#064e3b",
158
- 950: "#022c22",
159
- },
160
- teal: {
161
- 50: "#f0fdfa",
162
- 100: "#ccfbf1",
163
- 200: "#99f6e4",
164
- 300: "#5eead4",
165
- 400: "#2dd4bf",
166
- 500: "#14b8a6",
167
- 600: "#0d9488",
168
- 700: "#0f766e",
169
- 800: "#115e59",
170
- 900: "#134e4a",
171
- 950: "#042f2e",
172
- },
173
- cyan: {
174
- 50: "#ecfeff",
175
- 100: "#cffafe",
176
- 200: "#a5f3fc",
177
- 300: "#67e8f9",
178
- 400: "#22d3ee",
179
- 500: "#06b6d4",
180
- 600: "#0891b2",
181
- 700: "#0e7490",
182
- 800: "#155e75",
183
- 900: "#164e63",
184
- 950: "#083344",
185
- },
186
- sky: {
187
- 50: "#f0f9ff",
188
- 100: "#e0f2fe",
189
- 200: "#bae6fd",
190
- 300: "#7dd3fc",
191
- 400: "#38bdf8",
192
- 500: "#0ea5e9",
193
- 600: "#0284c7",
194
- 700: "#0369a1",
195
- 800: "#075985",
196
- 900: "#0c4a6e",
197
- 950: "#082f49",
198
- },
199
- blue: {
200
- 50: "#eff6ff",
201
- 100: "#dbeafe",
202
- 200: "#bfdbfe",
203
- 300: "#93c5fd",
204
- 400: "#60a5fa",
205
- 500: "#3b82f6",
206
- 600: "#2563eb",
207
- 700: "#1d4ed8",
208
- 800: "#1e40af",
209
- 900: "#1e3a8a",
210
- 950: "#172554",
211
- },
212
- indigo: {
213
- 50: "#eef2ff",
214
- 100: "#e0e7ff",
215
- 200: "#c7d2fe",
216
- 300: "#a5b4fc",
217
- 400: "#818cf8",
218
- 500: "#6366f1",
219
- 600: "#4f46e5",
220
- 700: "#4338ca",
221
- 800: "#3730a3",
222
- 900: "#312e81",
223
- 950: "#1e1b4b",
224
- },
225
- violet: {
226
- 50: "#f5f3ff",
227
- 100: "#ede9fe",
228
- 200: "#ddd6fe",
229
- 300: "#c4b5fd",
230
- 400: "#a78bfa",
231
- 500: "#8b5cf6",
232
- 600: "#7c3aed",
233
- 700: "#6d28d9",
234
- 800: "#5b21b6",
235
- 900: "#4c1d95",
236
- 950: "#2e1065",
237
- },
238
- purple: {
239
- 50: "#faf5ff",
240
- 100: "#f3e8ff",
241
- 200: "#e9d5ff",
242
- 300: "#d8b4fe",
243
- 400: "#c084fc",
244
- 500: "#a855f7",
245
- 600: "#9333ea",
246
- 700: "#7e22ce",
247
- 800: "#6b21a8",
248
- 900: "#581c87",
249
- 950: "#3b0764",
250
- },
251
- fuchsia: {
252
- 50: "#fdf4ff",
253
- 100: "#fae8ff",
254
- 200: "#f5d0fe",
255
- 300: "#f0abfc",
256
- 400: "#e879f9",
257
- 500: "#d946ef",
258
- 600: "#c026d3",
259
- 700: "#a21caf",
260
- 800: "#86198f",
261
- 900: "#701a75",
262
- 950: "#4a044e",
263
- },
264
- pink: {
265
- 50: "#fdf2f8",
266
- 100: "#fce7f3",
267
- 200: "#fbcfe8",
268
- 300: "#f9a8d4",
269
- 400: "#f472b6",
270
- 500: "#ec4899",
271
- 600: "#db2777",
272
- 700: "#be185d",
273
- 800: "#9d174d",
274
- 900: "#831843",
275
- 950: "#500724",
276
- },
277
- rose: {
278
- 50: "#fff1f2",
279
- 100: "#ffe4e6",
280
- 200: "#fecdd3",
281
- 300: "#fda4af",
282
- 400: "#fb7185",
283
- 500: "#f43f5e",
284
- 600: "#e11d48",
285
- 700: "#be123c",
286
- 800: "#9f1239",
287
- 900: "#881337",
288
- 950: "#4c0519",
289
- },
290
- };