@sbb-esta/lyne-elements 4.0.4 → 4.1.0
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/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/autocomplete/autocomplete-base-element.js +0 -1
- package/breadcrumb/breadcrumb/breadcrumb.component.js +5 -5
- package/core/styles/core.scss +14 -0
- package/core/styles/mixins/link.scss +0 -1
- package/core.css +166 -0
- package/custom-elements.json +701 -314
- package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/development/autocomplete/autocomplete-base-element.js +1 -2
- package/development/breadcrumb/breadcrumb/breadcrumb.component.js +1 -2
- package/development/dialog/dialog/dialog.component.d.ts.map +1 -1
- package/development/dialog/dialog/dialog.component.js +1 -3
- package/development/link/common/block-link-common.js +1 -1
- package/development/link/common/inline-link-common.js +1 -1
- package/development/link/common/link-common.js +1 -1
- package/development/link/common.js +1 -1
- package/development/{link-common-CYr3PeRf.js → link-common-d27fHmQw.js} +1 -2
- package/development/link.js +1 -1
- package/development/overlay/overlay-base-element.d.ts +8 -2
- package/development/overlay/overlay-base-element.d.ts.map +1 -1
- package/development/overlay/overlay-base-element.js +21 -8
- package/development/overlay/overlay.component.d.ts.map +1 -1
- package/development/overlay/overlay.component.js +1 -3
- package/development/popover/popover.component.d.ts +2 -2
- package/development/popover/popover.component.d.ts.map +1 -1
- package/development/popover/popover.component.js +5 -5
- package/development/tabs/common.d.ts +4 -0
- package/development/tabs/common.d.ts.map +1 -0
- package/development/tabs/common.js +170 -0
- package/development/tabs/tab-group/tab-group.component.d.ts.map +1 -1
- package/development/tabs/tab-group/tab-group.component.js +11 -18
- package/development/tabs/tab-label/tab-label.component.d.ts.map +1 -1
- package/development/tabs/tab-label/tab-label.component.js +110 -134
- package/development/tabs/tab-nav-bar/tab-nav-bar.component.d.ts +30 -0
- package/development/tabs/tab-nav-bar/tab-nav-bar.component.d.ts.map +1 -0
- package/development/tabs/tab-nav-bar/tab-nav-bar.component.js +105 -0
- package/development/tabs/tab-nav-bar.d.ts +5 -0
- package/development/tabs/tab-nav-bar.d.ts.map +1 -0
- package/development/tabs/tab-nav-bar.js +5 -0
- package/development/tabs.d.ts +1 -0
- package/development/tabs.d.ts.map +1 -1
- package/development/tabs.js +4 -2
- package/development/toast/toast.component.js +2 -2
- package/dialog/dialog/dialog.component.d.ts.map +1 -1
- package/dialog/dialog/dialog.component.js +5 -5
- package/index.d.ts +2 -0
- package/index.js +2 -0
- package/link/common/block-link-common.js +1 -1
- package/link/common/inline-link-common.js +1 -1
- package/link/common/link-common.js +1 -1
- package/link/common.js +1 -1
- package/{link-common-D9TmX32v.js → link-common-7IiqjmPD.js} +1 -1
- package/link.js +1 -1
- package/off-brand-theme.css +166 -0
- package/overlay/overlay-base-element.d.ts +8 -2
- package/overlay/overlay-base-element.d.ts.map +1 -1
- package/overlay/overlay-base-element.js +49 -39
- package/overlay/overlay.component.d.ts.map +1 -1
- package/overlay/overlay.component.js +7 -7
- package/package.json +11 -1
- package/popover/popover.component.d.ts +2 -2
- package/popover/popover.component.d.ts.map +1 -1
- package/popover/popover.component.js +4 -4
- package/safety-theme.css +166 -0
- package/standard-theme.css +166 -0
- package/tabs/common.d.ts +4 -0
- package/tabs/common.d.ts.map +1 -0
- package/tabs/common.js +6 -0
- package/tabs/tab-group/tab-group.component.d.ts.map +1 -1
- package/tabs/tab-group/tab-group.component.js +38 -38
- package/tabs/tab-label/tab-label.component.d.ts.map +1 -1
- package/tabs/tab-label/tab-label.component.js +34 -35
- package/tabs/tab-nav-bar/tab-nav-bar.component.d.ts +30 -0
- package/tabs/tab-nav-bar/tab-nav-bar.component.d.ts.map +1 -0
- package/tabs/tab-nav-bar/tab-nav-bar.component.js +66 -0
- package/tabs/tab-nav-bar.d.ts +5 -0
- package/tabs/tab-nav-bar.d.ts.map +1 -0
- package/tabs/tab-nav-bar.js +4 -0
- package/tabs.d.ts +1 -0
- package/tabs.d.ts.map +1 -1
- package/tabs.js +5 -3
- package/toast/toast.component.js +1 -1
|
@@ -14,206 +14,184 @@ import { forceType, omitEmptyConverter } from "../../core/decorators.js";
|
|
|
14
14
|
import { SbbDisabledMixin, SbbElementInternalsMixin } from "../../core/mixins.js";
|
|
15
15
|
import { boxSizingStyles } from "../../core/styles.js";
|
|
16
16
|
import { SbbIconNameMixin } from "../../icon.js";
|
|
17
|
+
import { tabLabelCommonStyles } from "../common.js";
|
|
17
18
|
const style = css`:host {
|
|
18
|
-
--sbb-tab-label-height: var(--sbb-size-element-m);
|
|
19
|
-
--sbb-tab-label-color: var(--sbb-color-granite);
|
|
20
|
-
--sbb-tab-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));
|
|
21
|
-
--sbb-tab-label-line-color: var(--sbb-border-color-4-inverted);
|
|
22
|
-
--sbb-tab-label-cursor: var(--sbb-cursor-pointer);
|
|
23
|
-
--sbb-tab-label-pointer-events: unset;
|
|
24
|
-
--sbb-tab-label-inline-padding: var(--sbb-spacing-responsive-xs);
|
|
25
|
-
--sbb-tab-label-marker-transform: scale(0);
|
|
26
|
-
--sbb-tab-label-text-decoration: none;
|
|
27
19
|
--sbb-tab-label-animation-duration: var(
|
|
28
20
|
--sbb-disable-animation-duration,
|
|
29
21
|
var(--sbb-animation-duration-2x)
|
|
30
22
|
);
|
|
31
|
-
--sbb-tab-label-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
-
|
|
38
|
-
|
|
23
|
+
--sbb-tab-label-outline-border-radius-internal: calc(
|
|
24
|
+
var(--sbb-tab-label-outline-border-radius) - var(--sbb-focus-outline-offset)
|
|
25
|
+
);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
:host(:is(:is(:state(size-s),[state--size-s]), [size=s])) {
|
|
29
|
+
--sbb-tab-label-height: var(--sbb-size-element-xs);
|
|
30
|
+
--sbb-tab-label-inline-padding: var(--sbb-spacing-responsive-xxxs);
|
|
31
|
+
--sbb-tab-label-font-size: var(--sbb-text-font-size-s);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
:host(:is(:is(:state(size-l),[state--size-l]), [size=l])) {
|
|
35
|
+
--sbb-tab-label-height: var(--sbb-size-element-m);
|
|
36
|
+
--sbb-tab-label-inline-padding: var(--sbb-spacing-responsive-xs);
|
|
37
|
+
--sbb-tab-label-font-size: var(--sbb-text-font-size-m);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
:host(:is(:is(:state(size-xl),[state--size-xl]), [size=xl])) {
|
|
41
|
+
--sbb-tab-label-height: var(--sbb-size-element-m);
|
|
42
|
+
--sbb-tab-label-inline-padding: var(--sbb-spacing-responsive-xs);
|
|
43
|
+
--sbb-tab-label-font-size: var(--sbb-text-font-size-xl);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
:host(sbb-tab-label),
|
|
47
|
+
:host(sbb-tab-nav-bar) ::slotted(a) {
|
|
48
|
+
pointer-events: var(--sbb-tab-label-pointer-events, unset);
|
|
39
49
|
}
|
|
40
50
|
@media (forced-colors: active) {
|
|
41
|
-
:host
|
|
51
|
+
:host(sbb-tab-label),
|
|
52
|
+
:host(sbb-tab-nav-bar) ::slotted(a) {
|
|
42
53
|
--sbb-tab-label-color: ButtonText;
|
|
43
54
|
--sbb-tab-label-amount-color: ButtonText;
|
|
44
55
|
}
|
|
45
56
|
}
|
|
46
57
|
|
|
47
|
-
:host(
|
|
48
|
-
|
|
49
|
-
|
|
58
|
+
:host(sbb-tab-nav-bar) ::slotted(a),
|
|
59
|
+
:host(sbb-tab-label) .sbb-tab-label {
|
|
60
|
+
position: relative;
|
|
61
|
+
display: flex;
|
|
62
|
+
align-items: center;
|
|
63
|
+
gap: var(--sbb-tab-label-gap);
|
|
64
|
+
color: var(--sbb-tab-label-color);
|
|
65
|
+
margin: 0;
|
|
66
|
+
padding-inline: var(--sbb-tab-label-inline-padding);
|
|
67
|
+
min-height: var(--sbb-tab-label-height);
|
|
68
|
+
transition: color var(--sbb-tab-label-animation-duration) var(--sbb-tab-label-animation-easing);
|
|
69
|
+
font-size: var(--sbb-tab-label-font-size);
|
|
70
|
+
letter-spacing: var(--sbb-typo-letter-spacing-text);
|
|
71
|
+
font-weight: var(--sbb-tab-label-font-weight);
|
|
72
|
+
text-decoration: var(--sbb-tab-label-text-decoration);
|
|
73
|
+
}
|
|
74
|
+
:host(sbb-tab-nav-bar) ::slotted(a)::after,
|
|
75
|
+
:host(sbb-tab-label) .sbb-tab-label::after {
|
|
76
|
+
position: absolute;
|
|
77
|
+
content: "";
|
|
78
|
+
inset-inline: 0;
|
|
79
|
+
inset-block-end: 0;
|
|
80
|
+
height: var(--sbb-tab-label-marker-thickness);
|
|
81
|
+
background-color: var(--sbb-tab-label-color);
|
|
82
|
+
scale: var(--sbb-tab-label-marker-scale, 0);
|
|
83
|
+
transition-duration: var(--sbb-tab-label-animation-duration);
|
|
84
|
+
transition-timing-function: var(--sbb-tab-label-animation-easing);
|
|
85
|
+
transition-property: scale, background-color;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
:host(sbb-tab-nav-bar) .sbb-tab-nav-bar > [data-has-divider],
|
|
89
|
+
:host(sbb-tab-label:is(:state(has-divider),[state--has-divider])) {
|
|
90
|
+
position: relative;
|
|
91
|
+
}
|
|
92
|
+
:host(sbb-tab-nav-bar) .sbb-tab-nav-bar > [data-has-divider]::before,
|
|
93
|
+
:host(sbb-tab-label:is(:state(has-divider),[state--has-divider]))::before {
|
|
94
|
+
content: "";
|
|
95
|
+
position: absolute;
|
|
96
|
+
inset-inline-start: 0;
|
|
97
|
+
inset-block-end: 0;
|
|
98
|
+
width: var(--sbb-tab-group-width);
|
|
99
|
+
height: var(--sbb-border-width-1x);
|
|
100
|
+
background-color: var(--sbb-tab-label-line-color);
|
|
50
101
|
}
|
|
51
102
|
|
|
52
|
-
:host(
|
|
103
|
+
:host(sbb-tab-nav-bar) ::slotted(a.sbb-disabled),
|
|
104
|
+
:host(sbb-tab-label[disabled]) {
|
|
53
105
|
--sbb-tab-label-cursor: unset;
|
|
54
106
|
--sbb-tab-label-pointer-events: none;
|
|
55
107
|
--sbb-tab-label-text-decoration: line-through;
|
|
56
108
|
}
|
|
57
109
|
@media (forced-colors: active) {
|
|
58
|
-
:host(
|
|
110
|
+
:host(sbb-tab-nav-bar) ::slotted(a.sbb-disabled),
|
|
111
|
+
:host(sbb-tab-label[disabled]) {
|
|
59
112
|
--sbb-tab-label-color: GrayText;
|
|
60
113
|
--sbb-tab-label-amount-color: GrayText;
|
|
61
114
|
}
|
|
62
115
|
}
|
|
63
116
|
|
|
64
|
-
:host(
|
|
117
|
+
:host(sbb-tab-nav-bar) ::slotted(a.sbb-active:not(.sbb-disabled)),
|
|
118
|
+
:host(sbb-tab-label[active]:not([disabled])) {
|
|
65
119
|
--sbb-tab-label-color: var(--sbb-color-3);
|
|
66
120
|
--sbb-tab-label-cursor: unset;
|
|
67
121
|
--sbb-tab-label-pointer-events: none;
|
|
68
|
-
--sbb-tab-label-marker-
|
|
122
|
+
--sbb-tab-label-marker-scale: 1;
|
|
69
123
|
}
|
|
70
124
|
@media (forced-colors: active) {
|
|
71
|
-
:host(
|
|
125
|
+
:host(sbb-tab-nav-bar) ::slotted(a.sbb-active:not(.sbb-disabled)),
|
|
126
|
+
:host(sbb-tab-label[active]:not([disabled])) {
|
|
72
127
|
--sbb-tab-label-color: ButtonText;
|
|
73
128
|
--sbb-tab-label-amount-color: ButtonText;
|
|
74
129
|
}
|
|
75
130
|
}
|
|
76
131
|
|
|
77
132
|
@media (any-hover: hover) {
|
|
78
|
-
:host(:hover:not(
|
|
79
|
-
|
|
133
|
+
:host(sbb-tab-nav-bar) ::slotted(a:hover:not(.sbb-disabled)),
|
|
134
|
+
:host(sbb-tab-label:hover:not([disabled])) {
|
|
135
|
+
--sbb-tab-label-marker-scale: 1;
|
|
80
136
|
}
|
|
81
137
|
}
|
|
82
138
|
|
|
83
|
-
:host(:active)
|
|
139
|
+
:host(sbb-tab-nav-bar) ::slotted(a:active:not(.sbb-disabled)),
|
|
140
|
+
:host(sbb-tab-label:active) {
|
|
84
141
|
--sbb-tab-label-color: var(--sbb-color-3);
|
|
85
142
|
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
143
|
+
@media (forced-colors: active) {
|
|
144
|
+
:host(sbb-tab-nav-bar) ::slotted(a:active:not(.sbb-disabled)),
|
|
145
|
+
:host(sbb-tab-label:active) {
|
|
146
|
+
--sbb-tab-label-color: ButtonText;
|
|
147
|
+
--sbb-tab-label-amount-color: ButtonText;
|
|
148
|
+
}
|
|
89
149
|
}
|
|
90
|
-
|
|
150
|
+
|
|
151
|
+
:host(sbb-tab-nav-bar) ::slotted(a:focus-visible),
|
|
152
|
+
:host(sbb-tab-label:focus-visible) .sbb-tab-label {
|
|
91
153
|
outline-offset: var(--sbb-focus-outline-offset);
|
|
92
154
|
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
93
|
-
|
|
94
|
-
position: absolute;
|
|
95
|
-
display: block;
|
|
96
|
-
inset: 0;
|
|
97
|
-
z-index: 1;
|
|
98
|
-
border-radius: calc(var(--sbb-border-radius-2x) - var(--sbb-focus-outline-offset));
|
|
155
|
+
border-radius: var(--sbb-tab-label-outline-border-radius-internal);
|
|
99
156
|
}
|
|
100
157
|
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
display: flex;
|
|
106
|
-
align-items: center;
|
|
107
|
-
padding-inline: var(--sbb-tab-label-inline-padding);
|
|
108
|
-
gap: var(--sbb-spacing-fixed-2x);
|
|
109
|
-
user-select: none;
|
|
110
|
-
cursor: var(--sbb-tab-label-cursor);
|
|
111
|
-
transition: color var(--sbb-tab-label-animation-duration) var(--sbb-tab-label-animation-easing);
|
|
112
|
-
}
|
|
113
|
-
:host(:is(:state(has-divider),[state--has-divider])) .sbb-tab-label::after {
|
|
114
|
-
content: "";
|
|
115
|
-
position: absolute;
|
|
116
|
-
inset-inline-start: 0;
|
|
117
|
-
inset-block-end: 0;
|
|
118
|
-
width: var(--sbb-tab-group-width);
|
|
119
|
-
height: var(--sbb-border-width-1x);
|
|
120
|
-
background-color: var(--sbb-tab-label-line-color);
|
|
121
|
-
}
|
|
122
|
-
.sbb-tab-label::before {
|
|
123
|
-
position: absolute;
|
|
124
|
-
content: "";
|
|
125
|
-
inset-inline: 0;
|
|
126
|
-
inset-block-end: 0;
|
|
127
|
-
height: var(--sbb-border-width-3x);
|
|
128
|
-
background-color: var(--sbb-tab-label-color);
|
|
129
|
-
transform: var(--sbb-tab-label-marker-transform);
|
|
130
|
-
transition-duration: var(--sbb-tab-label-animation-duration);
|
|
131
|
-
transition-timing-function: var(--sbb-tab-label-animation-easing);
|
|
132
|
-
transition-property: transform, background-color;
|
|
133
|
-
z-index: 1;
|
|
158
|
+
:host {
|
|
159
|
+
display: inline-block;
|
|
160
|
+
max-width: 100%;
|
|
161
|
+
outline: none !important;
|
|
134
162
|
}
|
|
135
163
|
|
|
136
|
-
.sbb-tab-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
164
|
+
.sbb-tab-label {
|
|
165
|
+
cursor: var(--sbb-tab-label-cursor);
|
|
166
|
+
user-select: none;
|
|
167
|
+
-webkit-tap-highlight-color: transparent;
|
|
140
168
|
}
|
|
141
169
|
|
|
142
170
|
.sbb-tab-label__icon {
|
|
143
171
|
display: flex;
|
|
144
172
|
flex-shrink: 0;
|
|
145
|
-
color: var(--sbb-tab-label-color);
|
|
146
|
-
transition: color var(--sbb-tab-label-animation-duration) var(--sbb-tab-label-animation-easing);
|
|
147
173
|
}
|
|
148
174
|
:host(:not(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) .sbb-tab-label__icon {
|
|
149
175
|
display: none;
|
|
150
176
|
}
|
|
151
177
|
|
|
152
178
|
.sbb-tab-label__text {
|
|
153
|
-
color: var(--sbb-tab-label-color);
|
|
154
|
-
transition: color var(--sbb-tab-label-animation-duration) var(--sbb-tab-label-animation-easing);
|
|
155
179
|
overflow: hidden;
|
|
156
180
|
white-space: nowrap;
|
|
157
181
|
text-overflow: ellipsis;
|
|
158
|
-
--sbb-text-font-size: var(--sbb-text-font-size-m);
|
|
159
|
-
font-family: var(--sbb-typo-font-family);
|
|
160
|
-
font-weight: normal;
|
|
161
|
-
line-height: var(--sbb-typo-line-height-text);
|
|
162
|
-
letter-spacing: var(--sbb-typo-letter-spacing-text);
|
|
163
|
-
font-size: var(--sbb-text-font-size);
|
|
164
|
-
font-weight: bold;
|
|
165
|
-
}
|
|
166
|
-
:host(:is(:state(size-s),[state--size-s])) .sbb-tab-label__text {
|
|
167
|
-
--sbb-text-font-size: var(--sbb-text-font-size-s);
|
|
168
|
-
font-family: var(--sbb-typo-font-family);
|
|
169
|
-
font-weight: normal;
|
|
170
|
-
line-height: var(--sbb-typo-line-height-text);
|
|
171
|
-
letter-spacing: var(--sbb-typo-letter-spacing-text);
|
|
172
|
-
font-size: var(--sbb-text-font-size);
|
|
173
|
-
font-weight: bold;
|
|
174
|
-
}
|
|
175
|
-
:host(:is(:state(size-xl),[state--size-xl])) .sbb-tab-label__text {
|
|
176
|
-
--sbb-text-font-size: var(--sbb-text-font-size-xl);
|
|
177
|
-
font-family: var(--sbb-typo-font-family);
|
|
178
|
-
font-weight: normal;
|
|
179
|
-
line-height: var(--sbb-typo-line-height-text);
|
|
180
|
-
letter-spacing: var(--sbb-typo-letter-spacing-text);
|
|
181
|
-
font-size: var(--sbb-text-font-size);
|
|
182
|
-
font-weight: bold;
|
|
183
182
|
}
|
|
184
183
|
:host(:not(:is(:state(slotted),[state--slotted]))) .sbb-tab-label__text {
|
|
185
184
|
display: none;
|
|
186
185
|
}
|
|
187
186
|
|
|
188
187
|
.sbb-tab-label__amount {
|
|
189
|
-
|
|
188
|
+
margin: 0;
|
|
190
189
|
color: var(--sbb-tab-label-amount-color);
|
|
191
|
-
transition: color var(--sbb-tab-label-animation-duration) var(--sbb-tab-label-animation-easing);
|
|
192
|
-
--sbb-text-font-size: var(--sbb-text-font-size-m);
|
|
193
|
-
font-family: var(--sbb-typo-font-family);
|
|
194
190
|
font-weight: normal;
|
|
195
|
-
|
|
196
|
-
letter-spacing: var(--sbb-typo-letter-spacing-text);
|
|
197
|
-
font-size: var(--sbb-text-font-size);
|
|
191
|
+
text-decoration: var(--sbb-tab-label-text-decoration);
|
|
198
192
|
}
|
|
199
193
|
:host(:not(:is(:state(slotted-amount),[state--slotted-amount]), [amount])) .sbb-tab-label__amount {
|
|
200
194
|
display: none;
|
|
201
|
-
}
|
|
202
|
-
:host(:is(:state(size-s),[state--size-s])) .sbb-tab-label__amount {
|
|
203
|
-
--sbb-text-font-size: var(--sbb-text-font-size-s);
|
|
204
|
-
font-family: var(--sbb-typo-font-family);
|
|
205
|
-
font-weight: normal;
|
|
206
|
-
line-height: var(--sbb-typo-line-height-text);
|
|
207
|
-
letter-spacing: var(--sbb-typo-letter-spacing-text);
|
|
208
|
-
font-size: var(--sbb-text-font-size);
|
|
209
|
-
}
|
|
210
|
-
:host(:is(:state(size-xl),[state--size-xl])) .sbb-tab-label__amount {
|
|
211
|
-
--sbb-text-font-size: var(--sbb-text-font-size-xl);
|
|
212
|
-
font-family: var(--sbb-typo-font-family);
|
|
213
|
-
font-weight: normal;
|
|
214
|
-
line-height: var(--sbb-typo-line-height-text);
|
|
215
|
-
letter-spacing: var(--sbb-typo-letter-spacing-text);
|
|
216
|
-
font-size: var(--sbb-text-font-size);
|
|
217
195
|
}`;
|
|
218
196
|
let SbbTabLabelElement = (() => {
|
|
219
197
|
var _level_accessor_storage, _active_accessor_storage, _amount_accessor_storage, _a;
|
|
@@ -364,7 +342,6 @@ let SbbTabLabelElement = (() => {
|
|
|
364
342
|
render() {
|
|
365
343
|
const TAGNAME = `h${Number(this.level) < 7 ? this.level : "1"}`;
|
|
366
344
|
return html`
|
|
367
|
-
<div class="sbb-tab-label__wrapper">
|
|
368
345
|
<${unsafeStatic(TAGNAME)} class="sbb-tab-label">
|
|
369
346
|
<span class="sbb-tab-label__icon">
|
|
370
347
|
${this.renderIconSlot()}
|
|
@@ -372,11 +349,10 @@ let SbbTabLabelElement = (() => {
|
|
|
372
349
|
<span class="sbb-tab-label__text">
|
|
373
350
|
<slot></slot>
|
|
374
351
|
</span>
|
|
375
|
-
<
|
|
352
|
+
<p class="sbb-tab-label__amount">
|
|
376
353
|
<slot name="amount">${this.amount}</slot>
|
|
377
|
-
</
|
|
354
|
+
</p>
|
|
378
355
|
</${unsafeStatic(TAGNAME)}>
|
|
379
|
-
</div>
|
|
380
356
|
`;
|
|
381
357
|
}
|
|
382
358
|
}, _level_accessor_storage = new WeakMap(), _active_accessor_storage = new WeakMap(), _amount_accessor_storage = new WeakMap(), _classThis = _a, (() => {
|
|
@@ -396,10 +372,10 @@ let SbbTabLabelElement = (() => {
|
|
|
396
372
|
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
397
373
|
_classThis = _classDescriptor.value;
|
|
398
374
|
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
399
|
-
})(), _a.role = "tab", _a.styles = [boxSizingStyles, style], __runInitializers(_classThis, _classExtraInitializers), _a;
|
|
375
|
+
})(), _a.role = "tab", _a.styles = [boxSizingStyles, tabLabelCommonStyles, style], __runInitializers(_classThis, _classExtraInitializers), _a;
|
|
400
376
|
return _classThis;
|
|
401
377
|
})();
|
|
402
378
|
export {
|
|
403
379
|
SbbTabLabelElement
|
|
404
380
|
};
|
|
405
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tab-label.component.js","sources":["../../../../../src/elements/tabs/tab-label/tab-label.component.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { html, unsafeStatic } from 'lit/static-html.js';\n\nimport { SbbPropertyWatcherController } from '../../core/controllers.ts';\nimport { forceType, omitEmptyConverter } from '../../core/decorators.ts';\nimport { SbbDisabledMixin, SbbElementInternalsMixin } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport { SbbIconNameMixin } from '../../icon.ts';\nimport type { SbbTitleLevel } from '../../title.ts';\nimport type { SbbTabElement } from '../tab/tab.component.ts';\nimport type { SbbTabChangedEventDetails, SbbTabGroupElement } from '../tab-group.ts';\n\nimport style from './tab-label.scss?lit&inline';\n\n/**\n * Combined with a `sbb-tab-group`, it displays a tab's title.\n *\n * @slot - Use the unnamed slot to add content to the tab title.\n * @slot icon - Use this slot to display an icon to the left of the title, by providing the `sbb-icon` component.\n * @slot amount - Provide a number to show an amount to the right of the title.\n */\nexport\n@customElement('sbb-tab-label')\nclass SbbTabLabelElement extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbElementInternalsMixin(LitElement)),\n) {\n  public static override role = 'tab';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  /** Whether the tab is selected. */\n  private _selected: boolean = false;\n  private _previousSize: SbbTabGroupElement['size'] | null = null;\n\n  /**\n   * The level will correspond to the heading tag generated in the title.\n   * Use this property to generate the appropriate header tag, taking SEO into consideration.\n   */\n  @property() public accessor level: SbbTitleLevel = '1';\n\n  /** Active tab state. */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor active: boolean = false;\n\n  /** Amount displayed inside the tab. */\n  @forceType()\n  @property({ reflect: true, converter: omitEmptyConverter })\n  public accessor amount: string = '';\n\n  /** Get the `sbb-tab` related to the `sbb-tab-label`. */\n  public get tab(): SbbTabElement | null {\n    return this.nextElementSibling?.localName === 'sbb-tab'\n      ? (this.nextElementSibling as SbbTabElement)\n      : null;\n  }\n\n  /** Get the parent `sbb-tab-group`. */\n  public get group(): SbbTabGroupElement | null {\n    return this.closest('sbb-tab-group');\n  }\n\n  public constructor() {\n    super();\n\n    this.addEventListener('click', () => this.activate());\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.group, {\n        size: (g) => {\n          if (this._previousSize) {\n            this.internals.states.delete(`size-${this._previousSize}`);\n          }\n          this._previousSize = g?.size || null;\n          if (this._previousSize) {\n            this.internals.states.add(`size-${this._previousSize}`);\n          }\n        },\n      }),\n    );\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.slot = 'tab-bar';\n    this.tabIndex = this.active ? 0 : -1;\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('active')) {\n      this.internals.ariaSelected = `${this.active}`;\n\n      if (this.active && !this.disabled) {\n        this.activate();\n      } else {\n        this.deactivate();\n      }\n    }\n\n    if (changedProperties.has('disabled') && this.disabled) {\n      this.tabIndex = -1;\n      if (this.active) {\n        this.deactivate();\n        this.group?.activateTab(0);\n      }\n    }\n  }\n\n  /** Deactivate the tab. */\n  public deactivate(): void {\n    this.active = false;\n    this.tab?.['deactivate']();\n    this._selected = false;\n    this.tabIndex = -1;\n  }\n\n  /** Select the tab, deactivating the current selected one, and dispatch the tabchange event. */\n  public activate(): void {\n    if (this.disabled) {\n      if (import.meta.env.DEV) {\n        console.warn('You cannot activate a disabled tab');\n      }\n      return;\n    }\n\n    const tabLabels: SbbTabLabelElement[] = this.group?.labels || [];\n    const prevActiveTabLabel = tabLabels.find((e) => e._selected);\n    if (prevActiveTabLabel !== this) {\n      prevActiveTabLabel?.deactivate();\n      this.active = true;\n      this.tab?.['activate']();\n      this._selected = true;\n      this.tabIndex = 0;\n      this.tab?.dispatchEvent(new Event('active', { bubbles: true, composed: true }));\n      this.group?.dispatchEvent(\n        new CustomEvent<SbbTabChangedEventDetails>('tabchange', {\n          bubbles: true,\n          composed: true,\n          detail: {\n            activeIndex: tabLabels.findIndex((e) => e === this),\n            activeTabLabel: this,\n            activeTab: this.tab as SbbTabElement,\n            previousIndex: tabLabels.findIndex((e) => e === prevActiveTabLabel),\n            previousTabLabel: prevActiveTabLabel,\n            previousTab: prevActiveTabLabel?.tab as SbbTabElement,\n          },\n        }),\n      );\n    }\n  }\n\n  /**\n   * @internal\n   */\n  protected linkToTab(): void {\n    if (!this.tab) {\n      if (import.meta.env.DEV) {\n        console.warn(\n          `Missing content: you should provide a related content for the tab ${this.outerHTML}.`,\n        );\n      }\n      return;\n    }\n    this.internals.ariaControlsElements = [this.tab];\n  }\n\n  protected override render(): TemplateResult {\n    const TAGNAME = `h${Number(this.level) < 7 ? this.level : '1'}`;\n\n    /* eslint-disable lit/binding-positions */\n    return html`\n      <div class=\"sbb-tab-label__wrapper\">\n        <${unsafeStatic(TAGNAME)} class=\"sbb-tab-label\">\n          <span class=\"sbb-tab-label__icon\">\n            ${this.renderIconSlot()}\n          </span>\n          <span class=\"sbb-tab-label__text\">\n            <slot></slot>\n          </span>\n          <span class=\"sbb-tab-label__amount\">\n            <slot name=\"amount\">${this.amount}</slot>\n          </span>\n        </${unsafeStatic(TAGNAME)}>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tab-label': SbbTabLabelElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
381
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tab-label.component.js","sources":["../../../../../src/elements/tabs/tab-label/tab-label.component.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { html, unsafeStatic } from 'lit/static-html.js';\n\nimport { SbbPropertyWatcherController } from '../../core/controllers.ts';\nimport { forceType, omitEmptyConverter } from '../../core/decorators.ts';\nimport { SbbDisabledMixin, SbbElementInternalsMixin } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport { SbbIconNameMixin } from '../../icon.ts';\nimport type { SbbTitleLevel } from '../../title.ts';\nimport { tabLabelCommonStyles } from '../common.ts';\nimport type { SbbTabElement } from '../tab/tab.component.ts';\nimport type { SbbTabChangedEventDetails, SbbTabGroupElement } from '../tab-group.ts';\n\nimport style from './tab-label.scss?lit&inline';\n\n/**\n * Combined with a `sbb-tab-group`, it displays a tab's title.\n *\n * @slot - Use the unnamed slot to add content to the tab title.\n * @slot icon - Use this slot to display an icon to the left of the title, by providing the `sbb-icon` component.\n * @slot amount - Provide a number to show an amount to the right of the title.\n */\nexport\n@customElement('sbb-tab-label')\nclass SbbTabLabelElement extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbElementInternalsMixin(LitElement)),\n) {\n  public static override role = 'tab';\n  public static override styles: CSSResultGroup = [boxSizingStyles, tabLabelCommonStyles, style];\n\n  /** Whether the tab is selected. */\n  private _selected: boolean = false;\n  private _previousSize: SbbTabGroupElement['size'] | null = null;\n\n  /**\n   * The level will correspond to the heading tag generated in the title.\n   * Use this property to generate the appropriate header tag, taking SEO into consideration.\n   */\n  @property() public accessor level: SbbTitleLevel = '1';\n\n  /** Active tab state. */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor active: boolean = false;\n\n  /** Amount displayed inside the tab. */\n  @forceType()\n  @property({ reflect: true, converter: omitEmptyConverter })\n  public accessor amount: string = '';\n\n  /** Get the `sbb-tab` related to the `sbb-tab-label`. */\n  public get tab(): SbbTabElement | null {\n    return this.nextElementSibling?.localName === 'sbb-tab'\n      ? (this.nextElementSibling as SbbTabElement)\n      : null;\n  }\n\n  /** Get the parent `sbb-tab-group`. */\n  public get group(): SbbTabGroupElement | null {\n    return this.closest('sbb-tab-group');\n  }\n\n  public constructor() {\n    super();\n\n    this.addEventListener('click', () => this.activate());\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.group, {\n        size: (g) => {\n          if (this._previousSize) {\n            this.internals.states.delete(`size-${this._previousSize}`);\n          }\n          this._previousSize = g?.size || null;\n          if (this._previousSize) {\n            this.internals.states.add(`size-${this._previousSize}`);\n          }\n        },\n      }),\n    );\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.slot = 'tab-bar';\n    this.tabIndex = this.active ? 0 : -1;\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('active')) {\n      this.internals.ariaSelected = `${this.active}`;\n\n      if (this.active && !this.disabled) {\n        this.activate();\n      } else {\n        this.deactivate();\n      }\n    }\n\n    if (changedProperties.has('disabled') && this.disabled) {\n      this.tabIndex = -1;\n      if (this.active) {\n        this.deactivate();\n        this.group?.activateTab(0);\n      }\n    }\n  }\n\n  /** Deactivate the tab. */\n  public deactivate(): void {\n    this.active = false;\n    this.tab?.['deactivate']();\n    this._selected = false;\n    this.tabIndex = -1;\n  }\n\n  /** Select the tab, deactivating the current selected one, and dispatch the tabchange event. */\n  public activate(): void {\n    if (this.disabled) {\n      if (import.meta.env.DEV) {\n        console.warn('You cannot activate a disabled tab');\n      }\n      return;\n    }\n\n    const tabLabels: SbbTabLabelElement[] = this.group?.labels || [];\n    const prevActiveTabLabel = tabLabels.find((e) => e._selected);\n    if (prevActiveTabLabel !== this) {\n      prevActiveTabLabel?.deactivate();\n      this.active = true;\n      this.tab?.['activate']();\n      this._selected = true;\n      this.tabIndex = 0;\n      this.tab?.dispatchEvent(new Event('active', { bubbles: true, composed: true }));\n      this.group?.dispatchEvent(\n        new CustomEvent<SbbTabChangedEventDetails>('tabchange', {\n          bubbles: true,\n          composed: true,\n          detail: {\n            activeIndex: tabLabels.findIndex((e) => e === this),\n            activeTabLabel: this,\n            activeTab: this.tab as SbbTabElement,\n            previousIndex: tabLabels.findIndex((e) => e === prevActiveTabLabel),\n            previousTabLabel: prevActiveTabLabel,\n            previousTab: prevActiveTabLabel?.tab as SbbTabElement,\n          },\n        }),\n      );\n    }\n  }\n\n  /**\n   * @internal\n   */\n  protected linkToTab(): void {\n    if (!this.tab) {\n      if (import.meta.env.DEV) {\n        console.warn(\n          `Missing content: you should provide a related content for the tab ${this.outerHTML}.`,\n        );\n      }\n      return;\n    }\n    this.internals.ariaControlsElements = [this.tab];\n  }\n\n  protected override render(): TemplateResult {\n    const TAGNAME = `h${Number(this.level) < 7 ? this.level : '1'}`;\n\n    /* eslint-disable lit/binding-positions */\n    return html`\n        <${unsafeStatic(TAGNAME)} class=\"sbb-tab-label\">\n          <span class=\"sbb-tab-label__icon\">\n            ${this.renderIconSlot()}\n          </span>\n          <span class=\"sbb-tab-label__text\">\n            <slot></slot>\n          </span>\n          <p class=\"sbb-tab-label__amount\">\n            <slot name=\"amount\">${this.amount}</slot>\n          </p>\n        </${unsafeStatic(TAGNAME)}>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tab-label': SbbTabLabelElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IA0BM,sBAAkB,MAAA;;0BADvB,cAAc,eAAe,CAAC;;;;oBACE,iBAC/B,iBAAiB,yBAAyB,UAAU,CAAC,CAAC;;;;;;;;;;AAD/B,EAAA,mBAAQ,YAEhC;AAAA,IAoCC,cAAA;AACE,YAAA;AAzBU;AAKZ;AAKA;AAjBQ,WAAA,YAAqB;AACrB,WAAA,gBAAmD;AAM/B,yBAAA,yBAAA,kBAAA,MAAA,qBAAuB,GAAG;AAKtC,yBAAA,2BAAA,kBAAA,MAAA,wBAAA,GAAA,kBAAA,MAAA,sBAAkB,KAAK;AAKvB,yBAAA,2BAAA,kBAAA,MAAA,yBAAA,GAAA,kBAAA,MAAA,sBAAiB,EAAE;;AAiBjC,WAAK,iBAAiB,SAAS,MAAM,KAAK,UAAU;AACpD,WAAK,cACH,IAAI,6BAA6B,MAAM,MAAM,KAAK,OAAO;AAAA,QACvD,MAAM,CAAC,MAAK;AACV,cAAI,KAAK,eAAe;AACtB,iBAAK,UAAU,OAAO,OAAO,QAAQ,KAAK,aAAa,EAAE;AAAA,UAC3D;AACA,eAAK,gBAAgB,GAAG,QAAQ;AAChC,cAAI,KAAK,eAAe;AACtB,iBAAK,UAAU,OAAO,IAAI,QAAQ,KAAK,aAAa,EAAE;AAAA,UACxD;AAAA,QACF;AAAA,MAAA,CACD,CAAC;AAAA,IAEL;AAAA;AAAA;AAAA;AAAA;AAAA,IAzCW,IAAgB,QAAK;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAArB,IAAgB,MAAK,OAAA;AAAA,yBAAA,yBAAA;AAAA,IAAA;AAAA;AAAA,IAKjC,IAAgB,SAAM;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAtB,IAAgB,OAAM,OAAA;AAAA,yBAAA,0BAAA;AAAA,IAAA;AAAA;AAAA,IAKtB,IAAgB,SAAM;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAtB,IAAgB,OAAM,OAAA;AAAA,yBAAA,0BAAA;AAAA,IAAA;AAAA;AAAA,IAGtB,IAAW,MAAG;AACZ,aAAO,KAAK,oBAAoB,cAAc,YACzC,KAAK,qBACN;AAAA,IACN;AAAA;AAAA,IAGA,IAAW,QAAK;AACd,aAAO,KAAK,QAAQ,eAAe;AAAA,IACrC;AAAA,IAqBgB,oBAAiB;AAC/B,YAAM,kBAAA;AACN,WAAK,OAAO;AACZ,WAAK,WAAW,KAAK,SAAS,IAAI;AAAA,IACpC;AAAA,IAEmB,WAAW,mBAAuC;AACnE,YAAM,WAAW,iBAAiB;AAElC,UAAI,kBAAkB,IAAI,QAAQ,GAAG;AACnC,aAAK,UAAU,eAAe,GAAG,KAAK,MAAM;AAE5C,YAAI,KAAK,UAAU,CAAC,KAAK,UAAU;AACjC,eAAK,SAAA;AAAA,QACP,OAAO;AACL,eAAK,WAAA;AAAA,QACP;AAAA,MACF;AAEA,UAAI,kBAAkB,IAAI,UAAU,KAAK,KAAK,UAAU;AACtD,aAAK,WAAW;AAChB,YAAI,KAAK,QAAQ;AACf,eAAK,WAAA;AACL,eAAK,OAAO,YAAY,CAAC;AAAA,QAC3B;AAAA,MACF;AAAA,IACF;AAAA;AAAA,IAGO,aAAU;AACf,WAAK,SAAS;AACd,WAAK,MAAM,YAAY,EAAA;AACvB,WAAK,YAAY;AACjB,WAAK,WAAW;AAAA,IAClB;AAAA;AAAA,IAGO,WAAQ;AACb,UAAI,KAAK,UAAU;AACQ;AACvB,kBAAQ,KAAK,oCAAoC;AAAA,QACnD;AACA;AAAA,MACF;AAEA,YAAM,YAAkC,KAAK,OAAO,UAAU,CAAA;AAC9D,YAAM,qBAAqB,UAAU,KAAK,CAAC,MAAM,EAAE,SAAS;AAC5D,UAAI,uBAAuB,MAAM;AAC/B,4BAAoB,WAAA;AACpB,aAAK,SAAS;AACd,aAAK,MAAM,UAAU,EAAA;AACrB,aAAK,YAAY;AACjB,aAAK,WAAW;AAChB,aAAK,KAAK,cAAc,IAAI,MAAM,UAAU,EAAE,SAAS,MAAM,UAAU,KAAA,CAAM,CAAC;AAC9E,aAAK,OAAO,cACV,IAAI,YAAuC,aAAa;AAAA,UACtD,SAAS;AAAA,UACT,UAAU;AAAA,UACV,QAAQ;AAAA,YACN,aAAa,UAAU,UAAU,CAAC,MAAM,MAAM,IAAI;AAAA,YAClD,gBAAgB;AAAA,YAChB,WAAW,KAAK;AAAA,YAChB,eAAe,UAAU,UAAU,CAAC,MAAM,MAAM,kBAAkB;AAAA,YAClE,kBAAkB;AAAA,YAClB,aAAa,oBAAoB;AAAA,UAAA;AAAA,QAClC,CACF,CAAC;AAAA,MAEN;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKU,YAAS;AACjB,UAAI,CAAC,KAAK,KAAK;AACY;AACvB,kBAAQ,KACN,qEAAqE,KAAK,SAAS,GAAG;AAAA,QAE1F;AACA;AAAA,MACF;AACA,WAAK,UAAU,uBAAuB,CAAC,KAAK,GAAG;AAAA,IACjD;AAAA,IAEmB,SAAM;AACvB,YAAM,UAAU,IAAI,OAAO,KAAK,KAAK,IAAI,IAAI,KAAK,QAAQ,GAAG;AAG7D,aAAO;AAAA,WACA,aAAa,OAAO,CAAC;AAAA;AAAA,cAElB,KAAK,gBAAgB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kCAMD,KAAK,MAAM;AAAA;AAAA,YAEjC,aAAa,OAAO,CAAC;AAAA;AAAA,IAE/B;AAAA,KAlJY,yCAKZ,0CAKA;;AAVC,wBAAA,CAAA,UAAU;AAGV,yBAAA,CAAA,UAAA,GACA,SAAS,EAAE,SAAS,MAAM,MAAM,QAAA,CAAS,CAAC;AAI1C,yBAAA,CAAA,UAAA,GACA,SAAS,EAAE,SAAS,MAAM,WAAW,mBAAA,CAAoB,CAAC;AAT/C,iBAAA,IAAA,MAAA,mBAAA,EAAA,MAAA,YAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,OAAK,KAAA,CAAA,KAAA,UAAA;AAAA,UAAL,QAAK;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,qBAAA,wBAAA;AAKjC,iBAAA,IAAA,MAAA,oBAAA,EAAA,MAAA,YAAA,MAAA,UAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,YAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,QAAM,KAAA,CAAA,KAAA,UAAA;AAAA,UAAN,SAAM;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,sBAAA,yBAAA;AAKtB,iBAAA,IAAA,MAAA,oBAAA,EAAA,MAAA,YAAA,MAAA,UAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,YAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,QAAM,KAAA,CAAA,KAAA,UAAA;AAAA,UAAN,SAAM;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,sBAAA,yBAAA;AAxBxB,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QAGyB,GAAA,OAAO,OACP,GAAA,SAAyB,CAAC,iBAAiB,sBAAsB,KAAK,GAJzF,kBAAA,YAAA,uBAAA,GAAmB;;;"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { CSSResultGroup, PropertyValues, TemplateResult, LitElement } from 'lit';
|
|
2
|
+
declare const SbbTabNavBarElement_base: import('../../core/mixins.ts').AbstractConstructor<import('../../core/mixins.ts').SbbNamedSlotListMixinType<HTMLElement>> & import('../../core/mixins.ts').AbstractConstructor<import('../../core/mixins.ts').SbbElementInternalsMixinType> & typeof LitElement & import('../../core/mixins.ts').SbbElementInternalsConstructor;
|
|
3
|
+
/**
|
|
4
|
+
* It displays one or more tab-label-like elements, each one is an anchor element.
|
|
5
|
+
*
|
|
6
|
+
* @slot - Use the unnamed slot to add anchors.
|
|
7
|
+
*/
|
|
8
|
+
export declare class SbbTabNavBarElement extends SbbTabNavBarElement_base {
|
|
9
|
+
static styles: CSSResultGroup;
|
|
10
|
+
static readonly role = "navigation";
|
|
11
|
+
protected listChildLocalNames: string[];
|
|
12
|
+
/**
|
|
13
|
+
* Size variant, either s, l or xl.
|
|
14
|
+
* @default 'l' / 's' (lean)
|
|
15
|
+
*/
|
|
16
|
+
accessor size: 's' | 'l' | 'xl';
|
|
17
|
+
private _resizeController;
|
|
18
|
+
private _listElement;
|
|
19
|
+
private _onTabGroupElementResize;
|
|
20
|
+
protected firstUpdated(changedProperties: PropertyValues<this>): void;
|
|
21
|
+
private _updateWidthObserver;
|
|
22
|
+
protected render(): TemplateResult;
|
|
23
|
+
}
|
|
24
|
+
declare global {
|
|
25
|
+
interface HTMLElementTagNameMap {
|
|
26
|
+
'sbb-tab-nav-bar': SbbTabNavBarElement;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
export {};
|
|
30
|
+
//# sourceMappingURL=tab-nav-bar.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tab-nav-bar.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab-nav-bar/tab-nav-bar.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;;AAUjC;;;;GAIG;AACH,qBAEM,mBAAoB,SAAQ,wBAA2D;IAC3F,OAAuB,MAAM,EAAE,cAAc,CAK3C;IACF,gBAAgC,IAAI,gBAAgB;IAEpD,UAAmB,mBAAmB,WAAS;IAE/C;;;OAGG;IACH,SACgB,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAwB;IAE9D,OAAO,CAAC,iBAAiB,CAGtB;IAEH,OAAO,CAAC,YAAY,CAAwB;IAE5C,OAAO,CAAC,wBAAwB;cAWb,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAU9E,OAAO,CAAC,oBAAoB;cAeT,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,iBAAiB,EAAE,mBAAmB,CAAC;KACxC;CACF"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
var __typeError = (msg) => {
|
|
2
|
+
throw TypeError(msg);
|
|
3
|
+
};
|
|
4
|
+
var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
|
|
5
|
+
var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
|
|
6
|
+
var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
7
|
+
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
|
|
8
|
+
import { __runInitializers, __esDecorate } from "tslib";
|
|
9
|
+
import { ResizeController } from "@lit-labs/observers/resize-controller.js";
|
|
10
|
+
import { css, LitElement } from "lit";
|
|
11
|
+
import { customElement, property } from "lit/decorators.js";
|
|
12
|
+
import { isLean } from "../../core/dom/lean-context.js";
|
|
13
|
+
import { SbbNamedSlotListMixin, SbbElementInternalsMixin } from "../../core/mixins.js";
|
|
14
|
+
import { boxSizingStyles } from "../../core/styles.js";
|
|
15
|
+
import { tabLabelCommonStyles, tabGroupCommonStyles } from "../common.js";
|
|
16
|
+
const style = css`:host {
|
|
17
|
+
margin-block-end: var(--sbb-tab-group-content-gap);
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
.sbb-tab-nav-bar {
|
|
21
|
+
list-style: none;
|
|
22
|
+
margin: 0;
|
|
23
|
+
padding: 0;
|
|
24
|
+
font-size: inherit;
|
|
25
|
+
}`;
|
|
26
|
+
let SbbTabNavBarElement = (() => {
|
|
27
|
+
var _size_accessor_storage, _a;
|
|
28
|
+
let _classDecorators = [customElement("sbb-tab-nav-bar")];
|
|
29
|
+
let _classDescriptor;
|
|
30
|
+
let _classExtraInitializers = [];
|
|
31
|
+
let _classThis;
|
|
32
|
+
let _classSuper = SbbNamedSlotListMixin(SbbElementInternalsMixin(LitElement));
|
|
33
|
+
let _size_decorators;
|
|
34
|
+
let _size_initializers = [];
|
|
35
|
+
let _size_extraInitializers = [];
|
|
36
|
+
_a = class extends _classSuper {
|
|
37
|
+
constructor() {
|
|
38
|
+
super(...arguments);
|
|
39
|
+
__privateAdd(this, _size_accessor_storage);
|
|
40
|
+
this.listChildLocalNames = ["a"];
|
|
41
|
+
__privateSet(this, _size_accessor_storage, __runInitializers(this, _size_initializers, isLean() ? "s" : "l"));
|
|
42
|
+
this._resizeController = (__runInitializers(this, _size_extraInitializers), new ResizeController(this, {
|
|
43
|
+
target: null,
|
|
44
|
+
callback: () => this._onTabGroupElementResize()
|
|
45
|
+
}));
|
|
46
|
+
this._listElement = null;
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Size variant, either s, l or xl.
|
|
50
|
+
* @default 'l' / 's' (lean)
|
|
51
|
+
*/
|
|
52
|
+
get size() {
|
|
53
|
+
return __privateGet(this, _size_accessor_storage);
|
|
54
|
+
}
|
|
55
|
+
set size(value) {
|
|
56
|
+
__privateSet(this, _size_accessor_storage, value);
|
|
57
|
+
}
|
|
58
|
+
_onTabGroupElementResize() {
|
|
59
|
+
this.listChildren.forEach((anchor) => {
|
|
60
|
+
anchor.assignedSlot?.parentElement?.toggleAttribute("data-has-divider", anchor === this.listChildren[0] || anchor.offsetLeft === this.listChildren[0].offsetLeft);
|
|
61
|
+
});
|
|
62
|
+
this.style.setProperty("--sbb-tab-group-width", `${this._listElement?.clientWidth}px`);
|
|
63
|
+
}
|
|
64
|
+
firstUpdated(changedProperties) {
|
|
65
|
+
super.firstUpdated(changedProperties);
|
|
66
|
+
this._updateWidthObserver();
|
|
67
|
+
this.shadowRoot?.addEventListener("slotchange", () => this._updateWidthObserver());
|
|
68
|
+
}
|
|
69
|
+
_updateWidthObserver() {
|
|
70
|
+
const target = this.shadowRoot?.querySelector(`.${this.localName}`);
|
|
71
|
+
if (target && this._listElement !== target) {
|
|
72
|
+
if (this._listElement) {
|
|
73
|
+
this._resizeController.unobserve(this._listElement);
|
|
74
|
+
}
|
|
75
|
+
this._listElement = target;
|
|
76
|
+
this._resizeController.observe(target);
|
|
77
|
+
} else if (!target && this._listElement) {
|
|
78
|
+
this._resizeController.unobserve(this._listElement);
|
|
79
|
+
this._listElement = null;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
render() {
|
|
83
|
+
return this.renderList();
|
|
84
|
+
}
|
|
85
|
+
}, _size_accessor_storage = new WeakMap(), _classThis = _a, (() => {
|
|
86
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
87
|
+
_size_decorators = [property({ reflect: true })];
|
|
88
|
+
__esDecorate(_a, null, _size_decorators, { kind: "accessor", name: "size", static: false, private: false, access: { has: (obj) => "size" in obj, get: (obj) => obj.size, set: (obj, value) => {
|
|
89
|
+
obj.size = value;
|
|
90
|
+
} }, metadata: _metadata }, _size_initializers, _size_extraInitializers);
|
|
91
|
+
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
92
|
+
_classThis = _classDescriptor.value;
|
|
93
|
+
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
94
|
+
})(), _a.styles = [
|
|
95
|
+
boxSizingStyles,
|
|
96
|
+
tabLabelCommonStyles,
|
|
97
|
+
tabGroupCommonStyles,
|
|
98
|
+
style
|
|
99
|
+
], _a.role = "navigation", __runInitializers(_classThis, _classExtraInitializers), _a;
|
|
100
|
+
return _classThis;
|
|
101
|
+
})();
|
|
102
|
+
export {
|
|
103
|
+
SbbTabNavBarElement
|
|
104
|
+
};
|
|
105
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLW5hdi1iYXIuY29tcG9uZW50LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvdGFicy90YWItbmF2LWJhci90YWItbmF2LWJhci5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVzaXplQ29udHJvbGxlciB9IGZyb20gJ0BsaXQtbGFicy9vYnNlcnZlcnMvcmVzaXplLWNvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgUHJvcGVydHlWYWx1ZXMsIFRlbXBsYXRlUmVzdWx0IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IExpdEVsZW1lbnQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgY3VzdG9tRWxlbWVudCwgcHJvcGVydHkgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IGlzTGVhbiB9IGZyb20gJy4uLy4uL2NvcmUvZG9tL2xlYW4tY29udGV4dC50cyc7XG5pbXBvcnQgeyBTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW4sIFNiYk5hbWVkU2xvdExpc3RNaXhpbiB9IGZyb20gJy4uLy4uL2NvcmUvbWl4aW5zLnRzJztcbmltcG9ydCB7IGJveFNpemluZ1N0eWxlcyB9IGZyb20gJy4uLy4uL2NvcmUvc3R5bGVzLnRzJztcbmltcG9ydCB7IHRhYkdyb3VwQ29tbW9uU3R5bGVzLCB0YWJMYWJlbENvbW1vblN0eWxlcyB9IGZyb20gJy4uL2NvbW1vbi50cyc7XG5cbmltcG9ydCBzdHlsZSBmcm9tICcuL3RhYi1uYXYtYmFyLnNjc3M/bGl0JmlubGluZSc7XG5cbi8qKlxuICogSXQgZGlzcGxheXMgb25lIG9yIG1vcmUgdGFiLWxhYmVsLWxpa2UgZWxlbWVudHMsIGVhY2ggb25lIGlzIGFuIGFuY2hvciBlbGVtZW50LlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGFuY2hvcnMuXG4gKi9cbmV4cG9ydFxuQGN1c3RvbUVsZW1lbnQoJ3NiYi10YWItbmF2LWJhcicpXG5jbGFzcyBTYmJUYWJOYXZCYXJFbGVtZW50IGV4dGVuZHMgU2JiTmFtZWRTbG90TGlzdE1peGluKFNiYkVsZW1lbnRJbnRlcm5hbHNNaXhpbihMaXRFbGVtZW50KSkge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBbXG4gICAgYm94U2l6aW5nU3R5bGVzLFxuICAgIHRhYkxhYmVsQ29tbW9uU3R5bGVzLFxuICAgIHRhYkdyb3VwQ29tbW9uU3R5bGVzLFxuICAgIHN0eWxlLFxuICBdO1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHJlYWRvbmx5IHJvbGUgPSAnbmF2aWdhdGlvbic7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIGxpc3RDaGlsZExvY2FsTmFtZXMgPSBbJ2EnXTtcblxuICAvKipcbiAgICogU2l6ZSB2YXJpYW50LCBlaXRoZXIgcywgbCBvciB4bC5cbiAgICogQGRlZmF1bHQgJ2wnIC8gJ3MnIChsZWFuKVxuICAgKi9cbiAgQHByb3BlcnR5KHsgcmVmbGVjdDogdHJ1ZSB9KVxuICBwdWJsaWMgYWNjZXNzb3Igc2l6ZTogJ3MnIHwgJ2wnIHwgJ3hsJyA9IGlzTGVhbigpID8gJ3MnIDogJ2wnO1xuXG4gIHByaXZhdGUgX3Jlc2l6ZUNvbnRyb2xsZXIgPSBuZXcgUmVzaXplQ29udHJvbGxlcih0aGlzLCB7XG4gICAgdGFyZ2V0OiBudWxsLFxuICAgIGNhbGxiYWNrOiAoKSA9PiB0aGlzLl9vblRhYkdyb3VwRWxlbWVudFJlc2l6ZSgpLFxuICB9KTtcblxuICBwcml2YXRlIF9saXN0RWxlbWVudDogRWxlbWVudCB8IG51bGwgPSBudWxsO1xuXG4gIHByaXZhdGUgX29uVGFiR3JvdXBFbGVtZW50UmVzaXplKCk6IHZvaWQge1xuICAgIHRoaXMubGlzdENoaWxkcmVuLmZvckVhY2goKGFuY2hvcikgPT4ge1xuICAgICAgYW5jaG9yLmFzc2lnbmVkU2xvdD8ucGFyZW50RWxlbWVudD8udG9nZ2xlQXR0cmlidXRlKFxuICAgICAgICAnZGF0YS1oYXMtZGl2aWRlcicsXG4gICAgICAgIGFuY2hvciA9PT0gdGhpcy5saXN0Q2hpbGRyZW5bMF0gfHwgYW5jaG9yLm9mZnNldExlZnQgPT09IHRoaXMubGlzdENoaWxkcmVuWzBdLm9mZnNldExlZnQsXG4gICAgICApO1xuICAgIH0pO1xuXG4gICAgdGhpcy5zdHlsZS5zZXRQcm9wZXJ0eSgnLS1zYmItdGFiLWdyb3VwLXdpZHRoJywgYCR7dGhpcy5fbGlzdEVsZW1lbnQ/LmNsaWVudFdpZHRofXB4YCk7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgZmlyc3RVcGRhdGVkKGNoYW5nZWRQcm9wZXJ0aWVzOiBQcm9wZXJ0eVZhbHVlczx0aGlzPik6IHZvaWQge1xuICAgIHN1cGVyLmZpcnN0VXBkYXRlZChjaGFuZ2VkUHJvcGVydGllcyk7XG5cbiAgICB0aGlzLl91cGRhdGVXaWR0aE9ic2VydmVyKCk7XG5cbiAgICAvLyBXaGVuZXZlciBzbG90dGVkIGVsZW1lbnQgY2hhbmdlLCB0aGUgdGFyZ2V0IHRvIG9ic2VydmUgbWlnaHQgY2hhbmdlIGFzIHdlbGxcbiAgICAvLyAoY2hhbmdlIGZyb20gc2luZ2xlIHRvIG11bHRpcGxlIGVsZW1lbnRzIG9yIHZpY2UgdmVyc2EpLlxuICAgIHRoaXMuc2hhZG93Um9vdD8uYWRkRXZlbnRMaXN0ZW5lcignc2xvdGNoYW5nZScsICgpID0+IHRoaXMuX3VwZGF0ZVdpZHRoT2JzZXJ2ZXIoKSk7XG4gIH1cblxuICBwcml2YXRlIF91cGRhdGVXaWR0aE9ic2VydmVyKCk6IHZvaWQge1xuICAgIGNvbnN0IHRhcmdldCA9IHRoaXMuc2hhZG93Um9vdD8ucXVlcnlTZWxlY3RvcihgLiR7dGhpcy5sb2NhbE5hbWV9YCk7XG5cbiAgICBpZiAodGFyZ2V0ICYmIHRoaXMuX2xpc3RFbGVtZW50ICE9PSB0YXJnZXQpIHtcbiAgICAgIGlmICh0aGlzLl9saXN0RWxlbWVudCkge1xuICAgICAgICB0aGlzLl9yZXNpemVDb250cm9sbGVyLnVub2JzZXJ2ZSh0aGlzLl9saXN0RWxlbWVudCk7XG4gICAgICB9XG4gICAgICB0aGlzLl9saXN0RWxlbWVudCA9IHRhcmdldDtcbiAgICAgIHRoaXMuX3Jlc2l6ZUNvbnRyb2xsZXIub2JzZXJ2ZSh0YXJnZXQpO1xuICAgIH0gZWxzZSBpZiAoIXRhcmdldCAmJiB0aGlzLl9saXN0RWxlbWVudCkge1xuICAgICAgdGhpcy5fcmVzaXplQ29udHJvbGxlci51bm9ic2VydmUodGhpcy5fbGlzdEVsZW1lbnQpO1xuICAgICAgdGhpcy5fbGlzdEVsZW1lbnQgPSBudWxsO1xuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiB0aGlzLnJlbmRlckxpc3QoKTtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXRhYi1uYXYtYmFyJzogU2JiVGFiTmF2QmFyRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7SUFtQk0sdUJBQW1CLE1BQUE7OzBCQUR4QixjQUFjLGlCQUFpQixDQUFDOzs7O0FBQ0MsTUFBQSxjQUFBLHNCQUFzQix5QkFBeUIsVUFBVSxDQUFDOzs7O0FBQWxFLEVBQUEsbUJBQVEsWUFBMkQ7QUFBQTs7QUFnQjNGO0FBUG1CLFdBQUEsc0JBQXNCLENBQUMsR0FBRztBQU83Qix5QkFBQSx3QkFBQSxrQkFBQSxNQUFBLG9CQUF5QixPQUFBLElBQVcsTUFBTSxHQUFHO0FBRXJELFdBQUEscUJBQWlCLGtCQUFBLE1BQUEsdUJBQUEsR0FBRyxJQUFJLGlCQUFpQixNQUFNO0FBQUEsUUFDckQsUUFBUTtBQUFBLFFBQ1IsVUFBVSxNQUFNLEtBQUsseUJBQUE7QUFBQSxNQUF3QixDQUM5QztBQUVPLFdBQUEsZUFBK0I7QUFBQSxJQXlDekM7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLElBaERFLElBQWdCLE9BQUk7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQXBCLElBQWdCLEtBQUksT0FBQTtBQUFBLHlCQUFBLHdCQUFBO0FBQUEsSUFBQTtBQUFBLElBU1osMkJBQXdCO0FBQzlCLFdBQUssYUFBYSxRQUFRLENBQUMsV0FBVTtBQUNuQyxlQUFPLGNBQWMsZUFBZSxnQkFDbEMsb0JBQ0EsV0FBVyxLQUFLLGFBQWEsQ0FBQyxLQUFLLE9BQU8sZUFBZSxLQUFLLGFBQWEsQ0FBQyxFQUFFLFVBQVU7QUFBQSxNQUU1RixDQUFDO0FBRUQsV0FBSyxNQUFNLFlBQVkseUJBQXlCLEdBQUcsS0FBSyxjQUFjLFdBQVcsSUFBSTtBQUFBLElBQ3ZGO0FBQUEsSUFFbUIsYUFBYSxtQkFBdUM7QUFDckUsWUFBTSxhQUFhLGlCQUFpQjtBQUVwQyxXQUFLLHFCQUFBO0FBSUwsV0FBSyxZQUFZLGlCQUFpQixjQUFjLE1BQU0sS0FBSyxzQkFBc0I7QUFBQSxJQUNuRjtBQUFBLElBRVEsdUJBQW9CO0FBQzFCLFlBQU0sU0FBUyxLQUFLLFlBQVksY0FBYyxJQUFJLEtBQUssU0FBUyxFQUFFO0FBRWxFLFVBQUksVUFBVSxLQUFLLGlCQUFpQixRQUFRO0FBQzFDLFlBQUksS0FBSyxjQUFjO0FBQ3JCLGVBQUssa0JBQWtCLFVBQVUsS0FBSyxZQUFZO0FBQUEsUUFDcEQ7QUFDQSxhQUFLLGVBQWU7QUFDcEIsYUFBSyxrQkFBa0IsUUFBUSxNQUFNO0FBQUEsTUFDdkMsV0FBVyxDQUFDLFVBQVUsS0FBSyxjQUFjO0FBQ3ZDLGFBQUssa0JBQWtCLFVBQVUsS0FBSyxZQUFZO0FBQ2xELGFBQUssZUFBZTtBQUFBLE1BQ3RCO0FBQUEsSUFDRjtBQUFBLElBRW1CLFNBQU07QUFDdkIsYUFBTyxLQUFLLFdBQUE7QUFBQSxJQUNkO0FBQUEsS0EvQ0E7O0FBREMsdUJBQUEsQ0FBQSxTQUFTLEVBQUUsU0FBUyxLQUFBLENBQU0sQ0FBQztBQUM1QixpQkFBQSxJQUFBLE1BQUEsa0JBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxRQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLFVBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixNQUFJLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFKLE9BQUk7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEsb0JBQUEsdUJBQUE7QUFoQnRCLGlCQUFBLE1BQUEsbUJBQUEsRUFBQSxPQUFBLFdBQUEsR0FBQSxrQkFBQSxFQUFBLE1BQUEsU0FBQSxNQUFBLFdBQUEsTUFBQSxVQUFBLFVBQUEsR0FBQSxNQUFBLHVCQUFBOzs7UUFDeUIsR0FBQSxTQUF5QjtBQUFBLElBQzlDO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsRUFBQSxHQUU4QixHQUFBLE9BQU8sY0FQbkMsa0JBQUEsWUFBQSx1QkFBQSxHQUFvQjs7OyJ9
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tab-nav-bar.d.ts","sourceRoot":"","sources":["../../../../src/elements/tabs/tab-nav-bar.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,wCAAwC,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { SbbTabNavBarElement } from "./tab-nav-bar/tab-nav-bar.component.js";
|
|
2
|
+
export {
|
|
3
|
+
SbbTabNavBarElement
|
|
4
|
+
};
|
|
5
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLW5hdi1iYXIuanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOyJ9
|
package/development/tabs.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tabs.d.ts","sourceRoot":"","sources":["../../../src/elements/tabs.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,eAAe,CAAC;AAC9B,cAAc,qBAAqB,CAAC;AACpC,cAAc,qBAAqB,CAAC"}
|
|
1
|
+
{"version":3,"file":"tabs.d.ts","sourceRoot":"","sources":["../../../src/elements/tabs.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,eAAe,CAAC;AAC9B,cAAc,qBAAqB,CAAC;AACpC,cAAc,qBAAqB,CAAC;AACpC,cAAc,6CAA6C,CAAC"}
|
package/development/tabs.js
CHANGED
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
import { SbbTabElement } from "./tabs/tab/tab.component.js";
|
|
2
2
|
import { SbbTabGroupElement } from "./tabs/tab-group/tab-group.component.js";
|
|
3
3
|
import { SbbTabLabelElement } from "./tabs/tab-label/tab-label.component.js";
|
|
4
|
+
import { SbbTabNavBarElement } from "./tabs/tab-nav-bar/tab-nav-bar.component.js";
|
|
4
5
|
export {
|
|
5
6
|
SbbTabElement,
|
|
6
7
|
SbbTabGroupElement,
|
|
7
|
-
SbbTabLabelElement
|
|
8
|
+
SbbTabLabelElement,
|
|
9
|
+
SbbTabNavBarElement
|
|
8
10
|
};
|
|
9
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFicy5qcyIsInNvdXJjZXMiOltdLCJzb3VyY2VzQ29udGVudCI6W10sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7In0=
|