@iamproperty/components 3.4.7 → 3.5.0

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.
Files changed (210) hide show
  1. package/assets/bootstrap/LICENSE +22 -0
  2. package/assets/bootstrap/README.md +246 -0
  3. package/assets/bootstrap/js/src/alert.js +87 -0
  4. package/assets/bootstrap/js/src/base-component.js +85 -0
  5. package/assets/bootstrap/js/src/button.js +72 -0
  6. package/assets/bootstrap/js/src/carousel.js +475 -0
  7. package/assets/bootstrap/js/src/collapse.js +302 -0
  8. package/assets/bootstrap/js/src/dom/data.js +55 -0
  9. package/assets/bootstrap/js/src/dom/event-handler.js +320 -0
  10. package/assets/bootstrap/js/src/dom/manipulator.js +71 -0
  11. package/assets/bootstrap/js/src/dom/selector-engine.js +83 -0
  12. package/assets/bootstrap/js/src/dropdown.js +454 -0
  13. package/assets/bootstrap/js/src/modal.js +377 -0
  14. package/assets/bootstrap/js/src/offcanvas.js +283 -0
  15. package/assets/bootstrap/js/src/popover.js +97 -0
  16. package/assets/bootstrap/js/src/scrollspy.js +294 -0
  17. package/assets/bootstrap/js/src/tab.js +305 -0
  18. package/assets/bootstrap/js/src/toast.js +225 -0
  19. package/assets/bootstrap/js/src/tooltip.js +633 -0
  20. package/assets/bootstrap/js/src/util/backdrop.js +149 -0
  21. package/assets/bootstrap/js/src/util/component-functions.js +34 -0
  22. package/assets/bootstrap/js/src/util/config.js +66 -0
  23. package/assets/bootstrap/js/src/util/focustrap.js +115 -0
  24. package/assets/bootstrap/js/src/util/index.js +336 -0
  25. package/assets/bootstrap/js/src/util/sanitizer.js +118 -0
  26. package/assets/bootstrap/js/src/util/scrollbar.js +114 -0
  27. package/assets/bootstrap/js/src/util/swipe.js +146 -0
  28. package/assets/bootstrap/js/src/util/template-factory.js +160 -0
  29. package/assets/bootstrap/package.json +181 -0
  30. package/assets/bootstrap/scss/_accordion.scss +149 -0
  31. package/assets/bootstrap/scss/_alert.scss +71 -0
  32. package/assets/bootstrap/scss/_badge.scss +38 -0
  33. package/assets/bootstrap/scss/_breadcrumb.scss +40 -0
  34. package/assets/bootstrap/scss/_button-group.scss +142 -0
  35. package/assets/bootstrap/scss/_buttons.scss +207 -0
  36. package/assets/bootstrap/scss/_card.scss +234 -0
  37. package/assets/bootstrap/scss/_carousel.scss +226 -0
  38. package/assets/bootstrap/scss/_close.scss +40 -0
  39. package/assets/bootstrap/scss/_containers.scss +41 -0
  40. package/assets/bootstrap/scss/_dropdown.scss +249 -0
  41. package/assets/bootstrap/scss/_forms.scss +9 -0
  42. package/assets/bootstrap/scss/_functions.scss +302 -0
  43. package/assets/bootstrap/scss/_grid.scss +33 -0
  44. package/assets/bootstrap/scss/_helpers.scss +10 -0
  45. package/assets/bootstrap/scss/_images.scss +42 -0
  46. package/assets/bootstrap/scss/_list-group.scss +192 -0
  47. package/assets/bootstrap/scss/_maps.scss +54 -0
  48. package/assets/bootstrap/scss/_mixins.scss +43 -0
  49. package/assets/bootstrap/scss/_modal.scss +237 -0
  50. package/assets/bootstrap/scss/_nav.scss +172 -0
  51. package/assets/bootstrap/scss/_navbar.scss +278 -0
  52. package/assets/bootstrap/scss/_offcanvas.scss +144 -0
  53. package/assets/bootstrap/scss/_pagination.scss +109 -0
  54. package/assets/bootstrap/scss/_placeholders.scss +51 -0
  55. package/assets/bootstrap/scss/_popover.scss +196 -0
  56. package/assets/bootstrap/scss/_progress.scss +59 -0
  57. package/assets/bootstrap/scss/_reboot.scss +610 -0
  58. package/assets/bootstrap/scss/_root.scss +73 -0
  59. package/assets/bootstrap/scss/_spinners.scss +85 -0
  60. package/assets/bootstrap/scss/_tables.scss +164 -0
  61. package/assets/bootstrap/scss/_toasts.scss +73 -0
  62. package/assets/bootstrap/scss/_tooltip.scss +120 -0
  63. package/assets/bootstrap/scss/_transitions.scss +27 -0
  64. package/assets/bootstrap/scss/_type.scss +106 -0
  65. package/assets/bootstrap/scss/_utilities.scss +647 -0
  66. package/assets/bootstrap/scss/_variables.scss +1634 -0
  67. package/assets/bootstrap/scss/bootstrap-grid.scss +64 -0
  68. package/assets/bootstrap/scss/bootstrap-reboot.scss +9 -0
  69. package/assets/bootstrap/scss/bootstrap-utilities.scss +18 -0
  70. package/assets/bootstrap/scss/bootstrap.scss +51 -0
  71. package/assets/bootstrap/scss/forms/_floating-labels.scss +75 -0
  72. package/assets/bootstrap/scss/forms/_form-check.scss +175 -0
  73. package/assets/bootstrap/scss/forms/_form-control.scss +194 -0
  74. package/assets/bootstrap/scss/forms/_form-range.scss +91 -0
  75. package/assets/bootstrap/scss/forms/_form-select.scss +71 -0
  76. package/assets/bootstrap/scss/forms/_form-text.scss +11 -0
  77. package/assets/bootstrap/scss/forms/_input-group.scss +132 -0
  78. package/assets/bootstrap/scss/forms/_labels.scss +36 -0
  79. package/assets/bootstrap/scss/forms/_validation.scss +12 -0
  80. package/assets/bootstrap/scss/helpers/_clearfix.scss +3 -0
  81. package/assets/bootstrap/scss/helpers/_color-bg.scss +10 -0
  82. package/assets/bootstrap/scss/helpers/_colored-links.scss +12 -0
  83. package/assets/bootstrap/scss/helpers/_position.scss +36 -0
  84. package/assets/bootstrap/scss/helpers/_ratio.scss +26 -0
  85. package/assets/bootstrap/scss/helpers/_stacks.scss +15 -0
  86. package/assets/bootstrap/scss/helpers/_stretched-link.scss +15 -0
  87. package/assets/bootstrap/scss/helpers/_text-truncation.scss +7 -0
  88. package/assets/bootstrap/scss/helpers/_visually-hidden.scss +8 -0
  89. package/assets/bootstrap/scss/helpers/_vr.scss +8 -0
  90. package/assets/bootstrap/scss/mixins/_alert.scss +15 -0
  91. package/assets/bootstrap/scss/mixins/_backdrop.scss +14 -0
  92. package/assets/bootstrap/scss/mixins/_banner.scss +9 -0
  93. package/assets/bootstrap/scss/mixins/_border-radius.scss +78 -0
  94. package/assets/bootstrap/scss/mixins/_box-shadow.scss +18 -0
  95. package/assets/bootstrap/scss/mixins/_breakpoints.scss +127 -0
  96. package/assets/bootstrap/scss/mixins/_buttons.scss +70 -0
  97. package/assets/bootstrap/scss/mixins/_caret.scss +64 -0
  98. package/assets/bootstrap/scss/mixins/_clearfix.scss +9 -0
  99. package/assets/bootstrap/scss/mixins/_color-scheme.scss +7 -0
  100. package/assets/bootstrap/scss/mixins/_container.scss +11 -0
  101. package/assets/bootstrap/scss/mixins/_deprecate.scss +10 -0
  102. package/assets/bootstrap/scss/mixins/_forms.scss +152 -0
  103. package/assets/bootstrap/scss/mixins/_gradients.scss +47 -0
  104. package/assets/bootstrap/scss/mixins/_grid.scss +151 -0
  105. package/assets/bootstrap/scss/mixins/_image.scss +16 -0
  106. package/assets/bootstrap/scss/mixins/_list-group.scss +24 -0
  107. package/assets/bootstrap/scss/mixins/_lists.scss +7 -0
  108. package/assets/bootstrap/scss/mixins/_pagination.scss +10 -0
  109. package/assets/bootstrap/scss/mixins/_reset-text.scss +17 -0
  110. package/assets/bootstrap/scss/mixins/_resize.scss +6 -0
  111. package/assets/bootstrap/scss/mixins/_table-variants.scss +24 -0
  112. package/assets/bootstrap/scss/mixins/_text-truncate.scss +8 -0
  113. package/assets/bootstrap/scss/mixins/_transition.scss +26 -0
  114. package/assets/bootstrap/scss/mixins/_utilities.scss +97 -0
  115. package/assets/bootstrap/scss/mixins/_visually-hidden.scss +29 -0
  116. package/assets/bootstrap/scss/utilities/_api.scss +47 -0
  117. package/assets/bootstrap/scss/vendor/_rfs.scss +354 -0
  118. package/assets/css/components/accordion.css +1 -1
  119. package/assets/css/components/accordion.css.map +1 -1
  120. package/assets/css/components/admin-panel.css +1 -0
  121. package/assets/css/components/admin-panel.css.map +1 -0
  122. package/assets/css/components/alert.css +1 -1
  123. package/assets/css/components/alert.css.map +1 -1
  124. package/assets/css/components/carousel.css +1 -1
  125. package/assets/css/components/carousel.css.map +1 -1
  126. package/assets/css/components/charts.css +1 -1
  127. package/assets/css/components/charts.css.map +1 -1
  128. package/assets/css/components/container.css.map +1 -1
  129. package/assets/css/components/dialog.css +1 -1
  130. package/assets/css/components/dialog.css.map +1 -1
  131. package/assets/css/components/forms.css.map +1 -1
  132. package/assets/css/components/header.css +1 -1
  133. package/assets/css/components/header.css.map +1 -1
  134. package/assets/css/components/lists.css +1 -1
  135. package/assets/css/components/lists.css.map +1 -1
  136. package/assets/css/components/nav.css +1 -1
  137. package/assets/css/components/nav.css.map +1 -1
  138. package/assets/css/components/pagination.css.map +1 -1
  139. package/assets/css/components/property-searchbar.css +1 -1
  140. package/assets/css/components/property-searchbar.css.map +1 -1
  141. package/assets/css/components/stepper.css +1 -1
  142. package/assets/css/components/stepper.css.map +1 -1
  143. package/assets/css/components/table.css +1 -1
  144. package/assets/css/components/table.css.map +1 -1
  145. package/assets/css/components/tabs.css +1 -1
  146. package/assets/css/components/tabs.css.map +1 -1
  147. package/assets/css/components/tooltips.css +1 -1
  148. package/assets/css/components/tooltips.css.map +1 -1
  149. package/assets/css/core.min.css +1 -1
  150. package/assets/css/core.min.css.map +1 -1
  151. package/assets/css/style.min.css +1 -1
  152. package/assets/css/style.min.css.map +1 -1
  153. package/assets/js/components/accordion/accordion.component.min.js +1 -1
  154. package/assets/js/components/card/card.component.min.js +1 -1
  155. package/assets/js/components/filterlist/filterlist.component.min.js +1 -1
  156. package/assets/js/components/header/header.component.min.js +5 -5
  157. package/assets/js/components/table/table.component.js +4 -0
  158. package/assets/js/components/table/table.component.min.js +5 -5
  159. package/assets/js/components/table/table.component.min.js.map +1 -1
  160. package/assets/js/components/tabs/tabs.component.min.js +5 -5
  161. package/assets/js/dynamic.min.js +2 -2
  162. package/assets/js/dynamic.min.js.map +1 -1
  163. package/assets/js/modules/helpers.js +31 -6
  164. package/assets/js/modules/table.js +4 -5
  165. package/assets/js/scripts.bundle.js +31 -31
  166. package/assets/js/scripts.bundle.js.map +1 -1
  167. package/assets/js/scripts.bundle.min.js +2 -2
  168. package/assets/js/scripts.bundle.min.js.map +1 -1
  169. package/assets/js/tests/table.spec.js +3 -1
  170. package/assets/sass/_corefiles.scss +15 -15
  171. package/assets/sass/_forms.scss +7 -7
  172. package/assets/sass/_functions/functions.scss +1 -1
  173. package/assets/sass/_functions/mixins.scss +19 -21
  174. package/assets/sass/_functions/utilities.scss +51 -9
  175. package/assets/sass/_functions/variables.scss +77 -37
  176. package/assets/sass/_tests/colours.spec.scss +8 -22
  177. package/assets/sass/components/accordion.scss +13 -0
  178. package/assets/sass/components/admin-panel.scss +106 -0
  179. package/assets/sass/components/alert.scss +22 -0
  180. package/assets/sass/components/carousel.scss +72 -0
  181. package/assets/sass/components/charts.scss +37 -1
  182. package/assets/sass/components/container.scss +1 -1
  183. package/assets/sass/components/dialog.scss +7 -1
  184. package/assets/sass/components/lists.scss +14 -0
  185. package/assets/sass/components/nav.scss +1 -1
  186. package/assets/sass/components/pagination.scss +1 -1
  187. package/assets/sass/components/stepper.scss +3 -3
  188. package/assets/sass/components/table.scss +19 -15
  189. package/assets/sass/components/tabs.scss +20 -7
  190. package/assets/sass/components/tooltips.scss +1 -1
  191. package/assets/sass/foundations/buttons.scss +366 -0
  192. package/assets/sass/foundations/links.scss +75 -75
  193. package/assets/sass/foundations/media.scss +1 -1
  194. package/assets/sass/foundations/reboot.scss +3 -5
  195. package/assets/sass/foundations/root.scss +9 -29
  196. package/assets/sass/foundations/type.scss +1 -1
  197. package/assets/ts/components/table/table.component.ts +5 -0
  198. package/assets/ts/modules/helpers.ts +49 -8
  199. package/assets/ts/modules/table.ts +6 -6
  200. package/assets/ts/tests/table.spec.ts +4 -1
  201. package/dist/components.es.js +46 -42
  202. package/dist/components.umd.js +4 -4
  203. package/dist/style.css +1 -1
  204. package/package.json +2 -1
  205. package/assets/css/components/buttons.css +0 -1
  206. package/assets/css/components/buttons.css.map +0 -1
  207. package/assets/css/components/panel.css +0 -1
  208. package/assets/css/components/panel.css.map +0 -1
  209. package/assets/sass/components/buttons.scss +0 -252
  210. package/assets/sass/components/panel.scss +0 -161
