@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,362 +0,0 @@
1
- # Nav
2
-
3
- > Navigation available in Bootstrap share general markup and styles, from the base `<b-nav>` class
4
- > to the `active` and `disabled` states. Swap modifier props to switch between each style.
5
-
6
- ```html
7
- <div>
8
- <b-nav>
9
- <b-nav-item active>Active</b-nav-item>
10
- <b-nav-item>Link</b-nav-item>
11
- <b-nav-item>Another Link</b-nav-item>
12
- <b-nav-item disabled>Disabled</b-nav-item>
13
- </b-nav>
14
- </div>
15
-
16
- <!-- b-nav.vue -->
17
- ```
18
-
19
- ## Overview
20
-
21
- The base `<b-nav>` component is built with flexbox and provides a strong foundation for building all
22
- types of navigation components. It includes some style overrides (for working with lists), some link
23
- padding for larger hit areas, and basic disabled styling. No active states are included in the base
24
- nav.
25
-
26
- `<b-nav>` supports the following child components:
27
-
28
- - `<b-nav-item>` for actionable links (or router-links)
29
- - `<b-nav-text>` for plain text content
30
- - `<b-nav-form>` for inline forms
31
-
32
- ## Link appearance
33
-
34
- Two style variations are supported: `tabs` and `pills`, which support `active` state styling. These
35
- variants are mutually exclusive - use only one style or the other.
36
-
37
- ### Tab style
38
-
39
- Make the nav look like tabs by setting the `tabs` prop.
40
-
41
- ```html
42
- <div>
43
- <b-nav tabs>
44
- <b-nav-item active>Active</b-nav-item>
45
- <b-nav-item>Link</b-nav-item>
46
- <b-nav-item>Another Link</b-nav-item>
47
- <b-nav-item disabled>Disabled</b-nav-item>
48
- </b-nav>
49
- </div>
50
-
51
- <!-- b-nav-tabs.vue -->
52
- ```
53
-
54
- ### Pill style
55
-
56
- Use the pill style by setting the `pills` prop.
57
-
58
- ```html
59
- <div>
60
- <b-nav pills>
61
- <b-nav-item active>Active</b-nav-item>
62
- <b-nav-item>Link</b-nav-item>
63
- <b-nav-item>Another Link</b-nav-item>
64
- <b-nav-item disabled>Disabled</b-nav-item>
65
- </b-nav>
66
- </div>
67
-
68
- <!-- b-nav-pills.vue -->
69
- ```
70
-
71
- ### Small
72
-
73
- Make the nav smaller by setting the `small` prop.
74
-
75
- ```html
76
- <div>
77
- <b-nav small>
78
- <b-nav-item active>Active</b-nav-item>
79
- <b-nav-item>Link</b-nav-item>
80
- <b-nav-item>Another Link</b-nav-item>
81
- <b-nav-item disabled>Disabled</b-nav-item>
82
- </b-nav>
83
- </div>
84
-
85
- <!-- b-nav-small.vue -->
86
- ```
87
-
88
- ## Fill and justify
89
-
90
- Force your `<b-nav>` content to extend the full available width.
91
-
92
- ### Fill
93
-
94
- To proportionately fill all available space with your `<b-nav-item>` components, set the `fill`
95
- prop. Notice that all horizontal space is occupied, but not every nav item has the same width.
96
-
97
- ```html
98
- <div>
99
- <b-nav tabs fill>
100
- <b-nav-item active>Active</b-nav-item>
101
- <b-nav-item>Link</b-nav-item>
102
- <b-nav-item>Link with a long name </b-nav-item>
103
- <b-nav-item disabled>Disabled</b-nav-item>
104
- </b-nav>
105
- </div>
106
-
107
- <!-- b-nav-fill.vue -->
108
- ```
109
-
110
- ### Justified
111
-
112
- For equal-width elements, set the `justified` prop instead. All horizontal space will be occupied by
113
- nav links, but unlike `fill` above, every `<b-nav-item>` will be the same width.
114
-
115
- ```html
116
- <div>
117
- <b-nav tabs justified>
118
- <b-nav-item active>Active</b-nav-item>
119
- <b-nav-item>Link</b-nav-item>
120
- <b-nav-item>Link with a long name </b-nav-item>
121
- <b-nav-item disabled>Disabled</b-nav-item>
122
- </b-nav>
123
- </div>
124
-
125
- <!-- b-nav-justified.vue -->
126
- ```
127
-
128
- ## Alignment
129
-
130
- To align your `<b-nav-item>` components, use the `align` prop. Available values are `left`, `center`
131
- and `right`.
132
-
133
- ```html
134
- <div>
135
- <b-nav tabs align="center">
136
- <b-nav-item active>Active</b-nav-item>
137
- <b-nav-item>Link</b-nav-item>
138
- <b-nav-item>Link with a long name </b-nav-item>
139
- <b-nav-item disabled>Disabled</b-nav-item>
140
- </b-nav>
141
- </div>
142
-
143
- <!-- b-nav-alignment.vue -->
144
- ```
145
-
146
- ## Nav text content
147
-
148
- Use the `<b-nav-text>` child component to place plain text content into the nav:
149
-
150
- ```html
151
- <div>
152
- <b-nav >
153
- <b-nav-item href="#1">Link 1</b-nav-item>
154
- <b-nav-item href="#2">Link 2</b-nav-item>
155
- <b-nav-text>Plain text</b-nav-text>
156
- </b-nav>
157
- </div>
158
-
159
- <!-- b-nav-text.vue -->
160
- ```
161
-
162
- ## Nav inline forms
163
-
164
- Use the `<b-nav-form>` child component to place an _inline_ form into the nav:
165
-
166
- ```html
167
- <div>
168
- <b-nav pills>
169
- <b-nav-item href="#1" active>Link 1</b-nav-item>
170
- <b-nav-item href="#2">Link 2</b-nav-item>
171
- <b-nav-form @submit.stop.prevent="alert('Form Submitted')">
172
- <b-form-input aria-label="Input" class="mr-1"></b-form-input>
173
- <b-button type="submit">Ok</b-button>
174
- </b-nav-form>
175
- </b-nav>
176
- </div>
177
-
178
- <!-- b-nav-form.vue -->
179
- ```
180
-
181
- Refer to the [`<gl-form>` inline](?path=/docs/base-form-form--docs#inline-formm) documentation for
182
- additional details on placing form controls.
183
-
184
- ## Tabbed local content support
185
-
186
- See the [`<gl-tabs>`](?path=/docs/base-tabs--docs) component for creating tabbable panes of local
187
- content (not suited for navigation).
188
-
189
- ## Card integration
190
-
191
- Use a `<b-nav>` in a [`<gl-card>`](?path=/docs/base-card--docs) header, by enabling the
192
- `card-header` prop on `<b-nav>` and setting either the `pills` or `tabs` props:
193
-
194
- **Tabs style:**
195
-
196
- ```html
197
- <div>
198
- <b-card title="Card Title" no-body>
199
- <b-card-header header-tag="nav">
200
- <b-nav card-header tabs>
201
- <b-nav-item active>Active</b-nav-item>
202
- <b-nav-item>Inactive</b-nav-item>
203
- <b-nav-item disabled>Disabled</b-nav-item>
204
- </b-nav>
205
- </b-card-header>
206
-
207
- <b-card-body class="text-center">
208
- <b-card-text>
209
- With supporting text below as a natural lead-in to additional content.
210
- </b-card-text>
211
-
212
- <b-button variant="primary">Go somewhere</b-button>
213
- </b-card-body>
214
- </b-card>
215
- </div>
216
-
217
- <!-- nav-card-tabs.vue -->
218
- ```
219
-
220
- **Pill style:**
221
-
222
- ```html
223
- <div>
224
- <b-card title="Card Title" no-body>
225
- <b-card-header header-tag="nav">
226
- <b-nav card-header pills>
227
- <b-nav-item active>Active</b-nav-item>
228
- <b-nav-item>Inactive</b-nav-item>
229
- <b-nav-item disabled>Disabled</b-nav-item>
230
- </b-nav>
231
- </b-card-header>
232
-
233
- <b-card-body class="text-center">
234
- <b-card-text>
235
- With supporting text below as a natural lead-in to additional content.
236
- </b-card-text>
237
-
238
- <b-button variant="primary">Go somewhere</b-button>
239
- </b-card-body>
240
- </b-card>
241
- </div>
242
-
243
- <!-- nav-card-pills.vue -->
244
- ```
245
-
246
- **Plain style:**
247
-
248
- The `card-header` prop is only needed when you are applying `tabs` or `pills` style. Note that
249
- Bootstrap v4 SCSS does not have special styling for `active` state plain style nav items.
250
-
251
- ```html
252
- <div>
253
- <b-card title="Card Title" no-body>
254
- <b-card-header header-tag="nav">
255
- <b-nav>
256
- <b-nav-item active>Active</b-nav-item>
257
- <b-nav-item>Inactive</b-nav-item>
258
- <b-nav-item disabled>Disabled</b-nav-item>
259
- </b-nav>
260
- </b-card-header>
261
-
262
- <b-card-body class="text-center">
263
- <b-card-text>
264
- With supporting text below as a natural lead-in to additional content.
265
- </b-card-text>
266
-
267
- <b-button variant="primary">Go somewhere</b-button>
268
- </b-card-body>
269
- </b-card>
270
- </div>
271
-
272
- <!-- nav-card-plain.vue -->
273
- ```
274
-
275
- ### Using with Vue Router
276
-
277
- Have your card `<b-nav>` control vue router nested routes via `<router-view>` or `<nuxt-child>`
278
- components, to created tabbed content that changes with route URL:
279
-
280
- ```html
281
- // On page with route `/some/route`
282
- <div>
283
- <b-card title="Card Title" no-body>
284
- <b-card-header header-tag="nav">
285
- <b-nav card-header tabs>
286
- <!-- <b-nav-item>'s with child routes. Note the trailing slash on the first <b-nav-item> -->
287
- <b-nav-item to="/some/route/" exact exact-active-class="active">Active</b-nav-item>
288
- <b-nav-item to="/some/route/foo" exact exact-active-class="active">Foo</b-nav-item>
289
- <b-nav-item to="/some/route/bar" exact exact-active-class="active">Bar</b-nav-item>
290
- </b-nav>
291
- </b-card-header>
292
-
293
- <b-card-body>
294
- <!-- Child route gets rendered in <router-view> or <nuxt-child> -->
295
- <router-view></router-view>
296
- <!-- Or if using Nuxt.js
297
- <nuxt-child></nuxt-child>
298
- -->
299
- </b-card-body>
300
- </b-card>
301
- </div>
302
- ```
303
-
304
- Note: Vue Router does not support defining active routes with hashes (`#`), which is why you must
305
- define the "tab" content as child routes.
306
-
307
- **Example router config for above:**
308
-
309
- <!-- eslint-disable no-unused-vars, no-undef -->
310
-
311
- ```js
312
- const routes = [
313
- {
314
- path: '/some/route',
315
- // We don't provide a name on this parent route, but rather
316
- // set the name on the default child route instead
317
- // name: 'some-route',
318
- component: SomeRouteComponent,
319
- // Child route "tabs"
320
- children: [
321
- // Note we provide the above parent route name on the default child tab
322
- // route to ensure this tab is rendered by default when using named routes
323
- { path: '', component: DefaultTabComponent, name: 'some-route' },
324
- { path: 'foo', component: FooTabComponent },
325
- { path: 'bar', component: BarTabComponent }
326
- ]
327
- }
328
- ]
329
- ```
330
-
331
- One can also use Vue Router
332
- [named routes](https://router.vuejs.org/guide/essentials/named-routes.html#named-routes) and/or
333
- route params instead of path based routes.
334
-
335
- For more details see:
336
-
337
- - [Vue Router `<router-view>`](https://router.vuejs.org/api/#router-view)
338
- - [Nuxt.JS `<nuxt-child>`](https://nuxtjs.org/api/components-nuxt-child)
339
-
340
- ## Accessibility
341
-
342
- If you're using `<b-nav>` to provide a navigation bar, be sure to add a `role="navigation"` to the
343
- most logical parent container of `<b-nav>`, or wrap a `<nav>` element around `<b-nav>`. Do **not**
344
- add the role to the `<b-nav>` itself, as this would prevent it from being announced as an actual
345
- list by assistive technologies.
346
-
347
- ### Tabbed interface accessibility
348
-
349
- Note that navigation bars, even if visually styled as tabs, should **not** be given
350
- `role="tablist"`, `role="tab"` or `role="tabpanel"` attributes. These are only appropriate for
351
- [tabbed interfaces](?path=/docs/base-tabs--docs) that do not change the URL or `$route`, as
352
- described in the [WAI ARIA Authoring Practices](https://www.w3.org/TR/wai-aria-practices/#tabpanel).
353
- See [`<gl-tabs>`](?path=/docs/base-tabs--docs) for dynamic tabbed interfaces that are compliant with
354
- WAI ARIA.
355
-
356
- ## See also
357
-
358
- - [tabs](?path=/docs/base-tabs--docs) to create tabbable panes of local content.
359
- - [Router Link Support reference](?path=/docs/base-link--docs#router-link-support) for information
360
- about router-link specific props available on `<b-nav-item>`
361
-
362
- <!-- Component reference added automatically from component package.json -->
@@ -1,127 +0,0 @@
1
- import { mount } from '@vue/test-utils'
2
- import { BLink } from '../link/link'
3
- import { BNavItem } from './nav-item'
4
-
5
- describe('nav-item', () => {
6
- it('has expected default structure', async () => {
7
- const wrapper = mount(BNavItem)
8
-
9
- expect(wrapper.element.tagName).toBe('LI')
10
- expect(wrapper.classes()).toContain('nav-item')
11
- expect(wrapper.classes().length).toBe(1)
12
-
13
- const link = wrapper.find('a')
14
- expect(link).toBeDefined()
15
- expect(link.findComponent(BLink).exists()).toBe(true)
16
- expect(link.element.tagName).toBe('A')
17
- expect(link.classes()).toContain('nav-link')
18
- expect(link.classes().length).toBe(1)
19
- expect(link.attributes('href')).toBeDefined()
20
- expect(link.attributes('href')).toBe('#')
21
- expect(link.attributes('role')).toBeUndefined()
22
-
23
- wrapper.destroy()
24
- })
25
-
26
- it('has attrs on link when link-attrs set', async () => {
27
- const wrapper = mount(BNavItem, {
28
- context: {
29
- props: {
30
- linkAttrs: { role: 'tab' }
31
- }
32
- }
33
- })
34
-
35
- expect(wrapper.attributes('role')).toBeUndefined()
36
-
37
- const link = wrapper.find('a')
38
- expect(link).toBeDefined()
39
- expect(link.findComponent(BLink).exists()).toBe(true)
40
- expect(link.element.tagName).toBe('A')
41
- expect(link.attributes('role')).toBeDefined()
42
- expect(link.attributes('role')).toBe('tab')
43
-
44
- wrapper.destroy()
45
- })
46
-
47
- it('has custom classes on link when link-classes set', async () => {
48
- const wrapper = mount(BNavItem, {
49
- context: {
50
- props: {
51
- linkClasses: ['foo', { bar: true }]
52
- }
53
- }
54
- })
55
-
56
- const link = wrapper.find('a')
57
- expect(link).toBeDefined()
58
- expect(link.findComponent(BLink).exists()).toBe(true)
59
- expect(link.element.tagName).toBe('A')
60
- expect(link.classes()).toContain('foo')
61
- expect(link.classes()).toContain('bar')
62
- expect(link.classes()).toContain('nav-link')
63
-
64
- wrapper.destroy()
65
- })
66
-
67
- it('has class "disabled" on link when disabled set', async () => {
68
- const wrapper = mount(BNavItem, {
69
- context: {
70
- props: { disabled: true }
71
- }
72
- })
73
-
74
- const link = wrapper.find('a')
75
- expect(link).toBeDefined()
76
- expect(link.findComponent(BLink).exists()).toBe(true)
77
- expect(link.element.tagName).toBe('A')
78
- expect(link.classes()).toContain('disabled')
79
-
80
- wrapper.destroy()
81
- })
82
-
83
- it('emits click event when clicked', async () => {
84
- const spy = jest.fn()
85
- const wrapper = mount(BNavItem, {
86
- context: {
87
- on: { click: spy }
88
- }
89
- })
90
-
91
- expect(spy).not.toHaveBeenCalled()
92
- await wrapper.trigger('click')
93
- expect(spy).not.toHaveBeenCalled()
94
-
95
- const link = wrapper.find('a')
96
- expect(link).toBeDefined()
97
- expect(link.findComponent(BLink).exists()).toBe(true)
98
- expect(link.element.tagName).toBe('A')
99
- await link.trigger('click')
100
- expect(spy).toHaveBeenCalled()
101
-
102
- wrapper.destroy()
103
- })
104
-
105
- it('does not emit a click event when clicked and disabled', async () => {
106
- const spy = jest.fn()
107
- const wrapper = mount(BNavItem, {
108
- context: {
109
- props: { disabled: true },
110
- on: { click: spy }
111
- }
112
- })
113
-
114
- expect(spy).not.toHaveBeenCalled()
115
- await wrapper.trigger('click')
116
- expect(spy).not.toHaveBeenCalled()
117
-
118
- const link = wrapper.find('a')
119
- expect(link).toBeDefined()
120
- expect(link.findComponent(BLink).exists()).toBe(true)
121
- expect(link.element.tagName).toBe('A')
122
- await link.trigger('click')
123
- expect(spy).not.toHaveBeenCalled()
124
-
125
- wrapper.destroy()
126
- })
127
- })
@@ -1,177 +0,0 @@
1
- import { mount } from '@vue/test-utils'
2
- import { BNav } from './nav'
3
-
4
- describe('nav', () => {
5
- it('has expected default structure', async () => {
6
- const wrapper = mount(BNav)
7
-
8
- expect(wrapper.element.tagName).toBe('UL')
9
- expect(wrapper.classes()).toContain('nav')
10
- expect(wrapper.classes().length).toBe(1)
11
- expect(wrapper.text()).toBe('')
12
-
13
- wrapper.destroy()
14
- })
15
-
16
- it('renders custom root element when prop tag set', async () => {
17
- const wrapper = mount(BNav, {
18
- propsData: {
19
- tag: 'ol'
20
- }
21
- })
22
-
23
- expect(wrapper.element.tagName).toBe('OL')
24
- expect(wrapper.classes()).toContain('nav')
25
- expect(wrapper.classes().length).toBe(1)
26
- expect(wrapper.text()).toBe('')
27
-
28
- wrapper.destroy()
29
- })
30
-
31
- it('renders default slot content', async () => {
32
- const wrapper = mount(BNav, {
33
- slots: {
34
- default: 'foobar'
35
- }
36
- })
37
-
38
- expect(wrapper.element.tagName).toBe('UL')
39
- expect(wrapper.classes()).toContain('nav')
40
- expect(wrapper.classes().length).toBe(1)
41
- expect(wrapper.text()).toBe('foobar')
42
-
43
- wrapper.destroy()
44
- })
45
-
46
- it('applies pill style', async () => {
47
- const wrapper = mount(BNav, {
48
- propsData: {
49
- pills: true
50
- }
51
- })
52
-
53
- expect(wrapper.element.tagName).toBe('UL')
54
- expect(wrapper.classes()).toContain('nav')
55
- expect(wrapper.classes()).toContain('nav-pills')
56
- expect(wrapper.classes().length).toBe(2)
57
- expect(wrapper.text()).toBe('')
58
-
59
- wrapper.destroy()
60
- })
61
-
62
- it('applies tab style', async () => {
63
- const wrapper = mount(BNav, {
64
- propsData: {
65
- tabs: true
66
- }
67
- })
68
-
69
- expect(wrapper.element.tagName).toBe('UL')
70
- expect(wrapper.classes()).toContain('nav')
71
- expect(wrapper.classes()).toContain('nav-tabs')
72
- expect(wrapper.classes().length).toBe(2)
73
- expect(wrapper.text()).toBe('')
74
-
75
- wrapper.destroy()
76
- })
77
-
78
- it('applies justify style when justified', async () => {
79
- const wrapper = mount(BNav, {
80
- propsData: {
81
- justified: true
82
- }
83
- })
84
-
85
- expect(wrapper.element.tagName).toBe('UL')
86
- expect(wrapper.classes()).toContain('nav')
87
- expect(wrapper.classes()).toContain('nav-justified')
88
- expect(wrapper.classes().length).toBe(2)
89
- expect(wrapper.text()).toBe('')
90
-
91
- wrapper.destroy()
92
- })
93
-
94
- it('applies fill style style when fill set', async () => {
95
- const wrapper = mount(BNav, {
96
- propsData: {
97
- fill: true
98
- }
99
- })
100
-
101
- expect(wrapper.element.tagName).toBe('UL')
102
- expect(wrapper.classes()).toContain('nav')
103
- expect(wrapper.classes()).toContain('nav-fill')
104
- expect(wrapper.classes().length).toBe(2)
105
- expect(wrapper.text()).toBe('')
106
-
107
- wrapper.destroy()
108
- })
109
-
110
- it('applies alignment correctly', async () => {
111
- const wrapper = mount(BNav, {
112
- propsData: {
113
- align: 'center'
114
- }
115
- })
116
-
117
- expect(wrapper.element.tagName).toBe('UL')
118
- expect(wrapper.classes()).toContain('nav')
119
- expect(wrapper.classes()).toContain('justify-content-center')
120
- expect(wrapper.classes().length).toBe(2)
121
- expect(wrapper.text()).toBe('')
122
-
123
- wrapper.destroy()
124
- })
125
-
126
- it('applies small style', async () => {
127
- const wrapper = mount(BNav, {
128
- propsData: {
129
- small: true
130
- }
131
- })
132
-
133
- expect(wrapper.element.tagName).toBe('UL')
134
- expect(wrapper.classes()).toContain('nav')
135
- expect(wrapper.classes()).toContain('small')
136
- expect(wrapper.classes().length).toBe(2)
137
- expect(wrapper.text()).toBe('')
138
-
139
- wrapper.destroy()
140
- })
141
-
142
- it('applies card-header-tabs class when tabs and card-header props set', async () => {
143
- const wrapper = mount(BNav, {
144
- propsData: {
145
- tabs: true,
146
- cardHeader: true
147
- }
148
- })
149
-
150
- expect(wrapper.element.tagName).toBe('UL')
151
- expect(wrapper.classes()).toContain('nav')
152
- expect(wrapper.classes()).toContain('nav-tabs')
153
- expect(wrapper.classes()).toContain('card-header-tabs')
154
- expect(wrapper.classes().length).toBe(3)
155
- expect(wrapper.text()).toBe('')
156
-
157
- wrapper.destroy()
158
- })
159
-
160
- it('applies card-header-pills class when pills and card-header props set', async () => {
161
- const wrapper = mount(BNav, {
162
- propsData: {
163
- pills: true,
164
- cardHeader: true
165
- }
166
- })
167
-
168
- expect(wrapper.element.tagName).toBe('UL')
169
- expect(wrapper.classes()).toContain('nav')
170
- expect(wrapper.classes()).toContain('nav-pills')
171
- expect(wrapper.classes()).toContain('card-header-pills')
172
- expect(wrapper.classes().length).toBe(3)
173
- expect(wrapper.text()).toBe('')
174
-
175
- wrapper.destroy()
176
- })
177
- })