@villedemontreal/angular-ui 2.1.0 → 3.0.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/esm2020/lib/alert/alert.component.mjs +7 -9
- package/esm2020/lib/avatar/avatar.component.mjs +102 -0
- package/esm2020/lib/avatar/index.mjs +8 -0
- package/esm2020/lib/avatar/module.mjs +24 -0
- package/esm2020/lib/bao.module.mjs +12 -4
- package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +5 -5
- package/esm2020/lib/button/button.component.mjs +3 -3
- package/esm2020/lib/card/card.component.mjs +2 -2
- package/esm2020/lib/checkbox/checkbox-group.component.mjs +5 -6
- package/esm2020/lib/checkbox/checkbox.component.mjs +40 -41
- package/esm2020/lib/core/colors.mjs +10 -27
- package/esm2020/lib/icon/icon.component.mjs +19 -19
- package/esm2020/lib/icon/icons-dictionary.mjs +3 -2
- package/esm2020/lib/list/list.component.mjs +2 -2
- package/esm2020/lib/radio/radio-group.component.mjs +40 -41
- package/esm2020/lib/radio/radio.component.mjs +41 -42
- package/esm2020/lib/shared/enum/display-mode.mjs +2 -11
- package/esm2020/lib/summary/summary.component.mjs +5 -7
- package/esm2020/lib/tabs/index.mjs +8 -0
- package/esm2020/lib/tabs/module.mjs +35 -0
- package/esm2020/lib/tabs/tabs.component.mjs +295 -0
- package/esm2020/lib/tag/tag.component.mjs +3 -3
- package/esm2020/public-api.mjs +4 -1
- package/fesm2015/villedemontreal-angular-ui.mjs +652 -224
- package/fesm2015/villedemontreal-angular-ui.mjs.map +1 -1
- package/fesm2020/villedemontreal-angular-ui.mjs +652 -224
- package/fesm2020/villedemontreal-angular-ui.mjs.map +1 -1
- package/lib/alert/alert.component.d.ts +2 -3
- package/lib/avatar/avatar.component.d.ts +26 -0
- package/lib/avatar/index.d.ts +2 -0
- package/lib/avatar/module.d.ts +8 -0
- package/lib/bao.module.d.ts +3 -1
- package/lib/breadcrumb/breadcrumb.component.d.ts +1 -1
- package/lib/button/button.component.d.ts +1 -1
- package/lib/checkbox/checkbox-group.component.d.ts +2 -2
- package/lib/checkbox/checkbox.component.d.ts +27 -27
- package/lib/core/colors.d.ts +1 -1
- package/lib/icon/icon.component.d.ts +9 -9
- package/lib/radio/radio-group.component.d.ts +19 -19
- package/lib/radio/radio.component.d.ts +27 -27
- package/lib/shared/enum/display-mode.d.ts +1 -1
- package/lib/summary/summary.component.d.ts +5 -5
- package/lib/tabs/index.d.ts +2 -0
- package/lib/tabs/module.d.ts +8 -0
- package/lib/tabs/tabs.component.d.ts +95 -0
- package/lib/tag/tag.component.d.ts +1 -1
- package/package.json +2 -2
- package/public-api.d.ts +3 -0
|
@@ -0,0 +1,295 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2022 Ville de Montreal. All rights reserved.
|
|
3
|
+
* Licensed under the MIT license.
|
|
4
|
+
* See LICENSE file in the project root for full license information.
|
|
5
|
+
*/
|
|
6
|
+
import { Component, ContentChild, ContentChildren, Directive, EventEmitter, HostListener, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
/**
|
|
9
|
+
* Unique number to generate a unique ID
|
|
10
|
+
*/
|
|
11
|
+
let tabsNextUniqueId = 0;
|
|
12
|
+
export class BaoTabHeader {
|
|
13
|
+
constructor(renderer, elementRef) {
|
|
14
|
+
this.renderer = renderer;
|
|
15
|
+
this.elementRef = elementRef;
|
|
16
|
+
/**
|
|
17
|
+
* Emits its index when tab is clicked
|
|
18
|
+
*/
|
|
19
|
+
this.onTabClick = new EventEmitter();
|
|
20
|
+
}
|
|
21
|
+
get nativeElement() {
|
|
22
|
+
return this.elementRef.nativeElement;
|
|
23
|
+
}
|
|
24
|
+
onClick(el) {
|
|
25
|
+
const tabIndex = el.id.split('-')[el.id.split('-').length - 1];
|
|
26
|
+
this.onTabClick.emit(tabIndex);
|
|
27
|
+
}
|
|
28
|
+
ngAfterViewInit() {
|
|
29
|
+
this.renderer.setAttribute(this.nativeElement, 'role', 'tab');
|
|
30
|
+
this.renderer.setAttribute(this.nativeElement, 'aria-selected', 'false');
|
|
31
|
+
this.renderer.setAttribute(this.nativeElement, 'tabindex', '-1');
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
BaoTabHeader.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTabHeader, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
35
|
+
BaoTabHeader.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.1.1", type: BaoTabHeader, selector: "bao-tab-header, [bao-tab-header]", outputs: { onTabClick: "onTabClick" }, host: { listeners: { "click": "onClick($event.target)" }, classAttribute: "bao-tab-header" }, exportAs: ["baoTabHeader"], ngImport: i0 });
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTabHeader, decorators: [{
|
|
37
|
+
type: Directive,
|
|
38
|
+
args: [{
|
|
39
|
+
selector: 'bao-tab-header, [bao-tab-header]',
|
|
40
|
+
exportAs: 'baoTabHeader',
|
|
41
|
+
host: {
|
|
42
|
+
class: 'bao-tab-header'
|
|
43
|
+
}
|
|
44
|
+
}]
|
|
45
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { onTabClick: [{
|
|
46
|
+
type: Output
|
|
47
|
+
}], onClick: [{
|
|
48
|
+
type: HostListener,
|
|
49
|
+
args: ['click', ['$event.target']]
|
|
50
|
+
}] } });
|
|
51
|
+
export class BaoTabPanel {
|
|
52
|
+
constructor(renderer, elementRef) {
|
|
53
|
+
this.renderer = renderer;
|
|
54
|
+
this.elementRef = elementRef;
|
|
55
|
+
}
|
|
56
|
+
get nativeElement() {
|
|
57
|
+
return this.elementRef.nativeElement;
|
|
58
|
+
}
|
|
59
|
+
ngAfterViewInit() {
|
|
60
|
+
this.renderer.setAttribute(this.nativeElement, 'role', 'tabpanel');
|
|
61
|
+
this.renderer.setAttribute(this.nativeElement, 'hidden', 'true');
|
|
62
|
+
this.renderer.setAttribute(this.nativeElement, 'tabindex', '0');
|
|
63
|
+
this.renderer.setAttribute(this.nativeElement, 'aria-expanded', 'false');
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
BaoTabPanel.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTabPanel, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
67
|
+
BaoTabPanel.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.1.1", type: BaoTabPanel, selector: "bao-panel, [bao-panel]", host: { classAttribute: "bao-panel" }, exportAs: ["baoPanel"], ngImport: i0 });
|
|
68
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTabPanel, decorators: [{
|
|
69
|
+
type: Directive,
|
|
70
|
+
args: [{
|
|
71
|
+
selector: 'bao-panel, [bao-panel]',
|
|
72
|
+
exportAs: 'baoPanel',
|
|
73
|
+
host: {
|
|
74
|
+
class: 'bao-panel'
|
|
75
|
+
}
|
|
76
|
+
}]
|
|
77
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; } });
|
|
78
|
+
export class BaoTablistComponent {
|
|
79
|
+
constructor(renderer, elementRef) {
|
|
80
|
+
this.renderer = renderer;
|
|
81
|
+
this.elementRef = elementRef;
|
|
82
|
+
/**
|
|
83
|
+
* Size of the tabs displayed
|
|
84
|
+
*/
|
|
85
|
+
this.size = 'large';
|
|
86
|
+
/**
|
|
87
|
+
* Optionnal value to be used as aria-label property on tablist component
|
|
88
|
+
*/
|
|
89
|
+
this.ariaLabel = 'onglets';
|
|
90
|
+
/**
|
|
91
|
+
* Emits the index of the new active tab
|
|
92
|
+
*/
|
|
93
|
+
this.activeTabChange = new EventEmitter();
|
|
94
|
+
this.uniqueId = `bao-tablist-${tabsNextUniqueId++}`;
|
|
95
|
+
}
|
|
96
|
+
get nativeElement() {
|
|
97
|
+
return this.elementRef.nativeElement;
|
|
98
|
+
}
|
|
99
|
+
get tabs() {
|
|
100
|
+
return this.elementRef.nativeElement.children;
|
|
101
|
+
}
|
|
102
|
+
leftKeyEvent() {
|
|
103
|
+
if (document.activeElement.parentElement.id === this.uniqueId) {
|
|
104
|
+
this.activeTabIndex = this.getNextActivableTabIndex(parseInt(this.activeTabIndex), false);
|
|
105
|
+
this.changeActiveTab(this.activeTabIndex, true);
|
|
106
|
+
this.activeTabChange.emit(this.activeTabIndex);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
rightKeyEvent() {
|
|
110
|
+
if (document.activeElement.parentElement.id === this.uniqueId) {
|
|
111
|
+
this.activeTabIndex = this.getNextActivableTabIndex(parseInt(this.activeTabIndex), true);
|
|
112
|
+
this.changeActiveTab(this.activeTabIndex, true);
|
|
113
|
+
this.activeTabChange.emit(this.activeTabIndex);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Makes the focus visible on tab header when changing from mouse to keyboard navigation
|
|
118
|
+
*/
|
|
119
|
+
tabKeyEvent() {
|
|
120
|
+
if (document.activeElement.parentElement.id === this.uniqueId) {
|
|
121
|
+
this.renderer.addClass(this.tabs[this.activeTabIndex], 'focus-visible');
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Makes the focus visible on tab header when changing from mouse to keyboard navigation
|
|
126
|
+
*/
|
|
127
|
+
tabShiftKeyEvent() {
|
|
128
|
+
if (document.activeElement.parentElement.id === this.uniqueId) {
|
|
129
|
+
this.renderer.addClass(this.tabs[this.activeTabIndex], 'focus-visible');
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
ngAfterViewInit() {
|
|
133
|
+
this.setTablistAttributes();
|
|
134
|
+
if (this.nativeElement.childElementCount) {
|
|
135
|
+
this.setInitialActiveTab();
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
ngAfterContentInit() {
|
|
139
|
+
this.tabHeaders.forEach((tab) => {
|
|
140
|
+
tab.onTabClick.subscribe((index) => {
|
|
141
|
+
this.renderer.removeClass(this.tabs[index], 'focus-visible');
|
|
142
|
+
this.activeTabIndex = index;
|
|
143
|
+
this.changeActiveTab(index, false);
|
|
144
|
+
this.activeTabChange.emit(index);
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
ngOnDestroy() {
|
|
149
|
+
this.tabHeaders.forEach((tab) => {
|
|
150
|
+
tab.onTabClick.unsubscribe();
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
setTablistAttributes() {
|
|
154
|
+
this.renderer.setAttribute(this.nativeElement, 'role', 'tablist');
|
|
155
|
+
this.renderer.setAttribute(this.nativeElement, 'aria-label', this.ariaLabel);
|
|
156
|
+
this.renderer.setProperty(this.nativeElement, 'id', this.uniqueId);
|
|
157
|
+
}
|
|
158
|
+
setInitialActiveTab() {
|
|
159
|
+
const firstTabIndex = Array.from(this.tabs).findIndex((tab) => !tab.attributes['disabled']);
|
|
160
|
+
this.activeTabIndex = firstTabIndex.toString();
|
|
161
|
+
this.renderer.setAttribute(this.tabs[firstTabIndex], 'aria-selected', 'true');
|
|
162
|
+
this.renderer.addClass(this.tabs[firstTabIndex], 'active');
|
|
163
|
+
this.renderer.addClass(this.tabs[firstTabIndex], 'focus-visible');
|
|
164
|
+
this.renderer.removeAttribute(this.tabs[firstTabIndex], 'tabindex');
|
|
165
|
+
}
|
|
166
|
+
changeActiveTab(newActiveTabIndex, isFocusVisible) {
|
|
167
|
+
Array.from(this.tabs).forEach((tab) => {
|
|
168
|
+
if (tab.id === `bao-tab-${newActiveTabIndex}`) {
|
|
169
|
+
if (isFocusVisible) {
|
|
170
|
+
this.renderer.addClass(tab, 'focus-visible');
|
|
171
|
+
}
|
|
172
|
+
this.renderer.setAttribute(tab, 'aria-selected', 'true');
|
|
173
|
+
this.renderer.addClass(tab, 'active');
|
|
174
|
+
this.renderer.removeAttribute(tab, 'tabindex');
|
|
175
|
+
tab.focus();
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
178
|
+
this.renderer.setAttribute(tab, 'aria-selected', 'false');
|
|
179
|
+
this.renderer.removeClass(tab, 'active');
|
|
180
|
+
this.renderer.setAttribute(tab, 'tabindex', '-1');
|
|
181
|
+
this.renderer.removeClass(tab, 'focus-visible');
|
|
182
|
+
}
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* Finds the next activable tab index when navigating with left and right arrow keys
|
|
187
|
+
* @param currentIndex Tab index which currently has focus
|
|
188
|
+
* @param isRight Whether the tab navigation is going in the right direction or not
|
|
189
|
+
* @returns Index of the new tab that will receive focus
|
|
190
|
+
*/
|
|
191
|
+
getNextActivableTabIndex(currentIndex, isRight) {
|
|
192
|
+
const nextIndex = isRight ? currentIndex + 1 : currentIndex - 1;
|
|
193
|
+
const nextIndexInTablist = ((nextIndex % this.tabs.length) + this.tabs.length) % this.tabs.length;
|
|
194
|
+
if (this.tabs[nextIndexInTablist].attributes['disabled']) {
|
|
195
|
+
return this.getNextActivableTabIndex(nextIndexInTablist, isRight);
|
|
196
|
+
}
|
|
197
|
+
return nextIndexInTablist.toString();
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
BaoTablistComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTablistComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
201
|
+
BaoTablistComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BaoTablistComponent, selector: "bao-tablist, [bao-tablist]", inputs: { size: "size", ariaLabel: "ariaLabel" }, outputs: { activeTabChange: "activeTabChange" }, host: { listeners: { "window:keydown.arrowleft": "leftKeyEvent()", "window:keydown.arrowright": "rightKeyEvent()", "window:keydown.tab": "tabKeyEvent()", "window:keydown.shift.tab": "tabShiftKeyEvent()" }, properties: { "class.bao-tablist-small": "size === \"small\"", "class.bao-tablist-medium": "size === \"medium\"", "class.bao-tablist-large": "size === \"large\"" }, classAttribute: "bao-tablist" }, queries: [{ propertyName: "tabHeaders", predicate: BaoTabHeader }], ngImport: i0, template: "<ng-content></ng-content>\n", styles: [".bao-tablist{color:#637381;display:block;overflow:auto;white-space:nowrap;box-shadow:inset 0 -.125rem #ced4da}.bao-tablist.bao-tablist-small{font-weight:700;font-size:.75rem;line-height:1rem}.bao-tablist.bao-tablist-small>.bao-tab-header{padding:.5rem}.bao-tablist.bao-tablist-medium{font-weight:700;font-size:.875rem;line-height:1.25rem}.bao-tablist.bao-tablist-medium>.bao-tab-header{padding:.625rem 1rem}.bao-tablist.bao-tablist-large{font-weight:700;font-size:1rem;line-height:1.5rem}.bao-tablist.bao-tablist-large>.bao-tab-header{padding:1rem}.bao-tablist button{all:unset}.bao-tablist>.bao-tab-header:hover:not(:disabled){color:#097d6c;cursor:pointer;box-shadow:inset 0 -.125rem #097d6c}.bao-tablist>.bao-tab-header.active{color:#097d6c;box-shadow:inset 0 -.125rem #097d6c}.bao-tablist>.bao-tab-header:focus.focus-visible{box-shadow:inset 0 0 0 .1875rem #98bcde;color:#637381}.bao-tablist>.bao-tab-header:disabled{color:#adb2bd}\n"], encapsulation: i0.ViewEncapsulation.None });
|
|
202
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTablistComponent, decorators: [{
|
|
203
|
+
type: Component,
|
|
204
|
+
args: [{ selector: 'bao-tablist, [bao-tablist]', encapsulation: ViewEncapsulation.None, host: {
|
|
205
|
+
class: 'bao-tablist',
|
|
206
|
+
'[class.bao-tablist-small]': 'size === "small"',
|
|
207
|
+
'[class.bao-tablist-medium]': 'size === "medium"',
|
|
208
|
+
'[class.bao-tablist-large]': 'size === "large"'
|
|
209
|
+
}, template: "<ng-content></ng-content>\n", styles: [".bao-tablist{color:#637381;display:block;overflow:auto;white-space:nowrap;box-shadow:inset 0 -.125rem #ced4da}.bao-tablist.bao-tablist-small{font-weight:700;font-size:.75rem;line-height:1rem}.bao-tablist.bao-tablist-small>.bao-tab-header{padding:.5rem}.bao-tablist.bao-tablist-medium{font-weight:700;font-size:.875rem;line-height:1.25rem}.bao-tablist.bao-tablist-medium>.bao-tab-header{padding:.625rem 1rem}.bao-tablist.bao-tablist-large{font-weight:700;font-size:1rem;line-height:1.5rem}.bao-tablist.bao-tablist-large>.bao-tab-header{padding:1rem}.bao-tablist button{all:unset}.bao-tablist>.bao-tab-header:hover:not(:disabled){color:#097d6c;cursor:pointer;box-shadow:inset 0 -.125rem #097d6c}.bao-tablist>.bao-tab-header.active{color:#097d6c;box-shadow:inset 0 -.125rem #097d6c}.bao-tablist>.bao-tab-header:focus.focus-visible{box-shadow:inset 0 0 0 .1875rem #98bcde;color:#637381}.bao-tablist>.bao-tab-header:disabled{color:#adb2bd}\n"] }]
|
|
210
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { tabHeaders: [{
|
|
211
|
+
type: ContentChildren,
|
|
212
|
+
args: [BaoTabHeader]
|
|
213
|
+
}], size: [{
|
|
214
|
+
type: Input
|
|
215
|
+
}], ariaLabel: [{
|
|
216
|
+
type: Input
|
|
217
|
+
}], activeTabChange: [{
|
|
218
|
+
type: Output
|
|
219
|
+
}], leftKeyEvent: [{
|
|
220
|
+
type: HostListener,
|
|
221
|
+
args: ['window:keydown.arrowleft']
|
|
222
|
+
}], rightKeyEvent: [{
|
|
223
|
+
type: HostListener,
|
|
224
|
+
args: ['window:keydown.arrowright']
|
|
225
|
+
}], tabKeyEvent: [{
|
|
226
|
+
type: HostListener,
|
|
227
|
+
args: ['window:keydown.tab']
|
|
228
|
+
}], tabShiftKeyEvent: [{
|
|
229
|
+
type: HostListener,
|
|
230
|
+
args: ['window:keydown.shift.tab']
|
|
231
|
+
}] } });
|
|
232
|
+
export class BaoTabsContainer {
|
|
233
|
+
constructor(renderer, elementRef) {
|
|
234
|
+
this.renderer = renderer;
|
|
235
|
+
this.elementRef = elementRef;
|
|
236
|
+
this.panelIdPrefix = 'bao-panel-';
|
|
237
|
+
this.tabIdPrefix = 'bao-tab-';
|
|
238
|
+
}
|
|
239
|
+
get tabs() {
|
|
240
|
+
return this.elementRef.nativeElement.querySelector('.bao-tablist').children;
|
|
241
|
+
}
|
|
242
|
+
get panels() {
|
|
243
|
+
return this.elementRef.nativeElement.querySelectorAll('.bao-panel');
|
|
244
|
+
}
|
|
245
|
+
ngAfterViewInit() {
|
|
246
|
+
this.setInitialActivePanel();
|
|
247
|
+
Array.from(this.tabs).forEach((tab, idx) => {
|
|
248
|
+
const tabId = `${this.tabIdPrefix}${idx}`;
|
|
249
|
+
const panelId = `${this.panelIdPrefix}${idx}`;
|
|
250
|
+
this.renderer.setProperty(tab, 'id', tabId);
|
|
251
|
+
this.renderer.setProperty(this.panels[idx], 'id', panelId);
|
|
252
|
+
this.renderer.setAttribute(tab, 'aria-controls', panelId);
|
|
253
|
+
this.renderer.setAttribute(this.panels[idx], 'aria-labelledby', tabId);
|
|
254
|
+
});
|
|
255
|
+
}
|
|
256
|
+
ngAfterContentInit() {
|
|
257
|
+
this.tablist.activeTabChange.subscribe((index) => this.changeActivePanel(index));
|
|
258
|
+
}
|
|
259
|
+
ngOnDestroy() {
|
|
260
|
+
this.tablist.activeTabChange.unsubscribe();
|
|
261
|
+
}
|
|
262
|
+
setInitialActivePanel() {
|
|
263
|
+
const firstTabIndex = Array.from(this.tabs).findIndex((tab) => !tab.attributes['disabled']);
|
|
264
|
+
this.renderer.removeAttribute(this.panels[firstTabIndex], 'hidden');
|
|
265
|
+
this.renderer.setAttribute(this.panels[firstTabIndex], 'aria-expanded', 'true');
|
|
266
|
+
}
|
|
267
|
+
changeActivePanel(newActiveId) {
|
|
268
|
+
this.panels.forEach((panel) => {
|
|
269
|
+
if (panel.id === `${this.panelIdPrefix}${newActiveId}`) {
|
|
270
|
+
this.renderer.removeAttribute(panel, 'hidden');
|
|
271
|
+
this.renderer.setAttribute(panel, 'aria-expanded', 'true');
|
|
272
|
+
}
|
|
273
|
+
else {
|
|
274
|
+
this.renderer.setAttribute(panel, 'hidden', 'true');
|
|
275
|
+
this.renderer.setAttribute(panel, 'aria-expanded', 'false');
|
|
276
|
+
}
|
|
277
|
+
});
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
BaoTabsContainer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTabsContainer, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
281
|
+
BaoTabsContainer.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.1.1", type: BaoTabsContainer, selector: "bao-tabs, [bao-tabs]", host: { classAttribute: "bao-tabs" }, queries: [{ propertyName: "tablist", first: true, predicate: BaoTablistComponent, descendants: true }], exportAs: ["baoTabs"], ngImport: i0 });
|
|
282
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTabsContainer, decorators: [{
|
|
283
|
+
type: Directive,
|
|
284
|
+
args: [{
|
|
285
|
+
selector: 'bao-tabs, [bao-tabs]',
|
|
286
|
+
exportAs: 'baoTabs',
|
|
287
|
+
host: {
|
|
288
|
+
class: 'bao-tabs'
|
|
289
|
+
}
|
|
290
|
+
}]
|
|
291
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { tablist: [{
|
|
292
|
+
type: ContentChild,
|
|
293
|
+
args: [BaoTablistComponent]
|
|
294
|
+
}] } });
|
|
295
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/tabs/tabs.component.ts","../../../../../projects/angular-ui/src/lib/tabs/tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2022 Ville de Montreal. All rights reserved.\n * Licensed under the MIT license.\n * See LICENSE file in the project root for full license information.\n */\n\nimport {\n  AfterContentInit,\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  Renderer2,\n  ViewEncapsulation\n} from '@angular/core';\n\n/**\n * Unique number to generate a unique ID\n */\nlet tabsNextUniqueId = 0;\n@Directive({\n  selector: 'bao-tab-header, [bao-tab-header]',\n  exportAs: 'baoTabHeader',\n  host: {\n    class: 'bao-tab-header'\n  }\n})\nexport class BaoTabHeader implements AfterViewInit {\n  /**\n   * Emits its index when tab is clicked\n   */\n  @Output() public onTabClick: EventEmitter<string> =\n    new EventEmitter<string>();\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>\n  ) {}\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  @HostListener('click', ['$event.target'])\n  onClick(el: HTMLElement) {\n    const tabIndex = el.id.split('-')[el.id.split('-').length - 1];\n    this.onTabClick.emit(tabIndex);\n  }\n\n  ngAfterViewInit(): void {\n    this.renderer.setAttribute(this.nativeElement, 'role', 'tab');\n    this.renderer.setAttribute(this.nativeElement, 'aria-selected', 'false');\n    this.renderer.setAttribute(this.nativeElement, 'tabindex', '-1');\n  }\n}\n\n@Directive({\n  selector: 'bao-panel, [bao-panel]',\n  exportAs: 'baoPanel',\n  host: {\n    class: 'bao-panel'\n  }\n})\nexport class BaoTabPanel implements AfterViewInit {\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>\n  ) {}\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  ngAfterViewInit(): void {\n    this.renderer.setAttribute(this.nativeElement, 'role', 'tabpanel');\n    this.renderer.setAttribute(this.nativeElement, 'hidden', 'true');\n    this.renderer.setAttribute(this.nativeElement, 'tabindex', '0');\n    this.renderer.setAttribute(this.nativeElement, 'aria-expanded', 'false');\n  }\n}\n\n@Component({\n  selector: 'bao-tablist, [bao-tablist]',\n  templateUrl: './tabs.component.html',\n  styleUrls: ['./tabs.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'bao-tablist',\n    '[class.bao-tablist-small]': 'size === \"small\"',\n    '[class.bao-tablist-medium]': 'size === \"medium\"',\n    '[class.bao-tablist-large]': 'size === \"large\"'\n  }\n})\nexport class BaoTablistComponent\n  implements AfterViewInit, AfterContentInit, OnDestroy\n{\n  @ContentChildren(BaoTabHeader) tabHeaders: QueryList<BaoTabHeader>;\n\n  /**\n   * Size of the tabs displayed\n   */\n  @Input() public size: 'small' | 'medium' | 'large' = 'large';\n\n  /**\n   * Optionnal value to be used as aria-label property on tablist component\n   */\n  @Input() public ariaLabel = 'onglets';\n\n  /**\n   * Emits the index of the new active tab\n   */\n  @Output() public activeTabChange: EventEmitter<string> =\n    new EventEmitter<string>();\n\n  /**\n   * Index of the tab that is currently active\n   */\n  private activeTabIndex: string;\n\n  /**\n   * Unique ID for every instance of BaoTablist component\n   */\n  private uniqueId: string;\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>\n  ) {\n    this.uniqueId = `bao-tablist-${tabsNextUniqueId++}`;\n  }\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  get tabs(): HTMLCollection {\n    return this.elementRef.nativeElement.children;\n  }\n\n  @HostListener('window:keydown.arrowleft')\n  leftKeyEvent() {\n    if (document.activeElement.parentElement.id === this.uniqueId) {\n      this.activeTabIndex = this.getNextActivableTabIndex(\n        parseInt(this.activeTabIndex),\n        false\n      );\n      this.changeActiveTab(this.activeTabIndex, true);\n      this.activeTabChange.emit(this.activeTabIndex);\n    }\n  }\n\n  @HostListener('window:keydown.arrowright')\n  rightKeyEvent() {\n    if (document.activeElement.parentElement.id === this.uniqueId) {\n      this.activeTabIndex = this.getNextActivableTabIndex(\n        parseInt(this.activeTabIndex),\n        true\n      );\n      this.changeActiveTab(this.activeTabIndex, true);\n      this.activeTabChange.emit(this.activeTabIndex);\n    }\n  }\n\n  /**\n   * Makes the focus visible on tab header when changing from mouse to keyboard navigation\n   */\n  @HostListener('window:keydown.tab')\n  tabKeyEvent() {\n    if (document.activeElement.parentElement.id === this.uniqueId) {\n      this.renderer.addClass(this.tabs[this.activeTabIndex], 'focus-visible');\n    }\n  }\n\n  /**\n   * Makes the focus visible on tab header when changing from mouse to keyboard navigation\n   */\n  @HostListener('window:keydown.shift.tab')\n  tabShiftKeyEvent() {\n    if (document.activeElement.parentElement.id === this.uniqueId) {\n      this.renderer.addClass(this.tabs[this.activeTabIndex], 'focus-visible');\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.setTablistAttributes();\n    if (this.nativeElement.childElementCount) {\n      this.setInitialActiveTab();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    this.tabHeaders.forEach((tab: BaoTabHeader) => {\n      tab.onTabClick.subscribe((index: string) => {\n        this.renderer.removeClass(this.tabs[index], 'focus-visible');\n        this.activeTabIndex = index;\n        this.changeActiveTab(index, false);\n        this.activeTabChange.emit(index);\n      });\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.tabHeaders.forEach((tab: BaoTabHeader) => {\n      tab.onTabClick.unsubscribe();\n    });\n  }\n\n  private setTablistAttributes(): void {\n    this.renderer.setAttribute(this.nativeElement, 'role', 'tablist');\n    this.renderer.setAttribute(\n      this.nativeElement,\n      'aria-label',\n      this.ariaLabel\n    );\n    this.renderer.setProperty(this.nativeElement, 'id', this.uniqueId);\n  }\n\n  private setInitialActiveTab(): void {\n    const firstTabIndex = Array.from(this.tabs).findIndex(\n      (tab: HTMLElement) => !tab.attributes['disabled']\n    );\n    this.activeTabIndex = firstTabIndex.toString();\n    this.renderer.setAttribute(\n      this.tabs[firstTabIndex],\n      'aria-selected',\n      'true'\n    );\n    this.renderer.addClass(this.tabs[firstTabIndex], 'active');\n    this.renderer.addClass(this.tabs[firstTabIndex], 'focus-visible');\n    this.renderer.removeAttribute(this.tabs[firstTabIndex], 'tabindex');\n  }\n\n  private changeActiveTab(\n    newActiveTabIndex: string,\n    isFocusVisible: boolean\n  ): void {\n    Array.from(this.tabs).forEach((tab: HTMLElement) => {\n      if (tab.id === `bao-tab-${newActiveTabIndex}`) {\n        if (isFocusVisible) {\n          this.renderer.addClass(tab, 'focus-visible');\n        }\n        this.renderer.setAttribute(tab, 'aria-selected', 'true');\n        this.renderer.addClass(tab, 'active');\n        this.renderer.removeAttribute(tab, 'tabindex');\n        tab.focus();\n      } else {\n        this.renderer.setAttribute(tab, 'aria-selected', 'false');\n        this.renderer.removeClass(tab, 'active');\n        this.renderer.setAttribute(tab, 'tabindex', '-1');\n        this.renderer.removeClass(tab, 'focus-visible');\n      }\n    });\n  }\n\n  /**\n   * Finds the next activable tab index when navigating with left and right arrow keys\n   * @param currentIndex Tab index which currently has focus\n   * @param isRight Whether the tab navigation is going in the right direction or not\n   * @returns Index of the new tab that will receive focus\n   */\n  private getNextActivableTabIndex(\n    currentIndex: number,\n    isRight: boolean\n  ): string {\n    const nextIndex = isRight ? currentIndex + 1 : currentIndex - 1;\n    const nextIndexInTablist =\n      ((nextIndex % this.tabs.length) + this.tabs.length) % this.tabs.length;\n    if (this.tabs[nextIndexInTablist].attributes['disabled']) {\n      return this.getNextActivableTabIndex(nextIndexInTablist, isRight);\n    }\n    return nextIndexInTablist.toString();\n  }\n}\n\n@Directive({\n  selector: 'bao-tabs, [bao-tabs]',\n  exportAs: 'baoTabs',\n  host: {\n    class: 'bao-tabs'\n  }\n})\nexport class BaoTabsContainer\n  implements AfterViewInit, AfterContentInit, OnDestroy\n{\n  @ContentChild(BaoTablistComponent) tablist: BaoTablistComponent;\n\n  private panelIdPrefix = 'bao-panel-';\n  private tabIdPrefix = 'bao-tab-';\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>\n  ) {}\n\n  get tabs(): HTMLCollection {\n    return this.elementRef.nativeElement.querySelector('.bao-tablist').children;\n  }\n\n  get panels(): NodeListOf<Element> {\n    return this.elementRef.nativeElement.querySelectorAll('.bao-panel');\n  }\n\n  ngAfterViewInit(): void {\n    this.setInitialActivePanel();\n    Array.from(this.tabs).forEach((tab: HTMLElement, idx) => {\n      const tabId = `${this.tabIdPrefix}${idx}`;\n      const panelId = `${this.panelIdPrefix}${idx}`;\n      this.renderer.setProperty(tab, 'id', tabId);\n      this.renderer.setProperty(this.panels[idx], 'id', panelId);\n      this.renderer.setAttribute(tab, 'aria-controls', panelId);\n      this.renderer.setAttribute(this.panels[idx], 'aria-labelledby', tabId);\n    });\n  }\n\n  ngAfterContentInit(): void {\n    this.tablist.activeTabChange.subscribe((index: string) =>\n      this.changeActivePanel(index)\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.tablist.activeTabChange.unsubscribe();\n  }\n\n  private setInitialActivePanel(): void {\n    const firstTabIndex = Array.from(this.tabs).findIndex(\n      (tab: HTMLElement) => !tab.attributes['disabled']\n    );\n    this.renderer.removeAttribute(this.panels[firstTabIndex], 'hidden');\n    this.renderer.setAttribute(\n      this.panels[firstTabIndex],\n      'aria-expanded',\n      'true'\n    );\n  }\n\n  private changeActivePanel(newActiveId: string): void {\n    this.panels.forEach((panel: Element) => {\n      if (panel.id === `${this.panelIdPrefix}${newActiveId}`) {\n        this.renderer.removeAttribute(panel, 'hidden');\n        this.renderer.setAttribute(panel, 'aria-expanded', 'true');\n      } else {\n        this.renderer.setAttribute(panel, 'hidden', 'true');\n        this.renderer.setAttribute(panel, 'aria-expanded', 'false');\n      }\n    });\n  }\n}\n","<ng-content></ng-content>\n"]}
|
|
@@ -49,7 +49,7 @@ export class BaoTagComponent {
|
|
|
49
49
|
}
|
|
50
50
|
}
|
|
51
51
|
BaoTagComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTagComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
52
|
-
BaoTagComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BaoTagComponent, selector: "bao-tag, [bao-tag], [baoTag]", inputs: { type: "type", variant: "variant", hiddenText: "hiddenText" }, host: { properties: { "class.bao-tag-neutral-light": "type === \"neutral\" && variant === \"light\"", "class.bao-tag-neutral-strong": "type === \"neutral\" && variant === \"strong\"", "class.bao-tag-info-light": "type === \"info\" && variant === \"light\"", "class.bao-tag-info-strong": "type === \"info\" && variant === \"strong\"", "class.bao-tag-positive-light": "type === \"positive\" && variant === \"light\"", "class.bao-tag-positive-strong": "type === \"positive\" && variant === \"strong\"", "class.bao-tag-alert-light": "type === \"alert\" && variant === \"light\"", "class.bao-tag-alert-strong": "type === \"alert\" && variant === \"strong\"", "class.bao-tag-negative-light": "type === \"negative\" && variant === \"light\"", "class.bao-tag-negative-strong": "type === \"negative\" && variant === \"strong\"" }, classAttribute: "bao-tag" }, ngImport: i0, template: "<ng-content select=\"bao-icon\"></ng-content>\n<ng-content></ng-content>\n", styles: [".bao-tag{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:.125rem;line-height:1.5rem}.bao-tag.has-icon{padding-left:.25rem}.bao-tag.bao-tag-info-light{background-color:#e6f5f9;color:#004b7b}.bao-tag.bao-tag-info-strong{background-color:#0079c4;color:#fff}.bao-tag.bao-tag-positive-light{background-color:#e7f6f0;color:#025d29}.bao-tag.bao-tag-positive-strong{background-color:#0da566;color:#fff}.bao-tag.bao-tag-negative-light{background-color:#ffebe6;color:#851a00}.bao-tag.bao-tag-negative-strong{background-color:#d3310a;color:#fff}.bao-tag.bao-tag-alert-light{background-color:#fefae6;color:#6c4600}.bao-tag.bao-tag-alert-strong{background-color:#ffb833;color:#212529}.bao-tag.bao-tag-neutral-light{background-color:#dee2e6;color:#212529}.bao-tag.bao-tag-neutral-strong{background-color:#212529;color:#fff}.bao-tag>span{font-weight:700;font-size:.875rem;line-height:1.25rem}.bao-tag>.bao-icon{height:1rem;width:1rem;
|
|
52
|
+
BaoTagComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BaoTagComponent, selector: "bao-tag, [bao-tag], [baoTag]", inputs: { type: "type", variant: "variant", hiddenText: "hiddenText" }, host: { properties: { "class.bao-tag-neutral-light": "type === \"neutral\" && variant === \"light\"", "class.bao-tag-neutral-strong": "type === \"neutral\" && variant === \"strong\"", "class.bao-tag-info-light": "type === \"info\" && variant === \"light\"", "class.bao-tag-info-strong": "type === \"info\" && variant === \"strong\"", "class.bao-tag-positive-light": "type === \"positive\" && variant === \"light\"", "class.bao-tag-positive-strong": "type === \"positive\" && variant === \"strong\"", "class.bao-tag-alert-light": "type === \"alert\" && variant === \"light\"", "class.bao-tag-alert-strong": "type === \"alert\" && variant === \"strong\"", "class.bao-tag-negative-light": "type === \"negative\" && variant === \"light\"", "class.bao-tag-negative-strong": "type === \"negative\" && variant === \"strong\"" }, classAttribute: "bao-tag" }, ngImport: i0, template: "<ng-content select=\"bao-icon\"></ng-content>\n<ng-content></ng-content>\n", styles: [".bao-tag{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:.125rem;line-height:1.5rem}.bao-tag.has-icon{padding-left:.25rem}.bao-tag.bao-tag-info-light{background-color:#e6f5f9;color:#004b7b}.bao-tag.bao-tag-info-strong{background-color:#0079c4;color:#fff}.bao-tag.bao-tag-positive-light{background-color:#e7f6f0;color:#025d29}.bao-tag.bao-tag-positive-strong{background-color:#0da566;color:#fff}.bao-tag.bao-tag-negative-light{background-color:#ffebe6;color:#851a00}.bao-tag.bao-tag-negative-strong{background-color:#d3310a;color:#fff}.bao-tag.bao-tag-alert-light{background-color:#fefae6;color:#6c4600}.bao-tag.bao-tag-alert-strong{background-color:#ffb833;color:#212529}.bao-tag.bao-tag-neutral-light{background-color:#dee2e6;color:#212529}.bao-tag.bao-tag-neutral-strong{background-color:#212529;color:#fff}.bao-tag>span{font-weight:700;font-size:.875rem;line-height:1.25rem}.bao-tag>.bao-icon{height:1rem;width:1rem;margin-right:.25rem}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
53
53
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTagComponent, decorators: [{
|
|
54
54
|
type: Component,
|
|
55
55
|
args: [{ selector: 'bao-tag, [bao-tag], [baoTag]', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
@@ -64,7 +64,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
64
64
|
'[class.bao-tag-alert-strong]': 'type === "alert" && variant === "strong"',
|
|
65
65
|
'[class.bao-tag-negative-light]': 'type === "negative" && variant === "light"',
|
|
66
66
|
'[class.bao-tag-negative-strong]': 'type === "negative" && variant === "strong"'
|
|
67
|
-
}, template: "<ng-content select=\"bao-icon\"></ng-content>\n<ng-content></ng-content>\n", styles: [".bao-tag{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:.125rem;line-height:1.5rem}.bao-tag.has-icon{padding-left:.25rem}.bao-tag.bao-tag-info-light{background-color:#e6f5f9;color:#004b7b}.bao-tag.bao-tag-info-strong{background-color:#0079c4;color:#fff}.bao-tag.bao-tag-positive-light{background-color:#e7f6f0;color:#025d29}.bao-tag.bao-tag-positive-strong{background-color:#0da566;color:#fff}.bao-tag.bao-tag-negative-light{background-color:#ffebe6;color:#851a00}.bao-tag.bao-tag-negative-strong{background-color:#d3310a;color:#fff}.bao-tag.bao-tag-alert-light{background-color:#fefae6;color:#6c4600}.bao-tag.bao-tag-alert-strong{background-color:#ffb833;color:#212529}.bao-tag.bao-tag-neutral-light{background-color:#dee2e6;color:#212529}.bao-tag.bao-tag-neutral-strong{background-color:#212529;color:#fff}.bao-tag>span{font-weight:700;font-size:.875rem;line-height:1.25rem}.bao-tag>.bao-icon{height:1rem;width:1rem;
|
|
67
|
+
}, template: "<ng-content select=\"bao-icon\"></ng-content>\n<ng-content></ng-content>\n", styles: [".bao-tag{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:.125rem;line-height:1.5rem}.bao-tag.has-icon{padding-left:.25rem}.bao-tag.bao-tag-info-light{background-color:#e6f5f9;color:#004b7b}.bao-tag.bao-tag-info-strong{background-color:#0079c4;color:#fff}.bao-tag.bao-tag-positive-light{background-color:#e7f6f0;color:#025d29}.bao-tag.bao-tag-positive-strong{background-color:#0da566;color:#fff}.bao-tag.bao-tag-negative-light{background-color:#ffebe6;color:#851a00}.bao-tag.bao-tag-negative-strong{background-color:#d3310a;color:#fff}.bao-tag.bao-tag-alert-light{background-color:#fefae6;color:#6c4600}.bao-tag.bao-tag-alert-strong{background-color:#ffb833;color:#212529}.bao-tag.bao-tag-neutral-light{background-color:#dee2e6;color:#212529}.bao-tag.bao-tag-neutral-strong{background-color:#212529;color:#fff}.bao-tag>span{font-weight:700;font-size:.875rem;line-height:1.25rem}.bao-tag>.bao-icon{height:1rem;width:1rem;margin-right:.25rem}\n"] }]
|
|
68
68
|
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { type: [{
|
|
69
69
|
type: Input
|
|
70
70
|
}], variant: [{
|
|
@@ -72,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
72
72
|
}], hiddenText: [{
|
|
73
73
|
type: Input
|
|
74
74
|
}] } });
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL2xpYi90YWcvdGFnLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL2xpYi90YWcvdGFnLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCxPQUFPLEVBRUwsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFFVCxLQUFLLEVBRUwsaUJBQWlCLEVBQ2xCLE1BQU0sZUFBZSxDQUFDOztBQUV2QixNQUFNLElBQUksR0FBRyxNQUFNLENBQUM7QUFDcEIsTUFBTSxrQkFBa0IsR0FBRyxhQUFhLENBQUM7QUFDekMsTUFBTSx3QkFBd0IsR0FBRyxTQUFTLENBQUM7QUFDM0MsTUFBTSxRQUFRLEdBQUcsVUFBVSxDQUFDO0FBQzVCLE1BQU0sUUFBUSxHQUFHLFVBQVUsQ0FBQztBQTRCNUIsTUFBTSxPQUFPLGVBQWU7SUFpQjFCLFlBQ1UsUUFBbUIsRUFDbkIsVUFBbUM7UUFEbkMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUNuQixlQUFVLEdBQVYsVUFBVSxDQUF5QjtRQWxCN0M7O1dBRUc7UUFDYSxTQUFJLEdBQ2xCLFNBQVMsQ0FBQztRQUVaOztXQUVHO1FBQ2EsWUFBTyxHQUF1QixPQUFPLENBQUM7UUFFdEQ7O1dBRUc7UUFDYSxlQUFVLEdBQUcsV0FBVyxDQUFDO0lBS3RDLENBQUM7SUFFSixJQUFJLGFBQWE7UUFDZixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDO0lBQ3ZDLENBQUM7SUFFTSxlQUFlO1FBQ3BCLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUNyQixJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVPLGFBQWE7UUFDbkIsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMzRCxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FDdkIsZ0JBQWdCLEVBQ2hCLGtCQUFrQixFQUNsQixJQUFJLENBQUMsVUFBVSxDQUNoQixDQUFDO1FBQ0YsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsZ0JBQWdCLEVBQUUsd0JBQXdCLENBQUMsQ0FBQztRQUNuRSxNQUFNLFVBQVUsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUMsSUFBSSxDQUM3RCxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTLEtBQUssSUFBSSxDQUMxQixDQUFDO1FBQ0YsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQ3hCLElBQUksQ0FBQyxhQUFhLEVBQ2xCLGdCQUFnQixFQUNoQixVQUFVLENBQ1gsQ0FBQztJQUNKLENBQUM7SUFFTyxZQUFZO1FBQ2xCLE1BQU0sUUFBUSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUN6RCxJQUFJLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsU0FBUyxLQUFLLFFBQVEsQ0FBQyxFQUFFO1lBQ2hELElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsUUFBUSxDQUFDLENBQUM7U0FDdEQ7SUFDSCxDQUFDOzs0R0F0RFUsZUFBZTtnR0FBZixlQUFlLCs5QkMvQzVCLDRFQUVBOzJGRDZDYSxlQUFlO2tCQTFCM0IsU0FBUzsrQkFDRSw4QkFBOEIsaUJBR3pCLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0sUUFDekM7d0JBQ0osS0FBSyxFQUFFLFNBQVM7d0JBQ2hCLCtCQUErQixFQUM3QiwyQ0FBMkM7d0JBQzdDLGdDQUFnQyxFQUM5Qiw0Q0FBNEM7d0JBQzlDLDRCQUE0QixFQUFFLHdDQUF3Qzt3QkFDdEUsNkJBQTZCLEVBQUUseUNBQXlDO3dCQUN4RSxnQ0FBZ0MsRUFDOUIsNENBQTRDO3dCQUM5QyxpQ0FBaUMsRUFDL0IsNkNBQTZDO3dCQUMvQyw2QkFBNkIsRUFBRSx5Q0FBeUM7d0JBQ3hFLDhCQUE4QixFQUFFLDBDQUEwQzt3QkFDMUUsZ0NBQWdDLEVBQzlCLDRDQUE0Qzt3QkFDOUMsaUNBQWlDLEVBQy9CLDZDQUE2QztxQkFDaEQ7eUhBTWUsSUFBSTtzQkFBbkIsS0FBSztnQkFNVSxPQUFPO3NCQUF0QixLQUFLO2dCQUtVLFVBQVU7c0JBQXpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDIyIFZpbGxlIGRlIE1vbnRyZWFsLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogTGljZW5zZWQgdW5kZXIgdGhlIE1JVCBsaWNlbnNlLlxuICogU2VlIExJQ0VOU0UgZmlsZSBpbiB0aGUgcHJvamVjdCByb290IGZvciBmdWxsIGxpY2Vuc2UgaW5mb3JtYXRpb24uXG4gKi9cbmltcG9ydCB7XG4gIEFmdGVyVmlld0luaXQsXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIElucHV0LFxuICBSZW5kZXJlcjIsXG4gIFZpZXdFbmNhcHN1bGF0aW9uXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5jb25zdCBTUEFOID0gJ3NwYW4nO1xuY29uc3QgU1BBTl9URVhUX1BST1BFUlRZID0gJ3RleHRDb250ZW50JztcbmNvbnN0IFNDUkVFTl9SRUFERVJfQ0xBU1NfTkFNRSA9ICdzci1vbmx5JztcbmNvbnN0IEJBT19JQ09OID0gJ2Jhby1pY29uJztcbmNvbnN0IEhBU19JQ09OID0gJ2hhcy1pY29uJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYmFvLXRhZywgW2Jhby10YWddLCBbYmFvVGFnXScsXG4gIHRlbXBsYXRlVXJsOiAnLi90YWcuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90YWcuY29tcG9uZW50LnNjc3MnXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2Jhby10YWcnLFxuICAgICdbY2xhc3MuYmFvLXRhZy1uZXV0cmFsLWxpZ2h0XSc6XG4gICAgICAndHlwZSA9PT0gXCJuZXV0cmFsXCIgJiYgdmFyaWFudCA9PT0gXCJsaWdodFwiJyxcbiAgICAnW2NsYXNzLmJhby10YWctbmV1dHJhbC1zdHJvbmddJzpcbiAgICAgICd0eXBlID09PSBcIm5ldXRyYWxcIiAmJiB2YXJpYW50ID09PSBcInN0cm9uZ1wiJyxcbiAgICAnW2NsYXNzLmJhby10YWctaW5mby1saWdodF0nOiAndHlwZSA9PT0gXCJpbmZvXCIgJiYgdmFyaWFudCA9PT0gXCJsaWdodFwiJyxcbiAgICAnW2NsYXNzLmJhby10YWctaW5mby1zdHJvbmddJzogJ3R5cGUgPT09IFwiaW5mb1wiICYmIHZhcmlhbnQgPT09IFwic3Ryb25nXCInLFxuICAgICdbY2xhc3MuYmFvLXRhZy1wb3NpdGl2ZS1saWdodF0nOlxuICAgICAgJ3R5cGUgPT09IFwicG9zaXRpdmVcIiAmJiB2YXJpYW50ID09PSBcImxpZ2h0XCInLFxuICAgICdbY2xhc3MuYmFvLXRhZy1wb3NpdGl2ZS1zdHJvbmddJzpcbiAgICAgICd0eXBlID09PSBcInBvc2l0aXZlXCIgJiYgdmFyaWFudCA9PT0gXCJzdHJvbmdcIicsXG4gICAgJ1tjbGFzcy5iYW8tdGFnLWFsZXJ0LWxpZ2h0XSc6ICd0eXBlID09PSBcImFsZXJ0XCIgJiYgdmFyaWFudCA9PT0gXCJsaWdodFwiJyxcbiAgICAnW2NsYXNzLmJhby10YWctYWxlcnQtc3Ryb25nXSc6ICd0eXBlID09PSBcImFsZXJ0XCIgJiYgdmFyaWFudCA9PT0gXCJzdHJvbmdcIicsXG4gICAgJ1tjbGFzcy5iYW8tdGFnLW5lZ2F0aXZlLWxpZ2h0XSc6XG4gICAgICAndHlwZSA9PT0gXCJuZWdhdGl2ZVwiICYmIHZhcmlhbnQgPT09IFwibGlnaHRcIicsXG4gICAgJ1tjbGFzcy5iYW8tdGFnLW5lZ2F0aXZlLXN0cm9uZ10nOlxuICAgICAgJ3R5cGUgPT09IFwibmVnYXRpdmVcIiAmJiB2YXJpYW50ID09PSBcInN0cm9uZ1wiJ1xuICB9XG59KVxuZXhwb3J0IGNsYXNzIEJhb1RhZ0NvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQge1xuICAvKipcbiAgICogVGhlIGNvbG9yIG9mIHRoZSB0YWcuXG4gICAqL1xuICBASW5wdXQoKSBwdWJsaWMgdHlwZTogJ25ldXRyYWwnIHwgJ2luZm8nIHwgJ3Bvc2l0aXZlJyB8ICdhbGVydCcgfCAnbmVnYXRpdmUnID1cbiAgICAnbmV1dHJhbCc7XG5cbiAgLyoqXG4gICAqIFRoZSBzaGFkZSBvZiB0aGUgdGFncyBjb2xvci5cbiAgICovXG4gIEBJbnB1dCgpIHB1YmxpYyB2YXJpYW50OiAnbGlnaHQnIHwgJ3N0cm9uZycgPSAnbGlnaHQnO1xuXG4gIC8qKlxuICAgKiBUaGUgaGlkZGVuIHRleHQgZm9yIHNjcmVlbiByZWFkZXJzLlxuICAgKi9cbiAgQElucHV0KCkgcHVibGljIGhpZGRlblRleHQgPSAnw4l0aXF1ZXR0ZSc7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyLFxuICAgIHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD5cbiAgKSB7fVxuXG4gIGdldCBuYXRpdmVFbGVtZW50KCk6IEhUTUxFbGVtZW50IHtcbiAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQ7XG4gIH1cblxuICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCkge1xuICAgIHRoaXMuYWRkSGlkZGVuVGV4dCgpO1xuICAgIHRoaXMuYWRkSWNvbkNsYXNzKCk7XG4gIH1cblxuICBwcml2YXRlIGFkZEhpZGRlblRleHQoKSB7XG4gICAgY29uc3Qgc2NyZWVuUmVhZGVyU3BhbiA9IHRoaXMucmVuZGVyZXIuY3JlYXRlRWxlbWVudChTUEFOKTtcbiAgICB0aGlzLnJlbmRlcmVyLnNldFByb3BlcnR5KFxuICAgICAgc2NyZWVuUmVhZGVyU3BhbixcbiAgICAgIFNQQU5fVEVYVF9QUk9QRVJUWSxcbiAgICAgIHRoaXMuaGlkZGVuVGV4dFxuICAgICk7XG4gICAgdGhpcy5yZW5kZXJlci5hZGRDbGFzcyhzY3JlZW5SZWFkZXJTcGFuLCBTQ1JFRU5fUkVBREVSX0NMQVNTX05BTUUpO1xuICAgIGNvbnN0IGxhYmVsQ2hpbGQgPSBBcnJheS5mcm9tKHRoaXMubmF0aXZlRWxlbWVudC5jaGlsZHJlbikuZmluZChcbiAgICAgIGMgPT4gYy5sb2NhbE5hbWUgPT09IFNQQU5cbiAgICApO1xuICAgIHRoaXMucmVuZGVyZXIuaW5zZXJ0QmVmb3JlKFxuICAgICAgdGhpcy5uYXRpdmVFbGVtZW50LFxuICAgICAgc2NyZWVuUmVhZGVyU3BhbixcbiAgICAgIGxhYmVsQ2hpbGRcbiAgICApO1xuICB9XG5cbiAgcHJpdmF0ZSBhZGRJY29uQ2xhc3MoKSB7XG4gICAgY29uc3QgY2hpbGRyZW4gPSBBcnJheS5mcm9tKHRoaXMubmF0aXZlRWxlbWVudC5jaGlsZHJlbik7XG4gICAgaWYgKGNoaWxkcmVuLnNvbWUoYyA9PiBjLmxvY2FsTmFtZSA9PT0gQkFPX0lDT04pKSB7XG4gICAgICB0aGlzLnJlbmRlcmVyLmFkZENsYXNzKHRoaXMubmF0aXZlRWxlbWVudCwgSEFTX0lDT04pO1xuICAgIH1cbiAgfVxufVxuIiwiPG5nLWNvbnRlbnQgc2VsZWN0PVwiYmFvLWljb25cIj48L25nLWNvbnRlbnQ+XG48bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4iXX0=
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -17,4 +17,7 @@ export * from './lib/checkbox/index';
|
|
|
17
17
|
export * from './lib/radio/index';
|
|
18
18
|
export * from './lib/common-components/index';
|
|
19
19
|
export * from './lib/summary/index';
|
|
20
|
-
|
|
20
|
+
export * from './lib/shared';
|
|
21
|
+
export * from './lib/avatar';
|
|
22
|
+
export * from './lib/tabs';
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUVILGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFlBQVksQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjIgVmlsbGUgZGUgTW9udHJlYWwuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UuXG4gKiBTZWUgTElDRU5TRSBmaWxlIGluIHRoZSBwcm9qZWN0IHJvb3QgZm9yIGZ1bGwgbGljZW5zZSBpbmZvcm1hdGlvbi5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9iYW8ubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2J1dHRvbi9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pY29uL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FsZXJ0L2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2JyZWFkY3J1bWIvaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2FyZC9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9iYWRnZS9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWcvaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaGVhZGVyLWluZm8vaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGlzdC9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGVja2JveC9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yYWRpby9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21tb24tY29tcG9uZW50cy9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdW1tYXJ5L2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NoYXJlZCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdmF0YXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFicyc7XG4iXX0=
|