@gitlab/ui 114.0.1 → 114.1.1

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 (136) hide show
  1. package/package.json +9 -28
  2. package/CHANGELOG.md +0 -13132
  3. package/src/vendor/bootstrap/LICENSE +0 -11
  4. package/src/vendor/bootstrap-vue/LICENSE +0 -11
  5. package/src/vendor/bootstrap-vue/package.json +0 -144
  6. package/src/vendor/bootstrap-vue/src/components/button/MODIFICATIONS.md +0 -16
  7. package/src/vendor/bootstrap-vue/src/components/button/README.md +0 -240
  8. package/src/vendor/bootstrap-vue/src/components/button/button-close.spec.js +0 -210
  9. package/src/vendor/bootstrap-vue/src/components/button/button.spec.js +0 -349
  10. package/src/vendor/bootstrap-vue/src/components/button/package.json +0 -105
  11. package/src/vendor/bootstrap-vue/src/components/dropdown/README.md +0 -730
  12. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-divider.spec.js +0 -58
  13. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-form.spec.js +0 -110
  14. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-group.spec.js +0 -94
  15. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-header.spec.js +0 -73
  16. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item-button.spec.js +0 -117
  17. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.spec.js +0 -147
  18. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.spec.js +0 -59
  19. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown.spec.js +0 -1121
  20. package/src/vendor/bootstrap-vue/src/components/dropdown/package.json +0 -368
  21. package/src/vendor/bootstrap-vue/src/components/form/README.md +0 -365
  22. package/src/vendor/bootstrap-vue/src/components/form/form-invalid-feedback.spec.js +0 -170
  23. package/src/vendor/bootstrap-vue/src/components/form/form-text.spec.js +0 -93
  24. package/src/vendor/bootstrap-vue/src/components/form/form-valid-feedback.spec.js +0 -157
  25. package/src/vendor/bootstrap-vue/src/components/form/form.spec.js +0 -97
  26. package/src/vendor/bootstrap-vue/src/components/form/package.json +0 -112
  27. package/src/vendor/bootstrap-vue/src/components/form-checkbox/README.md +0 -691
  28. package/src/vendor/bootstrap-vue/src/components/form-checkbox/form-checkbox-group.spec.js +0 -525
  29. package/src/vendor/bootstrap-vue/src/components/form-checkbox/form-checkbox.spec.js +0 -922
  30. package/src/vendor/bootstrap-vue/src/components/form-checkbox/package.json +0 -172
  31. package/src/vendor/bootstrap-vue/src/components/form-group/README.md +0 -339
  32. package/src/vendor/bootstrap-vue/src/components/form-group/form-group.spec.js +0 -477
  33. package/src/vendor/bootstrap-vue/src/components/form-group/package.json +0 -183
  34. package/src/vendor/bootstrap-vue/src/components/form-radio/README.md +0 -437
  35. package/src/vendor/bootstrap-vue/src/components/form-radio/form-radio-group.spec.js +0 -357
  36. package/src/vendor/bootstrap-vue/src/components/form-radio/form-radio.spec.js +0 -587
  37. package/src/vendor/bootstrap-vue/src/components/form-radio/package.json +0 -162
  38. package/src/vendor/bootstrap-vue/src/components/form-select/README.md +0 -504
  39. package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option-group.spec.js +0 -138
  40. package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option.spec.js +0 -75
  41. package/src/vendor/bootstrap-vue/src/components/form-select/form-select.spec.js +0 -723
  42. package/src/vendor/bootstrap-vue/src/components/form-select/package.json +0 -132
  43. package/src/vendor/bootstrap-vue/src/components/form-textarea/README.md +0 -453
  44. package/src/vendor/bootstrap-vue/src/components/form-textarea/form-textarea.spec.js +0 -1000
  45. package/src/vendor/bootstrap-vue/src/components/form-textarea/package.json +0 -122
  46. package/src/vendor/bootstrap-vue/src/components/layout/README.md +0 -791
  47. package/src/vendor/bootstrap-vue/src/components/layout/col.spec.js +0 -192
  48. package/src/vendor/bootstrap-vue/src/components/layout/form-row.spec.js +0 -45
  49. package/src/vendor/bootstrap-vue/src/components/layout/package.json +0 -99
  50. package/src/vendor/bootstrap-vue/src/components/link/README.md +0 -76
  51. package/src/vendor/bootstrap-vue/src/components/link/link.spec.js +0 -434
  52. package/src/vendor/bootstrap-vue/src/components/link/package.json +0 -57
  53. package/src/vendor/bootstrap-vue/src/components/modal/MODIFICATIONS.md +0 -30
  54. package/src/vendor/bootstrap-vue/src/components/modal/README.md +0 -1067
  55. package/src/vendor/bootstrap-vue/src/components/modal/helpers/bv-modal-event.class.spec.js +0 -82
  56. package/src/vendor/bootstrap-vue/src/components/modal/modal.spec.js +0 -1418
  57. package/src/vendor/bootstrap-vue/src/components/modal/package.json +0 -544
  58. package/src/vendor/bootstrap-vue/src/components/nav/README.md +0 -362
  59. package/src/vendor/bootstrap-vue/src/components/nav/nav-item.spec.js +0 -127
  60. package/src/vendor/bootstrap-vue/src/components/nav/nav.spec.js +0 -177
  61. package/src/vendor/bootstrap-vue/src/components/nav/package.json +0 -73
  62. package/src/vendor/bootstrap-vue/src/components/popover/README.md +0 -919
  63. package/src/vendor/bootstrap-vue/src/components/popover/package.json +0 -261
  64. package/src/vendor/bootstrap-vue/src/components/popover/popover.spec.js +0 -198
  65. package/src/vendor/bootstrap-vue/src/components/table/README.md +0 -3157
  66. package/src/vendor/bootstrap-vue/src/components/table/helpers/default-sort-compare.spec.js +0 -112
  67. package/src/vendor/bootstrap-vue/src/components/table/helpers/normalize-fields.spec.js +0 -93
  68. package/src/vendor/bootstrap-vue/src/components/table/package.json +0 -1763
  69. package/src/vendor/bootstrap-vue/src/components/table/table-busy.spec.js +0 -150
  70. package/src/vendor/bootstrap-vue/src/components/table/table-caption.spec.js +0 -176
  71. package/src/vendor/bootstrap-vue/src/components/table/table-colgroup.spec.js +0 -81
  72. package/src/vendor/bootstrap-vue/src/components/table/table-filtering.spec.js +0 -409
  73. package/src/vendor/bootstrap-vue/src/components/table/table-item-formatter.spec.js +0 -56
  74. package/src/vendor/bootstrap-vue/src/components/table/table-lite.spec.js +0 -682
  75. package/src/vendor/bootstrap-vue/src/components/table/table-pagination.spec.js +0 -133
  76. package/src/vendor/bootstrap-vue/src/components/table/table-primarykey.spec.js +0 -83
  77. package/src/vendor/bootstrap-vue/src/components/table/table-provider.spec.js +0 -411
  78. package/src/vendor/bootstrap-vue/src/components/table/table-row-details.spec.js +0 -459
  79. package/src/vendor/bootstrap-vue/src/components/table/table-selectable.spec.js +0 -1182
  80. package/src/vendor/bootstrap-vue/src/components/table/table-simple.spec.js +0 -206
  81. package/src/vendor/bootstrap-vue/src/components/table/table-sorting.spec.js +0 -858
  82. package/src/vendor/bootstrap-vue/src/components/table/table-sticky-column.spec.js +0 -377
  83. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-bottom-row.spec.js +0 -94
  84. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-row-events.spec.js +0 -529
  85. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-top-row.spec.js +0 -88
  86. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-transition.spec.js +0 -83
  87. package/src/vendor/bootstrap-vue/src/components/table/table-tfoot-custom.spec.js +0 -91
  88. package/src/vendor/bootstrap-vue/src/components/table/table-tfoot-events.spec.js +0 -137
  89. package/src/vendor/bootstrap-vue/src/components/table/table-thead-events.spec.js +0 -155
  90. package/src/vendor/bootstrap-vue/src/components/table/table-thead-top.spec.js +0 -96
  91. package/src/vendor/bootstrap-vue/src/components/table/table.spec.js +0 -692
  92. package/src/vendor/bootstrap-vue/src/components/tabs/README.md +0 -433
  93. package/src/vendor/bootstrap-vue/src/components/tabs/package.json +0 -205
  94. package/src/vendor/bootstrap-vue/src/components/tabs/tab.spec.js +0 -330
  95. package/src/vendor/bootstrap-vue/src/components/tabs/tabs.spec.js +0 -778
  96. package/src/vendor/bootstrap-vue/src/components/toast/README.md +0 -655
  97. package/src/vendor/bootstrap-vue/src/components/toast/helpers/bv-toast.spec.js +0 -117
  98. package/src/vendor/bootstrap-vue/src/components/toast/package.json +0 -184
  99. package/src/vendor/bootstrap-vue/src/components/toast/toast.spec.js +0 -294
  100. package/src/vendor/bootstrap-vue/src/components/toast/toaster.spec.js +0 -77
  101. package/src/vendor/bootstrap-vue/src/components/tooltip/README.md +0 -559
  102. package/src/vendor/bootstrap-vue/src/components/tooltip/package.json +0 -258
  103. package/src/vendor/bootstrap-vue/src/components/tooltip/tooltip.spec.js +0 -1240
  104. package/src/vendor/bootstrap-vue/src/components/transition/package.json +0 -5
  105. package/src/vendor/bootstrap-vue/src/components/transporter/package.json +0 -5
  106. package/src/vendor/bootstrap-vue/src/components/transporter/transporter.spec.js +0 -85
  107. package/src/vendor/bootstrap-vue/src/directives/modal/modal.spec.js +0 -191
  108. package/src/vendor/bootstrap-vue/src/directives/tooltip/README.md +0 -521
  109. package/src/vendor/bootstrap-vue/src/directives/tooltip/package.json +0 -131
  110. package/src/vendor/bootstrap-vue/src/directives/tooltip/tooltip.spec.js +0 -190
  111. package/src/vendor/bootstrap-vue/src/directives/visible/README.md +0 -244
  112. package/src/vendor/bootstrap-vue/src/directives/visible/package.json +0 -24
  113. package/src/vendor/bootstrap-vue/src/mixins/attrs.spec.js +0 -194
  114. package/src/vendor/bootstrap-vue/src/mixins/click-out.spec.js +0 -52
  115. package/src/vendor/bootstrap-vue/src/mixins/focus-in.spec.js +0 -53
  116. package/src/vendor/bootstrap-vue/src/mixins/listen-on-document.spec.js +0 -117
  117. package/src/vendor/bootstrap-vue/src/mixins/listen-on-root.spec.js +0 -77
  118. package/src/vendor/bootstrap-vue/src/mixins/listen-on-window.spec.js +0 -115
  119. package/src/vendor/bootstrap-vue/src/mixins/listeners.spec.js +0 -245
  120. package/src/vendor/bootstrap-vue/src/utils/bv-event.class.spec.js +0 -66
  121. package/src/vendor/bootstrap-vue/src/utils/clone-deep.spec.js +0 -70
  122. package/src/vendor/bootstrap-vue/src/utils/config.spec.js +0 -169
  123. package/src/vendor/bootstrap-vue/src/utils/css-escape.spec.js +0 -82
  124. package/src/vendor/bootstrap-vue/src/utils/dom.spec.js +0 -291
  125. package/src/vendor/bootstrap-vue/src/utils/events.spec.js +0 -41
  126. package/src/vendor/bootstrap-vue/src/utils/get.spec.js +0 -109
  127. package/src/vendor/bootstrap-vue/src/utils/inspect.spec.js +0 -251
  128. package/src/vendor/bootstrap-vue/src/utils/loose-equal.spec.js +0 -203
  129. package/src/vendor/bootstrap-vue/src/utils/normalize-slot.spec.js +0 -63
  130. package/src/vendor/bootstrap-vue/src/utils/number.spec.js +0 -72
  131. package/src/vendor/bootstrap-vue/src/utils/object.spec.js +0 -61
  132. package/src/vendor/bootstrap-vue/src/utils/props.spec.js +0 -112
  133. package/src/vendor/bootstrap-vue/src/utils/router.spec.js +0 -248
  134. package/src/vendor/bootstrap-vue/src/utils/string.spec.js +0 -65
  135. package/src/vendor/bootstrap-vue/src/utils/stringify-object-values.spec.js +0 -47
  136. 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
- })