bootstrap 4.6.0 → 5.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.github/workflows/ci.yml +61 -0
- data/Gemfile +1 -0
- data/README.md +33 -6
- data/Rakefile +10 -1
- data/assets/javascripts/bootstrap/alert.js +53 -155
- data/assets/javascripts/bootstrap/base-component.js +83 -0
- data/assets/javascripts/bootstrap/button.js +43 -198
- data/assets/javascripts/bootstrap/carousel.js +285 -550
- data/assets/javascripts/bootstrap/collapse.js +169 -323
- data/assets/javascripts/bootstrap/dom/data.js +62 -0
- data/assets/javascripts/bootstrap/dom/event-handler.js +236 -0
- data/assets/javascripts/bootstrap/dom/manipulator.js +71 -0
- data/assets/javascripts/bootstrap/dom/selector-engine.js +103 -0
- data/assets/javascripts/bootstrap/dropdown.js +300 -467
- data/assets/javascripts/bootstrap/modal.js +226 -575
- data/assets/javascripts/bootstrap/offcanvas.js +245 -0
- data/assets/javascripts/bootstrap/popover.js +61 -205
- data/assets/javascripts/bootstrap/scrollspy.js +216 -287
- data/assets/javascripts/bootstrap/tab.js +226 -203
- data/assets/javascripts/bootstrap/toast.js +136 -209
- data/assets/javascripts/bootstrap/tooltip.js +411 -757
- data/assets/javascripts/bootstrap/util/backdrop.js +139 -0
- data/assets/javascripts/bootstrap/util/component-functions.js +41 -0
- data/assets/javascripts/bootstrap/util/config.js +67 -0
- data/assets/javascripts/bootstrap/util/focustrap.js +113 -0
- data/assets/javascripts/bootstrap/util/index.js +281 -0
- data/assets/javascripts/bootstrap/util/sanitizer.js +110 -0
- data/assets/javascripts/bootstrap/util/scrollbar.js +112 -0
- data/assets/javascripts/bootstrap/util/swipe.js +134 -0
- data/assets/javascripts/bootstrap/util/template-factory.js +150 -0
- data/assets/javascripts/bootstrap-global-this-define.js +6 -0
- data/assets/javascripts/bootstrap-global-this-undefine.js +2 -0
- data/assets/javascripts/bootstrap-sprockets.js +23 -7
- data/assets/javascripts/bootstrap.js +3649 -3587
- data/assets/javascripts/bootstrap.min.js +3 -3
- data/assets/stylesheets/_bootstrap-grid.scss +53 -21
- data/assets/stylesheets/_bootstrap-reboot.scss +5 -7
- data/assets/stylesheets/_bootstrap-utilities.scss +19 -0
- data/assets/stylesheets/_bootstrap.scss +21 -13
- data/assets/stylesheets/bootstrap/_accordion.scss +158 -0
- data/assets/stylesheets/bootstrap/_alert.scss +32 -16
- data/assets/stylesheets/bootstrap/_badge.scss +15 -31
- data/assets/stylesheets/bootstrap/_breadcrumb.scss +22 -24
- data/assets/stylesheets/bootstrap/_button-group.scss +27 -48
- data/assets/stylesheets/bootstrap/_buttons.scss +136 -71
- data/assets/stylesheets/bootstrap/_card.scss +66 -113
- data/assets/stylesheets/bootstrap/_carousel.scss +83 -36
- data/assets/stylesheets/bootstrap/_close.scss +51 -28
- data/assets/stylesheets/bootstrap/_containers.scss +41 -0
- data/assets/stylesheets/bootstrap/_dropdown.scss +129 -71
- data/assets/stylesheets/bootstrap/_forms.scss +9 -347
- data/assets/stylesheets/bootstrap/_functions.scss +181 -23
- data/assets/stylesheets/bootstrap/_grid.scss +18 -52
- data/assets/stylesheets/bootstrap/_helpers.scss +12 -0
- data/assets/stylesheets/bootstrap/_images.scss +1 -1
- data/assets/stylesheets/bootstrap/_list-group.scss +77 -34
- data/assets/stylesheets/bootstrap/_maps.scss +174 -0
- data/assets/stylesheets/bootstrap/_mixins.scss +10 -15
- data/assets/stylesheets/bootstrap/_modal.scss +107 -110
- data/assets/stylesheets/bootstrap/_nav.scss +102 -25
- data/assets/stylesheets/bootstrap/_navbar.scss +129 -172
- data/assets/stylesheets/bootstrap/_offcanvas.scss +146 -0
- data/assets/stylesheets/bootstrap/_pagination.scss +72 -37
- data/assets/stylesheets/bootstrap/_placeholders.scss +51 -0
- data/assets/stylesheets/bootstrap/_popover.scss +99 -73
- data/assets/stylesheets/bootstrap/_progress.scss +35 -14
- data/assets/stylesheets/bootstrap/_reboot.scss +319 -192
- data/assets/stylesheets/bootstrap/_root.scss +177 -9
- data/assets/stylesheets/bootstrap/_spinners.scss +44 -24
- data/assets/stylesheets/bootstrap/_tables.scss +101 -115
- data/assets/stylesheets/bootstrap/_toasts.scss +54 -27
- data/assets/stylesheets/bootstrap/_tooltip.scss +67 -63
- data/assets/stylesheets/bootstrap/_transitions.scss +8 -1
- data/assets/stylesheets/bootstrap/_type.scss +40 -59
- data/assets/stylesheets/bootstrap/_utilities.scss +806 -18
- data/assets/stylesheets/bootstrap/_variables-dark.scss +87 -0
- data/assets/stylesheets/bootstrap/_variables.scss +1216 -615
- data/assets/stylesheets/bootstrap/forms/_floating-labels.scss +95 -0
- data/assets/stylesheets/bootstrap/forms/_form-check.scss +189 -0
- data/assets/stylesheets/bootstrap/forms/_form-control.scss +214 -0
- data/assets/stylesheets/bootstrap/forms/_form-range.scss +91 -0
- data/assets/stylesheets/bootstrap/forms/_form-select.scss +80 -0
- data/assets/stylesheets/bootstrap/forms/_form-text.scss +11 -0
- data/assets/stylesheets/bootstrap/forms/_input-group.scss +132 -0
- data/assets/stylesheets/bootstrap/forms/_labels.scss +36 -0
- data/assets/stylesheets/bootstrap/forms/_validation.scss +12 -0
- data/assets/stylesheets/bootstrap/helpers/_color-bg.scss +7 -0
- data/assets/stylesheets/bootstrap/helpers/_colored-links.scss +30 -0
- data/assets/stylesheets/bootstrap/helpers/_focus-ring.scss +5 -0
- data/assets/stylesheets/bootstrap/helpers/_icon-link.scss +25 -0
- data/assets/stylesheets/bootstrap/helpers/_position.scss +36 -0
- data/assets/stylesheets/bootstrap/helpers/_ratio.scss +26 -0
- data/assets/stylesheets/bootstrap/helpers/_stacks.scss +15 -0
- data/assets/stylesheets/bootstrap/helpers/_stretched-link.scss +15 -0
- data/assets/stylesheets/bootstrap/helpers/_text-truncation.scss +7 -0
- data/assets/stylesheets/bootstrap/helpers/_visually-hidden.scss +8 -0
- data/assets/stylesheets/bootstrap/helpers/_vr.scss +8 -0
- data/assets/stylesheets/bootstrap/mixins/_alert.scss +11 -6
- data/assets/stylesheets/bootstrap/mixins/_backdrop.scss +14 -0
- data/assets/stylesheets/bootstrap/mixins/_banner.scss +7 -0
- data/assets/stylesheets/bootstrap/mixins/_border-radius.scss +10 -8
- data/assets/stylesheets/bootstrap/mixins/_box-shadow.scss +7 -9
- data/assets/stylesheets/bootstrap/mixins/_breakpoints.scss +20 -16
- data/assets/stylesheets/bootstrap/mixins/_buttons.scss +60 -100
- data/assets/stylesheets/bootstrap/mixins/_caret.scss +34 -27
- data/assets/stylesheets/bootstrap/mixins/_clearfix.scss +2 -0
- data/assets/stylesheets/bootstrap/mixins/_color-mode.scss +21 -0
- data/assets/stylesheets/bootstrap/mixins/_color-scheme.scss +7 -0
- data/assets/stylesheets/bootstrap/mixins/_container.scss +11 -0
- data/assets/stylesheets/bootstrap/mixins/_forms.scss +53 -85
- data/assets/stylesheets/bootstrap/mixins/_gradients.scss +13 -11
- data/assets/stylesheets/bootstrap/mixins/_grid.scss +119 -37
- data/assets/stylesheets/bootstrap/mixins/_image.scss +1 -21
- data/assets/stylesheets/bootstrap/mixins/_list-group.scss +7 -2
- data/assets/stylesheets/bootstrap/mixins/_lists.scss +1 -1
- data/assets/stylesheets/bootstrap/mixins/_pagination.scss +7 -19
- data/assets/stylesheets/bootstrap/mixins/_reset-text.scss +3 -3
- data/assets/stylesheets/bootstrap/mixins/_table-variants.scss +24 -0
- data/assets/stylesheets/bootstrap/mixins/_transition.scss +1 -1
- data/assets/stylesheets/bootstrap/mixins/_utilities.scss +97 -0
- data/assets/stylesheets/bootstrap/mixins/_visually-hidden.scss +33 -0
- data/assets/stylesheets/bootstrap/utilities/_api.scss +47 -0
- data/assets/stylesheets/bootstrap/vendor/_rfs.scss +276 -132
- data/bootstrap.gemspec +6 -7
- data/lib/bootstrap/engine.rb +7 -1
- data/lib/bootstrap/version.rb +2 -2
- data/tasks/updater/js.rb +31 -7
- data/tasks/updater/network.rb +9 -3
- data/tasks/updater/scss.rb +2 -2
- data/tasks/updater.rb +2 -2
- data/test/dummy_rails/app/assets/javascripts/application.js +4 -3
- data/test/dummy_rails/app/views/layouts/application.html.erb +3 -1
- data/test/dummy_rails/app/views/pages/root.html +89 -0
- data/test/dummy_rails/config/application.rb +0 -3
- data/test/gemfiles/rails_4_2.gemfile +1 -1
- data/test/gemfiles/rails_5_0.gemfile +1 -1
- data/test/gemfiles/rails_5_1.gemfile +1 -1
- data/test/gemfiles/rails_5_2.gemfile +8 -0
- data/test/gemfiles/rails_6_0.gemfile +1 -0
- data/test/gemfiles/rails_6_1.gemfile +8 -0
- data/test/gemfiles/rails_7_0_dartsass.gemfile +8 -0
- data/test/gemfiles/rails_7_0_sassc.gemfile +8 -0
- data/test/test_helper.rb +3 -2
- metadata +97 -85
- data/.travis.yml +0 -31
- data/assets/javascripts/bootstrap/util.js +0 -192
- data/assets/stylesheets/bootstrap/_code.scss +0 -48
- data/assets/stylesheets/bootstrap/_custom-forms.scss +0 -526
- data/assets/stylesheets/bootstrap/_input-group.scss +0 -208
- data/assets/stylesheets/bootstrap/_jumbotron.scss +0 -17
- data/assets/stylesheets/bootstrap/_media.scss +0 -8
- data/assets/stylesheets/bootstrap/_print.scss +0 -141
- data/assets/stylesheets/bootstrap/mixins/_background-variant.scss +0 -23
- data/assets/stylesheets/bootstrap/mixins/_badge.scss +0 -17
- data/assets/stylesheets/bootstrap/mixins/_float.scss +0 -14
- data/assets/stylesheets/bootstrap/mixins/_grid-framework.scss +0 -80
- data/assets/stylesheets/bootstrap/mixins/_hover.scss +0 -37
- data/assets/stylesheets/bootstrap/mixins/_nav-divider.scss +0 -11
- data/assets/stylesheets/bootstrap/mixins/_screen-reader.scss +0 -34
- data/assets/stylesheets/bootstrap/mixins/_size.scss +0 -7
- data/assets/stylesheets/bootstrap/mixins/_table-row.scss +0 -39
- data/assets/stylesheets/bootstrap/mixins/_text-emphasis.scss +0 -17
- data/assets/stylesheets/bootstrap/mixins/_text-hide.scss +0 -11
- data/assets/stylesheets/bootstrap/mixins/_visibility.scss +0 -8
- data/assets/stylesheets/bootstrap/utilities/_align.scss +0 -8
- data/assets/stylesheets/bootstrap/utilities/_background.scss +0 -19
- data/assets/stylesheets/bootstrap/utilities/_borders.scss +0 -75
- data/assets/stylesheets/bootstrap/utilities/_display.scss +0 -26
- data/assets/stylesheets/bootstrap/utilities/_embed.scss +0 -39
- data/assets/stylesheets/bootstrap/utilities/_flex.scss +0 -51
- data/assets/stylesheets/bootstrap/utilities/_float.scss +0 -11
- data/assets/stylesheets/bootstrap/utilities/_interactions.scss +0 -5
- data/assets/stylesheets/bootstrap/utilities/_overflow.scss +0 -5
- data/assets/stylesheets/bootstrap/utilities/_position.scss +0 -32
- data/assets/stylesheets/bootstrap/utilities/_screenreaders.scss +0 -11
- data/assets/stylesheets/bootstrap/utilities/_shadows.scss +0 -6
- data/assets/stylesheets/bootstrap/utilities/_sizing.scss +0 -20
- data/assets/stylesheets/bootstrap/utilities/_spacing.scss +0 -73
- data/assets/stylesheets/bootstrap/utilities/_stretched-link.scss +0 -19
- data/assets/stylesheets/bootstrap/utilities/_text.scss +0 -72
- data/assets/stylesheets/bootstrap/utilities/_visibility.scss +0 -13
- data/test/dummy_rails/app/views/pages/root.html.slim +0 -58
- /data/assets/stylesheets/bootstrap/{utilities → helpers}/_clearfix.scss +0 -0
|
@@ -1,891 +1,545 @@
|
|
|
1
1
|
/*!
|
|
2
|
-
* Bootstrap tooltip.js
|
|
3
|
-
* Copyright 2011-
|
|
2
|
+
* Bootstrap tooltip.js v5.3.2 (https://getbootstrap.com/)
|
|
3
|
+
* Copyright 2011-2023 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors)
|
|
4
4
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
|
|
5
5
|
*/
|
|
6
6
|
(function (global, factory) {
|
|
7
|
-
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('
|
|
8
|
-
typeof define === 'function' && define.amd ? define(['
|
|
9
|
-
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.Tooltip = factory(global.
|
|
10
|
-
}(this, (function (
|
|
11
|
-
|
|
12
|
-
function
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
descriptor.configurable = true;
|
|
23
|
-
if ("value" in descriptor) descriptor.writable = true;
|
|
24
|
-
Object.defineProperty(target, descriptor.key, descriptor);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
function _createClass(Constructor, protoProps, staticProps) {
|
|
29
|
-
if (protoProps) _defineProperties(Constructor.prototype, protoProps);
|
|
30
|
-
if (staticProps) _defineProperties(Constructor, staticProps);
|
|
31
|
-
return Constructor;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
function _extends() {
|
|
35
|
-
_extends = Object.assign || function (target) {
|
|
36
|
-
for (var i = 1; i < arguments.length; i++) {
|
|
37
|
-
var source = arguments[i];
|
|
38
|
-
|
|
39
|
-
for (var key in source) {
|
|
40
|
-
if (Object.prototype.hasOwnProperty.call(source, key)) {
|
|
41
|
-
target[key] = source[key];
|
|
42
|
-
}
|
|
7
|
+
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('@popperjs/core'), require('./base-component.js'), require('./dom/event-handler.js'), require('./dom/manipulator.js'), require('./util/index.js'), require('./util/sanitizer.js'), require('./util/template-factory.js')) :
|
|
8
|
+
typeof define === 'function' && define.amd ? define(['@popperjs/core', './base-component', './dom/event-handler', './dom/manipulator', './util/index', './util/sanitizer', './util/template-factory'], factory) :
|
|
9
|
+
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.Tooltip = factory(global["@popperjs/core"], global.BaseComponent, global.EventHandler, global.Manipulator, global.Index, global.Sanitizer, global.TemplateFactory));
|
|
10
|
+
})(this, (function (Popper, BaseComponent, EventHandler, Manipulator, index_js, sanitizer_js, TemplateFactory) { 'use strict';
|
|
11
|
+
|
|
12
|
+
function _interopNamespaceDefault(e) {
|
|
13
|
+
const n = Object.create(null, { [Symbol.toStringTag]: { value: 'Module' } });
|
|
14
|
+
if (e) {
|
|
15
|
+
for (const k in e) {
|
|
16
|
+
if (k !== 'default') {
|
|
17
|
+
const d = Object.getOwnPropertyDescriptor(e, k);
|
|
18
|
+
Object.defineProperty(n, k, d.get ? d : {
|
|
19
|
+
enumerable: true,
|
|
20
|
+
get: () => e[k]
|
|
21
|
+
});
|
|
43
22
|
}
|
|
44
23
|
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
return _extends.apply(this, arguments);
|
|
24
|
+
}
|
|
25
|
+
n.default = e;
|
|
26
|
+
return Object.freeze(n);
|
|
50
27
|
}
|
|
51
28
|
|
|
29
|
+
const Popper__namespace = /*#__PURE__*/_interopNamespaceDefault(Popper);
|
|
30
|
+
|
|
52
31
|
/**
|
|
53
32
|
* --------------------------------------------------------------------------
|
|
54
|
-
* Bootstrap
|
|
33
|
+
* Bootstrap tooltip.js
|
|
55
34
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
|
|
56
35
|
* --------------------------------------------------------------------------
|
|
57
36
|
*/
|
|
58
|
-
var uriAttrs = ['background', 'cite', 'href', 'itemtype', 'longdesc', 'poster', 'src', 'xlink:href'];
|
|
59
|
-
var ARIA_ATTRIBUTE_PATTERN = /^aria-[\w-]*$/i;
|
|
60
|
-
var DefaultWhitelist = {
|
|
61
|
-
// Global attributes allowed on any supplied element below.
|
|
62
|
-
'*': ['class', 'dir', 'id', 'lang', 'role', ARIA_ATTRIBUTE_PATTERN],
|
|
63
|
-
a: ['target', 'href', 'title', 'rel'],
|
|
64
|
-
area: [],
|
|
65
|
-
b: [],
|
|
66
|
-
br: [],
|
|
67
|
-
col: [],
|
|
68
|
-
code: [],
|
|
69
|
-
div: [],
|
|
70
|
-
em: [],
|
|
71
|
-
hr: [],
|
|
72
|
-
h1: [],
|
|
73
|
-
h2: [],
|
|
74
|
-
h3: [],
|
|
75
|
-
h4: [],
|
|
76
|
-
h5: [],
|
|
77
|
-
h6: [],
|
|
78
|
-
i: [],
|
|
79
|
-
img: ['src', 'srcset', 'alt', 'title', 'width', 'height'],
|
|
80
|
-
li: [],
|
|
81
|
-
ol: [],
|
|
82
|
-
p: [],
|
|
83
|
-
pre: [],
|
|
84
|
-
s: [],
|
|
85
|
-
small: [],
|
|
86
|
-
span: [],
|
|
87
|
-
sub: [],
|
|
88
|
-
sup: [],
|
|
89
|
-
strong: [],
|
|
90
|
-
u: [],
|
|
91
|
-
ul: []
|
|
92
|
-
};
|
|
93
|
-
/**
|
|
94
|
-
* A pattern that recognizes a commonly useful subset of URLs that are safe.
|
|
95
|
-
*
|
|
96
|
-
* Shoutout to Angular 7 https://github.com/angular/angular/blob/7.2.4/packages/core/src/sanitization/url_sanitizer.ts
|
|
97
|
-
*/
|
|
98
|
-
|
|
99
|
-
var SAFE_URL_PATTERN = /^(?:(?:https?|mailto|ftp|tel|file):|[^#&/:?]*(?:[#/?]|$))/gi;
|
|
100
|
-
/**
|
|
101
|
-
* A pattern that matches safe data URLs. Only matches image, video and audio types.
|
|
102
|
-
*
|
|
103
|
-
* Shoutout to Angular 7 https://github.com/angular/angular/blob/7.2.4/packages/core/src/sanitization/url_sanitizer.ts
|
|
104
|
-
*/
|
|
105
|
-
|
|
106
|
-
var DATA_URL_PATTERN = /^data:(?:image\/(?:bmp|gif|jpeg|jpg|png|tiff|webp)|video\/(?:mpeg|mp4|ogg|webm)|audio\/(?:mp3|oga|ogg|opus));base64,[\d+/a-z]+=*$/i;
|
|
107
|
-
|
|
108
|
-
function allowedAttribute(attr, allowedAttributeList) {
|
|
109
|
-
var attrName = attr.nodeName.toLowerCase();
|
|
110
|
-
|
|
111
|
-
if (allowedAttributeList.indexOf(attrName) !== -1) {
|
|
112
|
-
if (uriAttrs.indexOf(attrName) !== -1) {
|
|
113
|
-
return Boolean(attr.nodeValue.match(SAFE_URL_PATTERN) || attr.nodeValue.match(DATA_URL_PATTERN));
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
return true;
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
var regExp = allowedAttributeList.filter(function (attrRegex) {
|
|
120
|
-
return attrRegex instanceof RegExp;
|
|
121
|
-
}); // Check if a regular expression validates the attribute.
|
|
122
|
-
|
|
123
|
-
for (var i = 0, len = regExp.length; i < len; i++) {
|
|
124
|
-
if (attrName.match(regExp[i])) {
|
|
125
|
-
return true;
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
return false;
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
function sanitizeHtml(unsafeHtml, whiteList, sanitizeFn) {
|
|
133
|
-
if (unsafeHtml.length === 0) {
|
|
134
|
-
return unsafeHtml;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
if (sanitizeFn && typeof sanitizeFn === 'function') {
|
|
138
|
-
return sanitizeFn(unsafeHtml);
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
var domParser = new window.DOMParser();
|
|
142
|
-
var createdDocument = domParser.parseFromString(unsafeHtml, 'text/html');
|
|
143
|
-
var whitelistKeys = Object.keys(whiteList);
|
|
144
|
-
var elements = [].slice.call(createdDocument.body.querySelectorAll('*'));
|
|
145
|
-
|
|
146
|
-
var _loop = function _loop(i, len) {
|
|
147
|
-
var el = elements[i];
|
|
148
|
-
var elName = el.nodeName.toLowerCase();
|
|
149
|
-
|
|
150
|
-
if (whitelistKeys.indexOf(el.nodeName.toLowerCase()) === -1) {
|
|
151
|
-
el.parentNode.removeChild(el);
|
|
152
|
-
return "continue";
|
|
153
|
-
}
|
|
154
37
|
|
|
155
|
-
var attributeList = [].slice.call(el.attributes);
|
|
156
|
-
var whitelistedAttributes = [].concat(whiteList['*'] || [], whiteList[elName] || []);
|
|
157
|
-
attributeList.forEach(function (attr) {
|
|
158
|
-
if (!allowedAttribute(attr, whitelistedAttributes)) {
|
|
159
|
-
el.removeAttribute(attr.nodeName);
|
|
160
|
-
}
|
|
161
|
-
});
|
|
162
|
-
};
|
|
163
|
-
|
|
164
|
-
for (var i = 0, len = elements.length; i < len; i++) {
|
|
165
|
-
var _ret = _loop(i);
|
|
166
|
-
|
|
167
|
-
if (_ret === "continue") continue;
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
return createdDocument.body.innerHTML;
|
|
171
|
-
}
|
|
172
38
|
|
|
173
39
|
/**
|
|
174
|
-
* ------------------------------------------------------------------------
|
|
175
40
|
* Constants
|
|
176
|
-
* ------------------------------------------------------------------------
|
|
177
41
|
*/
|
|
178
42
|
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
sanitizeFn: '(null|function)',
|
|
203
|
-
whiteList: 'object',
|
|
204
|
-
popperConfig: '(null|object)'
|
|
205
|
-
};
|
|
206
|
-
var AttachmentMap = {
|
|
43
|
+
const NAME = 'tooltip';
|
|
44
|
+
const DISALLOWED_ATTRIBUTES = new Set(['sanitize', 'allowList', 'sanitizeFn']);
|
|
45
|
+
const CLASS_NAME_FADE = 'fade';
|
|
46
|
+
const CLASS_NAME_MODAL = 'modal';
|
|
47
|
+
const CLASS_NAME_SHOW = 'show';
|
|
48
|
+
const SELECTOR_TOOLTIP_INNER = '.tooltip-inner';
|
|
49
|
+
const SELECTOR_MODAL = `.${CLASS_NAME_MODAL}`;
|
|
50
|
+
const EVENT_MODAL_HIDE = 'hide.bs.modal';
|
|
51
|
+
const TRIGGER_HOVER = 'hover';
|
|
52
|
+
const TRIGGER_FOCUS = 'focus';
|
|
53
|
+
const TRIGGER_CLICK = 'click';
|
|
54
|
+
const TRIGGER_MANUAL = 'manual';
|
|
55
|
+
const EVENT_HIDE = 'hide';
|
|
56
|
+
const EVENT_HIDDEN = 'hidden';
|
|
57
|
+
const EVENT_SHOW = 'show';
|
|
58
|
+
const EVENT_SHOWN = 'shown';
|
|
59
|
+
const EVENT_INSERTED = 'inserted';
|
|
60
|
+
const EVENT_CLICK = 'click';
|
|
61
|
+
const EVENT_FOCUSIN = 'focusin';
|
|
62
|
+
const EVENT_FOCUSOUT = 'focusout';
|
|
63
|
+
const EVENT_MOUSEENTER = 'mouseenter';
|
|
64
|
+
const EVENT_MOUSELEAVE = 'mouseleave';
|
|
65
|
+
const AttachmentMap = {
|
|
207
66
|
AUTO: 'auto',
|
|
208
67
|
TOP: 'top',
|
|
209
|
-
RIGHT: 'right',
|
|
68
|
+
RIGHT: index_js.isRTL() ? 'left' : 'right',
|
|
210
69
|
BOTTOM: 'bottom',
|
|
211
|
-
LEFT: 'left'
|
|
70
|
+
LEFT: index_js.isRTL() ? 'right' : 'left'
|
|
212
71
|
};
|
|
213
|
-
|
|
72
|
+
const Default = {
|
|
73
|
+
allowList: sanitizer_js.DefaultAllowlist,
|
|
214
74
|
animation: true,
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
75
|
+
boundary: 'clippingParents',
|
|
76
|
+
container: false,
|
|
77
|
+
customClass: '',
|
|
218
78
|
delay: 0,
|
|
79
|
+
fallbackPlacements: ['top', 'right', 'bottom', 'left'],
|
|
219
80
|
html: false,
|
|
220
|
-
|
|
81
|
+
offset: [0, 6],
|
|
221
82
|
placement: 'top',
|
|
222
|
-
|
|
223
|
-
container: false,
|
|
224
|
-
fallbackPlacement: 'flip',
|
|
225
|
-
boundary: 'scrollParent',
|
|
226
|
-
customClass: '',
|
|
83
|
+
popperConfig: null,
|
|
227
84
|
sanitize: true,
|
|
228
85
|
sanitizeFn: null,
|
|
229
|
-
|
|
230
|
-
|
|
86
|
+
selector: false,
|
|
87
|
+
template: '<div class="tooltip" role="tooltip">' + '<div class="tooltip-arrow"></div>' + '<div class="tooltip-inner"></div>' + '</div>',
|
|
88
|
+
title: '',
|
|
89
|
+
trigger: 'hover focus'
|
|
231
90
|
};
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
91
|
+
const DefaultType = {
|
|
92
|
+
allowList: 'object',
|
|
93
|
+
animation: 'boolean',
|
|
94
|
+
boundary: '(string|element)',
|
|
95
|
+
container: '(string|element|boolean)',
|
|
96
|
+
customClass: '(string|function)',
|
|
97
|
+
delay: '(number|object)',
|
|
98
|
+
fallbackPlacements: 'array',
|
|
99
|
+
html: 'boolean',
|
|
100
|
+
offset: '(array|string|function)',
|
|
101
|
+
placement: '(string|function)',
|
|
102
|
+
popperConfig: '(null|object|function)',
|
|
103
|
+
sanitize: 'boolean',
|
|
104
|
+
sanitizeFn: '(null|function)',
|
|
105
|
+
selector: '(string|boolean)',
|
|
106
|
+
template: 'string',
|
|
107
|
+
title: '(string|element|function)',
|
|
108
|
+
trigger: 'string'
|
|
245
109
|
};
|
|
246
|
-
|
|
247
|
-
var CLASS_NAME_SHOW = 'show';
|
|
248
|
-
var SELECTOR_TOOLTIP_INNER = '.tooltip-inner';
|
|
249
|
-
var SELECTOR_ARROW = '.arrow';
|
|
250
|
-
var TRIGGER_HOVER = 'hover';
|
|
251
|
-
var TRIGGER_FOCUS = 'focus';
|
|
252
|
-
var TRIGGER_CLICK = 'click';
|
|
253
|
-
var TRIGGER_MANUAL = 'manual';
|
|
110
|
+
|
|
254
111
|
/**
|
|
255
|
-
*
|
|
256
|
-
* Class Definition
|
|
257
|
-
* ------------------------------------------------------------------------
|
|
112
|
+
* Class definition
|
|
258
113
|
*/
|
|
259
114
|
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
if (typeof
|
|
115
|
+
class Tooltip extends BaseComponent {
|
|
116
|
+
constructor(element, config) {
|
|
117
|
+
if (typeof Popper__namespace === 'undefined') {
|
|
263
118
|
throw new TypeError('Bootstrap\'s tooltips require Popper (https://popper.js.org)');
|
|
264
|
-
}
|
|
265
|
-
|
|
119
|
+
}
|
|
120
|
+
super(element, config);
|
|
266
121
|
|
|
122
|
+
// Private
|
|
267
123
|
this._isEnabled = true;
|
|
268
124
|
this._timeout = 0;
|
|
269
|
-
this.
|
|
125
|
+
this._isHovered = null;
|
|
270
126
|
this._activeTrigger = {};
|
|
271
|
-
this._popper = null;
|
|
127
|
+
this._popper = null;
|
|
128
|
+
this._templateFactory = null;
|
|
129
|
+
this._newContent = null;
|
|
272
130
|
|
|
273
|
-
|
|
274
|
-
this.config = this._getConfig(config);
|
|
131
|
+
// Protected
|
|
275
132
|
this.tip = null;
|
|
276
|
-
|
|
277
133
|
this._setListeners();
|
|
278
|
-
|
|
279
|
-
|
|
134
|
+
if (!this._config.selector) {
|
|
135
|
+
this._fixTitle();
|
|
136
|
+
}
|
|
137
|
+
}
|
|
280
138
|
|
|
281
|
-
|
|
139
|
+
// Getters
|
|
140
|
+
static get Default() {
|
|
141
|
+
return Default;
|
|
142
|
+
}
|
|
143
|
+
static get DefaultType() {
|
|
144
|
+
return DefaultType;
|
|
145
|
+
}
|
|
146
|
+
static get NAME() {
|
|
147
|
+
return NAME;
|
|
148
|
+
}
|
|
282
149
|
|
|
283
150
|
// Public
|
|
284
|
-
|
|
151
|
+
enable() {
|
|
285
152
|
this._isEnabled = true;
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
_proto.disable = function disable() {
|
|
153
|
+
}
|
|
154
|
+
disable() {
|
|
289
155
|
this._isEnabled = false;
|
|
290
|
-
}
|
|
291
|
-
|
|
292
|
-
_proto.toggleEnabled = function toggleEnabled() {
|
|
156
|
+
}
|
|
157
|
+
toggleEnabled() {
|
|
293
158
|
this._isEnabled = !this._isEnabled;
|
|
294
|
-
}
|
|
295
|
-
|
|
296
|
-
_proto.toggle = function toggle(event) {
|
|
159
|
+
}
|
|
160
|
+
toggle() {
|
|
297
161
|
if (!this._isEnabled) {
|
|
298
162
|
return;
|
|
299
163
|
}
|
|
300
|
-
|
|
301
|
-
if (
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
if (!context) {
|
|
306
|
-
context = new this.constructor(event.currentTarget, this._getDelegateConfig());
|
|
307
|
-
$__default['default'](event.currentTarget).data(dataKey, context);
|
|
308
|
-
}
|
|
309
|
-
|
|
310
|
-
context._activeTrigger.click = !context._activeTrigger.click;
|
|
311
|
-
|
|
312
|
-
if (context._isWithActiveTrigger()) {
|
|
313
|
-
context._enter(null, context);
|
|
314
|
-
} else {
|
|
315
|
-
context._leave(null, context);
|
|
316
|
-
}
|
|
317
|
-
} else {
|
|
318
|
-
if ($__default['default'](this.getTipElement()).hasClass(CLASS_NAME_SHOW)) {
|
|
319
|
-
this._leave(null, this);
|
|
320
|
-
|
|
321
|
-
return;
|
|
322
|
-
}
|
|
323
|
-
|
|
324
|
-
this._enter(null, this);
|
|
164
|
+
this._activeTrigger.click = !this._activeTrigger.click;
|
|
165
|
+
if (this._isShown()) {
|
|
166
|
+
this._leave();
|
|
167
|
+
return;
|
|
325
168
|
}
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
169
|
+
this._enter();
|
|
170
|
+
}
|
|
171
|
+
dispose() {
|
|
329
172
|
clearTimeout(this._timeout);
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
if (this.tip) {
|
|
335
|
-
$__default['default'](this.tip).remove();
|
|
336
|
-
}
|
|
337
|
-
|
|
338
|
-
this._isEnabled = null;
|
|
339
|
-
this._timeout = null;
|
|
340
|
-
this._hoverState = null;
|
|
341
|
-
this._activeTrigger = null;
|
|
342
|
-
|
|
343
|
-
if (this._popper) {
|
|
344
|
-
this._popper.destroy();
|
|
173
|
+
EventHandler.off(this._element.closest(SELECTOR_MODAL), EVENT_MODAL_HIDE, this._hideModalHandler);
|
|
174
|
+
if (this._element.getAttribute('data-bs-original-title')) {
|
|
175
|
+
this._element.setAttribute('title', this._element.getAttribute('data-bs-original-title'));
|
|
345
176
|
}
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
this.
|
|
351
|
-
};
|
|
352
|
-
|
|
353
|
-
_proto.show = function show() {
|
|
354
|
-
var _this = this;
|
|
355
|
-
|
|
356
|
-
if ($__default['default'](this.element).css('display') === 'none') {
|
|
177
|
+
this._disposePopper();
|
|
178
|
+
super.dispose();
|
|
179
|
+
}
|
|
180
|
+
show() {
|
|
181
|
+
if (this._element.style.display === 'none') {
|
|
357
182
|
throw new Error('Please use show on visible elements');
|
|
358
183
|
}
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
if (showEvent.isDefaultPrevented() || !isInTheDom) {
|
|
368
|
-
return;
|
|
369
|
-
}
|
|
370
|
-
|
|
371
|
-
var tip = this.getTipElement();
|
|
372
|
-
var tipId = Util__default['default'].getUID(this.constructor.NAME);
|
|
373
|
-
tip.setAttribute('id', tipId);
|
|
374
|
-
this.element.setAttribute('aria-describedby', tipId);
|
|
375
|
-
this.setContent();
|
|
376
|
-
|
|
377
|
-
if (this.config.animation) {
|
|
378
|
-
$__default['default'](tip).addClass(CLASS_NAME_FADE);
|
|
379
|
-
}
|
|
380
|
-
|
|
381
|
-
var placement = typeof this.config.placement === 'function' ? this.config.placement.call(this, tip, this.element) : this.config.placement;
|
|
382
|
-
|
|
383
|
-
var attachment = this._getAttachment(placement);
|
|
384
|
-
|
|
385
|
-
this.addAttachmentClass(attachment);
|
|
386
|
-
|
|
387
|
-
var container = this._getContainer();
|
|
388
|
-
|
|
389
|
-
$__default['default'](tip).data(this.constructor.DATA_KEY, this);
|
|
390
|
-
|
|
391
|
-
if (!$__default['default'].contains(this.element.ownerDocument.documentElement, this.tip)) {
|
|
392
|
-
$__default['default'](tip).appendTo(container);
|
|
393
|
-
}
|
|
394
|
-
|
|
395
|
-
$__default['default'](this.element).trigger(this.constructor.Event.INSERTED);
|
|
396
|
-
this._popper = new Popper__default['default'](this.element, tip, this._getPopperConfig(attachment));
|
|
397
|
-
$__default['default'](tip).addClass(CLASS_NAME_SHOW);
|
|
398
|
-
$__default['default'](tip).addClass(this.config.customClass); // If this is a touch-enabled device we add extra
|
|
399
|
-
// empty mouseover listeners to the body's immediate children;
|
|
400
|
-
// only needed because of broken event delegation on iOS
|
|
401
|
-
// https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html
|
|
402
|
-
|
|
403
|
-
if ('ontouchstart' in document.documentElement) {
|
|
404
|
-
$__default['default'](document.body).children().on('mouseover', null, $__default['default'].noop);
|
|
405
|
-
}
|
|
406
|
-
|
|
407
|
-
var complete = function complete() {
|
|
408
|
-
if (_this.config.animation) {
|
|
409
|
-
_this._fixTransition();
|
|
410
|
-
}
|
|
411
|
-
|
|
412
|
-
var prevHoverState = _this._hoverState;
|
|
413
|
-
_this._hoverState = null;
|
|
414
|
-
$__default['default'](_this.element).trigger(_this.constructor.Event.SHOWN);
|
|
415
|
-
|
|
416
|
-
if (prevHoverState === HOVER_STATE_OUT) {
|
|
417
|
-
_this._leave(null, _this);
|
|
418
|
-
}
|
|
419
|
-
};
|
|
420
|
-
|
|
421
|
-
if ($__default['default'](this.tip).hasClass(CLASS_NAME_FADE)) {
|
|
422
|
-
var transitionDuration = Util__default['default'].getTransitionDurationFromElement(this.tip);
|
|
423
|
-
$__default['default'](this.tip).one(Util__default['default'].TRANSITION_END, complete).emulateTransitionEnd(transitionDuration);
|
|
424
|
-
} else {
|
|
425
|
-
complete();
|
|
426
|
-
}
|
|
184
|
+
if (!(this._isWithContent() && this._isEnabled)) {
|
|
185
|
+
return;
|
|
186
|
+
}
|
|
187
|
+
const showEvent = EventHandler.trigger(this._element, this.constructor.eventName(EVENT_SHOW));
|
|
188
|
+
const shadowRoot = index_js.findShadowRoot(this._element);
|
|
189
|
+
const isInTheDom = (shadowRoot || this._element.ownerDocument.documentElement).contains(this._element);
|
|
190
|
+
if (showEvent.defaultPrevented || !isInTheDom) {
|
|
191
|
+
return;
|
|
427
192
|
}
|
|
428
|
-
};
|
|
429
|
-
|
|
430
|
-
_proto.hide = function hide(callback) {
|
|
431
|
-
var _this2 = this;
|
|
432
|
-
|
|
433
|
-
var tip = this.getTipElement();
|
|
434
|
-
var hideEvent = $__default['default'].Event(this.constructor.Event.HIDE);
|
|
435
|
-
|
|
436
|
-
var complete = function complete() {
|
|
437
|
-
if (_this2._hoverState !== HOVER_STATE_SHOW && tip.parentNode) {
|
|
438
|
-
tip.parentNode.removeChild(tip);
|
|
439
|
-
}
|
|
440
|
-
|
|
441
|
-
_this2._cleanTipClass();
|
|
442
|
-
|
|
443
|
-
_this2.element.removeAttribute('aria-describedby');
|
|
444
|
-
|
|
445
|
-
$__default['default'](_this2.element).trigger(_this2.constructor.Event.HIDDEN);
|
|
446
193
|
|
|
447
|
-
|
|
448
|
-
|
|
194
|
+
// TODO: v6 remove this or make it optional
|
|
195
|
+
this._disposePopper();
|
|
196
|
+
const tip = this._getTipElement();
|
|
197
|
+
this._element.setAttribute('aria-describedby', tip.getAttribute('id'));
|
|
198
|
+
const {
|
|
199
|
+
container
|
|
200
|
+
} = this._config;
|
|
201
|
+
if (!this._element.ownerDocument.documentElement.contains(this.tip)) {
|
|
202
|
+
container.append(tip);
|
|
203
|
+
EventHandler.trigger(this._element, this.constructor.eventName(EVENT_INSERTED));
|
|
204
|
+
}
|
|
205
|
+
this._popper = this._createPopper(tip);
|
|
206
|
+
tip.classList.add(CLASS_NAME_SHOW);
|
|
207
|
+
|
|
208
|
+
// If this is a touch-enabled device we add extra
|
|
209
|
+
// empty mouseover listeners to the body's immediate children;
|
|
210
|
+
// only needed because of broken event delegation on iOS
|
|
211
|
+
// https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html
|
|
212
|
+
if ('ontouchstart' in document.documentElement) {
|
|
213
|
+
for (const element of [].concat(...document.body.children)) {
|
|
214
|
+
EventHandler.on(element, 'mouseover', index_js.noop);
|
|
449
215
|
}
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
216
|
+
}
|
|
217
|
+
const complete = () => {
|
|
218
|
+
EventHandler.trigger(this._element, this.constructor.eventName(EVENT_SHOWN));
|
|
219
|
+
if (this._isHovered === false) {
|
|
220
|
+
this._leave();
|
|
453
221
|
}
|
|
222
|
+
this._isHovered = false;
|
|
454
223
|
};
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
if (
|
|
224
|
+
this._queueCallback(complete, this.tip, this._isAnimated());
|
|
225
|
+
}
|
|
226
|
+
hide() {
|
|
227
|
+
if (!this._isShown()) {
|
|
459
228
|
return;
|
|
460
229
|
}
|
|
230
|
+
const hideEvent = EventHandler.trigger(this._element, this.constructor.eventName(EVENT_HIDE));
|
|
231
|
+
if (hideEvent.defaultPrevented) {
|
|
232
|
+
return;
|
|
233
|
+
}
|
|
234
|
+
const tip = this._getTipElement();
|
|
235
|
+
tip.classList.remove(CLASS_NAME_SHOW);
|
|
461
236
|
|
|
462
|
-
|
|
237
|
+
// If this is a touch-enabled device we remove the extra
|
|
463
238
|
// empty mouseover listeners we added for iOS support
|
|
464
|
-
|
|
465
239
|
if ('ontouchstart' in document.documentElement) {
|
|
466
|
-
|
|
240
|
+
for (const element of [].concat(...document.body.children)) {
|
|
241
|
+
EventHandler.off(element, 'mouseover', index_js.noop);
|
|
242
|
+
}
|
|
467
243
|
}
|
|
468
|
-
|
|
469
244
|
this._activeTrigger[TRIGGER_CLICK] = false;
|
|
470
245
|
this._activeTrigger[TRIGGER_FOCUS] = false;
|
|
471
246
|
this._activeTrigger[TRIGGER_HOVER] = false;
|
|
247
|
+
this._isHovered = null; // it is a trick to support manual triggering
|
|
472
248
|
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
249
|
+
const complete = () => {
|
|
250
|
+
if (this._isWithActiveTrigger()) {
|
|
251
|
+
return;
|
|
252
|
+
}
|
|
253
|
+
if (!this._isHovered) {
|
|
254
|
+
this._disposePopper();
|
|
255
|
+
}
|
|
256
|
+
this._element.removeAttribute('aria-describedby');
|
|
257
|
+
EventHandler.trigger(this._element, this.constructor.eventName(EVENT_HIDDEN));
|
|
258
|
+
};
|
|
259
|
+
this._queueCallback(complete, this.tip, this._isAnimated());
|
|
260
|
+
}
|
|
261
|
+
update() {
|
|
262
|
+
if (this._popper) {
|
|
263
|
+
this._popper.update();
|
|
478
264
|
}
|
|
265
|
+
}
|
|
479
266
|
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
267
|
+
// Protected
|
|
268
|
+
_isWithContent() {
|
|
269
|
+
return Boolean(this._getTitle());
|
|
270
|
+
}
|
|
271
|
+
_getTipElement() {
|
|
272
|
+
if (!this.tip) {
|
|
273
|
+
this.tip = this._createTipElement(this._newContent || this._getContentForTemplate());
|
|
486
274
|
}
|
|
487
|
-
} // Protected
|
|
488
|
-
;
|
|
489
|
-
|
|
490
|
-
_proto.isWithContent = function isWithContent() {
|
|
491
|
-
return Boolean(this.getTitle());
|
|
492
|
-
};
|
|
493
|
-
|
|
494
|
-
_proto.addAttachmentClass = function addAttachmentClass(attachment) {
|
|
495
|
-
$__default['default'](this.getTipElement()).addClass(CLASS_PREFIX + "-" + attachment);
|
|
496
|
-
};
|
|
497
|
-
|
|
498
|
-
_proto.getTipElement = function getTipElement() {
|
|
499
|
-
this.tip = this.tip || $__default['default'](this.config.template)[0];
|
|
500
275
|
return this.tip;
|
|
501
|
-
}
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
this
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
276
|
+
}
|
|
277
|
+
_createTipElement(content) {
|
|
278
|
+
const tip = this._getTemplateFactory(content).toHtml();
|
|
279
|
+
|
|
280
|
+
// TODO: remove this check in v6
|
|
281
|
+
if (!tip) {
|
|
282
|
+
return null;
|
|
283
|
+
}
|
|
284
|
+
tip.classList.remove(CLASS_NAME_FADE, CLASS_NAME_SHOW);
|
|
285
|
+
// TODO: v6 the following can be achieved with CSS only
|
|
286
|
+
tip.classList.add(`bs-${this.constructor.NAME}-auto`);
|
|
287
|
+
const tipId = index_js.getUID(this.constructor.NAME).toString();
|
|
288
|
+
tip.setAttribute('id', tipId);
|
|
289
|
+
if (this._isAnimated()) {
|
|
290
|
+
tip.classList.add(CLASS_NAME_FADE);
|
|
291
|
+
}
|
|
292
|
+
return tip;
|
|
293
|
+
}
|
|
294
|
+
setContent(content) {
|
|
295
|
+
this._newContent = content;
|
|
296
|
+
if (this._isShown()) {
|
|
297
|
+
this._disposePopper();
|
|
298
|
+
this.show();
|
|
521
299
|
}
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
}
|
|
527
|
-
|
|
528
|
-
$element.html(content);
|
|
300
|
+
}
|
|
301
|
+
_getTemplateFactory(content) {
|
|
302
|
+
if (this._templateFactory) {
|
|
303
|
+
this._templateFactory.changeContent(content);
|
|
529
304
|
} else {
|
|
530
|
-
|
|
305
|
+
this._templateFactory = new TemplateFactory({
|
|
306
|
+
...this._config,
|
|
307
|
+
// the `content` var has to be after `this._config`
|
|
308
|
+
// to override config.content in case of popover
|
|
309
|
+
content,
|
|
310
|
+
extraClass: this._resolvePossibleFunction(this._config.customClass)
|
|
311
|
+
});
|
|
531
312
|
}
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
313
|
+
return this._templateFactory;
|
|
314
|
+
}
|
|
315
|
+
_getContentForTemplate() {
|
|
316
|
+
return {
|
|
317
|
+
[SELECTOR_TOOLTIP_INNER]: this._getTitle()
|
|
318
|
+
};
|
|
319
|
+
}
|
|
320
|
+
_getTitle() {
|
|
321
|
+
return this._resolvePossibleFunction(this._config.title) || this._element.getAttribute('data-bs-original-title');
|
|
322
|
+
}
|
|
536
323
|
|
|
537
|
-
|
|
538
|
-
|
|
324
|
+
// Private
|
|
325
|
+
_initializeOnDelegatedTarget(event) {
|
|
326
|
+
return this.constructor.getOrCreateInstance(event.delegateTarget, this._getDelegateConfig());
|
|
327
|
+
}
|
|
328
|
+
_isAnimated() {
|
|
329
|
+
return this._config.animation || this.tip && this.tip.classList.contains(CLASS_NAME_FADE);
|
|
330
|
+
}
|
|
331
|
+
_isShown() {
|
|
332
|
+
return this.tip && this.tip.classList.contains(CLASS_NAME_SHOW);
|
|
333
|
+
}
|
|
334
|
+
_createPopper(tip) {
|
|
335
|
+
const placement = index_js.execute(this._config.placement, [this, tip, this._element]);
|
|
336
|
+
const attachment = AttachmentMap[placement.toUpperCase()];
|
|
337
|
+
return Popper__namespace.createPopper(this._element, tip, this._getPopperConfig(attachment));
|
|
338
|
+
}
|
|
339
|
+
_getOffset() {
|
|
340
|
+
const {
|
|
341
|
+
offset
|
|
342
|
+
} = this._config;
|
|
343
|
+
if (typeof offset === 'string') {
|
|
344
|
+
return offset.split(',').map(value => Number.parseInt(value, 10));
|
|
539
345
|
}
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
346
|
+
if (typeof offset === 'function') {
|
|
347
|
+
return popperData => offset(popperData, this._element);
|
|
348
|
+
}
|
|
349
|
+
return offset;
|
|
350
|
+
}
|
|
351
|
+
_resolvePossibleFunction(arg) {
|
|
352
|
+
return index_js.execute(arg, [this._element]);
|
|
353
|
+
}
|
|
354
|
+
_getPopperConfig(attachment) {
|
|
355
|
+
const defaultBsPopperConfig = {
|
|
549
356
|
placement: attachment,
|
|
550
|
-
modifiers: {
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
},
|
|
555
|
-
arrow: {
|
|
556
|
-
element: SELECTOR_ARROW
|
|
557
|
-
},
|
|
558
|
-
preventOverflow: {
|
|
559
|
-
boundariesElement: this.config.boundary
|
|
357
|
+
modifiers: [{
|
|
358
|
+
name: 'flip',
|
|
359
|
+
options: {
|
|
360
|
+
fallbackPlacements: this._config.fallbackPlacements
|
|
560
361
|
}
|
|
561
|
-
},
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
362
|
+
}, {
|
|
363
|
+
name: 'offset',
|
|
364
|
+
options: {
|
|
365
|
+
offset: this._getOffset()
|
|
565
366
|
}
|
|
566
|
-
},
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
367
|
+
}, {
|
|
368
|
+
name: 'preventOverflow',
|
|
369
|
+
options: {
|
|
370
|
+
boundary: this._config.boundary
|
|
371
|
+
}
|
|
372
|
+
}, {
|
|
373
|
+
name: 'arrow',
|
|
374
|
+
options: {
|
|
375
|
+
element: `.${this.constructor.NAME}-arrow`
|
|
376
|
+
}
|
|
377
|
+
}, {
|
|
378
|
+
name: 'preSetPlacement',
|
|
379
|
+
enabled: true,
|
|
380
|
+
phase: 'beforeMain',
|
|
381
|
+
fn: data => {
|
|
382
|
+
// Pre-set Popper's placement attribute in order to read the arrow sizes properly.
|
|
383
|
+
// Otherwise, Popper mixes up the width and height dimensions since the initial arrow style is for top placement
|
|
384
|
+
this._getTipElement().setAttribute('data-popper-placement', data.state.placement);
|
|
385
|
+
}
|
|
386
|
+
}]
|
|
570
387
|
};
|
|
571
|
-
return
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
if (typeof this.config.offset === 'function') {
|
|
580
|
-
offset.fn = function (data) {
|
|
581
|
-
data.offsets = _extends({}, data.offsets, _this4.config.offset(data.offsets, _this4.element) || {});
|
|
582
|
-
return data;
|
|
583
|
-
};
|
|
584
|
-
} else {
|
|
585
|
-
offset.offset = this.config.offset;
|
|
586
|
-
}
|
|
587
|
-
|
|
588
|
-
return offset;
|
|
589
|
-
};
|
|
590
|
-
|
|
591
|
-
_proto._getContainer = function _getContainer() {
|
|
592
|
-
if (this.config.container === false) {
|
|
593
|
-
return document.body;
|
|
594
|
-
}
|
|
595
|
-
|
|
596
|
-
if (Util__default['default'].isElement(this.config.container)) {
|
|
597
|
-
return $__default['default'](this.config.container);
|
|
598
|
-
}
|
|
599
|
-
|
|
600
|
-
return $__default['default'](document).find(this.config.container);
|
|
601
|
-
};
|
|
602
|
-
|
|
603
|
-
_proto._getAttachment = function _getAttachment(placement) {
|
|
604
|
-
return AttachmentMap[placement.toUpperCase()];
|
|
605
|
-
};
|
|
606
|
-
|
|
607
|
-
_proto._setListeners = function _setListeners() {
|
|
608
|
-
var _this5 = this;
|
|
609
|
-
|
|
610
|
-
var triggers = this.config.trigger.split(' ');
|
|
611
|
-
triggers.forEach(function (trigger) {
|
|
388
|
+
return {
|
|
389
|
+
...defaultBsPopperConfig,
|
|
390
|
+
...index_js.execute(this._config.popperConfig, [defaultBsPopperConfig])
|
|
391
|
+
};
|
|
392
|
+
}
|
|
393
|
+
_setListeners() {
|
|
394
|
+
const triggers = this._config.trigger.split(' ');
|
|
395
|
+
for (const trigger of triggers) {
|
|
612
396
|
if (trigger === 'click') {
|
|
613
|
-
|
|
614
|
-
|
|
397
|
+
EventHandler.on(this._element, this.constructor.eventName(EVENT_CLICK), this._config.selector, event => {
|
|
398
|
+
const context = this._initializeOnDelegatedTarget(event);
|
|
399
|
+
context.toggle();
|
|
615
400
|
});
|
|
616
401
|
} else if (trigger !== TRIGGER_MANUAL) {
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
402
|
+
const eventIn = trigger === TRIGGER_HOVER ? this.constructor.eventName(EVENT_MOUSEENTER) : this.constructor.eventName(EVENT_FOCUSIN);
|
|
403
|
+
const eventOut = trigger === TRIGGER_HOVER ? this.constructor.eventName(EVENT_MOUSELEAVE) : this.constructor.eventName(EVENT_FOCUSOUT);
|
|
404
|
+
EventHandler.on(this._element, eventIn, this._config.selector, event => {
|
|
405
|
+
const context = this._initializeOnDelegatedTarget(event);
|
|
406
|
+
context._activeTrigger[event.type === 'focusin' ? TRIGGER_FOCUS : TRIGGER_HOVER] = true;
|
|
407
|
+
context._enter();
|
|
408
|
+
});
|
|
409
|
+
EventHandler.on(this._element, eventOut, this._config.selector, event => {
|
|
410
|
+
const context = this._initializeOnDelegatedTarget(event);
|
|
411
|
+
context._activeTrigger[event.type === 'focusout' ? TRIGGER_FOCUS : TRIGGER_HOVER] = context._element.contains(event.relatedTarget);
|
|
412
|
+
context._leave();
|
|
623
413
|
});
|
|
624
414
|
}
|
|
625
|
-
}
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
_this5.hide();
|
|
415
|
+
}
|
|
416
|
+
this._hideModalHandler = () => {
|
|
417
|
+
if (this._element) {
|
|
418
|
+
this.hide();
|
|
630
419
|
}
|
|
631
420
|
};
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
trigger: 'manual',
|
|
638
|
-
selector: ''
|
|
639
|
-
});
|
|
640
|
-
} else {
|
|
641
|
-
this._fixTitle();
|
|
642
|
-
}
|
|
643
|
-
};
|
|
644
|
-
|
|
645
|
-
_proto._fixTitle = function _fixTitle() {
|
|
646
|
-
var titleType = typeof this.element.getAttribute('data-original-title');
|
|
647
|
-
|
|
648
|
-
if (this.element.getAttribute('title') || titleType !== 'string') {
|
|
649
|
-
this.element.setAttribute('data-original-title', this.element.getAttribute('title') || '');
|
|
650
|
-
this.element.setAttribute('title', '');
|
|
651
|
-
}
|
|
652
|
-
};
|
|
653
|
-
|
|
654
|
-
_proto._enter = function _enter(event, context) {
|
|
655
|
-
var dataKey = this.constructor.DATA_KEY;
|
|
656
|
-
context = context || $__default['default'](event.currentTarget).data(dataKey);
|
|
657
|
-
|
|
658
|
-
if (!context) {
|
|
659
|
-
context = new this.constructor(event.currentTarget, this._getDelegateConfig());
|
|
660
|
-
$__default['default'](event.currentTarget).data(dataKey, context);
|
|
661
|
-
}
|
|
662
|
-
|
|
663
|
-
if (event) {
|
|
664
|
-
context._activeTrigger[event.type === 'focusin' ? TRIGGER_FOCUS : TRIGGER_HOVER] = true;
|
|
665
|
-
}
|
|
666
|
-
|
|
667
|
-
if ($__default['default'](context.getTipElement()).hasClass(CLASS_NAME_SHOW) || context._hoverState === HOVER_STATE_SHOW) {
|
|
668
|
-
context._hoverState = HOVER_STATE_SHOW;
|
|
421
|
+
EventHandler.on(this._element.closest(SELECTOR_MODAL), EVENT_MODAL_HIDE, this._hideModalHandler);
|
|
422
|
+
}
|
|
423
|
+
_fixTitle() {
|
|
424
|
+
const title = this._element.getAttribute('title');
|
|
425
|
+
if (!title) {
|
|
669
426
|
return;
|
|
670
427
|
}
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
context._hoverState = HOVER_STATE_SHOW;
|
|
674
|
-
|
|
675
|
-
if (!context.config.delay || !context.config.delay.show) {
|
|
676
|
-
context.show();
|
|
677
|
-
return;
|
|
428
|
+
if (!this._element.getAttribute('aria-label') && !this._element.textContent.trim()) {
|
|
429
|
+
this._element.setAttribute('aria-label', title);
|
|
678
430
|
}
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
};
|
|
686
|
-
|
|
687
|
-
_proto._leave = function _leave(event, context) {
|
|
688
|
-
var dataKey = this.constructor.DATA_KEY;
|
|
689
|
-
context = context || $__default['default'](event.currentTarget).data(dataKey);
|
|
690
|
-
|
|
691
|
-
if (!context) {
|
|
692
|
-
context = new this.constructor(event.currentTarget, this._getDelegateConfig());
|
|
693
|
-
$__default['default'](event.currentTarget).data(dataKey, context);
|
|
694
|
-
}
|
|
695
|
-
|
|
696
|
-
if (event) {
|
|
697
|
-
context._activeTrigger[event.type === 'focusout' ? TRIGGER_FOCUS : TRIGGER_HOVER] = false;
|
|
698
|
-
}
|
|
699
|
-
|
|
700
|
-
if (context._isWithActiveTrigger()) {
|
|
431
|
+
this._element.setAttribute('data-bs-original-title', title); // DO NOT USE IT. Is only for backwards compatibility
|
|
432
|
+
this._element.removeAttribute('title');
|
|
433
|
+
}
|
|
434
|
+
_enter() {
|
|
435
|
+
if (this._isShown() || this._isHovered) {
|
|
436
|
+
this._isHovered = true;
|
|
701
437
|
return;
|
|
702
438
|
}
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
439
|
+
this._isHovered = true;
|
|
440
|
+
this._setTimeout(() => {
|
|
441
|
+
if (this._isHovered) {
|
|
442
|
+
this.show();
|
|
443
|
+
}
|
|
444
|
+
}, this._config.delay.show);
|
|
445
|
+
}
|
|
446
|
+
_leave() {
|
|
447
|
+
if (this._isWithActiveTrigger()) {
|
|
709
448
|
return;
|
|
710
449
|
}
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
if (
|
|
714
|
-
|
|
450
|
+
this._isHovered = false;
|
|
451
|
+
this._setTimeout(() => {
|
|
452
|
+
if (!this._isHovered) {
|
|
453
|
+
this.hide();
|
|
715
454
|
}
|
|
716
|
-
},
|
|
717
|
-
}
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
455
|
+
}, this._config.delay.hide);
|
|
456
|
+
}
|
|
457
|
+
_setTimeout(handler, timeout) {
|
|
458
|
+
clearTimeout(this._timeout);
|
|
459
|
+
this._timeout = setTimeout(handler, timeout);
|
|
460
|
+
}
|
|
461
|
+
_isWithActiveTrigger() {
|
|
462
|
+
return Object.values(this._activeTrigger).includes(true);
|
|
463
|
+
}
|
|
464
|
+
_getConfig(config) {
|
|
465
|
+
const dataAttributes = Manipulator.getDataAttributes(this._element);
|
|
466
|
+
for (const dataAttribute of Object.keys(dataAttributes)) {
|
|
467
|
+
if (DISALLOWED_ATTRIBUTES.has(dataAttribute)) {
|
|
468
|
+
delete dataAttributes[dataAttribute];
|
|
723
469
|
}
|
|
724
470
|
}
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
config = _extends({}, this.constructor.Default, dataAttributes, typeof config === 'object' && config ? config : {});
|
|
737
|
-
|
|
471
|
+
config = {
|
|
472
|
+
...dataAttributes,
|
|
473
|
+
...(typeof config === 'object' && config ? config : {})
|
|
474
|
+
};
|
|
475
|
+
config = this._mergeConfigObj(config);
|
|
476
|
+
config = this._configAfterMerge(config);
|
|
477
|
+
this._typeCheckConfig(config);
|
|
478
|
+
return config;
|
|
479
|
+
}
|
|
480
|
+
_configAfterMerge(config) {
|
|
481
|
+
config.container = config.container === false ? document.body : index_js.getElement(config.container);
|
|
738
482
|
if (typeof config.delay === 'number') {
|
|
739
483
|
config.delay = {
|
|
740
484
|
show: config.delay,
|
|
741
485
|
hide: config.delay
|
|
742
486
|
};
|
|
743
487
|
}
|
|
744
|
-
|
|
745
488
|
if (typeof config.title === 'number') {
|
|
746
489
|
config.title = config.title.toString();
|
|
747
490
|
}
|
|
748
|
-
|
|
749
491
|
if (typeof config.content === 'number') {
|
|
750
492
|
config.content = config.content.toString();
|
|
751
493
|
}
|
|
752
|
-
|
|
753
|
-
Util__default['default'].typeCheckConfig(NAME, config, this.constructor.DefaultType);
|
|
754
|
-
|
|
755
|
-
if (config.sanitize) {
|
|
756
|
-
config.template = sanitizeHtml(config.template, config.whiteList, config.sanitizeFn);
|
|
757
|
-
}
|
|
758
|
-
|
|
759
494
|
return config;
|
|
760
|
-
}
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
|
|
766
|
-
for (var key in this.config) {
|
|
767
|
-
if (this.constructor.Default[key] !== this.config[key]) {
|
|
768
|
-
config[key] = this.config[key];
|
|
769
|
-
}
|
|
495
|
+
}
|
|
496
|
+
_getDelegateConfig() {
|
|
497
|
+
const config = {};
|
|
498
|
+
for (const [key, value] of Object.entries(this._config)) {
|
|
499
|
+
if (this.constructor.Default[key] !== value) {
|
|
500
|
+
config[key] = value;
|
|
770
501
|
}
|
|
771
502
|
}
|
|
503
|
+
config.selector = false;
|
|
504
|
+
config.trigger = 'manual';
|
|
772
505
|
|
|
506
|
+
// In the future can be replaced with:
|
|
507
|
+
// const keysWithDifferentValues = Object.entries(this._config).filter(entry => this.constructor.Default[entry[0]] !== this._config[entry[0]])
|
|
508
|
+
// `Object.fromEntries(keysWithDifferentValues)`
|
|
773
509
|
return config;
|
|
774
|
-
}
|
|
775
|
-
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
|
|
780
|
-
if (tabClass !== null && tabClass.length) {
|
|
781
|
-
$tip.removeClass(tabClass.join(''));
|
|
510
|
+
}
|
|
511
|
+
_disposePopper() {
|
|
512
|
+
if (this._popper) {
|
|
513
|
+
this._popper.destroy();
|
|
514
|
+
this._popper = null;
|
|
782
515
|
}
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
this.tip = popperData.instance.popper;
|
|
787
|
-
|
|
788
|
-
this._cleanTipClass();
|
|
789
|
-
|
|
790
|
-
this.addAttachmentClass(this._getAttachment(popperData.placement));
|
|
791
|
-
};
|
|
792
|
-
|
|
793
|
-
_proto._fixTransition = function _fixTransition() {
|
|
794
|
-
var tip = this.getTipElement();
|
|
795
|
-
var initConfigAnimation = this.config.animation;
|
|
796
|
-
|
|
797
|
-
if (tip.getAttribute('x-placement') !== null) {
|
|
798
|
-
return;
|
|
516
|
+
if (this.tip) {
|
|
517
|
+
this.tip.remove();
|
|
518
|
+
this.tip = null;
|
|
799
519
|
}
|
|
520
|
+
}
|
|
800
521
|
|
|
801
|
-
|
|
802
|
-
|
|
803
|
-
this.hide();
|
|
804
|
-
this.show();
|
|
805
|
-
this.config.animation = initConfigAnimation;
|
|
806
|
-
} // Static
|
|
807
|
-
;
|
|
808
|
-
|
|
809
|
-
Tooltip._jQueryInterface = function _jQueryInterface(config) {
|
|
522
|
+
// Static
|
|
523
|
+
static jQueryInterface(config) {
|
|
810
524
|
return this.each(function () {
|
|
811
|
-
|
|
812
|
-
|
|
813
|
-
|
|
814
|
-
var _config = typeof config === 'object' && config;
|
|
815
|
-
|
|
816
|
-
if (!data && /dispose|hide/.test(config)) {
|
|
525
|
+
const data = Tooltip.getOrCreateInstance(this, config);
|
|
526
|
+
if (typeof config !== 'string') {
|
|
817
527
|
return;
|
|
818
528
|
}
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
data = new Tooltip(this, _config);
|
|
822
|
-
$element.data(DATA_KEY, data);
|
|
823
|
-
}
|
|
824
|
-
|
|
825
|
-
if (typeof config === 'string') {
|
|
826
|
-
if (typeof data[config] === 'undefined') {
|
|
827
|
-
throw new TypeError("No method named \"" + config + "\"");
|
|
828
|
-
}
|
|
829
|
-
|
|
830
|
-
data[config]();
|
|
529
|
+
if (typeof data[config] === 'undefined') {
|
|
530
|
+
throw new TypeError(`No method named "${config}"`);
|
|
831
531
|
}
|
|
532
|
+
data[config]();
|
|
832
533
|
});
|
|
833
|
-
}
|
|
834
|
-
|
|
835
|
-
_createClass(Tooltip, null, [{
|
|
836
|
-
key: "VERSION",
|
|
837
|
-
get: function get() {
|
|
838
|
-
return VERSION;
|
|
839
|
-
}
|
|
840
|
-
}, {
|
|
841
|
-
key: "Default",
|
|
842
|
-
get: function get() {
|
|
843
|
-
return Default;
|
|
844
|
-
}
|
|
845
|
-
}, {
|
|
846
|
-
key: "NAME",
|
|
847
|
-
get: function get() {
|
|
848
|
-
return NAME;
|
|
849
|
-
}
|
|
850
|
-
}, {
|
|
851
|
-
key: "DATA_KEY",
|
|
852
|
-
get: function get() {
|
|
853
|
-
return DATA_KEY;
|
|
854
|
-
}
|
|
855
|
-
}, {
|
|
856
|
-
key: "Event",
|
|
857
|
-
get: function get() {
|
|
858
|
-
return Event;
|
|
859
|
-
}
|
|
860
|
-
}, {
|
|
861
|
-
key: "EVENT_KEY",
|
|
862
|
-
get: function get() {
|
|
863
|
-
return EVENT_KEY;
|
|
864
|
-
}
|
|
865
|
-
}, {
|
|
866
|
-
key: "DefaultType",
|
|
867
|
-
get: function get() {
|
|
868
|
-
return DefaultType;
|
|
869
|
-
}
|
|
870
|
-
}]);
|
|
534
|
+
}
|
|
535
|
+
}
|
|
871
536
|
|
|
872
|
-
return Tooltip;
|
|
873
|
-
}();
|
|
874
537
|
/**
|
|
875
|
-
* ------------------------------------------------------------------------
|
|
876
538
|
* jQuery
|
|
877
|
-
* ------------------------------------------------------------------------
|
|
878
539
|
*/
|
|
879
540
|
|
|
880
|
-
|
|
881
|
-
$__default['default'].fn[NAME] = Tooltip._jQueryInterface;
|
|
882
|
-
$__default['default'].fn[NAME].Constructor = Tooltip;
|
|
883
|
-
|
|
884
|
-
$__default['default'].fn[NAME].noConflict = function () {
|
|
885
|
-
$__default['default'].fn[NAME] = JQUERY_NO_CONFLICT;
|
|
886
|
-
return Tooltip._jQueryInterface;
|
|
887
|
-
};
|
|
541
|
+
index_js.defineJQueryPlugin(Tooltip);
|
|
888
542
|
|
|
889
543
|
return Tooltip;
|
|
890
544
|
|
|
891
|
-
}))
|
|
545
|
+
}));
|