@gitlab/ui 114.1.0 → 114.1.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.
Files changed (141) hide show
  1. package/dist/components/base/breadcrumb/breadcrumb.js +4 -16
  2. package/dist/index.css +1 -1
  3. package/dist/index.css.map +1 -1
  4. package/package.json +7 -26
  5. package/src/components/base/breadcrumb/breadcrumb.scss +18 -2
  6. package/src/components/base/breadcrumb/breadcrumb.vue +4 -17
  7. package/CHANGELOG.md +0 -13139
  8. package/src/vendor/bootstrap/LICENSE +0 -11
  9. package/src/vendor/bootstrap-vue/LICENSE +0 -11
  10. package/src/vendor/bootstrap-vue/package.json +0 -144
  11. package/src/vendor/bootstrap-vue/src/components/button/MODIFICATIONS.md +0 -16
  12. package/src/vendor/bootstrap-vue/src/components/button/README.md +0 -240
  13. package/src/vendor/bootstrap-vue/src/components/button/button-close.spec.js +0 -210
  14. package/src/vendor/bootstrap-vue/src/components/button/button.spec.js +0 -349
  15. package/src/vendor/bootstrap-vue/src/components/button/package.json +0 -105
  16. package/src/vendor/bootstrap-vue/src/components/dropdown/README.md +0 -730
  17. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-divider.spec.js +0 -58
  18. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-form.spec.js +0 -110
  19. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-group.spec.js +0 -94
  20. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-header.spec.js +0 -73
  21. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item-button.spec.js +0 -117
  22. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.spec.js +0 -147
  23. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.spec.js +0 -59
  24. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown.spec.js +0 -1121
  25. package/src/vendor/bootstrap-vue/src/components/dropdown/package.json +0 -368
  26. package/src/vendor/bootstrap-vue/src/components/form/README.md +0 -365
  27. package/src/vendor/bootstrap-vue/src/components/form/form-invalid-feedback.spec.js +0 -170
  28. package/src/vendor/bootstrap-vue/src/components/form/form-text.spec.js +0 -93
  29. package/src/vendor/bootstrap-vue/src/components/form/form-valid-feedback.spec.js +0 -157
  30. package/src/vendor/bootstrap-vue/src/components/form/form.spec.js +0 -97
  31. package/src/vendor/bootstrap-vue/src/components/form/package.json +0 -112
  32. package/src/vendor/bootstrap-vue/src/components/form-checkbox/README.md +0 -691
  33. package/src/vendor/bootstrap-vue/src/components/form-checkbox/form-checkbox-group.spec.js +0 -525
  34. package/src/vendor/bootstrap-vue/src/components/form-checkbox/form-checkbox.spec.js +0 -922
  35. package/src/vendor/bootstrap-vue/src/components/form-checkbox/package.json +0 -172
  36. package/src/vendor/bootstrap-vue/src/components/form-group/README.md +0 -339
  37. package/src/vendor/bootstrap-vue/src/components/form-group/form-group.spec.js +0 -477
  38. package/src/vendor/bootstrap-vue/src/components/form-group/package.json +0 -183
  39. package/src/vendor/bootstrap-vue/src/components/form-radio/README.md +0 -437
  40. package/src/vendor/bootstrap-vue/src/components/form-radio/form-radio-group.spec.js +0 -357
  41. package/src/vendor/bootstrap-vue/src/components/form-radio/form-radio.spec.js +0 -587
  42. package/src/vendor/bootstrap-vue/src/components/form-radio/package.json +0 -162
  43. package/src/vendor/bootstrap-vue/src/components/form-select/README.md +0 -504
  44. package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option-group.spec.js +0 -138
  45. package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option.spec.js +0 -75
  46. package/src/vendor/bootstrap-vue/src/components/form-select/form-select.spec.js +0 -723
  47. package/src/vendor/bootstrap-vue/src/components/form-select/package.json +0 -132
  48. package/src/vendor/bootstrap-vue/src/components/form-textarea/README.md +0 -453
  49. package/src/vendor/bootstrap-vue/src/components/form-textarea/form-textarea.spec.js +0 -1000
  50. package/src/vendor/bootstrap-vue/src/components/form-textarea/package.json +0 -122
  51. package/src/vendor/bootstrap-vue/src/components/layout/README.md +0 -791
  52. package/src/vendor/bootstrap-vue/src/components/layout/col.spec.js +0 -192
  53. package/src/vendor/bootstrap-vue/src/components/layout/form-row.spec.js +0 -45
  54. package/src/vendor/bootstrap-vue/src/components/layout/package.json +0 -99
  55. package/src/vendor/bootstrap-vue/src/components/link/README.md +0 -76
  56. package/src/vendor/bootstrap-vue/src/components/link/link.spec.js +0 -434
  57. package/src/vendor/bootstrap-vue/src/components/link/package.json +0 -57
  58. package/src/vendor/bootstrap-vue/src/components/modal/MODIFICATIONS.md +0 -30
  59. package/src/vendor/bootstrap-vue/src/components/modal/README.md +0 -1067
  60. package/src/vendor/bootstrap-vue/src/components/modal/helpers/bv-modal-event.class.spec.js +0 -82
  61. package/src/vendor/bootstrap-vue/src/components/modal/modal.spec.js +0 -1418
  62. package/src/vendor/bootstrap-vue/src/components/modal/package.json +0 -544
  63. package/src/vendor/bootstrap-vue/src/components/nav/README.md +0 -362
  64. package/src/vendor/bootstrap-vue/src/components/nav/nav-item.spec.js +0 -127
  65. package/src/vendor/bootstrap-vue/src/components/nav/nav.spec.js +0 -177
  66. package/src/vendor/bootstrap-vue/src/components/nav/package.json +0 -73
  67. package/src/vendor/bootstrap-vue/src/components/popover/README.md +0 -919
  68. package/src/vendor/bootstrap-vue/src/components/popover/package.json +0 -261
  69. package/src/vendor/bootstrap-vue/src/components/popover/popover.spec.js +0 -198
  70. package/src/vendor/bootstrap-vue/src/components/table/README.md +0 -3157
  71. package/src/vendor/bootstrap-vue/src/components/table/helpers/default-sort-compare.spec.js +0 -112
  72. package/src/vendor/bootstrap-vue/src/components/table/helpers/normalize-fields.spec.js +0 -93
  73. package/src/vendor/bootstrap-vue/src/components/table/package.json +0 -1763
  74. package/src/vendor/bootstrap-vue/src/components/table/table-busy.spec.js +0 -150
  75. package/src/vendor/bootstrap-vue/src/components/table/table-caption.spec.js +0 -176
  76. package/src/vendor/bootstrap-vue/src/components/table/table-colgroup.spec.js +0 -81
  77. package/src/vendor/bootstrap-vue/src/components/table/table-filtering.spec.js +0 -409
  78. package/src/vendor/bootstrap-vue/src/components/table/table-item-formatter.spec.js +0 -56
  79. package/src/vendor/bootstrap-vue/src/components/table/table-lite.spec.js +0 -682
  80. package/src/vendor/bootstrap-vue/src/components/table/table-pagination.spec.js +0 -133
  81. package/src/vendor/bootstrap-vue/src/components/table/table-primarykey.spec.js +0 -83
  82. package/src/vendor/bootstrap-vue/src/components/table/table-provider.spec.js +0 -411
  83. package/src/vendor/bootstrap-vue/src/components/table/table-row-details.spec.js +0 -459
  84. package/src/vendor/bootstrap-vue/src/components/table/table-selectable.spec.js +0 -1182
  85. package/src/vendor/bootstrap-vue/src/components/table/table-simple.spec.js +0 -206
  86. package/src/vendor/bootstrap-vue/src/components/table/table-sorting.spec.js +0 -858
  87. package/src/vendor/bootstrap-vue/src/components/table/table-sticky-column.spec.js +0 -377
  88. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-bottom-row.spec.js +0 -94
  89. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-row-events.spec.js +0 -529
  90. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-top-row.spec.js +0 -88
  91. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-transition.spec.js +0 -83
  92. package/src/vendor/bootstrap-vue/src/components/table/table-tfoot-custom.spec.js +0 -91
  93. package/src/vendor/bootstrap-vue/src/components/table/table-tfoot-events.spec.js +0 -137
  94. package/src/vendor/bootstrap-vue/src/components/table/table-thead-events.spec.js +0 -155
  95. package/src/vendor/bootstrap-vue/src/components/table/table-thead-top.spec.js +0 -96
  96. package/src/vendor/bootstrap-vue/src/components/table/table.spec.js +0 -692
  97. package/src/vendor/bootstrap-vue/src/components/tabs/README.md +0 -433
  98. package/src/vendor/bootstrap-vue/src/components/tabs/package.json +0 -205
  99. package/src/vendor/bootstrap-vue/src/components/tabs/tab.spec.js +0 -330
  100. package/src/vendor/bootstrap-vue/src/components/tabs/tabs.spec.js +0 -778
  101. package/src/vendor/bootstrap-vue/src/components/toast/README.md +0 -655
  102. package/src/vendor/bootstrap-vue/src/components/toast/helpers/bv-toast.spec.js +0 -117
  103. package/src/vendor/bootstrap-vue/src/components/toast/package.json +0 -184
  104. package/src/vendor/bootstrap-vue/src/components/toast/toast.spec.js +0 -294
  105. package/src/vendor/bootstrap-vue/src/components/toast/toaster.spec.js +0 -77
  106. package/src/vendor/bootstrap-vue/src/components/tooltip/README.md +0 -559
  107. package/src/vendor/bootstrap-vue/src/components/tooltip/package.json +0 -258
  108. package/src/vendor/bootstrap-vue/src/components/tooltip/tooltip.spec.js +0 -1240
  109. package/src/vendor/bootstrap-vue/src/components/transition/package.json +0 -5
  110. package/src/vendor/bootstrap-vue/src/components/transporter/package.json +0 -5
  111. package/src/vendor/bootstrap-vue/src/components/transporter/transporter.spec.js +0 -85
  112. package/src/vendor/bootstrap-vue/src/directives/modal/modal.spec.js +0 -191
  113. package/src/vendor/bootstrap-vue/src/directives/tooltip/README.md +0 -521
  114. package/src/vendor/bootstrap-vue/src/directives/tooltip/package.json +0 -131
  115. package/src/vendor/bootstrap-vue/src/directives/tooltip/tooltip.spec.js +0 -190
  116. package/src/vendor/bootstrap-vue/src/directives/visible/README.md +0 -244
  117. package/src/vendor/bootstrap-vue/src/directives/visible/package.json +0 -24
  118. package/src/vendor/bootstrap-vue/src/mixins/attrs.spec.js +0 -194
  119. package/src/vendor/bootstrap-vue/src/mixins/click-out.spec.js +0 -52
  120. package/src/vendor/bootstrap-vue/src/mixins/focus-in.spec.js +0 -53
  121. package/src/vendor/bootstrap-vue/src/mixins/listen-on-document.spec.js +0 -117
  122. package/src/vendor/bootstrap-vue/src/mixins/listen-on-root.spec.js +0 -77
  123. package/src/vendor/bootstrap-vue/src/mixins/listen-on-window.spec.js +0 -115
  124. package/src/vendor/bootstrap-vue/src/mixins/listeners.spec.js +0 -245
  125. package/src/vendor/bootstrap-vue/src/utils/bv-event.class.spec.js +0 -66
  126. package/src/vendor/bootstrap-vue/src/utils/clone-deep.spec.js +0 -70
  127. package/src/vendor/bootstrap-vue/src/utils/config.spec.js +0 -169
  128. package/src/vendor/bootstrap-vue/src/utils/css-escape.spec.js +0 -82
  129. package/src/vendor/bootstrap-vue/src/utils/dom.spec.js +0 -291
  130. package/src/vendor/bootstrap-vue/src/utils/events.spec.js +0 -41
  131. package/src/vendor/bootstrap-vue/src/utils/get.spec.js +0 -109
  132. package/src/vendor/bootstrap-vue/src/utils/inspect.spec.js +0 -251
  133. package/src/vendor/bootstrap-vue/src/utils/loose-equal.spec.js +0 -203
  134. package/src/vendor/bootstrap-vue/src/utils/normalize-slot.spec.js +0 -63
  135. package/src/vendor/bootstrap-vue/src/utils/number.spec.js +0 -72
  136. package/src/vendor/bootstrap-vue/src/utils/object.spec.js +0 -61
  137. package/src/vendor/bootstrap-vue/src/utils/props.spec.js +0 -112
  138. package/src/vendor/bootstrap-vue/src/utils/router.spec.js +0 -248
  139. package/src/vendor/bootstrap-vue/src/utils/string.spec.js +0 -65
  140. package/src/vendor/bootstrap-vue/src/utils/stringify-object-values.spec.js +0 -47
  141. package/src/vendor/bootstrap-vue/src/utils/warn.spec.js +0 -54