@@ -0,0 +1,633 @@
1
+ /**
2
+ * --------------------------------------------------------------------------
3
+ * Bootstrap (v5.2.3): tooltip.js
4
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
5
+ * --------------------------------------------------------------------------
6
+ */
7
+
8
+ import * as Popper from '@popperjs/core'
9
+ import { defineJQueryPlugin, findShadowRoot, getElement, getUID, isRTL, noop } from './util/index'
10
+ import { DefaultAllowlist } from './util/sanitizer'
11
+ import EventHandler from './dom/event-handler'
12
+ import Manipulator from './dom/manipulator'
13
+ import BaseComponent from './base-component'
14
+ import TemplateFactory from './util/template-factory'
15
+
16
+ /**
17
+ * Constants
18
+ */
19
+
20
+ const NAME = 'tooltip'
21
+ const DISALLOWED_ATTRIBUTES = new Set(['sanitize', 'allowList', 'sanitizeFn'])
22
+
23
+ const CLASS_NAME_FADE = 'fade'
24
+ const CLASS_NAME_MODAL = 'modal'
25
+ const CLASS_NAME_SHOW = 'show'
26
+
27
+ const SELECTOR_TOOLTIP_INNER = '.tooltip-inner'
28
+ const SELECTOR_MODAL = `.${CLASS_NAME_MODAL}`
29
+
30
+ const EVENT_MODAL_HIDE = 'hide.bs.modal'
31
+
32
+ const TRIGGER_HOVER = 'hover'
33
+ const TRIGGER_FOCUS = 'focus'
34
+ const TRIGGER_CLICK = 'click'
35
+ const TRIGGER_MANUAL = 'manual'
36
+
37
+ const EVENT_HIDE = 'hide'
38
+ const EVENT_HIDDEN = 'hidden'
39
+ const EVENT_SHOW = 'show'
40
+ const EVENT_SHOWN = 'shown'
41
+ const EVENT_INSERTED = 'inserted'
42
+ const EVENT_CLICK = 'click'
43
+ const EVENT_FOCUSIN = 'focusin'
44
+ const EVENT_FOCUSOUT = 'focusout'
45
+ const EVENT_MOUSEENTER = 'mouseenter'
46
+ const EVENT_MOUSELEAVE = 'mouseleave'
47
+
48
+ const AttachmentMap = {
49
+ AUTO: 'auto',
50
+ TOP: 'top',
51
+ RIGHT: isRTL() ? 'left' : 'right',
52
+ BOTTOM: 'bottom',
53
+ LEFT: isRTL() ? 'right' : 'left'
54
+ }
55
+
56
+ const Default = {
57
+ allowList: DefaultAllowlist,
58
+ animation: true,
59
+ boundary: 'clippingParents',
60
+ container: false,
61
+ customClass: '',
62
+ delay: 0,
63
+ fallbackPlacements: ['top', 'right', 'bottom', 'left'],
64
+ html: false,
65
+ offset: [0, 0],
66
+ placement: 'top',
67
+ popperConfig: null,
68
+ sanitize: true,
69
+ sanitizeFn: null,
70
+ selector: false,
71
+ template: '<div class="tooltip" role="tooltip">' +
72
+ '<div class="tooltip-arrow"></div>' +
73
+ '<div class="tooltip-inner"></div>' +
74
+ '</div>',
75
+ title: '',
76
+ trigger: 'hover focus'
77
+ }
78
+
79
+ const DefaultType = {
80
+ allowList: 'object',
81
+ animation: 'boolean',
82
+ boundary: '(string|element)',
83
+ container: '(string|element|boolean)',
84
+ customClass: '(string|function)',
85
+ delay: '(number|object)',
86
+ fallbackPlacements: 'array',
87
+ html: 'boolean',
88
+ offset: '(array|string|function)',
89
+ placement: '(string|function)',
90
+ popperConfig: '(null|object|function)',
91
+ sanitize: 'boolean',
92
+ sanitizeFn: '(null|function)',
93
+ selector: '(string|boolean)',
94
+ template: 'string',
95
+ title: '(string|element|function)',
96
+ trigger: 'string'
97
+ }
98
+
99
+ /**
100
+ * Class definition
101
+ */
102
+
103
+ class Tooltip extends BaseComponent {
104
+ constructor(element, config) {
105
+ if (typeof Popper === 'undefined') {
106
+ throw new TypeError('Bootstrap\'s tooltips require Popper (https://popper.js.org)')
107
+ }
108
+
109
+ super(element, config)
110
+
111
+ // Private
112
+ this._isEnabled = true
113
+ this._timeout = 0
114
+ this._isHovered = null
115
+ this._activeTrigger = {}
116
+ this._popper = null
117
+ this._templateFactory = null
118
+ this._newContent = null
119
+
120
+ // Protected
121
+ this.tip = null
122
+
123
+ this._setListeners()
124
+
125
+ if (!this._config.selector) {
126
+ this._fixTitle()
127
+ }
128
+ }
129
+
130
+ // Getters
131
+ static get Default() {
132
+ return Default
133
+ }
134
+
135
+ static get DefaultType() {
136
+ return DefaultType
137
+ }
138
+
139
+ static get NAME() {
140
+ return NAME
141
+ }
142
+
143
+ // Public
144
+ enable() {
145
+ this._isEnabled = true
146
+ }
147
+
148
+ disable() {
149
+ this._isEnabled = false
150
+ }
151
+
152
+ toggleEnabled() {
153
+ this._isEnabled = !this._isEnabled
154
+ }
155
+
156
+ toggle() {
157
+ if (!this._isEnabled) {
158
+ return
159
+ }
160
+
161
+ this._activeTrigger.click = !this._activeTrigger.click
162
+ if (this._isShown()) {
163
+ this._leave()
164
+ return
165
+ }
166
+
167
+ this._enter()
168
+ }
169
+
170
+ dispose() {
171
+ clearTimeout(this._timeout)
172
+
173
+ EventHandler.off(this._element.closest(SELECTOR_MODAL), EVENT_MODAL_HIDE, this._hideModalHandler)
174
+
175
+ if (this._element.getAttribute('data-bs-original-title')) {
176
+ this._element.setAttribute('title', this._element.getAttribute('data-bs-original-title'))
177
+ }
178
+
179
+ this._disposePopper()
180
+ super.dispose()
181
+ }
182
+
183
+ show() {
184
+ if (this._element.style.display === 'none') {
185
+ throw new Error('Please use show on visible elements')
186
+ }
187
+
188
+ if (!(this._isWithContent() && this._isEnabled)) {
189
+ return
190
+ }
191
+
192
+ const showEvent = EventHandler.trigger(this._element, this.constructor.eventName(EVENT_SHOW))
193
+ const shadowRoot = findShadowRoot(this._element)
194
+ const isInTheDom = (shadowRoot || this._element.ownerDocument.documentElement).contains(this._element)
195
+
196
+ if (showEvent.defaultPrevented || !isInTheDom) {
197
+ return
198
+ }
199
+
200
+ // todo v6 remove this OR make it optional
201
+ this._disposePopper()
202
+
203
+ const tip = this._getTipElement()
204
+
205
+ this._element.setAttribute('aria-describedby', tip.getAttribute('id'))
206
+
207
+ const { container } = this._config
208
+
209
+ if (!this._element.ownerDocument.documentElement.contains(this.tip)) {
210
+ container.append(tip)
211
+ EventHandler.trigger(this._element, this.constructor.eventName(EVENT_INSERTED))
212
+ }
213
+
214
+ this._popper = this._createPopper(tip)
215
+
216
+ tip.classList.add(CLASS_NAME_SHOW)
217
+
218
+ // If this is a touch-enabled device we add extra
219
+ // empty mouseover listeners to the body's immediate children;
220
+ // only needed because of broken event delegation on iOS
221
+ // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html
222
+ if ('ontouchstart' in document.documentElement) {
223
+ for (const element of [].concat(...document.body.children)) {
224
+ EventHandler.on(element, 'mouseover', noop)
225
+ }
226
+ }
227
+
228
+ const complete = () => {
229
+ EventHandler.trigger(this._element, this.constructor.eventName(EVENT_SHOWN))
230
+
231
+ if (this._isHovered === false) {
232
+ this._leave()
233
+ }
234
+
235
+ this._isHovered = false
236
+ }
237
+
238
+ this._queueCallback(complete, this.tip, this._isAnimated())
239
+ }
240
+
241
+ hide() {
242
+ if (!this._isShown()) {
243
+ return
244
+ }
245
+
246
+ const hideEvent = EventHandler.trigger(this._element, this.constructor.eventName(EVENT_HIDE))
247
+ if (hideEvent.defaultPrevented) {
248
+ return
249
+ }
250
+
251
+ const tip = this._getTipElement()
252
+ tip.classList.remove(CLASS_NAME_SHOW)
253
+
254
+ // If this is a touch-enabled device we remove the extra
255
+ // empty mouseover listeners we added for iOS support
256
+ if ('ontouchstart' in document.documentElement) {
257
+ for (const element of [].concat(...document.body.children)) {
258
+ EventHandler.off(element, 'mouseover', noop)
259
+ }
260
+ }
261
+
262
+ this._activeTrigger[TRIGGER_CLICK] = false
263
+ this._activeTrigger[TRIGGER_FOCUS] = false
264
+ this._activeTrigger[TRIGGER_HOVER] = false
265
+ this._isHovered = null // it is a trick to support manual triggering
266
+
267
+ const complete = () => {
268
+ if (this._isWithActiveTrigger()) {
269
+ return
270
+ }
271
+
272
+ if (!this._isHovered) {
273
+ this._disposePopper()
274
+ }
275
+
276
+ this._element.removeAttribute('aria-describedby')
277
+ EventHandler.trigger(this._element, this.constructor.eventName(EVENT_HIDDEN))
278
+ }
279
+
280
+ this._queueCallback(complete, this.tip, this._isAnimated())
281
+ }
282
+
283
+ update() {
284
+ if (this._popper) {
285
+ this._popper.update()
286
+ }
287
+ }
288
+
289
+ // Protected
290
+ _isWithContent() {
291
+ return Boolean(this._getTitle())
292
+ }
293
+
294
+ _getTipElement() {
295
+ if (!this.tip) {
296
+ this.tip = this._createTipElement(this._newContent || this._getContentForTemplate())
297
+ }
298
+
299
+ return this.tip
300
+ }
301
+
302
+ _createTipElement(content) {
303
+ const tip = this._getTemplateFactory(content).toHtml()
304
+
305
+ // todo: remove this check on v6
306
+ if (!tip) {
307
+ return null
308
+ }
309
+
310
+ tip.classList.remove(CLASS_NAME_FADE, CLASS_NAME_SHOW)
311
+ // todo: on v6 the following can be achieved with CSS only
312
+ tip.classList.add(`bs-${this.constructor.NAME}-auto`)
313
+
314
+ const tipId = getUID(this.constructor.NAME).toString()
315
+
316
+ tip.setAttribute('id', tipId)
317
+
318
+ if (this._isAnimated()) {
319
+ tip.classList.add(CLASS_NAME_FADE)
320
+ }
321
+
322
+ return tip
323
+ }
324
+
325
+ setContent(content) {
326
+ this._newContent = content
327
+ if (this._isShown()) {
328
+ this._disposePopper()
329
+ this.show()
330
+ }
331
+ }
332
+
333
+ _getTemplateFactory(content) {
334
+ if (this._templateFactory) {
335
+ this._templateFactory.changeContent(content)
336
+ } else {
337
+ this._templateFactory = new TemplateFactory({
338
+ ...this._config,
339
+ // the `content` var has to be after `this._config`
340
+ // to override config.content in case of popover
341
+ content,
342
+ extraClass: this._resolvePossibleFunction(this._config.customClass)
343
+ })
344
+ }
345
+
346
+ return this._templateFactory
347
+ }
348
+
349
+ _getContentForTemplate() {
350
+ return {
351
+ [SELECTOR_TOOLTIP_INNER]: this._getTitle()
352
+ }
353
+ }
354
+
355
+ _getTitle() {
356
+ return this._resolvePossibleFunction(this._config.title) || this._element.getAttribute('data-bs-original-title')
357
+ }
358
+
359
+ // Private
360
+ _initializeOnDelegatedTarget(event) {
361
+ return this.constructor.getOrCreateInstance(event.delegateTarget, this._getDelegateConfig())
362
+ }
363
+
364
+ _isAnimated() {
365
+ return this._config.animation || (this.tip && this.tip.classList.contains(CLASS_NAME_FADE))
366
+ }
367
+
368
+ _isShown() {
369
+ return this.tip && this.tip.classList.contains(CLASS_NAME_SHOW)
370
+ }
371
+
372
+ _createPopper(tip) {
373
+ const placement = typeof this._config.placement === 'function' ?
374
+ this._config.placement.call(this, tip, this._element) :
375
+ this._config.placement
376
+ const attachment = AttachmentMap[placement.toUpperCase()]
377
+ return Popper.createPopper(this._element, tip, this._getPopperConfig(attachment))
378
+ }
379
+
380
+ _getOffset() {
381
+ const { offset } = this._config
382
+
383
+ if (typeof offset === 'string') {
384
+ return offset.split(',').map(value => Number.parseInt(value, 10))
385
+ }
386
+
387
+ if (typeof offset === 'function') {
388
+ return popperData => offset(popperData, this._element)
389
+ }
390
+
391
+ return offset
392
+ }
393
+
394
+ _resolvePossibleFunction(arg) {
395
+ return typeof arg === 'function' ? arg.call(this._element) : arg
396
+ }
397
+
398
+ _getPopperConfig(attachment) {
399
+ const defaultBsPopperConfig = {
400
+ placement: attachment,
401
+ modifiers: [
402
+ {
403
+ name: 'flip',
404
+ options: {
405
+ fallbackPlacements: this._config.fallbackPlacements
406
+ }
407
+ },
408
+ {
409
+ name: 'offset',
410
+ options: {
411
+ offset: this._getOffset()
412
+ }
413
+ },
414
+ {
415
+ name: 'preventOverflow',
416
+ options: {
417
+ boundary: this._config.boundary
418
+ }
419
+ },
420
+ {
421
+ name: 'arrow',
422
+ options: {
423
+ element: `.${this.constructor.NAME}-arrow`
424
+ }
425
+ },
426
+ {
427
+ name: 'preSetPlacement',
428
+ enabled: true,
429
+ phase: 'beforeMain',
430
+ fn: data => {
431
+ // Pre-set Popper's placement attribute in order to read the arrow sizes properly.
432
+ // Otherwise, Popper mixes up the width and height dimensions since the initial arrow style is for top placement
433
+ this._getTipElement().setAttribute('data-popper-placement', data.state.placement)
434
+ }
435
+ }
436
+ ]
437
+ }
438
+
439
+ return {
440
+ ...defaultBsPopperConfig,
441
+ ...(typeof this._config.popperConfig === 'function' ? this._config.popperConfig(defaultBsPopperConfig) : this._config.popperConfig)
442
+ }
443
+ }
444
+
445
+ _setListeners() {
446
+ const triggers = this._config.trigger.split(' ')
447
+
448
+ for (const trigger of triggers) {
449
+ if (trigger === 'click') {
450
+ EventHandler.on(this._element, this.constructor.eventName(EVENT_CLICK), this._config.selector, event => {
451
+ const context = this._initializeOnDelegatedTarget(event)
452
+ context.toggle()
453
+ })
454
+ } else if (trigger !== TRIGGER_MANUAL) {
455
+ const eventIn = trigger === TRIGGER_HOVER ?
456
+ this.constructor.eventName(EVENT_MOUSEENTER) :
457
+ this.constructor.eventName(EVENT_FOCUSIN)
458
+ const eventOut = trigger === TRIGGER_HOVER ?
459
+ this.constructor.eventName(EVENT_MOUSELEAVE) :
460
+ this.constructor.eventName(EVENT_FOCUSOUT)
461
+
462
+ EventHandler.on(this._element, eventIn, this._config.selector, event => {
463
+ const context = this._initializeOnDelegatedTarget(event)
464
+ context._activeTrigger[event.type === 'focusin' ? TRIGGER_FOCUS : TRIGGER_HOVER] = true
465
+ context._enter()
466
+ })
467
+ EventHandler.on(this._element, eventOut, this._config.selector, event => {
468
+ const context = this._initializeOnDelegatedTarget(event)
469
+ context._activeTrigger[event.type === 'focusout' ? TRIGGER_FOCUS : TRIGGER_HOVER] =
470
+ context._element.contains(event.relatedTarget)
471
+
472
+ context._leave()
473
+ })
474
+ }
475
+ }
476
+
477
+ this._hideModalHandler = () => {
478
+ if (this._element) {
479
+ this.hide()
480
+ }
481
+ }
482
+
483
+ EventHandler.on(this._element.closest(SELECTOR_MODAL), EVENT_MODAL_HIDE, this._hideModalHandler)
484
+ }
485
+
486
+ _fixTitle() {
487
+ const title = this._element.getAttribute('title')
488
+
489
+ if (!title) {
490
+ return
491
+ }
492
+
493
+ if (!this._element.getAttribute('aria-label') && !this._element.textContent.trim()) {
494
+ this._element.setAttribute('aria-label', title)
495
+ }
496
+
497
+ this._element.setAttribute('data-bs-original-title', title) // DO NOT USE IT. Is only for backwards compatibility
498
+ this._element.removeAttribute('title')
499
+ }
500
+
501
+ _enter() {
502
+ if (this._isShown() || this._isHovered) {
503
+ this._isHovered = true
504
+ return
505
+ }
506
+
507
+ this._isHovered = true
508
+
509
+ this._setTimeout(() => {
510
+ if (this._isHovered) {
511
+ this.show()
512
+ }
513
+ }, this._config.delay.show)
514
+ }
515
+
516
+ _leave() {
517
+ if (this._isWithActiveTrigger()) {
518
+ return
519
+ }
520
+
521
+ this._isHovered = false
522
+
523
+ this._setTimeout(() => {
524
+ if (!this._isHovered) {
525
+ this.hide()
526
+ }
527
+ }, this._config.delay.hide)
528
+ }
529
+
530
+ _setTimeout(handler, timeout) {
531
+ clearTimeout(this._timeout)
532
+ this._timeout = setTimeout(handler, timeout)
533
+ }
534
+
535
+ _isWithActiveTrigger() {
536
+ return Object.values(this._activeTrigger).includes(true)
537
+ }
538
+
539
+ _getConfig(config) {
540
+ const dataAttributes = Manipulator.getDataAttributes(this._element)
541
+
542
+ for (const dataAttribute of Object.keys(dataAttributes)) {
543
+ if (DISALLOWED_ATTRIBUTES.has(dataAttribute)) {
544
+ delete dataAttributes[dataAttribute]
545
+ }
546
+ }
547
+
548
+ config = {
549
+ ...dataAttributes,
550
+ ...(typeof config === 'object' && config ? config : {})
551
+ }
552
+ config = this._mergeConfigObj(config)
553
+ config = this._configAfterMerge(config)
554
+ this._typeCheckConfig(config)
555
+ return config
556
+ }
557
+
558
+ _configAfterMerge(config) {
559
+ config.container = config.container === false ? document.body : getElement(config.container)
560
+
561
+ if (typeof config.delay === 'number') {
562
+ config.delay = {
563
+ show: config.delay,
564
+ hide: config.delay
565
+ }
566
+ }
567
+
568
+ if (typeof config.title === 'number') {
569
+ config.title = config.title.toString()
570
+ }
571
+
572
+ if (typeof config.content === 'number') {
573
+ config.content = config.content.toString()
574
+ }
575
+
576
+ return config
577
+ }
578
+
579
+ _getDelegateConfig() {
580
+ const config = {}
581
+
582
+ for (const key in this._config) {
583
+ if (this.constructor.Default[key] !== this._config[key]) {
584
+ config[key] = this._config[key]
585
+ }
586
+ }
587
+
588
+ config.selector = false
589
+ config.trigger = 'manual'
590
+
591
+ // In the future can be replaced with:
592
+ // const keysWithDifferentValues = Object.entries(this._config).filter(entry => this.constructor.Default[entry[0]] !== this._config[entry[0]])
593
+ // `Object.fromEntries(keysWithDifferentValues)`
594
+ return config
595
+ }
596
+
597
+ _disposePopper() {
598
+ if (this._popper) {
599
+ this._popper.destroy()
600
+ this._popper = null
601
+ }
602
+
603
+ if (this.tip) {
604
+ this.tip.remove()
605
+ this.tip = null
606
+ }
607
+ }
608
+
609
+ // Static
610
+ static jQueryInterface(config) {
611
+ return this.each(function () {
612
+ const data = Tooltip.getOrCreateInstance(this, config)
613
+
614
+ if (typeof config !== 'string') {
615
+ return
616
+ }
617
+
618
+ if (typeof data[config] === 'undefined') {
619
+ throw new TypeError(`No method named "${config}"`)
620
+ }
621
+
622
+ data[config]()
623
+ })
624
+ }
625
+ }
626
+
627
+ /**
628
+ * jQuery
629
+ */
630
+
631
+ defineJQueryPlugin(Tooltip)
632
+
633
+ export default Tooltip