theme.js 1.2 KB
Newer Older
D
DCloud_LXH 已提交
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 { isPlainObject, isStr } from './util'

const borderStyles = {
  black: 'rgba(0,0,0,0.4)',
  white: 'rgba(255,255,255,0.4)'
}

export function normalizeTabBarStyles (borderStyle) {
  if (borderStyle && borderStyle in borderStyles) {
    return borderStyles[borderStyle]
  }
  return borderStyle
}

export function normallizeStyles (pageStyle, themeConfig, mode = 'light') {
  const modeStyle = themeConfig[mode]
  const styles = {}
  if (!modeStyle) {
    return styles
  }
  Object.keys(pageStyle).forEach((key) => {
    const styleItem = pageStyle[key] // Object Array String
    styles[key] = (() => {
      if (isPlainObject(styleItem)) {
        return normallizeStyles(styleItem, themeConfig, mode)
      } else if (Array.isArray(styleItem)) {
        return styleItem.map((item) => isPlainObject(item)
          ? normallizeStyles(item, themeConfig, mode)
          : item)
      } else if (isStr(styleItem) && styleItem.startsWith('@')) {
        const _key = styleItem.replace('@', '')
        let _styleItem = modeStyle[_key]
        switch (key) {
          case 'borderStyle':
            _styleItem = normalizeTabBarStyles(_styleItem)
            break
        }
        return _styleItem
      }
      return styleItem
    })()
  })
  return styles
}