@@ -1,117 +0,0 @@
1
- import { createWrapper, mount } from '@vue/test-utils'
2
- import { Vue } from '../../../vue'
3
- import { waitNT, waitRAF } from '../../../../tests/utils'
4
- import { ToastPlugin } from '../index'
5
-
6
- Vue.use(ToastPlugin)
7
-
8
- describe('$bvToast', () => {
9
- it('$bvToast.show() and $bvToast.hide() works', async () => {
10
- const App = {
11
- render(h) {
12
- return h(
13
- 'b-toast',
14
- {
15
- props: {
16
- id: 'test1',
17
- static: true,
18
- visible: false,
19
- noAutoHide: true
20
- }
21
- },
22
- 'content'
23
- )
24
- }
25
- }
26
- const wrapper = mount(App, {
27
- attachTo: document.body
28
- })
29
-
30
- expect(wrapper.vm).toBeDefined()
31
-
32
- await waitNT(wrapper.vm)
33
- await waitRAF()
34
- await waitNT(wrapper.vm)
35
- await waitRAF()
36
-
37
- expect(wrapper.vm.$bvToast).toBeDefined()
38
- expect(wrapper.vm.$bvToast.show).toBeDefined()
39
- expect(typeof wrapper.vm.$bvToast.show).toEqual('function')
40
- expect(wrapper.vm.$bvToast.hide).toBeDefined()
41
- expect(typeof wrapper.vm.$bvToast.hide).toEqual('function')
42
-
43
- expect(wrapper.find('.toast').exists()).toBe(false)
44
-
45
- wrapper.vm.$bvToast.show('test1')
46
-
47
- await waitNT(wrapper.vm)
48
- await waitRAF()
49
- await waitNT(wrapper.vm)
50
- await waitRAF()
51
- await waitNT(wrapper.vm)
52
- await waitRAF()
53
-
54
- expect(wrapper.find('.toast').exists()).toBe(true)
55
-
56
- wrapper.vm.$bvToast.hide('test1')
57
-
58
- await waitNT(wrapper.vm)
59
- await waitRAF()
60
- await waitNT(wrapper.vm)
61
- await waitRAF()
62
- await waitNT(wrapper.vm)
63
- await waitRAF()
64
-
65
- expect(wrapper.find('.toast').exists()).toBe(false)
66
-
67
- wrapper.destroy()
68
- })
69
-
70
- it('$bvModal.toast() works', async () => {
71
- const App = {
72
- render(h) {
73
- return h('div', 'app')
74
- }
75
- }
76
- const wrapper = mount(App, {
77
- attachTo: document.body
78
- })
79
-
80
- expect(wrapper.vm).toBeDefined()
81
-
82
- // `$bvModal.toast`
83
- expect(wrapper.vm.$bvToast).toBeDefined()
84
- const bvToast = wrapper.vm.$bvToast
85
- expect(bvToast.toast).toBeDefined()
86
- expect(typeof bvToast.toast).toEqual('function')
87
-
88
- // Trigger a toast
89
- bvToast.toast('message', {
90
- id: 'test2',
91
- title: 'title',
92
- noAutoHide: true
93
- })
94
-
95
- await waitNT(wrapper.vm)
96
- await waitRAF()
97
- await waitNT(wrapper.vm)
98
- await waitRAF()
99
- await waitNT(wrapper.vm)
100
- await waitRAF()
101
-
102
- // Find the toast
103
- const toast = document.querySelector('#test2')
104
- expect(toast).toBeDefined()
105
- expect(toast).not.toEqual(null)
106
- const $toast = createWrapper(toast)
107
- expect($toast.element.tagName).toBe('DIV')
108
-
109
- // Find header
110
- expect($toast.find('.toast-header').exists()).toBe(true)
111
- expect($toast.find('.toast-header').text()).toContain('title')
112
-
113
- // Find body
114
- expect($toast.find('.toast-body').exists()).toBe(true)
115
- expect($toast.find('.toast-body').text()).toContain('message')
116
- })
117
- })
@@ -1,184 +0,0 @@
1
- {
2
- "name": "@bootstrap-vue/toast",
3
- "version": "1.0.0",
4
- "meta": {
5
- "title": "Toast",
6
- "slug": "toast",
7
- "description": "Push notifications to your visitors with a toast, a lightweight and easily customizable alert message.",
8
- "plugins": [
9
- "BVToastPlugin"
10
- ],
11
- "components": [
12
- {
13
- "component": "BToast",
14
- "props": [
15
- {
16
- "prop": "appendToast",
17
- "description": "When true, the toast will be appended to the bottom on the visible toasts, otherwise it will be prepended"
18
- },
19
- {
20
- "prop": "autoHideDelay",
21
- "description": "The number of milliseconds before the toast auto dismisses itself"
22
- },
23
- {
24
- "prop": "bodyClass",
25
- "description": "CSS class (or classes) to add to the toast body element"
26
- },
27
- {
28
- "prop": "headerClass",
29
- "description": "CSS class (or classes) to add to the toast header element"
30
- },
31
- {
32
- "prop": "headerTag",
33
- "version": "2.22.0",
34
- "description": "Specify the HTML tag to render instead of the default tag for the footer"
35
- },
36
- {
37
- "prop": "isStatus",
38
- "description": "When set to 'true', makes the toast have attributes aria-live=polite and role=status. When 'false' aria-live will be 'assertive' and role will be 'alert'"
39
- },
40
- {
41
- "prop": "noAutoHide",
42
- "description": "When set, disabled the toast from automatically dismissing itself"
43
- },
44
- {
45
- "prop": "noHoverPause",
46
- "description": "When set, disables the pausing of the auto hide delay when the mouse hovers the toast"
47
- },
48
- {
49
- "prop": "solid",
50
- "description": "When set, renderes the toast with a solid background rather than translucent"
51
- },
52
- {
53
- "prop": "title",
54
- "description": "The toast's title text"
55
- },
56
- {
57
- "prop": "toastClass",
58
- "description": "CSS class (or classes) to add to the toast wrapper element"
59
- },
60
- {
61
- "prop": "toaster",
62
- "description": "The name of the toaster target to render the toast in"
63
- },
64
- {
65
- "prop": "variant",
66
- "description": "Applies one of the Bootstrap theme color variants to the component"
67
- },
68
- {
69
- "prop": "visible",
70
- "description": "When true, shows the toast"
71
- }
72
- ],
73
- "events": [
74
- {
75
- "event": "change",
76
- "description": "Toast visibility state. Used to update the v-model",
77
- "args": [
78
- {
79
- "arg": "visible",
80
- "type": "Boolean",
81
- "description": "`true` if toast is visible, `false` otherwise"
82
- }
83
- ]
84
- },
85
- {
86
- "event": "hidden",
87
- "description": "Always emits after toast is hidden",
88
- "args": [
89
- {
90
- "arg": "bvEvent",
91
- "type": "BvEvent",
92
- "description": "BvEvent object"
93
- }
94
- ]
95
- },
96
- {
97
- "event": "hide",
98
- "description": "Always emits just before toast has hidden",
99
- "args": [
100
- {
101
- "arg": "bvEvent",
102
- "type": "BvEvent",
103
- "description": "BvEvent object"
104
- }
105
- ]
106
- },
107
- {
108
- "event": "show",
109
- "description": "Always emits just before toast is shown",
110
- "args": [
111
- {
112
- "arg": "bvEvent",
113
- "type": "BvEvent",
114
- "description": "BvEvent object"
115
- }
116
- ]
117
- },
118
- {
119
- "event": "shown",
120
- "description": "Always emits when toast is shown",
121
- "args": [
122
- {
123
- "arg": "bvEvent",
124
- "type": "BvEvent",
125
- "description": "BvEvent object"
126
- }
127
- ]
128
- }
129
- ],
130
- "slots": [
131
- {
132
- "name": "default",
133
- "description": "Toast body content. Optionally scoped",
134
- "scope": [
135
- {
136
- "prop": "hide",
137
- "type": "Function",
138
- "description": "Hides the toast when called. Useful if you are providing your own close button"
139
- }
140
- ]
141
- },
142
- {
143
- "name": "toast-title",
144
- "description": "Toast title. Optionally scoped",
145
- "scope": [
146
- {
147
- "prop": "hide",
148
- "type": "Function",
149
- "description": "Hides the toast when called. Useful if you are providing your own close button"
150
- }
151
- ]
152
- }
153
- ]
154
- },
155
- {
156
- "component": "BToaster",
157
- "props": [
158
- {
159
- "prop": "ariaAtomic",
160
- "description": "When screen reader's should read out the entire contents (set to string 'true') or just the changes (set to string 'false'). Leave blank for most cases"
161
- },
162
- {
163
- "prop": "ariaLive",
164
- "description": "When the rendered element is an aria-live region (for screen reader users), set to either 'polite' or 'assertive'"
165
- },
166
- {
167
- "prop": "name",
168
- "description": "The toaster's target name"
169
- },
170
- {
171
- "prop": "role",
172
- "description": "Sets the ARIA attribute 'role' to a specific value"
173
- }
174
- ],
175
- "slots": [
176
- {
177
- "name": "default",
178
- "description": "Content (toasts) to place in the toaster element"
179
- }
180
- ]
181
- }
182
- ]
183
- }
184
- }
@@ -1,294 +0,0 @@
1
- import { mount } from '@vue/test-utils'
2
- import { ensureEventEmitted, waitNT, waitRAF } from '../../../tests/utils'
3
- import { BToast } from './toast'
4
-
5
- describe('b-toast', () => {
6
- beforeAll(() => {
7
- // Prevent multiple Vue warnings in tests
8
- jest.spyOn(console, 'warn').mockImplementation(() => {})
9
- })
10
-
11
- afterAll(() => {
12
- console.warn.mockClear()
13
- })
14
-
15
- it('has expected structure', async () => {
16
- const wrapper = mount(BToast, {
17
- attachTo: document.body,
18
- propsData: {
19
- static: true,
20
- noAutoHide: true,
21
- visible: true,
22
- title: 'title'
23
- },
24
- slots: {
25
- default: 'content'
26
- }
27
- })
28
-
29
- expect(wrapper.vm).toBeDefined()
30
- await waitNT(wrapper.vm)
31
- await waitRAF()
32
- await waitNT(wrapper.vm)
33
- await waitRAF()
34
-
35
- expect(wrapper.element.tagName).toBe('DIV')
36
- expect(wrapper.classes()).toContain('b-toast')
37
- expect(wrapper.classes()).toContain('b-toast-prepend')
38
- expect(wrapper.classes().length).toBe(2)
39
- expect(wrapper.attributes('role')).toEqual('alert')
40
- expect(wrapper.attributes('aria-live')).toEqual('assertive')
41
- expect(wrapper.attributes('aria-atomic')).toEqual('true')
42
-
43
- expect(wrapper.find('.toast').exists()).toBe(true)
44
- const $toast = wrapper.find('.toast')
45
- expect($toast.element.tagName).toBe('DIV')
46
- expect($toast.classes()).toContain('toast')
47
- expect($toast.attributes('tabindex')).toEqual('0')
48
-
49
- expect($toast.find('.toast-body').exists()).toBe(true)
50
- const $body = $toast.find('.toast-body')
51
- expect($body.element.tagName).toBe('DIV')
52
- expect($body.classes().length).toBe(1)
53
- expect($body.text()).toEqual('content')
54
-
55
- wrapper.destroy()
56
- })
57
-
58
- it('visible prop works', async () => {
59
- const wrapper = mount(BToast, {
60
- attachTo: document.body,
61
- propsData: {
62
- static: true,
63
- noAutoHide: true,
64
- visible: false,
65
- title: 'title',
66
- href: '#foobar'
67
- },
68
- slots: {
69
- default: 'content'
70
- }
71
- })
72
-
73
- expect(wrapper.vm).toBeDefined()
74
- await waitNT(wrapper.vm)
75
- await waitRAF()
76
- await waitNT(wrapper.vm)
77
- await waitRAF()
78
- await waitNT(wrapper.vm)
79
- await waitRAF()
80
-
81
- expect(wrapper.element.nodeType).toBe(Node.COMMENT_NODE)
82
-
83
- expect(wrapper.emitted('show')).toBeUndefined()
84
- expect(wrapper.emitted('shown')).toBeUndefined()
85
- expect(wrapper.emitted('hide')).toBeUndefined()
86
- expect(wrapper.emitted('hidden')).toBeUndefined()
87
-
88
- await wrapper.setProps({ visible: true })
89
- await waitRAF()
90
- await waitNT(wrapper.vm)
91
- await waitRAF()
92
- await waitNT(wrapper.vm)
93
- await waitRAF()
94
-
95
- expect(wrapper.element.tagName).toBe('DIV')
96
-
97
- expect(wrapper.emitted('show')).toBeDefined()
98
- expect(wrapper.emitted('shown')).toBeDefined()
99
- expect(wrapper.emitted('hide')).toBeUndefined()
100
- expect(wrapper.emitted('hidden')).toBeUndefined()
101
- expect(wrapper.emitted('show').length).toBe(1)
102
- expect(wrapper.emitted('shown').length).toBe(1)
103
-
104
- await wrapper.setProps({ visible: false })
105
- await waitRAF()
106
- await waitNT(wrapper.vm)
107
- await waitRAF()
108
- await waitNT(wrapper.vm)
109
- await waitRAF()
110
-
111
- expect(wrapper.element.nodeType).toBe(Node.COMMENT_NODE)
112
-
113
- expect(wrapper.emitted('show')).toBeDefined()
114
- expect(wrapper.emitted('shown')).toBeDefined()
115
- expect(wrapper.emitted('hide')).toBeDefined()
116
- expect(wrapper.emitted('hidden')).toBeDefined()
117
- expect(wrapper.emitted('show').length).toBe(1)
118
- expect(wrapper.emitted('shown').length).toBe(1)
119
- expect(wrapper.emitted('hide').length).toBe(1)
120
- expect(wrapper.emitted('hidden').length).toBe(1)
121
-
122
- wrapper.destroy()
123
- })
124
-
125
- it('alert with link closes on click works', async () => {
126
- const wrapper = mount(BToast, {
127
- attachTo: document.body,
128
- propsData: {
129
- static: true,
130
- noAutoHide: true,
131
- visible: true,
132
- title: 'title',
133
- href: '#foobar'
134
- },
135
- slots: {
136
- default: 'content'
137
- }
138
- })
139
-
140
- expect(wrapper.vm).toBeDefined()
141
- await waitNT(wrapper.vm)
142
- await waitRAF()
143
- await waitNT(wrapper.vm)
144
- await waitRAF()
145
- await waitNT(wrapper.vm)
146
- await waitRAF()
147
- await waitNT(wrapper.vm)
148
-
149
- expect(wrapper.element.tagName).toBe('DIV')
150
-
151
- const $body = wrapper.find('.toast-body')
152
- expect($body.element.tagName).toBe('A')
153
- expect($body.attributes('href')).toEqual('#foobar')
154
-
155
- expect(wrapper.emitted('hide')).toBeUndefined()
156
- expect(wrapper.emitted('hidden')).toBeUndefined()
157
- expect(wrapper.emitted('change')).toBeUndefined()
158
-
159
- $body.element.focus()
160
- await $body.trigger('click')
161
- await waitRAF()
162
- await waitNT(wrapper.vm)
163
- await waitRAF()
164
- await waitNT(wrapper.vm)
165
- await waitRAF()
166
- await waitNT(wrapper.vm)
167
- await waitRAF()
168
- await waitNT(wrapper.vm)
169
-
170
- expect(wrapper.element.nodeType).toBe(Node.COMMENT_NODE)
171
-
172
- expect(wrapper.emitted('hide')).toBeDefined()
173
- expect(wrapper.emitted('hidden')).toBeDefined()
174
- expect(wrapper.emitted('change')).toBeDefined()
175
-
176
- wrapper.destroy()
177
- })
178
-
179
- it('auto-hide works', async () => {
180
- const wrapper = mount(BToast, {
181
- attachTo: document.body,
182
- propsData: {
183
- static: true,
184
- noAutoHide: false,
185
- visible: true,
186
- title: 'title',
187
- autoHideDelay: 1000
188
- },
189
- slots: {
190
- default: 'content'
191
- }
192
- })
193
-
194
- expect(wrapper.vm).toBeDefined()
195
-
196
- await waitNT(wrapper.vm)
197
- await waitRAF()
198
- await waitNT(wrapper.vm)
199
- await waitRAF()
200
-
201
- expect(wrapper.element.tagName).toBe('DIV')
202
- expect(wrapper.vm.$_dismissTimer).not.toEqual(null)
203
-
204
- await ensureEventEmitted(wrapper, 'hidden')
205
-
206
- expect(wrapper.vm.$_dismissTimer).toBe(null)
207
- expect(wrapper.element.nodeType).toBe(Node.COMMENT_NODE)
208
-
209
- wrapper.destroy()
210
- })
211
-
212
- it('hover pause works', async () => {
213
- const wrapper = mount(BToast, {
214
- attachTo: document.body,
215
- propsData: {
216
- static: true,
217
- noAutoHide: false,
218
- visible: true,
219
- title: 'title'
220
- },
221
- slots: {
222
- default: 'content'
223
- }
224
- })
225
-
226
- expect(wrapper.vm).toBeDefined()
227
-
228
- await waitNT(wrapper.vm)
229
- await waitRAF()
230
- await waitNT(wrapper.vm)
231
- await waitRAF()
232
- await waitNT(wrapper.vm)
233
- await waitRAF()
234
- await waitNT(wrapper.vm)
235
- await waitRAF()
236
-
237
- expect(wrapper.element.tagName).toBe('DIV')
238
- expect(wrapper.vm.$_dismissTimer).not.toEqual(null)
239
- await waitNT(wrapper.vm)
240
- await waitRAF()
241
-
242
- await wrapper.trigger('mouseenter')
243
- await waitRAF()
244
- expect(wrapper.vm.$_dismissTimer).toEqual(null)
245
-
246
- await wrapper.trigger('mouseleave')
247
- await waitRAF()
248
- expect(wrapper.vm.$_dismissTimer).not.toEqual(null)
249
-
250
- wrapper.destroy()
251
- })
252
-
253
- it('hover pause has no effect when no-hover-pause is set', async () => {
254
- const wrapper = mount(BToast, {
255
- attachTo: document.body,
256
- propsData: {
257
- static: true,
258
- noAutoHide: false,
259
- noHoverPause: true,
260
- visible: true,
261
- title: 'title'
262
- },
263
- slots: {
264
- default: 'content'
265
- }
266
- })
267
-
268
- expect(wrapper.vm).toBeDefined()
269
-
270
- await waitNT(wrapper.vm)
271
- await waitRAF()
272
- await waitNT(wrapper.vm)
273
- await waitRAF()
274
- await waitNT(wrapper.vm)
275
- await waitRAF()
276
- await waitNT(wrapper.vm)
277
- await waitRAF()
278
-
279
- expect(wrapper.element.tagName).toBe('DIV')
280
- expect(wrapper.vm.timer).not.toEqual(null)
281
- await waitNT(wrapper.vm)
282
- await waitRAF()
283
-
284
- await wrapper.trigger('mouseenter')
285
- await waitRAF()
286
- expect(wrapper.vm.timer).not.toEqual(null)
287
-
288
- await wrapper.trigger('mouseleave')
289
- await waitRAF()
290
- expect(wrapper.vm.timer).not.toEqual(null)
291
-
292
- wrapper.destroy()
293
- })
294
- })
@@ -1,77 +0,0 @@
1
- import { PortalTarget } from 'portal-vue'
2
- import { mount } from '@vue/test-utils'
3
- import { isVue3 } from '../../vue'
4
- import { waitNT, waitRAF } from '../../../tests/utils'
5
- import { BToaster } from './toaster'
6
-
7
- describe('b-toaster', () => {
8
- it('has expected structure', async () => {
9
- const wrapper = mount(BToaster, {
10
- attachTo: document.body,
11
- propsData: {
12
- name: 'foo'
13
- }
14
- })
15
-
16
- expect(wrapper.vm).toBeDefined()
17
- await waitNT(wrapper.vm)
18
- await waitRAF()
19
-
20
- expect(wrapper.element.tagName).toBe('DIV')
21
- expect(wrapper.attributes('id')).toBe('foo')
22
- expect(wrapper.attributes('aria-live')).toBeUndefined()
23
- expect(wrapper.attributes('aria-atomic')).toBeUndefined()
24
- expect(wrapper.attributes('role')).toBeUndefined()
25
- expect(wrapper.classes()).toContain('b-toaster')
26
- expect(wrapper.classes()).toContain('foo')
27
- expect(wrapper.classes().length).toBe(2)
28
-
29
- expect(wrapper.find('.b-toaster-slot').exists()).toBe(true)
30
- const $slot = wrapper.find('.b-toaster-slot')
31
- if (!isVue3) {
32
- expect($slot.findComponent(PortalTarget).exists()).toBe(true)
33
- }
34
- expect($slot.element.tagName).toBe('DIV')
35
- expect($slot.classes()).toContain('b-toaster-slot')
36
- expect($slot.classes()).toContain('vue-portal-target')
37
- expect($slot.classes().length).toBe(2)
38
- expect($slot.text()).toEqual('')
39
-
40
- wrapper.destroy()
41
- })
42
-
43
- it('accepts aria props', async () => {
44
- const wrapper = mount(BToaster, {
45
- attachTo: document.body,
46
- propsData: {
47
- name: 'bar',
48
- ariaLive: 'assertive',
49
- ariaAtomic: 'true',
50
- role: 'alert'
51
- }
52
- })
53
-
54
- expect(wrapper.vm).toBeDefined()
55
- await waitNT(wrapper.vm)
56
- await waitRAF()
57
-
58
- expect(wrapper.element.tagName).toBe('DIV')
59
- expect(wrapper.attributes('id')).toBe('bar')
60
- expect(wrapper.attributes('aria-live')).toEqual('assertive')
61
- expect(wrapper.attributes('aria-atomic')).toEqual('true')
62
- expect(wrapper.attributes('role')).toEqual('alert')
63
-
64
- expect(wrapper.find('.b-toaster-slot').exists()).toBe(true)
65
- const $slot = wrapper.find('.b-toaster-slot')
66
- if (!isVue3) {
67
- expect($slot.findComponent(PortalTarget).exists()).toBe(true)
68
- }
69
- expect($slot.element.tagName).toBe('DIV')
70
- expect($slot.classes()).toContain('b-toaster-slot')
71
- expect($slot.classes()).toContain('vue-portal-target')
72
- expect($slot.classes().length).toBe(2)
73
- expect($slot.text()).toEqual('')
74
-
75
- wrapper.destroy()
76
- })
77
- })