@gitlab/ui 114.1.0 → 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 +7 -26
  2. package/CHANGELOG.md +0 -13139
  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,377 +0,0 @@
1
- import { mount } from '@vue/test-utils'
2
- import { BTable } from './table'
3
- import { BTd } from './td'
4
- import { BTh } from './th'
5
-
6
- const items = [{ a: 1, b: 2, c: 3 }, { a: 4, b: 5, c: 6 }]
7
- const fields = [
8
- { key: 'a', stickyColumn: true, isRowHeader: true },
9
- { key: 'b', stickyColumn: true },
10
- 'c'
11
- ]
12
-
13
- describe('table > sticky columns', () => {
14
- it('has expected classes when sticky column is enabled and responsive', async () => {
15
- const wrapper = mount(BTable, {
16
- propsData: {
17
- responsive: true,
18
- footClone: true,
19
- items,
20
- fields
21
- }
22
- })
23
-
24
- expect(wrapper).toBeDefined()
25
- expect(wrapper.element.tagName).toBe('DIV')
26
- expect(wrapper.classes()).toContain('table-responsive')
27
- expect(wrapper.classes()).not.toContain('b-table-sticky-header')
28
- const table = wrapper.find('table')
29
- expect(table.classes()).toContain('table')
30
- expect(table.classes()).toContain('b-table')
31
-
32
- // Body
33
- let trs = wrapper.findAll('tbody > tr')
34
- expect(trs.length).toBe(2)
35
- let cells = trs.at(0).findAll('th, td')
36
- expect(cells.length).toBe(3)
37
-
38
- // First column should be BTh with sticky classes
39
- expect(
40
- cells
41
- .at(0)
42
- .findComponent(BTh)
43
- .exists()
44
- ).toBe(true)
45
- expect(cells.at(0).element.tagName).toBe('TH')
46
- expect(cells.at(0).classes()).toContain('b-table-sticky-column')
47
-
48
- // Second column should be BTd with sticky classes
49
- expect(
50
- cells
51
- .at(1)
52
- .findComponent(BTd)
53
- .exists()
54
- ).toBe(true)
55
- expect(cells.at(1).element.tagName).toBe('TD')
56
- expect(cells.at(1).classes()).toContain('b-table-sticky-column')
57
-
58
- // Third column should be td
59
- expect(cells.at(2).vm).toBeUndefined()
60
- expect(cells.at(2).element.tagName).toBe('TD')
61
- expect(cells.at(2).classes()).not.toContain('b-table-sticky-column')
62
-
63
- // Header cells
64
- trs = wrapper.findAll('thead > tr')
65
- expect(trs.length).toBe(1)
66
- cells = trs.at(0).findAll('th')
67
- expect(cells.length).toBe(3)
68
-
69
- // First column should be BTh with sticky classes
70
- expect(
71
- cells
72
- .at(0)
73
- .findComponent(BTh)
74
- .exists()
75
- ).toBe(true)
76
- expect(cells.at(0).element.tagName).toBe('TH')
77
- expect(cells.at(0).classes()).toContain('b-table-sticky-column')
78
-
79
- // Second column should be BTh with sticky classes
80
- expect(
81
- cells
82
- .at(1)
83
- .findComponent(BTh)
84
- .exists()
85
- ).toBe(true)
86
- expect(cells.at(1).element.tagName).toBe('TH')
87
- expect(cells.at(1).classes()).toContain('b-table-sticky-column')
88
-
89
- // Third column should be BTh
90
- expect(
91
- cells
92
- .at(2)
93
- .findComponent(BTh)
94
- .exists()
95
- ).toBe(true)
96
- expect(cells.at(2).element.tagName).toBe('TH')
97
- expect(cells.at(2).classes()).not.toContain('b-table-sticky-column')
98
-
99
- // Footer cells
100
- trs = wrapper.findAll('tfoot > tr')
101
- expect(trs.length).toBe(1)
102
- cells = trs.at(0).findAll('th')
103
- expect(cells.length).toBe(3)
104
-
105
- // First column should be BTh with sticky classes
106
- expect(
107
- cells
108
- .at(0)
109
- .findComponent(BTh)
110
- .exists()
111
- ).toBe(true)
112
- expect(cells.at(0).element.tagName).toBe('TH')
113
- expect(cells.at(0).classes()).toContain('b-table-sticky-column')
114
-
115
- // Second column should be BTh with sticky classes
116
- expect(
117
- cells
118
- .at(1)
119
- .findComponent(BTh)
120
- .exists()
121
- ).toBe(true)
122
- expect(cells.at(1).element.tagName).toBe('TH')
123
- expect(cells.at(1).classes()).toContain('b-table-sticky-column')
124
-
125
- // Third column should be BTh
126
- expect(
127
- cells
128
- .at(2)
129
- .findComponent(BTh)
130
- .exists()
131
- ).toBe(true)
132
- expect(cells.at(2).element.tagName).toBe('TH')
133
- expect(cells.at(2).classes()).not.toContain('b-table-sticky-column')
134
-
135
- wrapper.destroy()
136
- })
137
-
138
- it('has expected classes when sticky column is enabled with sticky headers', async () => {
139
- const wrapper = mount(BTable, {
140
- propsData: {
141
- responsive: false,
142
- stickyHeader: true,
143
- footClone: true,
144
- items,
145
- fields
146
- }
147
- })
148
-
149
- expect(wrapper).toBeDefined()
150
- expect(wrapper.element.tagName).toBe('DIV')
151
- expect(wrapper.classes()).not.toContain('table-responsive')
152
- expect(wrapper.classes()).toContain('b-table-sticky-header')
153
- const table = wrapper.find('table')
154
- expect(table.classes()).toContain('table')
155
- expect(table.classes()).toContain('b-table')
156
-
157
- // Tbody cells
158
- let trs = wrapper.findAll('tbody > tr')
159
- expect(trs.length).toBe(2)
160
- let cells = trs.at(0).findAll('th, td')
161
- expect(cells.length).toBe(3)
162
-
163
- // First column should be BTh with sticky classes
164
- expect(
165
- cells
166
- .at(0)
167
- .findComponent(BTh)
168
- .exists()
169
- ).toBe(true)
170
- expect(cells.at(0).element.tagName).toBe('TH')
171
- expect(cells.at(0).classes()).toContain('b-table-sticky-column')
172
-
173
- // Second column should be BTd with sticky classes
174
- expect(
175
- cells
176
- .at(1)
177
- .findComponent(BTd)
178
- .exists()
179
- ).toBe(true)
180
- expect(cells.at(1).element.tagName).toBe('TD')
181
- expect(cells.at(1).classes()).toContain('b-table-sticky-column')
182
-
183
- // Third column should be td
184
- expect(cells.at(2).vm).toBeUndefined()
185
- expect(cells.at(2).element.tagName).toBe('TD')
186
- expect(cells.at(2).classes()).not.toContain('b-table-sticky-column')
187
-
188
- // Header cells
189
- trs = wrapper.findAll('thead > tr')
190
- expect(trs.length).toBe(1)
191
- cells = trs.at(0).findAll('th')
192
- expect(cells.length).toBe(3)
193
-
194
- // First column should be BTh with sticky classes
195
- expect(
196
- cells
197
- .at(0)
198
- .findComponent(BTh)
199
- .exists()
200
- ).toBe(true)
201
- expect(cells.at(0).element.tagName).toBe('TH')
202
- expect(cells.at(0).classes()).toContain('b-table-sticky-column')
203
-
204
- // Second column should be BTh with sticky classes
205
- expect(
206
- cells
207
- .at(1)
208
- .findComponent(BTh)
209
- .exists()
210
- ).toBe(true)
211
- expect(cells.at(1).element.tagName).toBe('TH')
212
- expect(cells.at(1).classes()).toContain('b-table-sticky-column')
213
-
214
- // Third column should be BTh
215
- expect(
216
- cells
217
- .at(2)
218
- .findComponent(BTh)
219
- .exists()
220
- ).toBe(true)
221
- expect(cells.at(2).element.tagName).toBe('TH')
222
- expect(cells.at(2).classes()).not.toContain('b-table-sticky-column')
223
-
224
- // Footer cells
225
- trs = wrapper.findAll('tfoot > tr')
226
- expect(trs.length).toBe(1)
227
-
228
- cells = trs.at(0).findAll('th')
229
- expect(cells.length).toBe(3)
230
-
231
- // First column should be BTh with sticky classes
232
- expect(
233
- cells
234
- .at(0)
235
- .findComponent(BTh)
236
- .exists()
237
- ).toBe(true)
238
- expect(cells.at(0).element.tagName).toBe('TH')
239
- expect(cells.at(0).classes()).toContain('b-table-sticky-column')
240
-
241
- // Second column should be BTh with sticky classes
242
- expect(
243
- cells
244
- .at(1)
245
- .findComponent(BTh)
246
- .exists()
247
- ).toBe(true)
248
- expect(cells.at(1).element.tagName).toBe('TH')
249
- expect(cells.at(1).classes()).toContain('b-table-sticky-column')
250
-
251
- // Third column should be BTh
252
- expect(
253
- cells
254
- .at(2)
255
- .findComponent(BTh)
256
- .exists()
257
- ).toBe(true)
258
- expect(cells.at(2).element.tagName).toBe('TH')
259
- expect(cells.at(2).classes()).not.toContain('b-table-sticky-column')
260
-
261
- wrapper.destroy()
262
- })
263
-
264
- it('does not have sticky classes when sticky column is enabled and not responsive and no sticky header', async () => {
265
- const wrapper = mount(BTable, {
266
- propsData: {
267
- responsive: false,
268
- stickyHeader: false,
269
- footClone: true,
270
- items,
271
- fields
272
- }
273
- })
274
-
275
- expect(wrapper).toBeDefined()
276
- expect(wrapper.element.tagName).toBe('TABLE')
277
- expect(wrapper.classes()).not.toContain('table-responsive')
278
- expect(wrapper.classes()).not.toContain('b-table-sticky-header')
279
- expect(wrapper.classes()).toContain('table')
280
- expect(wrapper.classes()).toContain('b-table')
281
-
282
- // Body
283
- let trs = wrapper.findAll('tbody > tr')
284
- expect(trs.length).toBe(2)
285
- let cells = trs.at(0).findAll('th, td')
286
- expect(cells.length).toBe(3)
287
-
288
- // First column should be th
289
- expect(cells.at(0).vm).toBeUndefined()
290
- expect(cells.at(0).element.tagName).toBe('TH')
291
- expect(cells.at(0).classes()).not.toContain('b-table-sticky-column')
292
-
293
- // Second column should be td
294
- expect(cells.at(1).vm).toBeUndefined()
295
- expect(cells.at(1).element.tagName).toBe('TD')
296
- expect(cells.at(1).classes()).not.toContain('b-table-sticky-column')
297
-
298
- // Third column should be td
299
- expect(cells.at(2).vm).toBeUndefined()
300
- expect(cells.at(2).element.tagName).toBe('TD')
301
- expect(cells.at(2).classes()).not.toContain('b-table-sticky-column')
302
-
303
- // Header cells
304
- trs = wrapper.findAll('thead > tr')
305
- expect(trs.length).toBe(1)
306
- cells = trs.at(0).findAll('th')
307
- expect(cells.length).toBe(3)
308
-
309
- // First column should be BTh with sticky classes
310
- expect(
311
- cells
312
- .at(0)
313
- .findComponent(BTh)
314
- .exists()
315
- ).toBe(true)
316
- expect(cells.at(0).element.tagName).toBe('TH')
317
- expect(cells.at(0).classes()).not.toContain('b-table-sticky-column')
318
-
319
- // Second column should be BTh with sticky classes
320
- expect(
321
- cells
322
- .at(1)
323
- .findComponent(BTh)
324
- .exists()
325
- ).toBe(true)
326
- expect(cells.at(1).element.tagName).toBe('TH')
327
- expect(cells.at(1).classes()).not.toContain('b-table-sticky-column')
328
-
329
- // Third column should be BTh
330
- expect(
331
- cells
332
- .at(2)
333
- .findComponent(BTh)
334
- .exists()
335
- ).toBe(true)
336
- expect(cells.at(2).element.tagName).toBe('TH')
337
- expect(cells.at(2).classes()).not.toContain('b-table-sticky-column')
338
-
339
- // Footer cells
340
- trs = wrapper.findAll('tfoot > tr')
341
- expect(trs.length).toBe(1)
342
- cells = trs.at(0).findAll('th')
343
- expect(cells.length).toBe(3)
344
-
345
- // First column should be BTh with sticky classes
346
- expect(
347
- cells
348
- .at(0)
349
- .findComponent(BTh)
350
- .exists()
351
- ).toBe(true)
352
- expect(cells.at(0).element.tagName).toBe('TH')
353
- expect(cells.at(0).classes()).not.toContain('b-table-sticky-column')
354
-
355
- // Second column should be BTh with sticky classes
356
- expect(
357
- cells
358
- .at(1)
359
- .findComponent(BTh)
360
- .exists()
361
- ).toBe(true)
362
- expect(cells.at(1).element.tagName).toBe('TH')
363
- expect(cells.at(1).classes()).not.toContain('b-table-sticky-column')
364
-
365
- // Third column should be BTh
366
- expect(
367
- cells
368
- .at(2)
369
- .findComponent(BTh)
370
- .exists()
371
- ).toBe(true)
372
- expect(cells.at(2).element.tagName).toBe('TH')
373
- expect(cells.at(2).classes()).not.toContain('b-table-sticky-column')
374
-
375
- wrapper.destroy()
376
- })
377
- })
@@ -1,94 +0,0 @@
1
- import { mount } from '@vue/test-utils'
2
- import { BTable } from './table'
3
- import { normalizeFields } from './helpers/normalize-fields'
4
-
5
- const testItems = [{ a: 1, b: 2, c: 3 }, { a: 5, b: 5, c: 6 }, { a: 7, b: 8, c: 9 }]
6
- const testFields = ['a', 'b', 'c']
7
-
8
- describe('table > tbody bottom-row slot', () => {
9
- it('should not have bottom row by default', async () => {
10
- const wrapper = mount(BTable, {
11
- propsData: {
12
- fields: testFields,
13
- items: testItems
14
- }
15
- })
16
- expect(wrapper).toBeDefined()
17
- expect(wrapper.element.tagName).toBe('TABLE')
18
- expect(wrapper.find('tbody').exists()).toBe(true)
19
- expect(wrapper.findAll('tbody > tr').exists()).toBe(true)
20
- expect(wrapper.findAll('tbody > tr').length).toBe(testItems.length)
21
-
22
- wrapper.destroy()
23
- })
24
-
25
- it('should render named slot `bottom-row`', async () => {
26
- const wrapper = mount(BTable, {
27
- propsData: {
28
- fields: testFields,
29
- items: testItems
30
- },
31
- slots: {
32
- 'bottom-row': `<td span="${testFields.length}">foobar</td>`
33
- }
34
- })
35
- expect(wrapper).toBeDefined()
36
- expect(wrapper.element.tagName).toBe('TABLE')
37
- expect(wrapper.find('tbody').exists()).toBe(true)
38
- expect(wrapper.findAll('tbody > tr').exists()).toBe(true)
39
- expect(wrapper.findAll('tbody > tr').length).toBe(testItems.length + 1)
40
- expect(
41
- wrapper
42
- .findAll('tbody > tr')
43
- .at(testItems.length)
44
- .text()
45
- ).toBe('foobar')
46
- expect(
47
- wrapper
48
- .findAll('tbody > tr')
49
- .at(testItems.length)
50
- .classes()
51
- ).toContain('b-table-bottom-row')
52
-
53
- wrapper.destroy()
54
- })
55
-
56
- it('should render scoped slot `bottom-row`', async () => {
57
- let fields = []
58
- let columns
59
- const wrapper = mount(BTable, {
60
- propsData: {
61
- fields: testFields,
62
- items: testItems
63
- },
64
- scopedSlots: {
65
- 'bottom-row': function(scope) {
66
- fields = scope.fields
67
- columns = scope.columns
68
- return this.$createElement('td', { attrs: { span: columns } }, 'foobar')
69
- }
70
- }
71
- })
72
- expect(wrapper).toBeDefined()
73
- expect(wrapper.element.tagName).toBe('TABLE')
74
- expect(wrapper.find('tbody').exists()).toBe(true)
75
- expect(columns).toBe(3)
76
- expect(fields).toEqual(normalizeFields(testFields))
77
- expect(wrapper.findAll('tbody > tr').exists()).toBe(true)
78
- expect(wrapper.findAll('tbody > tr').length).toBe(testItems.length + 1)
79
- expect(
80
- wrapper
81
- .findAll('tbody > tr')
82
- .at(testItems.length)
83
- .text()
84
- ).toBe('foobar')
85
- expect(
86
- wrapper
87
- .findAll('tbody > tr')
88
- .at(testItems.length)
89
- .classes()
90
- ).toContain('b-table-bottom-row')
91
-
92
- wrapper.destroy()
93
- })
94
- })