@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,133 +0,0 @@
1
- import { mount } from '@vue/test-utils'
2
- import { BTable } from './table'
3
-
4
- const testItems = [
5
- { a: 1, b: 2, c: 3 },
6
- { a: 4, b: 5, c: 6 },
7
- { a: 7, b: 8, c: 9 },
8
- { a: 10, b: 11, c: 12 },
9
- { a: 13, b: 14, c: 15 }
10
- ]
11
-
12
- describe('table > pagination', () => {
13
- it('default should not be paginated', async () => {
14
- const wrapper = mount(BTable, {
15
- propsData: {
16
- items: testItems
17
- }
18
- })
19
- expect(wrapper.findAll('tbody > tr').length).toBe(5)
20
-
21
- wrapper.destroy()
22
- })
23
-
24
- it('should have 3 rows when per-page=3', async () => {
25
- const wrapper = mount(BTable, {
26
- propsData: {
27
- items: testItems,
28
- perPage: 3,
29
- currentPage: 1
30
- }
31
- })
32
- expect(wrapper.findAll('tbody > tr').length).toBe(3)
33
- const $trs = wrapper.findAll('tbody > tr')
34
- expect(
35
- $trs
36
- .at(0)
37
- .find('td')
38
- .text()
39
- ).toBe('1')
40
- expect(
41
- $trs
42
- .at(1)
43
- .find('td')
44
- .text()
45
- ).toBe('4')
46
- expect(
47
- $trs
48
- .at(2)
49
- .find('td')
50
- .text()
51
- ).toBe('7')
52
-
53
- wrapper.destroy()
54
- })
55
-
56
- it('changing pages should update rows', async () => {
57
- const wrapper = mount(BTable, {
58
- propsData: {
59
- items: testItems,
60
- perPage: 3,
61
- currentPage: 1
62
- }
63
- })
64
- expect(wrapper.findAll('tbody > tr').length).toBe(3)
65
- let $trs = wrapper.findAll('tbody > tr')
66
- expect(
67
- $trs
68
- .at(0)
69
- .find('td')
70
- .text()
71
- ).toBe('1')
72
- expect(
73
- $trs
74
- .at(1)
75
- .find('td')
76
- .text()
77
- ).toBe('4')
78
- expect(
79
- $trs
80
- .at(2)
81
- .find('td')
82
- .text()
83
- ).toBe('7')
84
-
85
- await wrapper.setProps({ currentPage: 2 })
86
-
87
- expect(wrapper.findAll('tbody > tr').length).toBe(2)
88
- $trs = wrapper.findAll('tbody > tr')
89
- expect(
90
- $trs
91
- .at(0)
92
- .find('td')
93
- .text()
94
- ).toBe('10')
95
- expect(
96
- $trs
97
- .at(1)
98
- .find('td')
99
- .text()
100
- ).toBe('13')
101
-
102
- await wrapper.setProps({ currentPage: 3 })
103
-
104
- expect(wrapper.findAll('tbody > tr').length).toBe(0)
105
-
106
- wrapper.destroy()
107
- })
108
-
109
- it('setting current-page to more than pages shows empty row when show-empty=true', async () => {
110
- const wrapper = mount(BTable, {
111
- propsData: {
112
- items: testItems,
113
- perPage: 3,
114
- currentPage: 1,
115
- showEmpty: true
116
- }
117
- })
118
- expect(wrapper.findAll('tbody > tr').length).toBe(3)
119
-
120
- await wrapper.setProps({ currentPage: 10 })
121
-
122
- expect(wrapper.findAll('tbody > tr').length).toBe(1)
123
- const $tr = wrapper.find('tbody > tr')
124
- expect($tr.text()).toBe(wrapper.vm.emptyText)
125
- expect($tr.classes()).toContain('b-table-empty-row')
126
- expect($tr.attributes('role')).toBe('row')
127
- expect(wrapper.find('tbody > tr > td').attributes('role')).toBe('cell')
128
- expect(wrapper.find('tbody > tr > td > div').attributes('role')).toBe('alert')
129
- expect(wrapper.find('tbody > tr > td > div').attributes('aria-live')).toBe('polite')
130
-
131
- wrapper.destroy()
132
- })
133
- })
@@ -1,83 +0,0 @@
1
- import { mount } from '@vue/test-utils'
2
- import { BTable } from './table'
3
-
4
- const testItems = [{ a: 1, b: 2, c: 3 }, { a: 5, b: 5, c: 6 }, { a: 7, b: 8, c: 9 }]
5
-
6
- describe('table > primary key', () => {
7
- it('default should not have ids on table rows', async () => {
8
- const wrapper = mount(BTable, {
9
- propsData: {
10
- items: testItems,
11
- id: 'test'
12
- }
13
- })
14
- expect(wrapper).toBeDefined()
15
- expect(wrapper.find('tbody').exists()).toBe(true)
16
- expect(
17
- wrapper
18
- .find('tbody')
19
- .findAll('tr')
20
- .exists()
21
- ).toBe(true)
22
- const trs = wrapper.find('tbody').findAll('tr')
23
- expect(trs.length).toBe(testItems.length)
24
- expect(trs.at(0).attributes('id')).toBeUndefined()
25
- expect(trs.at(1).attributes('id')).toBeUndefined()
26
- expect(trs.at(2).attributes('id')).toBeUndefined()
27
-
28
- wrapper.destroy()
29
- })
30
-
31
- it('should have ids on table rows when primary key set to field', async () => {
32
- const wrapper = mount(BTable, {
33
- propsData: {
34
- items: testItems,
35
- id: 'foo',
36
- primaryKey: 'a'
37
- }
38
- })
39
- expect(wrapper).toBeDefined()
40
- expect(wrapper.find('tbody').exists()).toBe(true)
41
- expect(
42
- wrapper
43
- .find('tbody')
44
- .findAll('tr')
45
- .exists()
46
- ).toBe(true)
47
- const trs = wrapper.find('tbody').findAll('tr')
48
- expect(trs.length).toBe(testItems.length)
49
- expect(trs.at(0).attributes('id')).toBeDefined()
50
- expect(trs.at(0).attributes('id')).toBe(`foo__row_${testItems[0].a}`)
51
- expect(trs.at(1).attributes('id')).toBeDefined()
52
- expect(trs.at(1).attributes('id')).toBe(`foo__row_${testItems[1].a}`)
53
- expect(trs.at(2).attributes('id')).toBeDefined()
54
- expect(trs.at(2).attributes('id')).toBe(`foo__row_${testItems[2].a}`)
55
-
56
- wrapper.destroy()
57
- })
58
-
59
- it('should not have ids on table rows when primary key set to nonexistent field', async () => {
60
- const wrapper = mount(BTable, {
61
- propsData: {
62
- items: testItems,
63
- id: 'foo',
64
- primaryKey: 'ZZZ'
65
- }
66
- })
67
- expect(wrapper).toBeDefined()
68
- expect(wrapper.find('tbody').exists()).toBe(true)
69
- expect(
70
- wrapper
71
- .find('tbody')
72
- .findAll('tr')
73
- .exists()
74
- ).toBe(true)
75
- const trs = wrapper.find('tbody').findAll('tr')
76
- expect(trs.length).toBe(testItems.length)
77
- expect(trs.at(0).attributes('id')).toBeUndefined()
78
- expect(trs.at(1).attributes('id')).toBeUndefined()
79
- expect(trs.at(2).attributes('id')).toBeUndefined()
80
-
81
- wrapper.destroy()
82
- })
83
- })
@@ -1,411 +0,0 @@
1
- import { mount } from '@vue/test-utils'
2
- import { waitNT } from '../../../tests/utils'
3
- import { BTable } from './table'
4
-
5
- const testItems = [
6
- { a: 1, b: 2, c: 3 },
7
- { a: 5, b: 5, c: 6 },
8
- { a: 7, b: 8, c: 9 },
9
- { a: 10, b: 11, c: 12 },
10
- { a: 13, b: 14, c: 15 }
11
- ]
12
-
13
- const testFields = Object.keys(testItems[0]).sort()
14
-
15
- describe('table > provider functions', () => {
16
- it('synchronous items provider works', async () => {
17
- const provider = () => {
18
- return testItems.slice()
19
- }
20
- const wrapper = mount(BTable, {
21
- propsData: {
22
- fields: testFields,
23
- items: provider
24
- }
25
- })
26
- expect(wrapper).toBeDefined()
27
-
28
- await waitNT(wrapper.vm)
29
-
30
- expect(wrapper.emitted('update:busy')).toBeDefined()
31
- expect(wrapper.emitted('input')).toBeDefined()
32
-
33
- expect(wrapper.find('tbody').exists()).toBe(true)
34
- expect(
35
- wrapper
36
- .find('tbody')
37
- .findAll('tr')
38
- .exists()
39
- ).toBe(true)
40
- expect(wrapper.find('tbody').findAll('tr').length).toBe(testItems.length)
41
-
42
- wrapper.destroy()
43
- })
44
-
45
- it('promise items provider works', async () => {
46
- let doResolve
47
- const promise = new Promise(resolve => {
48
- doResolve = resolve
49
- })
50
- const provider = () => {
51
- return promise
52
- }
53
- const wrapper = mount(BTable, {
54
- propsData: {
55
- fields: testFields,
56
- items: provider,
57
- showEmpty: true
58
- }
59
- })
60
- expect(wrapper).toBeDefined()
61
-
62
- await waitNT(wrapper.vm)
63
-
64
- expect(wrapper.emitted('update:busy')).toBeDefined()
65
-
66
- expect(wrapper.find('tbody').exists()).toBe(true)
67
- expect(
68
- wrapper
69
- .find('tbody')
70
- .findAll('tr')
71
- .exists()
72
- ).toBe(true)
73
- // Should have single empty row
74
- expect(wrapper.find('tbody').findAll('tr').length).toBe(1)
75
-
76
- await waitNT(wrapper.vm)
77
-
78
- expect(doResolve).toBeDefined()
79
- doResolve(testItems.slice())
80
-
81
- await waitNT(wrapper.vm)
82
-
83
- expect(
84
- wrapper
85
- .find('tbody')
86
- .findAll('tr')
87
- .exists()
88
- ).toBe(true)
89
- expect(wrapper.find('tbody').findAll('tr').length).toBe(testItems.length)
90
-
91
- wrapper.destroy()
92
- })
93
-
94
- it('callback items provider works', async () => {
95
- let callback
96
- const provider = (ctx, cb) => {
97
- callback = cb
98
- return null
99
- }
100
- const wrapper = mount(BTable, {
101
- propsData: {
102
- fields: testFields,
103
- items: provider,
104
- showEmpty: true
105
- }
106
- })
107
- expect(wrapper).toBeDefined()
108
-
109
- await waitNT(wrapper.vm)
110
-
111
- expect(wrapper.emitted('update:busy')).toBeDefined()
112
-
113
- expect(wrapper.find('tbody').exists()).toBe(true)
114
- expect(
115
- wrapper
116
- .find('tbody')
117
- .findAll('tr')
118
- .exists()
119
- ).toBe(true)
120
- // Should have single empty row
121
- expect(wrapper.find('tbody').findAll('tr').length).toBe(1)
122
-
123
- await waitNT(wrapper.vm)
124
-
125
- expect(callback).toBeDefined()
126
- callback(testItems.slice())
127
-
128
- await waitNT(wrapper.vm)
129
-
130
- expect(
131
- wrapper
132
- .find('tbody')
133
- .findAll('tr')
134
- .exists()
135
- ).toBe(true)
136
- expect(wrapper.find('tbody').findAll('tr').length).toBe(testItems.length)
137
-
138
- wrapper.destroy()
139
- })
140
-
141
- it('callback items provider expects 2 arguments', async () => {
142
- const provider = () => {
143
- return Promise.resolve(null)
144
- }
145
- const wrapper = mount(BTable, {
146
- propsData: {
147
- fields: testFields,
148
- items: provider,
149
- showEmpty: true
150
- }
151
- })
152
- expect(wrapper).toBeDefined()
153
-
154
- await waitNT(wrapper.vm)
155
-
156
- expect(wrapper.emitted('update:busy')).toBeDefined()
157
-
158
- expect(wrapper.find('tbody').exists()).toBe(true)
159
- expect(
160
- wrapper
161
- .find('tbody')
162
- .findAll('tr')
163
- .exists()
164
- ).toBe(true)
165
- // Should have single empty row
166
- expect(wrapper.find('tbody').findAll('tr').length).toBe(1)
167
-
168
- await waitNT(wrapper.vm)
169
- await waitNT(wrapper.vm)
170
-
171
- // Expect busy to be updated to false
172
- expect(wrapper.vm.localBusy).toBe(false)
173
- const last = wrapper.emitted('update:busy').length - 1
174
- expect(wrapper.emitted('update:busy')[last][0]).toBe(false)
175
-
176
- expect(
177
- wrapper
178
- .find('tbody')
179
- .findAll('tr')
180
- .exists()
181
- ).toBe(true)
182
- expect(wrapper.find('tbody').findAll('tr').length).toBe(1)
183
-
184
- wrapper.destroy()
185
- })
186
-
187
- it('provider refreshing works', async () => {
188
- const provider = () => {
189
- return testItems.slice()
190
- }
191
- const wrapper = mount(BTable, {
192
- propsData: {
193
- id: 'the-table',
194
- fields: testFields,
195
- items: provider
196
- }
197
- })
198
- expect(wrapper).toBeDefined()
199
-
200
- await waitNT(wrapper.vm)
201
-
202
- // Always initially emits a refresh when provider used
203
- expect(wrapper.emitted('refreshed')).toBeDefined()
204
- expect(wrapper.emitted('refreshed').length).toBe(1)
205
-
206
- // Instance refresh method
207
- wrapper.vm.refresh()
208
- await waitNT(wrapper.vm)
209
- await waitNT(wrapper.vm)
210
- expect(wrapper.emitted('refreshed').length).toBe(2)
211
-
212
- // Root event refreshing
213
- wrapper.vm.$root.$emit('bv::refresh::table', 'the-table')
214
- await waitNT(wrapper.vm)
215
- await waitNT(wrapper.vm)
216
- expect(wrapper.emitted('refreshed').length).toBe(3)
217
-
218
- wrapper.destroy()
219
- })
220
-
221
- it('refresh debouncing works', async () => {
222
- let callback
223
- const provider = (ctx, cb) => {
224
- callback = cb
225
- return null
226
- }
227
- const wrapper = mount(BTable, {
228
- propsData: {
229
- fields: testFields.map(f => ({ key: f, sortable: true })),
230
- items: provider,
231
- sortBy: null,
232
- sortDesc: true
233
- }
234
- })
235
- expect(wrapper).toBeDefined()
236
-
237
- expect(wrapper.emitted('refreshed')).toBeUndefined()
238
-
239
- await waitNT(wrapper.vm)
240
-
241
- expect(wrapper.emitted('refreshed')).toBeUndefined()
242
- expect(wrapper.vm.localBusy).toBe(true)
243
-
244
- // No refreshing if localBusy is true
245
- wrapper.vm.refresh()
246
- wrapper.vm.refresh()
247
- // Trigger a context change that would trigger an internal _providerUpdate
248
- await wrapper.setProps({ sortBy: 'b' })
249
- await waitNT(wrapper.vm)
250
- expect(wrapper.emitted('refreshed')).toBeUndefined()
251
-
252
- expect(callback).toBeDefined()
253
- callback(testItems.slice())
254
- await waitNT(wrapper.vm)
255
-
256
- // Refreshed event should happen only once, even though
257
- // triggered 3 times while busy
258
- expect(wrapper.emitted('refreshed')).toBeDefined()
259
- expect(wrapper.emitted('refreshed').length).toBe(1)
260
-
261
- // Just to be sure, we wait again and re-test
262
- await waitNT(wrapper.vm)
263
- expect(wrapper.emitted('refreshed').length).toBe(1)
264
- await waitNT(wrapper.vm)
265
- expect(wrapper.emitted('refreshed').length).toBe(1)
266
-
267
- wrapper.destroy()
268
- })
269
-
270
- it('reacts to items provider function change', async () => {
271
- const provider1 = () => {
272
- return testItems.slice()
273
- }
274
-
275
- const provider2 = () => {
276
- return testItems.slice(testItems.length - 1)
277
- }
278
-
279
- const wrapper = mount(BTable, {
280
- propsData: {
281
- fields: testFields,
282
- items: provider1
283
- }
284
- })
285
- expect(wrapper).toBeDefined()
286
-
287
- await waitNT(wrapper.vm)
288
-
289
- expect(wrapper.emitted('update:busy')).toBeDefined()
290
- expect(wrapper.emitted('input')).toBeDefined()
291
-
292
- expect(wrapper.find('tbody').exists()).toBe(true)
293
- expect(
294
- wrapper
295
- .find('tbody')
296
- .findAll('tr')
297
- .exists()
298
- ).toBe(true)
299
- expect(wrapper.find('tbody').findAll('tr').length).toBe(testItems.length)
300
-
301
- await wrapper.setProps({ items: provider2 })
302
- await waitNT(wrapper.vm)
303
- await waitNT(wrapper.vm)
304
-
305
- expect(wrapper.find('tbody').exists()).toBe(true)
306
- expect(
307
- wrapper
308
- .find('tbody')
309
- .findAll('tr')
310
- .exists()
311
- ).toBe(true)
312
-
313
- expect(wrapper.find('tbody').findAll('tr').length).toBe(1)
314
-
315
- wrapper.destroy()
316
- })
317
-
318
- it('calls provider only once when filter is pre-set object', async () => {
319
- let providerCallCount = 0
320
- const provider = () => {
321
- providerCallCount++
322
- return testItems.slice()
323
- }
324
-
325
- const wrapper = mount(BTable, {
326
- propsData: {
327
- filter: { a: '123' },
328
- fields: testFields.slice(),
329
- items: provider
330
- }
331
- })
332
-
333
- await waitNT(wrapper.vm)
334
-
335
- expect(providerCallCount).toBe(1)
336
-
337
- await waitNT(wrapper.vm)
338
- await waitNT(wrapper.vm)
339
- await waitNT(wrapper.vm)
340
-
341
- expect(providerCallCount).toBe(1)
342
-
343
- wrapper.destroy()
344
- })
345
-
346
- it('provider is called when filter object child property is changed', async () => {
347
- let lastProviderContext = {}
348
-
349
- // We need a wrapper app to get around a "bug" in Vue test utils that
350
- // doesn't let us change a child property in an object and update
351
- // that prop with the same object reference
352
- // https://forum.vuejs.org/t/vue-test-utils-watchers-on-object-properties-not-triggered/50900/11?u=tmorehouse
353
- const App = {
354
- data() {
355
- return {
356
- filter: {
357
- a: '123'
358
- },
359
- fields: testFields.slice()
360
- }
361
- },
362
- methods: {
363
- provider(ctx) {
364
- lastProviderContext = ctx
365
- return testItems.slice()
366
- }
367
- },
368
- render(h) {
369
- return h(BTable, {
370
- props: {
371
- items: this.provider,
372
- fields: this.fields,
373
- filter: this.filter
374
- }
375
- })
376
- }
377
- }
378
-
379
- const wrapper = mount(App, {
380
- attachTo: document.body
381
- })
382
-
383
- expect(wrapper.element.tagName).toBe('TABLE')
384
-
385
- const $table = wrapper.findComponent(BTable)
386
- expect($table.exists()).toBe(true)
387
-
388
- await waitNT(wrapper.vm)
389
- await waitNT(wrapper.vm)
390
- await waitNT(wrapper.vm)
391
-
392
- expect(lastProviderContext.filter).toEqual({
393
- a: '123'
394
- })
395
-
396
- // Change the filter criteria child property, but not the object reference
397
- // `setData` recursively traverses the object and only changes the leaf values
398
- await wrapper.setData({ filter: { a: '456' } })
399
- expect(wrapper.vm.filter).toEqual({ a: '456' })
400
-
401
- await waitNT(wrapper.vm)
402
- await waitNT(wrapper.vm)
403
- await waitNT(wrapper.vm)
404
-
405
- expect(lastProviderContext.filter).toEqual({
406
- a: '456'
407
- })
408
-
409
- wrapper.destroy()
410
- })
411
- })