/
var
/
www
/
html
/
lgpd
/
theme
/
boost
/
amd
/
src
/
Upload File
HOME
"use strict"; define(["exports", "./sanitizer", "jquery", "core/popper", "./util"], function (exports, _sanitizer, _jquery, _popper, _util) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var _jquery2 = _interopRequireDefault(_jquery); var _popper2 = _interopRequireDefault(_popper); var _util2 = _interopRequireDefault(_util); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(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 = 'tooltip'; var VERSION = '4.3.1'; var DATA_KEY = 'bs.tooltip'; var EVENT_KEY = ".".concat(DATA_KEY); var JQUERY_NO_CONFLICT = _jquery2.default.fn[NAME]; var CLASS_PREFIX = 'bs-tooltip'; var BSCLS_PREFIX_REGEX = new RegExp("(^|\\s)".concat(CLASS_PREFIX, "\\S+"), 'g'); var DISALLOWED_ATTRIBUTES = ['sanitize', 'whiteList', 'sanitizeFn']; var DefaultType = { animation: 'boolean', template: 'string', title: '(string|element|function)', trigger: 'string', delay: '(number|object)', html: 'boolean', selector: '(string|boolean)', placement: '(string|function)', offset: '(number|string|function)', container: '(string|element|boolean)', fallbackPlacement: '(string|array)', boundary: '(string|element)', sanitize: 'boolean', sanitizeFn: '(null|function)', whiteList: 'object' }; var AttachmentMap = { AUTO: 'auto', TOP: 'top', RIGHT: 'right', BOTTOM: 'bottom', LEFT: 'left' }; var Default = { animation: true, template: '<div class="tooltip" role="tooltip">' + '<div class="arrow"></div>' + '<div class="tooltip-inner"></div></div>', trigger: 'hover focus', title: '', delay: 0, html: false, selector: false, placement: 'top', offset: 0, container: false, fallbackPlacement: 'flip', boundary: 'scrollParent', sanitize: true, sanitizeFn: null, whiteList: _sanitizer.DefaultWhitelist }; var HoverState = { SHOW: 'show', OUT: 'out' }; var Event = { HIDE: "hide".concat(EVENT_KEY), HIDDEN: "hidden".concat(EVENT_KEY), SHOW: "show".concat(EVENT_KEY), SHOWN: "shown".concat(EVENT_KEY), INSERTED: "inserted".concat(EVENT_KEY), CLICK: "click".concat(EVENT_KEY), FOCUSIN: "focusin".concat(EVENT_KEY), FOCUSOUT: "focusout".concat(EVENT_KEY), MOUSEENTER: "mouseenter".concat(EVENT_KEY), MOUSELEAVE: "mouseleave".concat(EVENT_KEY) }; var ClassName = { FADE: 'fade', SHOW: 'show' }; var Selector = { TOOLTIP: '.tooltip', TOOLTIP_INNER: '.tooltip-inner', ARROW: '.arrow' }; var Trigger = { HOVER: 'hover', FOCUS: 'focus', CLICK: 'click', MANUAL: 'manual' /** * ------------------------------------------------------------------------ * Class Definition * ------------------------------------------------------------------------ */ }; var Tooltip = function () { function Tooltip(element, config) { _classCallCheck(this, Tooltip); /** * Check for Popper dependency * Popper - https://popper.js.org */ if (typeof _popper2.default === 'undefined') { throw new TypeError('Bootstrap\'s tooltips require Popper.js (https://popper.js.org/)'); } // private this._isEnabled = true; this._timeout = 0; this._hoverState = ''; this._activeTrigger = {}; this._popper = null; // Protected this.element = element; this.config = this._getConfig(config); this.tip = null; this._setListeners(); } // Getters _createClass(Tooltip, [{ key: "enable", value: function enable() { this._isEnabled = true; } }, { key: "disable", value: function disable() { this._isEnabled = false; } }, { key: "toggleEnabled", value: function toggleEnabled() { this._isEnabled = !this._isEnabled; } }, { key: "toggle", value: function toggle(event) { if (!this._isEnabled) { return; } if (event) { var dataKey = this.constructor.DATA_KEY; var context = (0, _jquery2.default)(event.currentTarget).data(dataKey); if (!context) { context = new this.constructor(event.currentTarget, this._getDelegateConfig()); (0, _jquery2.default)(event.currentTarget).data(dataKey, context); } context._activeTrigger.click = !context._activeTrigger.click; if (context._isWithActiveTrigger()) { context._enter(null, context); } else { context._leave(null, context); } } else { if ((0, _jquery2.default)(this.getTipElement()).hasClass(ClassName.SHOW)) { this._leave(null, this); return; } this._enter(null, this); } } }, { key: "dispose", value: function dispose() { clearTimeout(this._timeout); _jquery2.default.removeData(this.element, this.constructor.DATA_KEY); (0, _jquery2.default)(this.element).off(this.constructor.EVENT_KEY); (0, _jquery2.default)(this.element).closest('.modal').off('hide.bs.modal'); if (this.tip) { (0, _jquery2.default)(this.tip).remove(); } this._isEnabled = null; this._timeout = null; this._hoverState = null; this._activeTrigger = null; if (this._popper !== null) { this._popper.destroy(); } this._popper = null; this.element = null; this.config = null; this.tip = null; } }, { key: "show", value: function show() { var _this = this; if ((0, _jquery2.default)(this.element).css('display') === 'none') { throw new Error('Please use show on visible elements'); } var showEvent = _jquery2.default.Event(this.constructor.Event.SHOW); if (this.isWithContent() && this._isEnabled) { (0, _jquery2.default)(this.element).trigger(showEvent); var shadowRoot = _util2.default.findShadowRoot(this.element); var isInTheDom = _jquery2.default.contains(shadowRoot !== null ? shadowRoot : this.element.ownerDocument.documentElement, this.element); if (showEvent.isDefaultPrevented() || !isInTheDom) { return; } var tip = this.getTipElement(); var tipId = _util2.default.getUID(this.constructor.NAME); tip.setAttribute('id', tipId); this.element.setAttribute('aria-describedby', tipId); this.setContent(); if (this.config.animation) { (0, _jquery2.default)(tip).addClass(ClassName.FADE); } var placement = typeof this.config.placement === 'function' ? this.config.placement.call(this, tip, this.element) : this.config.placement; var attachment = this._getAttachment(placement); this.addAttachmentClass(attachment); var container = this._getContainer(); (0, _jquery2.default)(tip).data(this.constructor.DATA_KEY, this); if (!_jquery2.default.contains(this.element.ownerDocument.documentElement, this.tip)) { (0, _jquery2.default)(tip).appendTo(container); } (0, _jquery2.default)(this.element).trigger(this.constructor.Event.INSERTED); this._popper = new _popper2.default(this.element, tip, { placement: attachment, modifiers: { offset: this._getOffset(), flip: { behavior: this.config.fallbackPlacement }, arrow: { element: Selector.ARROW }, preventOverflow: { boundariesElement: this.config.boundary } }, onCreate: function onCreate(data) { if (data.originalPlacement !== data.placement) { _this._handlePopperPlacementChange(data); } }, onUpdate: function onUpdate(data) { return _this._handlePopperPlacementChange(data); } }); (0, _jquery2.default)(tip).addClass(ClassName.SHOW); // If this is a touch-enabled device we add extra // empty mouseover listeners to the body's immediate children; // only needed because of broken event delegation on iOS // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html if ('ontouchstart' in document.documentElement) { (0, _jquery2.default)(document.body).children().on('mouseover', null, _jquery2.default.noop); } var complete = function complete() { if (_this.config.animation) { _this._fixTransition(); } var prevHoverState = _this._hoverState; _this._hoverState = null; (0, _jquery2.default)(_this.element).trigger(_this.constructor.Event.SHOWN); if (prevHoverState === HoverState.OUT) { _this._leave(null, _this); } }; if ((0, _jquery2.default)(this.tip).hasClass(ClassName.FADE)) { var transitionDuration = _util2.default.getTransitionDurationFromElement(this.tip); (0, _jquery2.default)(this.tip).one(_util2.default.TRANSITION_END, complete).emulateTransitionEnd(transitionDuration); } else { complete(); } } } }, { key: "hide", value: function hide(callback) { var _this2 = this; var tip = this.getTipElement(); var hideEvent = _jquery2.default.Event(this.constructor.Event.HIDE); var complete = function complete() { if (_this2._hoverState !== HoverState.SHOW && tip.parentNode) { tip.parentNode.removeChild(tip); } _this2._cleanTipClass(); _this2.element.removeAttribute('aria-describedby'); (0, _jquery2.default)(_this2.element).trigger(_this2.constructor.Event.HIDDEN); if (_this2._popper !== null) { _this2._popper.destroy(); } if (callback) { callback(); } }; (0, _jquery2.default)(this.element).trigger(hideEvent); if (hideEvent.isDefaultPrevented()) { return; } (0, _jquery2.default)(tip).removeClass(ClassName.SHOW); // If this is a touch-enabled device we remove the extra // empty mouseover listeners we added for iOS support if ('ontouchstart' in document.documentElement) { (0, _jquery2.default)(document.body).children().off('mouseover', null, _jquery2.default.noop); } this._activeTrigger[Trigger.CLICK] = false; this._activeTrigger[Trigger.FOCUS] = false; this._activeTrigger[Trigger.HOVER] = false; if ((0, _jquery2.default)(this.tip).hasClass(ClassName.FADE)) { var transitionDuration = _util2.default.getTransitionDurationFromElement(tip); (0, _jquery2.default)(tip).one(_util2.default.TRANSITION_END, complete).emulateTransitionEnd(transitionDuration); } else { complete(); } this._hoverState = ''; } }, { key: "update", value: function update() { if (this._popper !== null) { this._popper.scheduleUpdate(); } } }, { key: "isWithContent", value: function isWithContent() { return Boolean(this.getTitle()); } }, { key: "addAttachmentClass", value: function addAttachmentClass(attachment) { (0, _jquery2.default)(this.getTipElement()).addClass("".concat(CLASS_PREFIX, "-").concat(attachment)); } }, { key: "getTipElement", value: function getTipElement() { this.tip = this.tip || (0, _jquery2.default)(this.config.template)[0]; return this.tip; } }, { key: "setContent", value: function setContent() { var tip = this.getTipElement(); this.setElementContent((0, _jquery2.default)(tip.querySelectorAll(Selector.TOOLTIP_INNER)), this.getTitle()); (0, _jquery2.default)(tip).removeClass("".concat(ClassName.FADE, " ").concat(ClassName.SHOW)); } }, { key: "setElementContent", value: function setElementContent($element, content) { if (_typeof(content) === 'object' && (content.nodeType || content.jquery)) { // Content is a DOM node or a jQuery if (this.config.html) { if (!(0, _jquery2.default)(content).parent().is($element)) { $element.empty().append(content); } } else { $element.text((0, _jquery2.default)(content).text()); } return; } if (this.config.html) { if (this.config.sanitize) { content = (0, _sanitizer.sanitizeHtml)(content, this.config.whiteList, this.config.sanitizeFn); } $element.html(content); } else { $element.text(content); } } }, { key: "getTitle", value: function getTitle() { var title = this.element.getAttribute('data-original-title'); if (!title) { title = typeof this.config.title === 'function' ? this.config.title.call(this.element) : this.config.title; } return title; } }, { key: "_getOffset", value: function _getOffset() { var _this3 = this; var offset = {}; if (typeof this.config.offset === 'function') { offset.fn = function (data) { data.offsets = _objectSpread({}, data.offsets, _this3.config.offset(data.offsets, _this3.element) || {}); return data; }; } else { offset.offset = this.config.offset; } return offset; } }, { key: "_getContainer", value: function _getContainer() { if (this.config.container === false) { return document.body; } if (_util2.default.isElement(this.config.container)) { return (0, _jquery2.default)(this.config.container); } return (0, _jquery2.default)(document).find(this.config.container); } }, { key: "_getAttachment", value: function _getAttachment(placement) { return AttachmentMap[placement.toUpperCase()]; } }, { key: "_setListeners", value: function _setListeners() { var _this4 = this; var triggers = this.config.trigger.split(' '); triggers.forEach(function (trigger) { if (trigger === 'click') { (0, _jquery2.default)(_this4.element).on(_this4.constructor.Event.CLICK, _this4.config.selector, function (event) { return _this4.toggle(event); }); } else if (trigger !== Trigger.MANUAL) { var eventIn = trigger === Trigger.HOVER ? _this4.constructor.Event.MOUSEENTER : _this4.constructor.Event.FOCUSIN; var eventOut = trigger === Trigger.HOVER ? _this4.constructor.Event.MOUSELEAVE : _this4.constructor.Event.FOCUSOUT; (0, _jquery2.default)(_this4.element).on(eventIn, _this4.config.selector, function (event) { return _this4._enter(event); }).on(eventOut, _this4.config.selector, function (event) { return _this4._leave(event); }); } }); (0, _jquery2.default)(this.element).closest('.modal').on('hide.bs.modal', function () { if (_this4.element) { _this4.hide(); } }); if (this.config.selector) { this.config = _objectSpread({}, this.config, { trigger: 'manual', selector: '' }); } else { this._fixTitle(); } } }, { key: "_fixTitle", value: function _fixTitle() { var titleType = _typeof(this.element.getAttribute('data-original-title')); if (this.element.getAttribute('title') || titleType !== 'string') { this.element.setAttribute('data-original-title', this.element.getAttribute('title') || ''); this.element.setAttribute('title', ''); } } }, { key: "_enter", value: function _enter(event, context) { var dataKey = this.constructor.DATA_KEY; context = context || (0, _jquery2.default)(event.currentTarget).data(dataKey); if (!context) { context = new this.constructor(event.currentTarget, this._getDelegateConfig()); (0, _jquery2.default)(event.currentTarget).data(dataKey, context); } if (event) { context._activeTrigger[event.type === 'focusin' ? Trigger.FOCUS : Trigger.HOVER] = true; } if ((0, _jquery2.default)(context.getTipElement()).hasClass(ClassName.SHOW) || context._hoverState === HoverState.SHOW) { context._hoverState = HoverState.SHOW; return; } clearTimeout(context._timeout); context._hoverState = HoverState.SHOW; if (!context.config.delay || !context.config.delay.show) { context.show(); return; } context._timeout = setTimeout(function () { if (context._hoverState === HoverState.SHOW) { context.show(); } }, context.config.delay.show); } }, { key: "_leave", value: function _leave(event, context) { var dataKey = this.constructor.DATA_KEY; context = context || (0, _jquery2.default)(event.currentTarget).data(dataKey); if (!context) { context = new this.constructor(event.currentTarget, this._getDelegateConfig()); (0, _jquery2.default)(event.currentTarget).data(dataKey, context); } if (event) { context._activeTrigger[event.type === 'focusout' ? Trigger.FOCUS : Trigger.HOVER] = false; } if (context._isWithActiveTrigger()) { return; } clearTimeout(context._timeout); context._hoverState = HoverState.OUT; if (!context.config.delay || !context.config.delay.hide) { context.hide(); return; } context._timeout = setTimeout(function () { if (context._hoverState === HoverState.OUT) { context.hide(); } }, context.config.delay.hide); } }, { key: "_isWithActiveTrigger", value: function _isWithActiveTrigger() { for (var trigger in this._activeTrigger) { if (this._activeTrigger[trigger]) { return true; } } return false; } }, { key: "_getConfig", value: function _getConfig(config) { var dataAttributes = (0, _jquery2.default)(this.element).data(); Object.keys(dataAttributes).forEach(function (dataAttr) { if (DISALLOWED_ATTRIBUTES.indexOf(dataAttr) !== -1) { delete dataAttributes[dataAttr]; } }); config = _objectSpread({}, this.constructor.Default, dataAttributes, _typeof(config) === 'object' && config ? config : {}); if (typeof config.delay === 'number') { config.delay = { show: config.delay, hide: config.delay }; } if (typeof config.title === 'number') { config.title = config.title.toString(); } if (typeof config.content === 'number') { config.content = config.content.toString(); } _util2.default.typeCheckConfig(NAME, config, this.constructor.DefaultType); if (config.sanitize) { config.template = (0, _sanitizer.sanitizeHtml)(config.template, config.whiteList, config.sanitizeFn); } return config; } }, { key: "_getDelegateConfig", value: function _getDelegateConfig() { var config = {}; if (this.config) { for (var key in this.config) { if (this.constructor.Default[key] !== this.config[key]) { config[key] = this.config[key]; } } } return config; } }, { key: "_cleanTipClass", value: function _cleanTipClass() { var $tip = (0, _jquery2.default)(this.getTipElement()); var tabClass = $tip.attr('class').match(BSCLS_PREFIX_REGEX); if (tabClass !== null && tabClass.length) { $tip.removeClass(tabClass.join('')); } } }, { key: "_handlePopperPlacementChange", value: function _handlePopperPlacementChange(popperData) { var popperInstance = popperData.instance; this.tip = popperInstance.popper; this._cleanTipClass(); this.addAttachmentClass(this._getAttachment(popperData.placement)); } }, { key: "_fixTransition", value: function _fixTransition() { var tip = this.getTipElement(); var initConfigAnimation = this.config.animation; if (tip.getAttribute('x-placement') !== null) { return; } (0, _jquery2.default)(tip).removeClass(ClassName.FADE); this.config.animation = false; this.hide(); this.show(); this.config.animation = initConfigAnimation; } }], [{ key: "_jQueryInterface", value: function _jQueryInterface(config) { return this.each(function () { var data = (0, _jquery2.default)(this).data(DATA_KEY); var _config = _typeof(config) === 'object' && config; if (!data && /dispose|hide/.test(config)) { return; } if (!data) { data = new Tooltip(this, _config); (0, _jquery2.default)(this).data(DATA_KEY, data); } if (typeof config === 'string') { if (typeof data[config] === 'undefined') { throw new TypeError("No method named \"".concat(config, "\"")); } data[config](); } }); } }, { key: "VERSION", get: function get() { return VERSION; } }, { key: "Default", get: function get() { return Default; } }, { key: "NAME", get: function get() { return NAME; } }, { key: "DATA_KEY", get: function get() { return DATA_KEY; } }, { key: "Event", get: function get() { return Event; } }, { key: "EVENT_KEY", get: function get() { return EVENT_KEY; } }, { key: "DefaultType", get: function get() { return DefaultType; } }]); return Tooltip; }(); /** * ------------------------------------------------------------------------ * jQuery * ------------------------------------------------------------------------ */ _jquery2.default.fn[NAME] = Tooltip._jQueryInterface; _jquery2.default.fn[NAME].Constructor = Tooltip; _jquery2.default.fn[NAME].noConflict = function () { _jquery2.default.fn[NAME] = JQUERY_NO_CONFLICT; return Tooltip._jQueryInterface; }; exports.default = Tooltip; });