« get me outta code hell

generateColorStyleRules.js « dependencies « content « src - hsmusic-wiki - HSMusic - static wiki software cataloguing collaborative creation
about summary refs log tree commit diff
path: root/src/content/dependencies/generateColorStyleRules.js
blob: 02c3380e7040a40b19690bdad7ec8327a4564ba0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
export default {
  extraDependencies: [
    'getColors',
  ],

  data(color) {
    return {color};
  },

  generate(data, {
    getColors,
  }) {
    if (!color) return '';

    const {
      primary,
      dark,
      dim,
      dimGhost,
      bg,
      bgBlack,
      shadow,
    } = getColors(data.color);

    const variables = [
      `--primary-color: ${primary}`,
      `--dark-color: ${dark}`,
      `--dim-color: ${dim}`,
      `--dim-ghost-color: ${dimGhost}`,
      `--bg-color: ${bg}`,
      `--bg-black-color: ${bgBlack}`,
      `--shadow-color: ${shadow}`,
      ...additionalVariables,
    ];

    return [
      `:root {`,
      ...variables.map((line) => `    ${line};`),
      `}`,
    ].join('\n');
  },
};