@villedemontreal/angular-ui 2.2.1 → 3.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/alert/alert.component.mjs +24 -26
- package/esm2020/lib/alert/module.mjs +5 -5
- 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/badge/badge.component.mjs +3 -3
- package/esm2020/lib/badge/module.mjs +5 -5
- package/esm2020/lib/bao.module.mjs +24 -14
- package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +8 -8
- package/esm2020/lib/breadcrumb/module.mjs +5 -5
- package/esm2020/lib/button/button.component.mjs +7 -7
- package/esm2020/lib/button/module.mjs +5 -5
- package/esm2020/lib/card/card.component.mjs +15 -15
- package/esm2020/lib/card/module.mjs +5 -5
- package/esm2020/lib/checkbox/checkbox-group.component.mjs +8 -9
- package/esm2020/lib/checkbox/checkbox.component.mjs +45 -46
- package/esm2020/lib/checkbox/module.mjs +5 -5
- package/esm2020/lib/common-components/error-text/errorText.component.mjs +3 -3
- package/esm2020/lib/common-components/guiding-text/guidingText.component.mjs +3 -3
- package/esm2020/lib/common-components/label-text/labelText.component.mjs +3 -3
- package/esm2020/lib/common-components/module.mjs +5 -5
- package/esm2020/lib/common-components/title-text/titleText.component.mjs +3 -3
- package/esm2020/lib/header-info/header-info.component.mjs +18 -18
- package/esm2020/lib/header-info/module.mjs +5 -5
- package/esm2020/lib/icon/bao-icon-registry.mjs +3 -3
- package/esm2020/lib/icon/icon.component.mjs +30 -34
- package/esm2020/lib/icon/icons-dictionary.mjs +3 -2
- package/esm2020/lib/icon/module.mjs +5 -5
- package/esm2020/lib/list/list.component.mjs +15 -15
- package/esm2020/lib/list/module.mjs +5 -5
- package/esm2020/lib/modal/index.mjs +12 -0
- package/esm2020/lib/modal/modal-animations.mjs +29 -0
- package/esm2020/lib/modal/modal-config.mjs +65 -0
- package/esm2020/lib/modal/modal-container.mjs +254 -0
- package/esm2020/lib/modal/modal-directives.mjs +84 -0
- package/esm2020/lib/modal/modal-ref.mjs +195 -0
- package/esm2020/lib/modal/modal.mjs +293 -0
- package/esm2020/lib/modal/module.mjs +44 -0
- package/esm2020/lib/radio/module.mjs +10 -12
- package/esm2020/lib/radio/radio-group.component.mjs +43 -44
- package/esm2020/lib/radio/radio.component.mjs +45 -46
- package/esm2020/lib/summary/list-summary.component.mjs +9 -16
- package/esm2020/lib/summary/module.mjs +5 -5
- package/esm2020/lib/summary/summary.component.mjs +10 -11
- 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/module.mjs +5 -5
- package/esm2020/lib/tag/tag.component.mjs +5 -5
- package/esm2020/public-api.mjs +4 -1
- package/fesm2015/villedemontreal-angular-ui.mjs +1778 -384
- package/fesm2015/villedemontreal-angular-ui.mjs.map +1 -1
- package/fesm2020/villedemontreal-angular-ui.mjs +1770 -384
- package/fesm2020/villedemontreal-angular-ui.mjs.map +1 -1
- package/{villedemontreal-angular-ui.d.ts → index.d.ts} +0 -0
- package/lib/alert/alert.component.d.ts +6 -7
- 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/badge/badge.component.d.ts +1 -1
- package/lib/bao.module.d.ts +4 -1
- package/lib/breadcrumb/breadcrumb.component.d.ts +2 -2
- package/lib/button/button.component.d.ts +2 -2
- package/lib/card/card.component.d.ts +5 -5
- package/lib/checkbox/checkbox-group.component.d.ts +3 -3
- package/lib/checkbox/checkbox.component.d.ts +28 -28
- package/lib/common-components/error-text/errorText.component.d.ts +1 -1
- package/lib/common-components/guiding-text/guidingText.component.d.ts +1 -1
- package/lib/common-components/label-text/labelText.component.d.ts +1 -1
- package/lib/common-components/title-text/titleText.component.d.ts +1 -1
- package/lib/header-info/header-info.component.d.ts +6 -6
- package/lib/icon/icon.component.d.ts +11 -11
- package/lib/list/list.component.d.ts +5 -5
- package/lib/modal/index.d.ts +6 -0
- package/lib/modal/modal-animations.d.ts +8 -0
- package/lib/modal/modal-config.d.ts +105 -0
- package/lib/modal/modal-container.d.ts +106 -0
- package/lib/modal/modal-directives.d.ts +25 -0
- package/lib/modal/modal-ref.d.ts +91 -0
- package/lib/modal/modal.d.ts +91 -0
- package/lib/modal/module.d.ts +12 -0
- package/lib/radio/radio-group.component.d.ts +19 -19
- package/lib/radio/radio.component.d.ts +28 -28
- package/lib/summary/list-summary.component.d.ts +2 -2
- package/lib/summary/summary.component.d.ts +7 -7
- 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 +2 -2
- package/package.json +7 -7
- package/public-api.d.ts +3 -0
|
@@ -17,16 +17,16 @@ const SUMMARY_DIRECTIVES = [
|
|
|
17
17
|
];
|
|
18
18
|
export class BaoSummaryModule {
|
|
19
19
|
}
|
|
20
|
-
BaoSummaryModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
21
|
-
BaoSummaryModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "
|
|
20
|
+
BaoSummaryModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoSummaryModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
21
|
+
BaoSummaryModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.1", ngImport: i0, type: BaoSummaryModule, declarations: [BaoSummaryComponent,
|
|
22
22
|
BaoSummaryDescription,
|
|
23
23
|
BaoListSummary,
|
|
24
24
|
BaoListSummaryItem], imports: [CommonModule, BaoCommonComponentsModule], exports: [BaoSummaryComponent,
|
|
25
25
|
BaoSummaryDescription,
|
|
26
26
|
BaoListSummary,
|
|
27
27
|
BaoListSummaryItem] });
|
|
28
|
-
BaoSummaryModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
29
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
28
|
+
BaoSummaryModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoSummaryModule, imports: [CommonModule, BaoCommonComponentsModule] });
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoSummaryModule, decorators: [{
|
|
30
30
|
type: NgModule,
|
|
31
31
|
args: [{
|
|
32
32
|
imports: [CommonModule, BaoCommonComponentsModule],
|
|
@@ -34,4 +34,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
34
34
|
exports: SUMMARY_DIRECTIVES
|
|
35
35
|
}]
|
|
36
36
|
}] });
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11aS9zcmMvbGliL3N1bW1hcnkvbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNqRSxPQUFPLEVBQ0wsbUJBQW1CLEVBQ25CLHFCQUFxQixFQUN0QixNQUFNLHFCQUFxQixDQUFDO0FBQzdCLE9BQU8sRUFBRSxjQUFjLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFFOUUsTUFBTSxrQkFBa0IsR0FBRztJQUN6QixtQkFBbUI7SUFDbkIscUJBQXFCO0lBQ3JCLGNBQWM7SUFDZCxrQkFBa0I7Q0FDbkIsQ0FBQztBQU9GLE1BQU0sT0FBTyxnQkFBZ0I7OzZHQUFoQixnQkFBZ0I7OEdBQWhCLGdCQUFnQixpQkFYM0IsbUJBQW1CO1FBQ25CLHFCQUFxQjtRQUNyQixjQUFjO1FBQ2Qsa0JBQWtCLGFBSVIsWUFBWSxFQUFFLHlCQUF5QixhQVBqRCxtQkFBbUI7UUFDbkIscUJBQXFCO1FBQ3JCLGNBQWM7UUFDZCxrQkFBa0I7OEdBUVAsZ0JBQWdCLFlBSmpCLFlBQVksRUFBRSx5QkFBeUI7MkZBSXRDLGdCQUFnQjtrQkFMNUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUseUJBQXlCLENBQUM7b0JBQ2xELFlBQVksRUFBRSxrQkFBa0I7b0JBQ2hDLE9BQU8sRUFBRSxrQkFBa0I7aUJBQzVCIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMiBWaWxsZSBkZSBNb250cmVhbC4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZS5cbiAqIFNlZSBMSUNFTlNFIGZpbGUgaW4gdGhlIHByb2plY3Qgcm9vdCBmb3IgZnVsbCBsaWNlbnNlIGluZm9ybWF0aW9uLlxuICovXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhb0NvbW1vbkNvbXBvbmVudHNNb2R1bGUgfSBmcm9tICcuLi9jb21tb24tY29tcG9uZW50cyc7XG5pbXBvcnQge1xuICBCYW9TdW1tYXJ5Q29tcG9uZW50LFxuICBCYW9TdW1tYXJ5RGVzY3JpcHRpb25cbn0gZnJvbSAnLi9zdW1tYXJ5LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCYW9MaXN0U3VtbWFyeSwgQmFvTGlzdFN1bW1hcnlJdGVtIH0gZnJvbSAnLi9saXN0LXN1bW1hcnkuY29tcG9uZW50JztcblxuY29uc3QgU1VNTUFSWV9ESVJFQ1RJVkVTID0gW1xuICBCYW9TdW1tYXJ5Q29tcG9uZW50LFxuICBCYW9TdW1tYXJ5RGVzY3JpcHRpb24sXG4gIEJhb0xpc3RTdW1tYXJ5LFxuICBCYW9MaXN0U3VtbWFyeUl0ZW1cbl07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEJhb0NvbW1vbkNvbXBvbmVudHNNb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFNVTU1BUllfRElSRUNUSVZFUyxcbiAgZXhwb3J0czogU1VNTUFSWV9ESVJFQ1RJVkVTXG59KVxuZXhwb3J0IGNsYXNzIEJhb1N1bW1hcnlNb2R1bGUge31cbiJdfQ==
|
|
@@ -19,10 +19,9 @@ export class BaoSummaryComponent {
|
|
|
19
19
|
* Initialize the ID for summary
|
|
20
20
|
*/
|
|
21
21
|
this._uniqueId = `bao-summary-${++summaryUniqueId}`;
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
this.id = this._uniqueId;
|
|
22
|
+
if (!this.id) {
|
|
23
|
+
this.id = this._uniqueId;
|
|
24
|
+
}
|
|
26
25
|
}
|
|
27
26
|
get nativeElement() {
|
|
28
27
|
return this.elementRef.nativeElement;
|
|
@@ -67,9 +66,9 @@ export class BaoSummaryComponent {
|
|
|
67
66
|
return element;
|
|
68
67
|
}
|
|
69
68
|
}
|
|
70
|
-
BaoSummaryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
71
|
-
BaoSummaryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
72
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
69
|
+
BaoSummaryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoSummaryComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
70
|
+
BaoSummaryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.1", type: BaoSummaryComponent, selector: "bao-summary, [bao-summary], [baoSummary]", inputs: { displayMode: "displayMode", id: "id" }, host: { properties: { "class.bao-displaymode-compact": "displayMode === \"compact\"" }, classAttribute: "bao-summary" }, ngImport: i0, template: "<ng-content select=\"bao-label\"></ng-content>\n<ng-content select=\"bao-guiding-text, [bao-guiding-text]\"></ng-content>\n\n<div class=\"bao-summary-content\">\n <div class=\"bao-summary-text\">\n <ng-content select=\"bao-title-text, [bao-title-text]\"></ng-content>\n <ng-content select=\"bao-summary-description\"></ng-content>\n <ng-content\n select=\"bao-list-summary, [bao-list-summary], [baoListSummary]\"\n ></ng-content>\n </div>\n <ng-content select=\"button[bao-button]\"></ng-content>\n</div>\n<ng-content select=\"bao-error, [bao-error]\"></ng-content>\n", styles: [".bao-container{padding-right:16px;padding-left:16px;margin-right:auto;margin-left:auto;width:100%}@media (min-width: 576px){.bao-container{max-width:576px}}@media (min-width: 768px){.bao-container{max-width:768px}}@media (min-width: 992px){.bao-container{max-width:992px}}@media (min-width: 1200px){.bao-container{max-width:1200px}}.bao-row{display:flex;flex-wrap:wrap;margin-right:-16px;margin-left:-16px}.bao-col-12,.bao-col-lg-7{position:relative;width:100%;padding-right:1rem;padding-left:1rem}@media (min-width: 992px){.bao-col-lg-7{flex:0 0 58.33333%;max-width:58.33333%}}.bao-summary .bao-label,.bao-summary .bao-guiding-text{margin:0 0 .5rem}.bao-summary .bao-summary-content{display:flex;flex-direction:row;align-items:flex-start;justify-content:space-between;border:.063rem solid #ced4da;box-sizing:border-box;border-radius:.25rem;padding:.5rem .5rem 1rem 1rem}.bao-summary .bao-summary-content .bao-summary-text{display:flex;flex-direction:column;padding:.5rem .5rem 0 0}.bao-summary .bao-summary-content .bao-summary-text .bao-summary-description{font-weight:400;font-size:1rem;line-height:1.5rem}.bao-summary .bao-summary-content .bao-summary-text .bao-summary-description p{margin-bottom:0}.bao-summary .bao-summary-content button.buttonText{display:none}.bao-summary .bao-summary-content button.buttonIcon{margin-left:.5rem}@media (min-width: 576px){.bao-summary:not(.bao-displaymode-compact) .bao-summary-content{padding:1.5rem 1.5rem 2rem 2rem}.bao-summary:not(.bao-displaymode-compact) .bao-summary-content button.buttonText{display:block;margin-left:.5rem}.bao-summary:not(.bao-displaymode-compact) .bao-summary-content button.buttonIcon{display:none}}.bao-summary .bao-error{margin-top:.5rem}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
71
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoSummaryComponent, decorators: [{
|
|
73
72
|
type: Component,
|
|
74
73
|
args: [{ selector: 'bao-summary, [bao-summary], [baoSummary]', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
75
74
|
class: 'bao-summary',
|
|
@@ -82,13 +81,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
82
81
|
}] } });
|
|
83
82
|
export class BaoSummaryDescription {
|
|
84
83
|
}
|
|
85
|
-
BaoSummaryDescription.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
86
|
-
BaoSummaryDescription.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
|
87
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
84
|
+
BaoSummaryDescription.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoSummaryDescription, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
85
|
+
BaoSummaryDescription.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.1", type: BaoSummaryDescription, selector: "bao-summary-description, [bao-summary-description], [baoSummaryDescription]", host: { classAttribute: "bao-summary-description" }, ngImport: i0 });
|
|
86
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoSummaryDescription, decorators: [{
|
|
88
87
|
type: Directive,
|
|
89
88
|
args: [{
|
|
90
89
|
selector: 'bao-summary-description, [bao-summary-description], [baoSummaryDescription]',
|
|
91
90
|
host: { class: 'bao-summary-description' }
|
|
92
91
|
}]
|
|
93
92
|
}] });
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"summary.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/summary/summary.component.ts","../../../../../projects/angular-ui/src/lib/summary/summary.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 */\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Directive,\n  ElementRef,\n  Input,\n  ViewEncapsulation,\n  AfterViewInit,\n  OnInit\n} from '@angular/core';\nimport { EDisplayMode } from '../shared';\n\nlet summaryUniqueId = 0;\n@Component({\n  selector: 'bao-summary, [bao-summary], [baoSummary]',\n  templateUrl: './summary.component.html',\n  styleUrls: ['./summary.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'bao-summary',\n    '[class.bao-displaymode-compact]': 'displayMode === \"compact\"'\n  }\n})\nexport class BaoSummaryComponent implements OnInit, AfterViewInit {\n  /**\n   * Set display mode\n   * RESPONSIVE (viewport width <=> is 576px)\n   * COMPACT (viewport width < 576px)\n   */\n  @Input() public displayMode = EDisplayMode.RESPONSIVE;\n\n  /**\n   * Set value of unique ID for bao-label\n   */\n  @Input() public id: string;\n\n  /**\n   * The aria-describebdy-error id for web accessibility\n   * only when error section appears\n   */\n  public ariaDescribedbyError?: string;\n\n  /**\n   * The aria-describebdy-text id for web accessibility\n   * only when we have de guidance text\n   */\n  public ariaDescribedbyGuidingText?: string;\n\n  /**\n   * The aria-labelledby id for web accessibility\n   */\n  public ariaLabelledby?: string;\n\n  /**\n   * Initialize the ID for summary\n   */\n  private _uniqueId = `bao-summary-${++summaryUniqueId}`;\n\n  private attribues: string;\n\n  constructor(private elementRef: ElementRef<HTMLElement>) {\n    if (!this.id) {\n      this.id = this._uniqueId;\n    }\n  }\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  public ngOnInit() {\n    this.ariaDescribedbyError = `${this.id}-ariadescribedby-error`;\n    this.ariaDescribedbyGuidingText = `${this.id}-ariadescribedby-guiding-text`;\n\n    this.ariaLabelledby = `${this.id}-arialabelledby`;\n  }\n\n  public ngAfterViewInit() {\n    this.setAriaDescribedByToDescription();\n  }\n\n  public setAriaDescribedByToDescription() {\n    const baoLabel = this.elementNode('BAO-LABEL');\n    const baoError = this.elementNode('BAO-ERROR');\n    const baoGuidingText = this.elementNode('BAO-GUIDING-TEXT');\n    const summaryDiv = this.elementNode('DIV');\n\n    if (summaryDiv) {\n      const summaryText = this.elementNode('DIV', summaryDiv);\n\n      if (summaryText && baoLabel) {\n        (baoLabel as HTMLElement).setAttribute('id', this.ariaLabelledby);\n        (summaryText as HTMLElement).setAttribute(\n          'aria-labelledby',\n          this.ariaLabelledby\n        );\n      }\n\n      if (summaryText && baoGuidingText) {\n        (baoGuidingText as HTMLElement).setAttribute(\n          'id',\n          this.ariaDescribedbyGuidingText\n        );\n        (summaryText as HTMLElement).setAttribute(\n          'aria-describedby',\n          this.ariaDescribedbyGuidingText\n        );\n      }\n\n      if (summaryText && baoError) {\n        (baoError as HTMLElement).setAttribute('id', this.ariaDescribedbyError);\n        this.attribues = baoGuidingText\n          ? `${this.ariaDescribedbyError}, ${this.ariaDescribedbyGuidingText}`\n          : this.ariaDescribedbyError;\n        (summaryText as HTMLElement).setAttribute(\n          'aria-describedby',\n          this.attribues\n        );\n      }\n    }\n  }\n\n  private elementNode(name: string, nativeElt?: Node): Node {\n    const childNodes = nativeElt\n      ? Array.from(nativeElt.childNodes)\n      : Array.from(this.nativeElement.childNodes);\n    const element = childNodes.find(x => x.nodeName === name);\n\n    return element;\n  }\n}\n\n@Directive({\n  selector:\n    'bao-summary-description, [bao-summary-description], [baoSummaryDescription]',\n  host: { class: 'bao-summary-description' }\n})\nexport class BaoSummaryDescription {}\n","<ng-content select=\"bao-label\"></ng-content>\n<ng-content select=\"bao-guiding-text, [bao-guiding-text]\"></ng-content>\n\n<div class=\"bao-summary-content\">\n  <div class=\"bao-summary-text\">\n    <ng-content select=\"bao-title-text, [bao-title-text]\"></ng-content>\n    <ng-content select=\"bao-summary-description\"></ng-content>\n    <ng-content\n      select=\"bao-list-summary, [bao-list-summary], [baoListSummary]\"\n    ></ng-content>\n  </div>\n  <ng-content select=\"button[bao-button]\"></ng-content>\n</div>\n<ng-content select=\"bao-error, [bao-error]\"></ng-content>\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
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
|
+
export * from './module';
|
|
7
|
+
export * from './tabs.component';
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXVpL3NyYy9saWIvdGFicy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBQ0gsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjIgVmlsbGUgZGUgTW9udHJlYWwuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UuXG4gKiBTZWUgTElDRU5TRSBmaWxlIGluIHRoZSBwcm9qZWN0IHJvb3QgZm9yIGZ1bGwgbGljZW5zZSBpbmZvcm1hdGlvbi5cbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJzLmNvbXBvbmVudCc7XG4iXX0=
|
|
@@ -0,0 +1,35 @@
|
|
|
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 { CommonModule } from '@angular/common';
|
|
7
|
+
import { NgModule } from '@angular/core';
|
|
8
|
+
import { BaoTablistComponent, BaoTabHeader, BaoTabPanel, BaoTabsContainer } from './tabs.component';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
const TABS_DIRECTIVES = [
|
|
11
|
+
BaoTabsContainer,
|
|
12
|
+
BaoTablistComponent,
|
|
13
|
+
BaoTabHeader,
|
|
14
|
+
BaoTabPanel
|
|
15
|
+
];
|
|
16
|
+
export class BaoTabsModule {
|
|
17
|
+
}
|
|
18
|
+
BaoTabsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoTabsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
19
|
+
BaoTabsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.1", ngImport: i0, type: BaoTabsModule, declarations: [BaoTabsContainer,
|
|
20
|
+
BaoTablistComponent,
|
|
21
|
+
BaoTabHeader,
|
|
22
|
+
BaoTabPanel], imports: [CommonModule], exports: [BaoTabsContainer,
|
|
23
|
+
BaoTablistComponent,
|
|
24
|
+
BaoTabHeader,
|
|
25
|
+
BaoTabPanel] });
|
|
26
|
+
BaoTabsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoTabsModule, imports: [CommonModule] });
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoTabsModule, decorators: [{
|
|
28
|
+
type: NgModule,
|
|
29
|
+
args: [{
|
|
30
|
+
imports: [CommonModule],
|
|
31
|
+
declarations: [TABS_DIRECTIVES],
|
|
32
|
+
exports: [TABS_DIRECTIVES]
|
|
33
|
+
}]
|
|
34
|
+
}] });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11aS9zcmMvbGliL3RhYnMvbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQ0wsbUJBQW1CLEVBQ25CLFlBQVksRUFDWixXQUFXLEVBQ1gsZ0JBQWdCLEVBQ2pCLE1BQU0sa0JBQWtCLENBQUM7O0FBRTFCLE1BQU0sZUFBZSxHQUFHO0lBQ3RCLGdCQUFnQjtJQUNoQixtQkFBbUI7SUFDbkIsWUFBWTtJQUNaLFdBQVc7Q0FDWixDQUFDO0FBT0YsTUFBTSxPQUFPLGFBQWE7OzBHQUFiLGFBQWE7MkdBQWIsYUFBYSxpQkFYeEIsZ0JBQWdCO1FBQ2hCLG1CQUFtQjtRQUNuQixZQUFZO1FBQ1osV0FBVyxhQUlELFlBQVksYUFQdEIsZ0JBQWdCO1FBQ2hCLG1CQUFtQjtRQUNuQixZQUFZO1FBQ1osV0FBVzsyR0FRQSxhQUFhLFlBSmQsWUFBWTsyRkFJWCxhQUFhO2tCQUx6QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsWUFBWSxFQUFFLENBQUMsZUFBZSxDQUFDO29CQUMvQixPQUFPLEVBQUUsQ0FBQyxlQUFlLENBQUM7aUJBQzNCIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMiBWaWxsZSBkZSBNb250cmVhbC4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZS5cbiAqIFNlZSBMSUNFTlNFIGZpbGUgaW4gdGhlIHByb2plY3Qgcm9vdCBmb3IgZnVsbCBsaWNlbnNlIGluZm9ybWF0aW9uLlxuICovXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIEJhb1RhYmxpc3RDb21wb25lbnQsXG4gIEJhb1RhYkhlYWRlcixcbiAgQmFvVGFiUGFuZWwsXG4gIEJhb1RhYnNDb250YWluZXJcbn0gZnJvbSAnLi90YWJzLmNvbXBvbmVudCc7XG5cbmNvbnN0IFRBQlNfRElSRUNUSVZFUyA9IFtcbiAgQmFvVGFic0NvbnRhaW5lcixcbiAgQmFvVGFibGlzdENvbXBvbmVudCxcbiAgQmFvVGFiSGVhZGVyLFxuICBCYW9UYWJQYW5lbFxuXTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogW1RBQlNfRElSRUNUSVZFU10sXG4gIGV4cG9ydHM6IFtUQUJTX0RJUkVDVElWRVNdXG59KVxuZXhwb3J0IGNsYXNzIEJhb1RhYnNNb2R1bGUge31cbiJdfQ==
|
|
@@ -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: "14.2.1", ngImport: i0, type: BaoTabHeader, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
35
|
+
BaoTabHeader.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.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: "14.2.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: "14.2.1", ngImport: i0, type: BaoTabPanel, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
67
|
+
BaoTabPanel.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.1", type: BaoTabPanel, selector: "bao-panel, [bao-panel]", host: { classAttribute: "bao-panel" }, exportAs: ["baoPanel"], ngImport: i0 });
|
|
68
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.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: "14.2.1", ngImport: i0, type: BaoTablistComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
201
|
+
BaoTablistComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.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: "14.2.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: "14.2.1", ngImport: i0, type: BaoTabsContainer, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
281
|
+
BaoTabsContainer.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.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: "14.2.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"]}
|
|
@@ -10,10 +10,10 @@ import * as i0 from "@angular/core";
|
|
|
10
10
|
const TAG_DIRECTIVES = [BaoTagComponent];
|
|
11
11
|
export class BaoTagModule {
|
|
12
12
|
}
|
|
13
|
-
BaoTagModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
14
|
-
BaoTagModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "
|
|
15
|
-
BaoTagModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
16
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
13
|
+
BaoTagModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoTagModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
14
|
+
BaoTagModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.1", ngImport: i0, type: BaoTagModule, declarations: [BaoTagComponent], imports: [CommonModule], exports: [BaoTagComponent] });
|
|
15
|
+
BaoTagModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoTagModule, imports: [CommonModule] });
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoTagModule, decorators: [{
|
|
17
17
|
type: NgModule,
|
|
18
18
|
args: [{
|
|
19
19
|
imports: [CommonModule],
|
|
@@ -21,4 +21,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
21
21
|
exports: [TAG_DIRECTIVES]
|
|
22
22
|
}]
|
|
23
23
|
}] });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11aS9zcmMvbGliL3RhZy9tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFFbEQsTUFBTSxjQUFjLEdBQUcsQ0FBQyxlQUFlLENBQUMsQ0FBQztBQU96QyxNQUFNLE9BQU8sWUFBWTs7eUdBQVosWUFBWTswR0FBWixZQUFZLGlCQVBELGVBQWUsYUFHM0IsWUFBWSxhQUhBLGVBQWU7MEdBTzFCLFlBQVksWUFKYixZQUFZOzJGQUlYLFlBQVk7a0JBTHhCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixZQUFZLEVBQUUsQ0FBQyxjQUFjLENBQUM7b0JBQzlCLE9BQU8sRUFBRSxDQUFDLGNBQWMsQ0FBQztpQkFDMUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDIyIFZpbGxlIGRlIE1vbnRyZWFsLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogTGljZW5zZWQgdW5kZXIgdGhlIE1JVCBsaWNlbnNlLlxuICogU2VlIExJQ0VOU0UgZmlsZSBpbiB0aGUgcHJvamVjdCByb290IGZvciBmdWxsIGxpY2Vuc2UgaW5mb3JtYXRpb24uXG4gKi9cbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmFvVGFnQ29tcG9uZW50IH0gZnJvbSAnLi90YWcuY29tcG9uZW50JztcblxuY29uc3QgVEFHX0RJUkVDVElWRVMgPSBbQmFvVGFnQ29tcG9uZW50XTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogW1RBR19ESVJFQ1RJVkVTXSxcbiAgZXhwb3J0czogW1RBR19ESVJFQ1RJVkVTXVxufSlcbmV4cG9ydCBjbGFzcyBCYW9UYWdNb2R1bGUge31cbiJdfQ==
|