/
var
/
www
/
html
/
lgpd
/
theme
/
boost
/
amd
/
src
/
Upload File
HOME
"use strict"; define(["exports", "jquery"], function (exports, _jquery) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var _jquery2 = _interopRequireDefault(_jquery); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } /** * ------------------------------------------------------------------------ * Constants * ------------------------------------------------------------------------ */ var NAME = 'button'; var VERSION = '4.3.1'; var DATA_KEY = 'bs.button'; var EVENT_KEY = ".".concat(DATA_KEY); var DATA_API_KEY = '.data-api'; var JQUERY_NO_CONFLICT = _jquery2.default.fn[NAME]; var ClassName = { ACTIVE: 'active', BUTTON: 'btn', FOCUS: 'focus' }; var Selector = { DATA_TOGGLE_CARROT: '[data-toggle^="button"]', DATA_TOGGLE: '[data-toggle="buttons"]', INPUT: 'input:not([type="hidden"])', ACTIVE: '.active', BUTTON: '.btn' }; var Event = { CLICK_DATA_API: "click".concat(EVENT_KEY).concat(DATA_API_KEY), FOCUS_BLUR_DATA_API: "focus".concat(EVENT_KEY).concat(DATA_API_KEY, " ") + "blur".concat(EVENT_KEY).concat(DATA_API_KEY) /** * ------------------------------------------------------------------------ * Class Definition * ------------------------------------------------------------------------ */ }; var Button = function () { function Button(element) { _classCallCheck(this, Button); this._element = element; } // Getters _createClass(Button, [{ key: "toggle", value: function toggle() { var triggerChangeEvent = true; var addAriaPressed = true; var rootElement = (0, _jquery2.default)(this._element).closest(Selector.DATA_TOGGLE)[0]; if (rootElement) { var input = this._element.querySelector(Selector.INPUT); if (input) { if (input.type === 'radio') { if (input.checked && this._element.classList.contains(ClassName.ACTIVE)) { triggerChangeEvent = false; } else { var activeElement = rootElement.querySelector(Selector.ACTIVE); if (activeElement) { (0, _jquery2.default)(activeElement).removeClass(ClassName.ACTIVE); } } } if (triggerChangeEvent) { if (input.hasAttribute('disabled') || rootElement.hasAttribute('disabled') || input.classList.contains('disabled') || rootElement.classList.contains('disabled')) { return; } input.checked = !this._element.classList.contains(ClassName.ACTIVE); (0, _jquery2.default)(input).trigger('change'); } input.focus(); addAriaPressed = false; } } if (addAriaPressed) { this._element.setAttribute('aria-pressed', !this._element.classList.contains(ClassName.ACTIVE)); } if (triggerChangeEvent) { (0, _jquery2.default)(this._element).toggleClass(ClassName.ACTIVE); } } }, { key: "dispose", value: function dispose() { _jquery2.default.removeData(this._element, DATA_KEY); this._element = null; } }], [{ key: "_jQueryInterface", value: function _jQueryInterface(config) { return this.each(function () { var data = (0, _jquery2.default)(this).data(DATA_KEY); if (!data) { data = new Button(this); (0, _jquery2.default)(this).data(DATA_KEY, data); } if (config === 'toggle') { data[config](); } }); } }, { key: "VERSION", get: function get() { return VERSION; } }]); return Button; }(); /** * ------------------------------------------------------------------------ * Data Api implementation * ------------------------------------------------------------------------ */ (0, _jquery2.default)(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) { event.preventDefault(); var button = event.target; if (!(0, _jquery2.default)(button).hasClass(ClassName.BUTTON)) { button = (0, _jquery2.default)(button).closest(Selector.BUTTON); } Button._jQueryInterface.call((0, _jquery2.default)(button), 'toggle'); }).on(Event.FOCUS_BLUR_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) { var button = (0, _jquery2.default)(event.target).closest(Selector.BUTTON)[0]; (0, _jquery2.default)(button).toggleClass(ClassName.FOCUS, /^focus(in)?$/.test(event.type)); }); /** * ------------------------------------------------------------------------ * jQuery * ------------------------------------------------------------------------ */ _jquery2.default.fn[NAME] = Button._jQueryInterface; _jquery2.default.fn[NAME].Constructor = Button; _jquery2.default.fn[NAME].noConflict = function () { _jquery2.default.fn[NAME] = JQUERY_NO_CONFLICT; return Button._jQueryInterface; }; exports.default = Button; });