aboutsummaryrefslogtreecommitdiff
path: root/src/services/theme_data/iss_serializer.js
blob: 959852b7f7514e13684488b5f1997bbaad0c8bb1 (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
43
44
import { unroll } from './iss_utils.js'

const serializeShadow = s => {
  if (typeof s === 'object') {
    return `${s.inset ? 'inset ' : ''}${s.x} ${s.y} ${s.blur} ${s.spread} ${s.color} / ${s.alpha}`
  } else {
    return s
  }
}

export const serialize = (ruleset) => {
  return ruleset.map((rule) => {
    if (Object.keys(rule.directives || {}).length === 0) return false

    const header = unroll(rule).reverse().map(rule => {
      const { component } = rule
      const newVariant = (rule.variant == null || rule.variant === 'normal') ? '' : ('.' + rule.variant)
      const newState = (rule.state || []).filter(st => st !== 'normal')

      return `${component}${newVariant}${newState.map(st => ':' + st).join('')}`
    }).join(' ')

    const content = Object.entries(rule.directives).map(([directive, value]) => {
      if (directive.startsWith('--')) {
        const [valType, newValue] = value.split('|') // only first one! intentional!
        switch (valType) {
          case 'shadow':
            return `  ${directive}: ${valType.trim()} | ${newValue.map(serializeShadow).map(s => s.trim()).join(', ')}`
          default:
            return `  ${directive}: ${valType.trim()} | ${newValue.trim()}`
        }
      } else {
        switch (directive) {
          case 'shadow':
            return `  ${directive}: ${value.map(serializeShadow).join(', ')}`
          default:
            return `  ${directive}: ${value}`
        }
      }
    })

    return `${header} {\n${content.join(';\n')}\n}`
  }).filter(x => x).join('\n\n')
}