import Checkbox from './checkbox' const Switch = (($) => { /** * ------------------------------------------------------------------------ * Constants * ------------------------------------------------------------------------ */ const NAME = 'switch' const DATA_KEY = `bmd.${NAME}` const JQUERY_NAME = `bmd${NAME.charAt(0).toUpperCase() + NAME.slice(1)}` const JQUERY_NO_CONFLICT = $.fn[JQUERY_NAME] const Default = { template: `` } /** * ------------------------------------------------------------------------ * Class Definition * ------------------------------------------------------------------------ */ class Switch extends Checkbox { constructor($element, config, properties = {inputType: 'checkbox', outerClass: 'switch'}) { super($element, $.extend(true, {}, Default, config), properties) // selector: '.switch > label > input[type=checkbox]' } dispose() { super.dispose(DATA_KEY) } // ------------------------------------------------------------------------ // protected // ------------------------------------------------------------------------ // private // ------------------------------------------------------------------------ // static static _jQueryInterface(config) { return this.each(function () { let $element = $(this) let data = $element.data(DATA_KEY) if (!data) { data = new Switch($element, config) $element.data(DATA_KEY, data) } }) } } /** * ------------------------------------------------------------------------ * jQuery * ------------------------------------------------------------------------ */ $.fn[JQUERY_NAME] = Switch._jQueryInterface $.fn[JQUERY_NAME].Constructor = Switch $.fn[JQUERY_NAME].noConflict = () => { $.fn[JQUERY_NAME] = JQUERY_NO_CONFLICT return Switch._jQueryInterface } return Switch })(jQuery) export default Switch