2020-01-29 11:10:25 +01:00
|
|
|
export default class ClassBuilder {
|
2020-02-12 13:32:46 +01:00
|
|
|
constructor(block, defaultIgnoreList) {
|
2020-02-25 16:21:23 +01:00
|
|
|
this.block = `mdc-${block}`
|
2020-05-07 11:53:34 +02:00
|
|
|
this.defaultIgnoreList = defaultIgnoreList //will be ignored when building custom classes
|
2020-02-03 19:38:09 +01:00
|
|
|
}
|
|
|
|
|
2020-02-12 13:32:46 +01:00
|
|
|
/*
|
|
|
|
handles both blocks and elementss (BEM MD Notation)
|
|
|
|
params = {elementName: string, props: {modifiers{}, customs:{}, extras: []}}
|
|
|
|
All are optional
|
|
|
|
*/
|
|
|
|
build(params) {
|
2020-02-25 16:21:23 +01:00
|
|
|
if (!params) return this.block //return block if nothing passed
|
|
|
|
const { props, elementName } = params
|
|
|
|
let base = elementName ? `${this.block}__${elementName}` : this.block
|
|
|
|
if (!props) return base
|
|
|
|
return this._handleProps(base, props)
|
2020-02-03 19:38:09 +01:00
|
|
|
}
|
|
|
|
|
2020-02-12 13:32:46 +01:00
|
|
|
//Easily grab a simple element class
|
|
|
|
elem(elementName) {
|
2020-02-25 16:21:23 +01:00
|
|
|
return this.build({ elementName })
|
2020-02-03 19:38:09 +01:00
|
|
|
}
|
|
|
|
|
2020-02-12 13:32:46 +01:00
|
|
|
//use if a different base is needed than whats defined by this.block
|
|
|
|
debase(base, elementProps) {
|
2020-02-25 16:21:23 +01:00
|
|
|
if (!elementProps) return base
|
|
|
|
return this._handleProps(base, elementProps)
|
2020-02-12 13:32:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//proxies bindProps and checks for which elementProps exist before binding
|
|
|
|
_handleProps(base, elementProps) {
|
2020-02-25 16:21:23 +01:00
|
|
|
let cls = base
|
|
|
|
const { modifiers, customs, extras } = elementProps
|
|
|
|
if (modifiers) cls += this._bindProps(modifiers, base)
|
|
|
|
if (customs) cls += this._bindProps(customs, base, true)
|
|
|
|
if (extras) cls += ` ${extras.join(" ")}`
|
|
|
|
return cls.trim()
|
2020-02-12 13:32:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
Handles both modifiers and customs. Use property, value or both depending
|
|
|
|
on whether it is passsed props for custom or modifiers
|
|
|
|
if custom uses the following convention for scss mixins:
|
|
|
|
bbmd-{this.block}--{property}-{value}
|
|
|
|
bbmd-mdc-button--size-large
|
|
|
|
*/
|
|
|
|
_bindProps(elementProps, base, isCustom = false) {
|
|
|
|
return Object.entries(elementProps)
|
|
|
|
.map(([property, value]) => {
|
|
|
|
//disregard falsy and values set by defaultIgnoreList constructor param
|
|
|
|
if (
|
|
|
|
!!value &&
|
|
|
|
(!this.defaultIgnoreList || !this.defaultIgnoreList.includes(value))
|
|
|
|
) {
|
2020-02-25 16:21:23 +01:00
|
|
|
let classBase = isCustom ? `bbmd-${base}` : `${base}`
|
|
|
|
let valueType = typeof value
|
2020-02-12 13:32:46 +01:00
|
|
|
|
|
|
|
if (valueType == "string" || valueType == "number") {
|
|
|
|
return isCustom
|
|
|
|
? ` ${classBase}--${this._convertCamel(property)}-${value}`
|
2020-02-25 16:21:23 +01:00
|
|
|
: ` ${classBase}--${value}`
|
2020-02-12 13:32:46 +01:00
|
|
|
} else if (valueType == "boolean") {
|
2020-02-25 16:21:23 +01:00
|
|
|
return ` ${classBase}--${this._convertCamel(property)}`
|
2020-02-10 11:04:20 +01:00
|
|
|
}
|
2020-02-12 13:32:46 +01:00
|
|
|
}
|
|
|
|
})
|
2020-02-25 16:21:23 +01:00
|
|
|
.join("")
|
2020-02-12 13:32:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
_convertCamel(str) {
|
2020-02-25 16:21:23 +01:00
|
|
|
return str.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)
|
2020-02-10 11:04:20 +01:00
|
|
|
}
|
2020-01-29 11:10:25 +01:00
|
|
|
}
|