UNPKG

ifui

Version:

44 lines (37 loc) 963 B
/** * bem helper * b() // 'button' * b('text') // 'button__text' * b({ disabled }) // 'button button--disabled' * b('text', { disabled }) // 'button__text button__text--disabled' * b(['disabled', 'primary']) // 'button button--disabled button--primary' */ const ELEMENT = '__' const MODS = '--' const join = (name, el, symbol) => el ? name + symbol + el : name const prefix = (name, mods) => { if (typeof mods == 'string') { return join(name, mods, MODS) } if (Array.isArray(mods)) { return mods.map(item => prefix(name, item)) } const ret = {} Object.keys(mods).forEach(key => { ret[name + MODS + key] = mods[key] }) return ret } export default { methods: { b(el, mods) { const {name} = this.$options if (el && typeof el !== 'string') { mods = el el = '' } el = join(name, el, ELEMENT) return mods ? [el, prefix(el, mods)] : el } } }