@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.
- package/package.json +7 -26
- package/CHANGELOG.md +0 -13139
- package/src/vendor/bootstrap/LICENSE +0 -11
- package/src/vendor/bootstrap-vue/LICENSE +0 -11
- package/src/vendor/bootstrap-vue/package.json +0 -144
- package/src/vendor/bootstrap-vue/src/components/button/MODIFICATIONS.md +0 -16
- package/src/vendor/bootstrap-vue/src/components/button/README.md +0 -240
- package/src/vendor/bootstrap-vue/src/components/button/button-close.spec.js +0 -210
- package/src/vendor/bootstrap-vue/src/components/button/button.spec.js +0 -349
- package/src/vendor/bootstrap-vue/src/components/button/package.json +0 -105
- package/src/vendor/bootstrap-vue/src/components/dropdown/README.md +0 -730
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-divider.spec.js +0 -58
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-form.spec.js +0 -110
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-group.spec.js +0 -94
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-header.spec.js +0 -73
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item-button.spec.js +0 -117
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.spec.js +0 -147
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.spec.js +0 -59
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown.spec.js +0 -1121
- package/src/vendor/bootstrap-vue/src/components/dropdown/package.json +0 -368
- package/src/vendor/bootstrap-vue/src/components/form/README.md +0 -365
- package/src/vendor/bootstrap-vue/src/components/form/form-invalid-feedback.spec.js +0 -170
- package/src/vendor/bootstrap-vue/src/components/form/form-text.spec.js +0 -93
- package/src/vendor/bootstrap-vue/src/components/form/form-valid-feedback.spec.js +0 -157
- package/src/vendor/bootstrap-vue/src/components/form/form.spec.js +0 -97
- package/src/vendor/bootstrap-vue/src/components/form/package.json +0 -112
- package/src/vendor/bootstrap-vue/src/components/form-checkbox/README.md +0 -691
- package/src/vendor/bootstrap-vue/src/components/form-checkbox/form-checkbox-group.spec.js +0 -525
- package/src/vendor/bootstrap-vue/src/components/form-checkbox/form-checkbox.spec.js +0 -922
- package/src/vendor/bootstrap-vue/src/components/form-checkbox/package.json +0 -172
- package/src/vendor/bootstrap-vue/src/components/form-group/README.md +0 -339
- package/src/vendor/bootstrap-vue/src/components/form-group/form-group.spec.js +0 -477
- package/src/vendor/bootstrap-vue/src/components/form-group/package.json +0 -183
- package/src/vendor/bootstrap-vue/src/components/form-radio/README.md +0 -437
- package/src/vendor/bootstrap-vue/src/components/form-radio/form-radio-group.spec.js +0 -357
- package/src/vendor/bootstrap-vue/src/components/form-radio/form-radio.spec.js +0 -587
- package/src/vendor/bootstrap-vue/src/components/form-radio/package.json +0 -162
- package/src/vendor/bootstrap-vue/src/components/form-select/README.md +0 -504
- package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option-group.spec.js +0 -138
- package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option.spec.js +0 -75
- package/src/vendor/bootstrap-vue/src/components/form-select/form-select.spec.js +0 -723
- package/src/vendor/bootstrap-vue/src/components/form-select/package.json +0 -132
- package/src/vendor/bootstrap-vue/src/components/form-textarea/README.md +0 -453
- package/src/vendor/bootstrap-vue/src/components/form-textarea/form-textarea.spec.js +0 -1000
- package/src/vendor/bootstrap-vue/src/components/form-textarea/package.json +0 -122
- package/src/vendor/bootstrap-vue/src/components/layout/README.md +0 -791
- package/src/vendor/bootstrap-vue/src/components/layout/col.spec.js +0 -192
- package/src/vendor/bootstrap-vue/src/components/layout/form-row.spec.js +0 -45
- package/src/vendor/bootstrap-vue/src/components/layout/package.json +0 -99
- package/src/vendor/bootstrap-vue/src/components/link/README.md +0 -76
- package/src/vendor/bootstrap-vue/src/components/link/link.spec.js +0 -434
- package/src/vendor/bootstrap-vue/src/components/link/package.json +0 -57
- package/src/vendor/bootstrap-vue/src/components/modal/MODIFICATIONS.md +0 -30
- package/src/vendor/bootstrap-vue/src/components/modal/README.md +0 -1067
- package/src/vendor/bootstrap-vue/src/components/modal/helpers/bv-modal-event.class.spec.js +0 -82
- package/src/vendor/bootstrap-vue/src/components/modal/modal.spec.js +0 -1418
- package/src/vendor/bootstrap-vue/src/components/modal/package.json +0 -544
- package/src/vendor/bootstrap-vue/src/components/nav/README.md +0 -362
- package/src/vendor/bootstrap-vue/src/components/nav/nav-item.spec.js +0 -127
- package/src/vendor/bootstrap-vue/src/components/nav/nav.spec.js +0 -177
- package/src/vendor/bootstrap-vue/src/components/nav/package.json +0 -73
- package/src/vendor/bootstrap-vue/src/components/popover/README.md +0 -919
- package/src/vendor/bootstrap-vue/src/components/popover/package.json +0 -261
- package/src/vendor/bootstrap-vue/src/components/popover/popover.spec.js +0 -198
- package/src/vendor/bootstrap-vue/src/components/table/README.md +0 -3157
- package/src/vendor/bootstrap-vue/src/components/table/helpers/default-sort-compare.spec.js +0 -112
- package/src/vendor/bootstrap-vue/src/components/table/helpers/normalize-fields.spec.js +0 -93
- package/src/vendor/bootstrap-vue/src/components/table/package.json +0 -1763
- package/src/vendor/bootstrap-vue/src/components/table/table-busy.spec.js +0 -150
- package/src/vendor/bootstrap-vue/src/components/table/table-caption.spec.js +0 -176
- package/src/vendor/bootstrap-vue/src/components/table/table-colgroup.spec.js +0 -81
- package/src/vendor/bootstrap-vue/src/components/table/table-filtering.spec.js +0 -409
- package/src/vendor/bootstrap-vue/src/components/table/table-item-formatter.spec.js +0 -56
- package/src/vendor/bootstrap-vue/src/components/table/table-lite.spec.js +0 -682
- package/src/vendor/bootstrap-vue/src/components/table/table-pagination.spec.js +0 -133
- package/src/vendor/bootstrap-vue/src/components/table/table-primarykey.spec.js +0 -83
- package/src/vendor/bootstrap-vue/src/components/table/table-provider.spec.js +0 -411
- package/src/vendor/bootstrap-vue/src/components/table/table-row-details.spec.js +0 -459
- package/src/vendor/bootstrap-vue/src/components/table/table-selectable.spec.js +0 -1182
- package/src/vendor/bootstrap-vue/src/components/table/table-simple.spec.js +0 -206
- package/src/vendor/bootstrap-vue/src/components/table/table-sorting.spec.js +0 -858
- package/src/vendor/bootstrap-vue/src/components/table/table-sticky-column.spec.js +0 -377
- package/src/vendor/bootstrap-vue/src/components/table/table-tbody-bottom-row.spec.js +0 -94
- package/src/vendor/bootstrap-vue/src/components/table/table-tbody-row-events.spec.js +0 -529
- package/src/vendor/bootstrap-vue/src/components/table/table-tbody-top-row.spec.js +0 -88
- package/src/vendor/bootstrap-vue/src/components/table/table-tbody-transition.spec.js +0 -83
- package/src/vendor/bootstrap-vue/src/components/table/table-tfoot-custom.spec.js +0 -91
- package/src/vendor/bootstrap-vue/src/components/table/table-tfoot-events.spec.js +0 -137
- package/src/vendor/bootstrap-vue/src/components/table/table-thead-events.spec.js +0 -155
- package/src/vendor/bootstrap-vue/src/components/table/table-thead-top.spec.js +0 -96
- package/src/vendor/bootstrap-vue/src/components/table/table.spec.js +0 -692
- package/src/vendor/bootstrap-vue/src/components/tabs/README.md +0 -433
- package/src/vendor/bootstrap-vue/src/components/tabs/package.json +0 -205
- package/src/vendor/bootstrap-vue/src/components/tabs/tab.spec.js +0 -330
- package/src/vendor/bootstrap-vue/src/components/tabs/tabs.spec.js +0 -778
- package/src/vendor/bootstrap-vue/src/components/toast/README.md +0 -655
- package/src/vendor/bootstrap-vue/src/components/toast/helpers/bv-toast.spec.js +0 -117
- package/src/vendor/bootstrap-vue/src/components/toast/package.json +0 -184
- package/src/vendor/bootstrap-vue/src/components/toast/toast.spec.js +0 -294
- package/src/vendor/bootstrap-vue/src/components/toast/toaster.spec.js +0 -77
- package/src/vendor/bootstrap-vue/src/components/tooltip/README.md +0 -559
- package/src/vendor/bootstrap-vue/src/components/tooltip/package.json +0 -258
- package/src/vendor/bootstrap-vue/src/components/tooltip/tooltip.spec.js +0 -1240
- package/src/vendor/bootstrap-vue/src/components/transition/package.json +0 -5
- package/src/vendor/bootstrap-vue/src/components/transporter/package.json +0 -5
- package/src/vendor/bootstrap-vue/src/components/transporter/transporter.spec.js +0 -85
- package/src/vendor/bootstrap-vue/src/directives/modal/modal.spec.js +0 -191
- package/src/vendor/bootstrap-vue/src/directives/tooltip/README.md +0 -521
- package/src/vendor/bootstrap-vue/src/directives/tooltip/package.json +0 -131
- package/src/vendor/bootstrap-vue/src/directives/tooltip/tooltip.spec.js +0 -190
- package/src/vendor/bootstrap-vue/src/directives/visible/README.md +0 -244
- package/src/vendor/bootstrap-vue/src/directives/visible/package.json +0 -24
- package/src/vendor/bootstrap-vue/src/mixins/attrs.spec.js +0 -194
- package/src/vendor/bootstrap-vue/src/mixins/click-out.spec.js +0 -52
- package/src/vendor/bootstrap-vue/src/mixins/focus-in.spec.js +0 -53
- package/src/vendor/bootstrap-vue/src/mixins/listen-on-document.spec.js +0 -117
- package/src/vendor/bootstrap-vue/src/mixins/listen-on-root.spec.js +0 -77
- package/src/vendor/bootstrap-vue/src/mixins/listen-on-window.spec.js +0 -115
- package/src/vendor/bootstrap-vue/src/mixins/listeners.spec.js +0 -245
- package/src/vendor/bootstrap-vue/src/utils/bv-event.class.spec.js +0 -66
- package/src/vendor/bootstrap-vue/src/utils/clone-deep.spec.js +0 -70
- package/src/vendor/bootstrap-vue/src/utils/config.spec.js +0 -169
- package/src/vendor/bootstrap-vue/src/utils/css-escape.spec.js +0 -82
- package/src/vendor/bootstrap-vue/src/utils/dom.spec.js +0 -291
- package/src/vendor/bootstrap-vue/src/utils/events.spec.js +0 -41
- package/src/vendor/bootstrap-vue/src/utils/get.spec.js +0 -109
- package/src/vendor/bootstrap-vue/src/utils/inspect.spec.js +0 -251
- package/src/vendor/bootstrap-vue/src/utils/loose-equal.spec.js +0 -203
- package/src/vendor/bootstrap-vue/src/utils/normalize-slot.spec.js +0 -63
- package/src/vendor/bootstrap-vue/src/utils/number.spec.js +0 -72
- package/src/vendor/bootstrap-vue/src/utils/object.spec.js +0 -61
- package/src/vendor/bootstrap-vue/src/utils/props.spec.js +0 -112
- package/src/vendor/bootstrap-vue/src/utils/router.spec.js +0 -248
- package/src/vendor/bootstrap-vue/src/utils/string.spec.js +0 -65
- package/src/vendor/bootstrap-vue/src/utils/stringify-object-values.spec.js +0 -47
- 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
|
-
})
|