import Radio from "./radio"; const RadioInline = ($ => { /** * ------------------------------------------------------------------------ * Constants * ------------------------------------------------------------------------ */ const NAME = "radioInline"; 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 = { bmdFormGroup: { create: false, // no bmd-form-group creation if form-group not present. It messes with the layout. required: false } }; /** * ------------------------------------------------------------------------ * Class Definition * ------------------------------------------------------------------------ */ class RadioInline extends Radio { constructor( $element, config, properties = { inputType: "radio", outerClass: "radio-inline" } ) { super($element, $.extend(true, {}, Default, config), properties); } dispose() { super.dispose(DATA_KEY); } // ------------------------------------------------------------------------ // protected // ------------------------------------------------------------------------ // protected // ------------------------------------------------------------------------ // private // ------------------------------------------------------------------------ // static static _jQueryInterface(config) { return this.each(function() { let $element = $(this); let data = $element.data(DATA_KEY); if (!data) { data = new RadioInline($element, config); $element.data(DATA_KEY, data); } }); } } /** * ------------------------------------------------------------------------ * jQuery * ------------------------------------------------------------------------ */ $.fn[JQUERY_NAME] = RadioInline._jQueryInterface; $.fn[JQUERY_NAME].Constructor = RadioInline; $.fn[JQUERY_NAME].noConflict = () => { $.fn[JQUERY_NAME] = JQUERY_NO_CONFLICT; return RadioInline._jQueryInterface; }; return RadioInline; })(jQuery); export default RadioInline;