@villedemontreal/angular-ui 15.3.3 → 16.0.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.
Files changed (122) hide show
  1. package/{esm2020 → esm2022}/lib/alert/alert.component.mjs +17 -17
  2. package/{esm2020 → esm2022}/lib/alert/index.mjs +2 -2
  3. package/{esm2020 → esm2022}/lib/alert/module.mjs +14 -14
  4. package/{esm2020 → esm2022}/lib/avatar/avatar.component.mjs +8 -8
  5. package/{esm2020 → esm2022}/lib/avatar/index.mjs +2 -2
  6. package/{esm2020 → esm2022}/lib/avatar/module.mjs +6 -6
  7. package/{esm2020 → esm2022}/lib/badge/badge.component.mjs +5 -5
  8. package/{esm2020 → esm2022}/lib/badge/index.mjs +2 -2
  9. package/{esm2020 → esm2022}/lib/badge/module.mjs +6 -6
  10. package/{esm2020 → esm2022}/lib/bao.module.mjs +58 -58
  11. package/{esm2020 → esm2022}/lib/breadcrumb/breadcrumb.component.mjs +5 -5
  12. package/{esm2020 → esm2022}/lib/breadcrumb/index.mjs +2 -2
  13. package/{esm2020 → esm2022}/lib/breadcrumb/module.mjs +6 -6
  14. package/esm2022/lib/button/button.component.mjs +100 -0
  15. package/{esm2020 → esm2022}/lib/button/index.mjs +2 -2
  16. package/{esm2020 → esm2022}/lib/button/module.mjs +6 -6
  17. package/{esm2020 → esm2022}/lib/card/card.component.mjs +17 -17
  18. package/{esm2020 → esm2022}/lib/card/index.mjs +2 -2
  19. package/{esm2020 → esm2022}/lib/card/module.mjs +14 -14
  20. package/{esm2020 → esm2022}/lib/checkbox/checkbox-group.component.mjs +5 -5
  21. package/esm2022/lib/checkbox/checkbox.component.mjs +304 -0
  22. package/{esm2020 → esm2022}/lib/checkbox/index.mjs +2 -2
  23. package/{esm2020 → esm2022}/lib/checkbox/module.mjs +10 -10
  24. package/{esm2020 → esm2022}/lib/common-components/error-text/errorText.component.mjs +5 -5
  25. package/{esm2020 → esm2022}/lib/common-components/guiding-text/guidingText.component.mjs +5 -5
  26. package/{esm2020 → esm2022}/lib/common-components/index.mjs +2 -2
  27. package/{esm2020 → esm2022}/lib/common-components/label-text/labelText.component.mjs +5 -5
  28. package/{esm2020 → esm2022}/lib/common-components/module.mjs +12 -12
  29. package/{esm2020 → esm2022}/lib/common-components/title-text/titleText.component.mjs +5 -5
  30. package/{esm2020 → esm2022}/lib/core/breakpoints.mjs +2 -2
  31. package/{esm2020 → esm2022}/lib/core/colors.mjs +1 -1
  32. package/{esm2020 → esm2022}/lib/core/index.mjs +2 -2
  33. package/{esm2020 → esm2022}/lib/dropdown-menu/dropdown-menu.component.mjs +23 -23
  34. package/{esm2020 → esm2022}/lib/dropdown-menu/index.mjs +2 -2
  35. package/{esm2020 → esm2022}/lib/dropdown-menu/module.mjs +18 -18
  36. package/esm2022/lib/file/file-input.component.mjs +319 -0
  37. package/{esm2020 → esm2022}/lib/file/file-intl.mjs +8 -8
  38. package/{esm2020 → esm2022}/lib/file/file-preview.component.mjs +5 -5
  39. package/{esm2020 → esm2022}/lib/file/index.mjs +2 -2
  40. package/{esm2020 → esm2022}/lib/file/module.mjs +20 -20
  41. package/{esm2020 → esm2022}/lib/header-info/header-info.component.mjs +20 -20
  42. package/{esm2020 → esm2022}/lib/header-info/index.mjs +2 -2
  43. package/{esm2020 → esm2022}/lib/header-info/module.mjs +16 -16
  44. package/{esm2020 → esm2022}/lib/hyperlink/hyperlink.component.mjs +5 -5
  45. package/{esm2020 → esm2022}/lib/hyperlink/index.mjs +2 -2
  46. package/{esm2020 → esm2022}/lib/hyperlink/module.mjs +6 -6
  47. package/{esm2020 → esm2022}/lib/icon/bao-icon-registry.mjs +5 -5
  48. package/{esm2020 → esm2022}/lib/icon/icon.component.mjs +5 -5
  49. package/{esm2020 → esm2022}/lib/icon/icons-dictionary.mjs +2 -2
  50. package/{esm2020 → esm2022}/lib/icon/index.mjs +2 -2
  51. package/{esm2020 → esm2022}/lib/icon/module.mjs +6 -6
  52. package/{esm2020 → esm2022}/lib/list/index.mjs +2 -2
  53. package/{esm2020 → esm2022}/lib/list/list.component.mjs +17 -17
  54. package/{esm2020 → esm2022}/lib/list/module.mjs +14 -14
  55. package/{esm2020 → esm2022}/lib/modal/index.mjs +2 -2
  56. package/{esm2020 → esm2022}/lib/modal/modal-config.mjs +2 -2
  57. package/{esm2020 → esm2022}/lib/modal/modal-container.mjs +7 -7
  58. package/{esm2020 → esm2022}/lib/modal/modal-directives.mjs +5 -5
  59. package/{esm2020 → esm2022}/lib/modal/modal-ref.mjs +1 -1
  60. package/{esm2020 → esm2022}/lib/modal/modal.mjs +8 -8
  61. package/{esm2020 → esm2022}/lib/modal/module.mjs +6 -6
  62. package/{esm2020 → esm2022}/lib/radio/index.mjs +2 -2
  63. package/{esm2020 → esm2022}/lib/radio/module.mjs +20 -20
  64. package/{esm2020 → esm2022}/lib/radio/radio-group.component.mjs +12 -12
  65. package/{esm2020 → esm2022}/lib/radio/radio.component.mjs +13 -13
  66. package/{esm2020 → esm2022}/lib/shared/enum/display-mode.mjs +1 -1
  67. package/{esm2020 → esm2022}/lib/shared/index.mjs +2 -2
  68. package/{esm2020 → esm2022}/lib/snack-bar/index.mjs +2 -2
  69. package/esm2022/lib/snack-bar/module.mjs +51 -0
  70. package/{esm2020 → esm2022}/lib/snack-bar/simple-snack-bar.component.mjs +5 -5
  71. package/{esm2020 → esm2022}/lib/snack-bar/snack-bar-animations.mjs +2 -2
  72. package/{esm2020 → esm2022}/lib/snack-bar/snack-bar-config.mjs +1 -1
  73. package/{esm2020 → esm2022}/lib/snack-bar/snack-bar-container.mjs +10 -5
  74. package/{esm2020 → esm2022}/lib/snack-bar/snack-bar-ref.mjs +1 -1
  75. package/{esm2020 → esm2022}/lib/snack-bar/snack-bar.mjs +4 -4
  76. package/{esm2020 → esm2022}/lib/summary/index.mjs +2 -2
  77. package/{esm2020 → esm2022}/lib/summary/list-summary.component.mjs +8 -8
  78. package/{esm2020 → esm2022}/lib/summary/module.mjs +12 -12
  79. package/{esm2020 → esm2022}/lib/summary/summary.component.mjs +8 -8
  80. package/{esm2020 → esm2022}/lib/system-header/index.mjs +2 -2
  81. package/{esm2020 → esm2022}/lib/system-header/module.mjs +10 -10
  82. package/esm2022/lib/system-header/system-header.component.mjs +130 -0
  83. package/{esm2020 → esm2022}/lib/tabs/index.mjs +2 -2
  84. package/{esm2020 → esm2022}/lib/tabs/module.mjs +12 -12
  85. package/{esm2020 → esm2022}/lib/tabs/tabs.component.mjs +14 -14
  86. package/{esm2020 → esm2022}/lib/tag/index.mjs +2 -2
  87. package/{esm2020 → esm2022}/lib/tag/module.mjs +6 -6
  88. package/{esm2020 → esm2022}/lib/tag/tag.component.mjs +5 -5
  89. package/{esm2020 → esm2022}/public-api.mjs +2 -2
  90. package/{fesm2020 → fesm2022}/villedemontreal-angular-ui.mjs +585 -578
  91. package/fesm2022/villedemontreal-angular-ui.mjs.map +1 -0
  92. package/lib/alert/alert.component.d.ts +1 -1
  93. package/lib/avatar/avatar.component.d.ts +1 -1
  94. package/lib/badge/badge.component.d.ts +1 -1
  95. package/lib/button/button.component.d.ts +4 -4
  96. package/lib/card/card.component.d.ts +1 -1
  97. package/lib/checkbox/checkbox-group.component.d.ts +1 -1
  98. package/lib/checkbox/checkbox.component.d.ts +1 -1
  99. package/lib/common-components/label-text/labelText.component.d.ts +1 -1
  100. package/lib/dropdown-menu/dropdown-menu.component.d.ts +2 -2
  101. package/lib/file/file-input.component.d.ts +1 -1
  102. package/lib/file/file-preview.component.d.ts +1 -1
  103. package/lib/header-info/header-info.component.d.ts +1 -1
  104. package/lib/hyperlink/hyperlink.component.d.ts +1 -1
  105. package/lib/icon/icon.component.d.ts +1 -1
  106. package/lib/modal/modal-directives.d.ts +1 -1
  107. package/lib/radio/radio-group.component.d.ts +1 -1
  108. package/lib/radio/radio.component.d.ts +1 -1
  109. package/lib/summary/summary.component.d.ts +1 -1
  110. package/lib/system-header/system-header.component.d.ts +4 -3
  111. package/lib/tabs/tabs.component.d.ts +1 -1
  112. package/lib/tag/tag.component.d.ts +1 -1
  113. package/package.json +13 -19
  114. package/esm2020/lib/button/button.component.mjs +0 -100
  115. package/esm2020/lib/checkbox/checkbox.component.mjs +0 -304
  116. package/esm2020/lib/file/file-input.component.mjs +0 -319
  117. package/esm2020/lib/snack-bar/module.mjs +0 -52
  118. package/esm2020/lib/system-header/system-header.component.mjs +0 -128
  119. package/fesm2015/villedemontreal-angular-ui.mjs +0 -6119
  120. package/fesm2015/villedemontreal-angular-ui.mjs.map +0 -1
  121. package/fesm2020/villedemontreal-angular-ui.mjs.map +0 -1
  122. /package/{esm2020 → esm2022}/villedemontreal-angular-ui.mjs +0 -0
@@ -1,319 +0,0 @@
1
- /*
2
- * Copyright (c) 2023 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, ContentChildren, Directive, EventEmitter, forwardRef, HostListener, Input, Output, ViewChild, ViewChildren, ViewEncapsulation } from '@angular/core';
7
- import { NG_VALUE_ACCESSOR } from '@angular/forms';
8
- import { BaoErrorTextComponent } from '../common-components';
9
- import { BaoFilePreviewComponent } from './file-preview.component';
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "./file-intl";
12
- import * as i2 from "@angular/common";
13
- import * as i3 from "../common-components/error-text/errorText.component";
14
- import * as i4 from "../common-components/label-text/labelText.component";
15
- import * as i5 from "../button/button.component";
16
- /**
17
- * Unique number to generate a unique ID
18
- */
19
- let fileInputUniqueId = 0;
20
- let fileTextUniqueId = 0;
21
- export class BaoFileInputComponent {
22
- constructor(intl, elementRef, renderer, cdr) {
23
- this.intl = intl;
24
- this.elementRef = elementRef;
25
- this.renderer = renderer;
26
- this.cdr = cdr;
27
- /**
28
- * Size of the file input label
29
- */
30
- this.size = 'medium';
31
- /**
32
- * Maximum size accepted for uploaded files
33
- */
34
- this.maximalFileSize = -1;
35
- /**
36
- * Accepted types of files
37
- */
38
- this.acceptedMIMETypes = [];
39
- /**
40
- * Is field required
41
- */
42
- this.required = false;
43
- /**
44
- * Is field disabled
45
- */
46
- this.disabled = false;
47
- /**
48
- * File selected to be uploaded
49
- */
50
- this.uploadedFile = new EventEmitter();
51
- this.insertDefaultInstructions = false;
52
- this.isFileTooBig = false;
53
- this.isFileTypeInvalid = false;
54
- /**
55
- * Saves the registerOnChange function so the component can call it whenever it wants.
56
- */
57
- // eslint-disable-next-line @typescript-eslint/no-empty-function, @typescript-eslint/no-unused-vars
58
- this.propagateChange = (_) => { };
59
- /**
60
- * Saves the registerOnTouched function so the component can call it whenever it wants.
61
- */
62
- // eslint-disable-next-line @typescript-eslint/no-empty-function
63
- this.propagateTouched = () => { };
64
- this._intlChanges = intl.changes.subscribe(() => this.cdr.markForCheck());
65
- }
66
- get nativeElement() {
67
- return this.elementRef.nativeElement;
68
- }
69
- enterKeyEvent() {
70
- if (document.activeElement.id === this.inputId) {
71
- document.getElementById(this.inputId).click();
72
- }
73
- }
74
- tabKeyEvent() {
75
- if (document.activeElement.id === this.inputId) {
76
- this.renderer.addClass(this.dropzoneElement.nativeElement, 'dropzone-focus');
77
- }
78
- }
79
- shiftTabKeyEvent() {
80
- if (document.activeElement.id === this.inputId) {
81
- this.renderer.addClass(this.dropzoneElement.nativeElement, 'dropzone-focus');
82
- }
83
- }
84
- ngAfterContentInit() {
85
- this._errorForm.changes.subscribe(() => this.setErrorTextsAttribute());
86
- if (!this.inputId) {
87
- this.inputId = `file-input-${fileInputUniqueId++}`;
88
- }
89
- // If no content was added for dropzone instructions, add default text.
90
- const dropzoneElement = Array.from(this.nativeElement.children).find((el) => el.className === 'file-drop-zone');
91
- if (!Array.from(dropzoneElement.children).find(el => el.localName === 'bao-file-dropzone-instructions')) {
92
- this.insertDefaultInstructions = true;
93
- }
94
- this.setDescribedByAttribute();
95
- this._files.changes.subscribe((files) => {
96
- const filesList = files.map((el) => el.file);
97
- this.setValue(filesList);
98
- });
99
- }
100
- ngAfterViewInit() {
101
- this._errorTexts.changes.subscribe(() => this.setErrorTextsAttribute());
102
- }
103
- ngOnDestroy() {
104
- this._intlChanges.unsubscribe();
105
- }
106
- /**
107
- * Implements ControlValueAccessor interface
108
- */
109
- writeValue(obj) {
110
- this._value = obj;
111
- }
112
- /**
113
- * Implements ControlValueAccessor interface
114
- */
115
- registerOnChange(fn) {
116
- this.propagateChange = fn;
117
- }
118
- /**
119
- * Implements ControlValueAccessor interface
120
- */
121
- registerOnTouched(fn) {
122
- this.propagateTouched = fn;
123
- }
124
- /**
125
- * Implements ControlValueAccessor interface
126
- */
127
- setDisabledState(isDisabled) {
128
- this.disabled = isDisabled;
129
- }
130
- uploadFile(file) {
131
- if (!this.disabled) {
132
- this.isFileTypeInvalid = false;
133
- this.isFileTooBig = false;
134
- this.uploader.nativeElement.value = '';
135
- if (this.maximalFileSize > 0 && file.size > this.maximalFileSize) {
136
- this.isFileTooBig = true;
137
- }
138
- if (this.acceptedMIMETypes.length > 0 &&
139
- this.acceptedMIMETypes.indexOf(file.type) < 0) {
140
- this.isFileTypeInvalid = true;
141
- }
142
- if (!this.isFileTooBig && !this.isFileTypeInvalid) {
143
- this.uploadedFile.emit(file);
144
- }
145
- }
146
- }
147
- setValue(value) {
148
- this._value = value;
149
- this.propagateChange(this._value);
150
- this.propagateTouched();
151
- }
152
- setDescribedByAttribute() {
153
- const helperText = Array.from(this.nativeElement.children).find((el) => el.localName === 'bao-guiding-text');
154
- if (helperText) {
155
- this._helperTextId = `bao-guiding-text-${fileTextUniqueId++}`;
156
- this.renderer.setAttribute(helperText.firstElementChild, 'id', this._helperTextId);
157
- const inputElement = Array.from(this.nativeElement.children)
158
- .find((el) => el.className == 'file-drop-zone')
159
- .children.item(1);
160
- this.renderer.setAttribute(inputElement, 'aria-describedby', this._helperTextId);
161
- }
162
- }
163
- setErrorTextsAttribute() {
164
- const textsIds = [];
165
- const errors = Array.from(this.nativeElement.children).filter((el) => el.localName == 'bao-error');
166
- errors.forEach((errorText) => {
167
- const errorTextId = `bao-error-${fileTextUniqueId++}`;
168
- this.renderer.setAttribute(errorText.firstElementChild, 'id', errorTextId);
169
- textsIds.push(errorTextId);
170
- });
171
- const inputElement = Array.from(this.nativeElement.children)
172
- .find((el) => el.classList.contains('file-drop-zone'))
173
- .children.item(1);
174
- if (this._helperTextId) {
175
- textsIds.unshift(this._helperTextId);
176
- }
177
- this.renderer.setAttribute(inputElement, 'aria-describedby', textsIds.join(' '));
178
- }
179
- }
180
- BaoFileInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoFileInputComponent, deps: [{ token: i1.BaoFileIntl }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
181
- BaoFileInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: BaoFileInputComponent, selector: "bao-file-input, [bao-file-input]", inputs: { inputId: ["id", "inputId"], label: "label", size: "size", maximalFileSize: "maximalFileSize", acceptedMIMETypes: "acceptedMIMETypes", required: "required", disabled: "disabled" }, outputs: { uploadedFile: "uploadedFile" }, host: { listeners: { "window:keyup.enter": "enterKeyEvent()", "window:keyup.tab": "tabKeyEvent()", "window:keyup.shift.tab": "shiftTabKeyEvent()" }, properties: { "class.bao-file-label-small": "size === \"small\"", "class.bao-file-label-medium": "size === \"medium\"", "class.bao-file-input-disabled": "disabled" }, classAttribute: "bao-file-input" }, providers: [
182
- {
183
- provide: NG_VALUE_ACCESSOR,
184
- // tslint:disable-next-line:no-forward-ref
185
- useExisting: forwardRef(() => BaoFileInputComponent),
186
- multi: true
187
- }
188
- ], queries: [{ propertyName: "_files", predicate: BaoFilePreviewComponent, descendants: true }, { propertyName: "_errorForm", predicate: BaoErrorTextComponent, descendants: true }], viewQueries: [{ propertyName: "uploader", first: true, predicate: ["uploader"], descendants: true }, { propertyName: "dropzoneElement", first: true, predicate: ["dropzone"], descendants: true }, { propertyName: "_errorTexts", predicate: BaoErrorTextComponent, descendants: true }], ngImport: i0, template: "<label bao-label [required]=\"required\" [for]=\"inputId\">{{ label }}</label>\n<ng-content select=\"bao-guiding-text\"></ng-content>\n<div\n baoFileDrop\n class=\"file-drop-zone\"\n (fileDrop)=\"uploadFile($event)\"\n #dropzone\n>\n <button\n bao-button\n type=\"button\"\n displayType=\"utility\"\n level=\"secondary\"\n [disabled]=\"disabled\"\n (click)=\"uploader.click()\"\n aria-hidden=\"true\"\n tabIndex=\"-1\"\n >\n {{ intl.dropzoneButtonLabel }}\n </button>\n <input\n [id]=\"inputId\"\n type=\"file\"\n class=\"sr-only\"\n [disabled]=\"disabled\"\n (change)=\"uploadFile($event.target.files[0])\"\n #uploader\n />\n <ng-container\n ><div #ref>\n <ng-content select=\"bao-file-dropzone-instructions\"></ng-content></div\n ></ng-container>\n <ng-container *ngIf=\"ref.childNodes.length === 0\"\n ><bao-file-dropzone-instructions>{{\n intl.defaultDropzoneInstructions\n }}</bao-file-dropzone-instructions></ng-container\n >\n</div>\n<bao-error *ngIf=\"isFileTooBig\">\n {{ intl.fileTooBigErrorMessage }}\n</bao-error>\n<bao-error *ngIf=\"isFileTypeInvalid\">\n {{ intl.invalidFileTypeErrorMessage }}\n</bao-error>\n<ng-content select=\"bao-error\"></ng-content>\n<ng-content></ng-content>\n", styles: ["bao-file-input{width:100%;display:inline-flex;flex-direction:column}bao-file-input>ul{padding:0;margin:0}bao-file-input .bao-label>span{font-size:inherit;font-weight:inherit}bao-file-input.bao-file-label-small label{font-weight:700;font-size:.875rem;line-height:1.25rem}bao-file-input.bao-file-label-medium label{font-weight:700;font-size:1rem;line-height:1.5rem}bao-file-input .bao-guiding-text{margin-bottom:.5rem}bao-file-input .file-drop-zone{padding:.5rem;background-color:#fff;border-radius:.25rem;border-style:dashed;border-color:#ced4da;border-width:1px;display:inline-flex;align-items:center}bao-file-input .file-drop-zone:focus-within.dropzone-focus{box-shadow:0 0 0 .1875rem #98bcde;background-color:#eefaf8}bao-file-input .file-drop-zone>.bao-button{margin-right:.5rem}bao-file-input .file-drop-zone.drag-over{background-color:#eefaf8;border-color:#097d6c;cursor:drag}bao-file-input .file-drop-zone.drag-over>.bao-button{background-color:#eefaf8}bao-file-input.bao-file-input-disabled .file-drop-zone{background-color:#f8f9fa;border-color:#ced4da}bao-file-input.bao-file-input-disabled .file-drop-zone .bao-button{background-color:#f8f9fa}bao-file-input.bao-file-input-disabled .file-drop-zone .bao-button:hover{background-color:#f8f9fa}bao-file-input .bao-file-preview:first-child{margin-top:1rem}bao-file-input .bao-error{margin-top:.5rem}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i2.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i0.forwardRef(function () { return i3.BaoErrorTextComponent; }), selector: "bao-error, [bao-error]" }, { kind: "component", type: i0.forwardRef(function () { return i4.BaoLabelTextComponent; }), selector: "bao-label, [bao-label]", inputs: ["required"] }, { kind: "component", type: i0.forwardRef(function () { return i5.BaoButtonComponent; }), selector: "button[bao-button]", inputs: ["displayType", "level", "size", "loading", "reversed", "loadingSpinnerAriaLabel", "fullWidth"] }, { kind: "directive", type: i0.forwardRef(function () { return BaoFileDropzoneIntructions; }), selector: "bao-file-dropzone-instructions, [bao-file-dropzone-instructions]" }, { kind: "directive", type: i0.forwardRef(function () { return BaoFileDropDirective; }), selector: "[baoFileDrop]", outputs: ["fileDrop"] }], encapsulation: i0.ViewEncapsulation.None });
189
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoFileInputComponent, decorators: [{
190
- type: Component,
191
- args: [{ selector: 'bao-file-input, [bao-file-input]', providers: [
192
- {
193
- provide: NG_VALUE_ACCESSOR,
194
- // tslint:disable-next-line:no-forward-ref
195
- useExisting: forwardRef(() => BaoFileInputComponent),
196
- multi: true
197
- }
198
- ], encapsulation: ViewEncapsulation.None, host: {
199
- class: 'bao-file-input',
200
- '[class.bao-file-label-small]': 'size === "small"',
201
- '[class.bao-file-label-medium]': 'size === "medium"',
202
- '[class.bao-file-input-disabled]': 'disabled'
203
- }, template: "<label bao-label [required]=\"required\" [for]=\"inputId\">{{ label }}</label>\n<ng-content select=\"bao-guiding-text\"></ng-content>\n<div\n baoFileDrop\n class=\"file-drop-zone\"\n (fileDrop)=\"uploadFile($event)\"\n #dropzone\n>\n <button\n bao-button\n type=\"button\"\n displayType=\"utility\"\n level=\"secondary\"\n [disabled]=\"disabled\"\n (click)=\"uploader.click()\"\n aria-hidden=\"true\"\n tabIndex=\"-1\"\n >\n {{ intl.dropzoneButtonLabel }}\n </button>\n <input\n [id]=\"inputId\"\n type=\"file\"\n class=\"sr-only\"\n [disabled]=\"disabled\"\n (change)=\"uploadFile($event.target.files[0])\"\n #uploader\n />\n <ng-container\n ><div #ref>\n <ng-content select=\"bao-file-dropzone-instructions\"></ng-content></div\n ></ng-container>\n <ng-container *ngIf=\"ref.childNodes.length === 0\"\n ><bao-file-dropzone-instructions>{{\n intl.defaultDropzoneInstructions\n }}</bao-file-dropzone-instructions></ng-container\n >\n</div>\n<bao-error *ngIf=\"isFileTooBig\">\n {{ intl.fileTooBigErrorMessage }}\n</bao-error>\n<bao-error *ngIf=\"isFileTypeInvalid\">\n {{ intl.invalidFileTypeErrorMessage }}\n</bao-error>\n<ng-content select=\"bao-error\"></ng-content>\n<ng-content></ng-content>\n", styles: ["bao-file-input{width:100%;display:inline-flex;flex-direction:column}bao-file-input>ul{padding:0;margin:0}bao-file-input .bao-label>span{font-size:inherit;font-weight:inherit}bao-file-input.bao-file-label-small label{font-weight:700;font-size:.875rem;line-height:1.25rem}bao-file-input.bao-file-label-medium label{font-weight:700;font-size:1rem;line-height:1.5rem}bao-file-input .bao-guiding-text{margin-bottom:.5rem}bao-file-input .file-drop-zone{padding:.5rem;background-color:#fff;border-radius:.25rem;border-style:dashed;border-color:#ced4da;border-width:1px;display:inline-flex;align-items:center}bao-file-input .file-drop-zone:focus-within.dropzone-focus{box-shadow:0 0 0 .1875rem #98bcde;background-color:#eefaf8}bao-file-input .file-drop-zone>.bao-button{margin-right:.5rem}bao-file-input .file-drop-zone.drag-over{background-color:#eefaf8;border-color:#097d6c;cursor:drag}bao-file-input .file-drop-zone.drag-over>.bao-button{background-color:#eefaf8}bao-file-input.bao-file-input-disabled .file-drop-zone{background-color:#f8f9fa;border-color:#ced4da}bao-file-input.bao-file-input-disabled .file-drop-zone .bao-button{background-color:#f8f9fa}bao-file-input.bao-file-input-disabled .file-drop-zone .bao-button:hover{background-color:#f8f9fa}bao-file-input .bao-file-preview:first-child{margin-top:1rem}bao-file-input .bao-error{margin-top:.5rem}\n"] }]
204
- }], ctorParameters: function () { return [{ type: i1.BaoFileIntl }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { inputId: [{
205
- type: Input,
206
- args: ['id']
207
- }], label: [{
208
- type: Input
209
- }], size: [{
210
- type: Input
211
- }], maximalFileSize: [{
212
- type: Input
213
- }], acceptedMIMETypes: [{
214
- type: Input
215
- }], required: [{
216
- type: Input
217
- }], disabled: [{
218
- type: Input
219
- }], uploadedFile: [{
220
- type: Output
221
- }], _files: [{
222
- type: ContentChildren,
223
- args: [BaoFilePreviewComponent, { descendants: true }]
224
- }], _errorForm: [{
225
- type: ContentChildren,
226
- args: [BaoErrorTextComponent, { descendants: true }]
227
- }], _errorTexts: [{
228
- type: ViewChildren,
229
- args: [BaoErrorTextComponent]
230
- }], uploader: [{
231
- type: ViewChild,
232
- args: ['uploader', { static: false }]
233
- }], dropzoneElement: [{
234
- type: ViewChild,
235
- args: ['dropzone', { static: false }]
236
- }], enterKeyEvent: [{
237
- type: HostListener,
238
- args: ['window:keyup.enter']
239
- }], tabKeyEvent: [{
240
- type: HostListener,
241
- args: ['window:keyup.tab']
242
- }], shiftTabKeyEvent: [{
243
- type: HostListener,
244
- args: ['window:keyup.shift.tab']
245
- }] } });
246
- export class BaoFileDropDirective {
247
- constructor() {
248
- this.fileDrop = new EventEmitter();
249
- this._isDragOver = false;
250
- }
251
- onDragOver(event) {
252
- this.preventAndStop(event);
253
- this._isDragOver = true;
254
- }
255
- onDragLeave(event) {
256
- this.preventAndStop(event);
257
- this._isDragOver = false;
258
- }
259
- onDrop(event) {
260
- this.preventAndStop(event);
261
- this._isDragOver = false;
262
- const transfer = this.getDataTransfer(event);
263
- this.fileDrop.emit(transfer.files[0]);
264
- }
265
- preventAndStop(event) {
266
- event.preventDefault();
267
- event.stopPropagation();
268
- }
269
- getDataTransfer(event) {
270
- // eslint-disable-next-line @typescript-eslint/no-unsafe-return
271
- return event.dataTransfer
272
- ? event.dataTransfer
273
- : event.originalEvent.dataTransfer;
274
- }
275
- }
276
- BaoFileDropDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoFileDropDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
277
- BaoFileDropDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.3", type: BaoFileDropDirective, selector: "[baoFileDrop]", outputs: { fileDrop: "fileDrop" }, host: { listeners: { "dragover": "onDragOver($event)", "dragleave": "onDragLeave($event)", "drop": "onDrop($event)" }, properties: { "class.drag-over": "_isDragOver == true" } }, ngImport: i0 });
278
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoFileDropDirective, decorators: [{
279
- type: Directive,
280
- args: [{
281
- selector: '[baoFileDrop]',
282
- host: { '[class.drag-over]': '_isDragOver == true' }
283
- }]
284
- }], propDecorators: { fileDrop: [{
285
- type: Output
286
- }], onDragOver: [{
287
- type: HostListener,
288
- args: ['dragover', ['$event']]
289
- }], onDragLeave: [{
290
- type: HostListener,
291
- args: ['dragleave', ['$event']]
292
- }], onDrop: [{
293
- type: HostListener,
294
- args: ['drop', ['$event']]
295
- }] } });
296
- export class BaoFileDropzoneIntructions {
297
- constructor(renderer, elementRef) {
298
- this.renderer = renderer;
299
- this.elementRef = elementRef;
300
- }
301
- get nativeElement() {
302
- return this.elementRef.nativeElement;
303
- }
304
- ngAfterContentInit() {
305
- this.renderer.setAttribute(this.nativeElement, 'aria-hidden', 'true');
306
- }
307
- }
308
- BaoFileDropzoneIntructions.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoFileDropzoneIntructions, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
309
- BaoFileDropzoneIntructions.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.3", type: BaoFileDropzoneIntructions, selector: "bao-file-dropzone-instructions, [bao-file-dropzone-instructions]", host: { classAttribute: "bao-file-dropzone-instructions" }, ngImport: i0 });
310
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoFileDropzoneIntructions, decorators: [{
311
- type: Directive,
312
- args: [{
313
- selector: 'bao-file-dropzone-instructions, [bao-file-dropzone-instructions]',
314
- host: {
315
- class: 'bao-file-dropzone-instructions'
316
- }
317
- }]
318
- }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; } });
319
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/file/file-input.component.ts","../../../../../projects/angular-ui/src/lib/file/file-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2023 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  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostListener,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ViewChildren,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { BaoErrorTextComponent } from '../common-components';\nimport { Subscription } from 'rxjs';\nimport { BaoFileIntl } from './file-intl';\nimport { BaoFilePreviewComponent } from './file-preview.component';\n\n/**\n * Unique number to generate a unique ID\n */\nlet fileInputUniqueId = 0;\nlet fileTextUniqueId = 0;\n\n@Component({\n  selector: 'bao-file-input, [bao-file-input]',\n  templateUrl: './file-input.component.html',\n  styleUrls: ['./file-input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      // tslint:disable-next-line:no-forward-ref\n      useExisting: forwardRef(() => BaoFileInputComponent),\n      multi: true\n    }\n  ],\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'bao-file-input',\n    '[class.bao-file-label-small]': 'size === \"small\"',\n    '[class.bao-file-label-medium]': 'size === \"medium\"',\n    '[class.bao-file-input-disabled]': 'disabled'\n  }\n})\nexport class BaoFileInputComponent\n  implements AfterContentInit, AfterViewInit, OnDestroy, ControlValueAccessor\n{\n  /**\n   * Id of the file input field\n   */\n  @Input('id') public inputId?: string;\n\n  /**\n   * Label of field to be displayed above\n   */\n  @Input() public label: string;\n\n  /**\n   * Size of the file input label\n   */\n  @Input() public size: 'small' | 'medium' = 'medium';\n\n  /**\n   * Maximum size accepted for uploaded files\n   */\n  @Input() public maximalFileSize = -1;\n\n  /**\n   * Accepted types of files\n   */\n  @Input() public acceptedMIMETypes: string[] = [];\n\n  /**\n   * Is field required\n   */\n  @Input() public required? = false;\n\n  /**\n   * Is field disabled\n   */\n  @Input() public disabled? = false;\n\n  /**\n   * File selected to be uploaded\n   */\n  @Output() public uploadedFile: EventEmitter<File> = new EventEmitter<File>();\n\n  /**\n   * List of files that have been uploaded so far\n   */\n  @ContentChildren(BaoFilePreviewComponent, { descendants: true })\n  private _files: QueryList<BaoFilePreviewComponent>;\n\n  /**\n   * Form errors when component is used in a form\n   */\n  @ContentChildren(BaoErrorTextComponent, { descendants: true })\n  private _errorForm: QueryList<BaoErrorTextComponent>;\n\n  /**\n   * Error texts\n   */\n  @ViewChildren(BaoErrorTextComponent)\n  private _errorTexts: QueryList<BaoErrorTextComponent>;\n\n  /**\n   * File input that triggers uploading when clicked\n   */\n  @ViewChild('uploader', { static: false }) private uploader: ElementRef;\n\n  @ViewChild('dropzone', { static: false })\n  private dropzoneElement: ElementRef<HTMLElement>;\n\n  public insertDefaultInstructions = false;\n  public isFileTooBig = false;\n  public isFileTypeInvalid = false;\n  private _value: File[];\n  private _intlChanges: Subscription;\n  private _helperTextId: string;\n\n  constructor(\n    public intl: BaoFileIntl,\n    private elementRef: ElementRef<HTMLElement>,\n    private renderer: Renderer2,\n    private cdr: ChangeDetectorRef\n  ) {\n    this._intlChanges = intl.changes.subscribe(() => this.cdr.markForCheck());\n  }\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  @HostListener('window:keyup.enter')\n  enterKeyEvent() {\n    if (document.activeElement.id === this.inputId) {\n      document.getElementById(this.inputId).click();\n    }\n  }\n\n  @HostListener('window:keyup.tab')\n  tabKeyEvent() {\n    if (document.activeElement.id === this.inputId) {\n      this.renderer.addClass(\n        this.dropzoneElement.nativeElement,\n        'dropzone-focus'\n      );\n    }\n  }\n\n  @HostListener('window:keyup.shift.tab')\n  shiftTabKeyEvent() {\n    if (document.activeElement.id === this.inputId) {\n      this.renderer.addClass(\n        this.dropzoneElement.nativeElement,\n        'dropzone-focus'\n      );\n    }\n  }\n\n  public ngAfterContentInit(): void {\n    this._errorForm.changes.subscribe(() => this.setErrorTextsAttribute());\n    if (!this.inputId) {\n      this.inputId = `file-input-${fileInputUniqueId++}`;\n    }\n    // If no content was added for dropzone instructions, add default text.\n    const dropzoneElement = Array.from(this.nativeElement.children).find(\n      (el: HTMLElement) => el.className === 'file-drop-zone'\n    );\n    if (\n      !Array.from(dropzoneElement.children).find(\n        el => el.localName === 'bao-file-dropzone-instructions'\n      )\n    ) {\n      this.insertDefaultInstructions = true;\n    }\n    this.setDescribedByAttribute();\n    this._files.changes.subscribe(\n      (files: QueryList<BaoFilePreviewComponent>) => {\n        const filesList: File[] = files.map(\n          (el: BaoFilePreviewComponent) => el.file\n        );\n        this.setValue(filesList);\n      }\n    );\n  }\n\n  public ngAfterViewInit(): void {\n    this._errorTexts.changes.subscribe(() => this.setErrorTextsAttribute());\n  }\n\n  public ngOnDestroy(): void {\n    this._intlChanges.unsubscribe();\n  }\n\n  /**\n   * Implements ControlValueAccessor interface\n   */\n  public writeValue(obj: any): void {\n    this._value = obj;\n  }\n  /**\n   * Implements ControlValueAccessor interface\n   */\n  public registerOnChange(fn: (value: any) => void): void {\n    this.propagateChange = fn;\n  }\n  /**\n   * Implements ControlValueAccessor interface\n   */\n  public registerOnTouched(fn: any): void {\n    this.propagateTouched = fn;\n  }\n  /**\n   * Implements ControlValueAccessor interface\n   */\n  public setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  public uploadFile(file: File) {\n    if (!this.disabled) {\n      this.isFileTypeInvalid = false;\n      this.isFileTooBig = false;\n      this.uploader.nativeElement.value = '';\n      if (this.maximalFileSize > 0 && file.size > this.maximalFileSize) {\n        this.isFileTooBig = true;\n      }\n      if (\n        this.acceptedMIMETypes.length > 0 &&\n        this.acceptedMIMETypes.indexOf(file.type) < 0\n      ) {\n        this.isFileTypeInvalid = true;\n      }\n      if (!this.isFileTooBig && !this.isFileTypeInvalid) {\n        this.uploadedFile.emit(file);\n      }\n    }\n  }\n\n  /**\n   * Saves the registerOnChange function so the component can call it whenever it wants.\n   */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function, @typescript-eslint/no-unused-vars\n  public propagateChange = (_: any) => {};\n\n  /**\n   * Saves the registerOnTouched function so the component can call it whenever it wants.\n   */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  public propagateTouched = () => {};\n\n  private setValue(value: File[]) {\n    this._value = value;\n    this.propagateChange(this._value);\n    this.propagateTouched();\n  }\n\n  private setDescribedByAttribute(): void {\n    const helperText = Array.from(this.nativeElement.children).find(\n      (el: HTMLElement) => el.localName === 'bao-guiding-text'\n    );\n    if (helperText) {\n      this._helperTextId = `bao-guiding-text-${fileTextUniqueId++}`;\n      this.renderer.setAttribute(\n        helperText.firstElementChild,\n        'id',\n        this._helperTextId\n      );\n      const inputElement = Array.from(this.nativeElement.children)\n        .find((el: HTMLElement) => el.className == 'file-drop-zone')\n        .children.item(1);\n      this.renderer.setAttribute(\n        inputElement,\n        'aria-describedby',\n        this._helperTextId\n      );\n    }\n  }\n\n  private setErrorTextsAttribute(): void {\n    const textsIds = [];\n    const errors = Array.from(this.nativeElement.children).filter(\n      (el: HTMLElement) => el.localName == 'bao-error'\n    );\n    errors.forEach((errorText: HTMLElement) => {\n      const errorTextId = `bao-error-${fileTextUniqueId++}`;\n      this.renderer.setAttribute(\n        errorText.firstElementChild,\n        'id',\n        errorTextId\n      );\n      textsIds.push(errorTextId);\n    });\n    const inputElement = Array.from(this.nativeElement.children)\n      .find((el: HTMLElement) => el.classList.contains('file-drop-zone'))\n      .children.item(1);\n    if (this._helperTextId) {\n      textsIds.unshift(this._helperTextId);\n    }\n    this.renderer.setAttribute(\n      inputElement,\n      'aria-describedby',\n      textsIds.join(' ')\n    );\n  }\n}\n\n@Directive({\n  selector: '[baoFileDrop]',\n  host: { '[class.drag-over]': '_isDragOver == true' }\n})\nexport class BaoFileDropDirective {\n  @Output() public fileDrop: EventEmitter<File> = new EventEmitter<File>();\n  private _isDragOver = false;\n\n  @HostListener('dragover', ['$event'])\n  public onDragOver(event: DragEvent): void {\n    this.preventAndStop(event);\n    this._isDragOver = true;\n  }\n\n  @HostListener('dragleave', ['$event'])\n  public onDragLeave(event: DragEvent): void {\n    this.preventAndStop(event);\n    this._isDragOver = false;\n  }\n\n  @HostListener('drop', ['$event'])\n  public onDrop(event: DragEvent): void {\n    this.preventAndStop(event);\n    this._isDragOver = false;\n    const transfer = this.getDataTransfer(event);\n    this.fileDrop.emit(transfer.files[0]);\n  }\n\n  private preventAndStop(event: DragEvent): void {\n    event.preventDefault();\n    event.stopPropagation();\n  }\n\n  private getDataTransfer(event: DragEvent | any): DataTransfer {\n    // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n    return event.dataTransfer\n      ? event.dataTransfer\n      : event.originalEvent.dataTransfer;\n  }\n}\n\n@Directive({\n  selector: 'bao-file-dropzone-instructions, [bao-file-dropzone-instructions]',\n  host: {\n    class: 'bao-file-dropzone-instructions'\n  }\n})\nexport class BaoFileDropzoneIntructions implements AfterContentInit {\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  ngAfterContentInit(): void {\n    this.renderer.setAttribute(this.nativeElement, 'aria-hidden', 'true');\n  }\n}\n","<label bao-label [required]=\"required\" [for]=\"inputId\">{{ label }}</label>\n<ng-content select=\"bao-guiding-text\"></ng-content>\n<div\n  baoFileDrop\n  class=\"file-drop-zone\"\n  (fileDrop)=\"uploadFile($event)\"\n  #dropzone\n>\n  <button\n    bao-button\n    type=\"button\"\n    displayType=\"utility\"\n    level=\"secondary\"\n    [disabled]=\"disabled\"\n    (click)=\"uploader.click()\"\n    aria-hidden=\"true\"\n    tabIndex=\"-1\"\n  >\n    {{ intl.dropzoneButtonLabel }}\n  </button>\n  <input\n    [id]=\"inputId\"\n    type=\"file\"\n    class=\"sr-only\"\n    [disabled]=\"disabled\"\n    (change)=\"uploadFile($event.target.files[0])\"\n    #uploader\n  />\n  <ng-container\n    ><div #ref>\n      <ng-content select=\"bao-file-dropzone-instructions\"></ng-content></div\n  ></ng-container>\n  <ng-container *ngIf=\"ref.childNodes.length === 0\"\n    ><bao-file-dropzone-instructions>{{\n      intl.defaultDropzoneInstructions\n    }}</bao-file-dropzone-instructions></ng-container\n  >\n</div>\n<bao-error *ngIf=\"isFileTooBig\">\n  {{ intl.fileTooBigErrorMessage }}\n</bao-error>\n<bao-error *ngIf=\"isFileTypeInvalid\">\n  {{ intl.invalidFileTypeErrorMessage }}\n</bao-error>\n<ng-content select=\"bao-error\"></ng-content>\n<ng-content></ng-content>\n"]}
@@ -1,52 +0,0 @@
1
- /*
2
- * Copyright (c) 2023 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 { OverlayModule } from '@angular/cdk/overlay';
7
- import { PortalModule } from '@angular/cdk/portal';
8
- import { CommonModule } from '@angular/common';
9
- import { NgModule } from '@angular/core';
10
- import { BaoButtonModule } from '../button/module';
11
- import { BaoIconModule } from '../icon/module';
12
- import { BaoSimpleSnackBarComponent } from './simple-snack-bar.component';
13
- import { BaoSnackBarService } from './snack-bar';
14
- import { BaoSnackBarConfig } from './snack-bar-config';
15
- import { BaoSnackBarContainerComponent } from './snack-bar-container';
16
- import * as i0 from "@angular/core";
17
- const SNACKBAR_DIRECTIVES = [
18
- BaoSimpleSnackBarComponent,
19
- BaoSnackBarContainerComponent
20
- ];
21
- export class BaoSnackBarModule {
22
- }
23
- BaoSnackBarModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoSnackBarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
24
- BaoSnackBarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.3", ngImport: i0, type: BaoSnackBarModule, declarations: [BaoSimpleSnackBarComponent,
25
- BaoSnackBarContainerComponent], imports: [CommonModule,
26
- OverlayModule,
27
- PortalModule,
28
- BaoButtonModule,
29
- BaoIconModule], exports: [BaoSimpleSnackBarComponent,
30
- BaoSnackBarContainerComponent] });
31
- BaoSnackBarModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoSnackBarModule, providers: [BaoSnackBarService, BaoSnackBarConfig], imports: [CommonModule,
32
- OverlayModule,
33
- PortalModule,
34
- BaoButtonModule,
35
- BaoIconModule] });
36
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoSnackBarModule, decorators: [{
37
- type: NgModule,
38
- args: [{
39
- imports: [
40
- CommonModule,
41
- OverlayModule,
42
- PortalModule,
43
- BaoButtonModule,
44
- BaoIconModule
45
- ],
46
- providers: [BaoSnackBarService, BaoSnackBarConfig],
47
- declarations: SNACKBAR_DIRECTIVES,
48
- exports: SNACKBAR_DIRECTIVES,
49
- entryComponents: [SNACKBAR_DIRECTIVES]
50
- }]
51
- }] });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11aS9zcmMvbGliL3NuYWNrLWJhci9tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUMxRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDakQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDdkQsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBRXRFLE1BQU0sbUJBQW1CLEdBQUc7SUFDMUIsMEJBQTBCO0lBQzFCLDZCQUE2QjtDQUM5QixDQUFDO0FBZUYsTUFBTSxPQUFPLGlCQUFpQjs7OEdBQWpCLGlCQUFpQjsrR0FBakIsaUJBQWlCLGlCQWpCNUIsMEJBQTBCO1FBQzFCLDZCQUE2QixhQUszQixZQUFZO1FBQ1osYUFBYTtRQUNiLFlBQVk7UUFDWixlQUFlO1FBQ2YsYUFBYSxhQVZmLDBCQUEwQjtRQUMxQiw2QkFBNkI7K0dBZ0JsQixpQkFBaUIsYUFMakIsQ0FBQyxrQkFBa0IsRUFBRSxpQkFBaUIsQ0FBQyxZQU5oRCxZQUFZO1FBQ1osYUFBYTtRQUNiLFlBQVk7UUFDWixlQUFlO1FBQ2YsYUFBYTsyRkFPSixpQkFBaUI7a0JBYjdCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osYUFBYTt3QkFDYixZQUFZO3dCQUNaLGVBQWU7d0JBQ2YsYUFBYTtxQkFDZDtvQkFDRCxTQUFTLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxpQkFBaUIsQ0FBQztvQkFDbEQsWUFBWSxFQUFFLG1CQUFtQjtvQkFDakMsT0FBTyxFQUFFLG1CQUFtQjtvQkFDNUIsZUFBZSxFQUFFLENBQUMsbUJBQW1CLENBQUM7aUJBQ3ZDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMyBWaWxsZSBkZSBNb250cmVhbC4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZS5cbiAqIFNlZSBMSUNFTlNFIGZpbGUgaW4gdGhlIHByb2plY3Qgcm9vdCBmb3IgZnVsbCBsaWNlbnNlIGluZm9ybWF0aW9uLlxuICovXG5pbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgUG9ydGFsTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3BvcnRhbCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhb0J1dHRvbk1vZHVsZSB9IGZyb20gJy4uL2J1dHRvbi9tb2R1bGUnO1xuaW1wb3J0IHsgQmFvSWNvbk1vZHVsZSB9IGZyb20gJy4uL2ljb24vbW9kdWxlJztcbmltcG9ydCB7IEJhb1NpbXBsZVNuYWNrQmFyQ29tcG9uZW50IH0gZnJvbSAnLi9zaW1wbGUtc25hY2stYmFyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCYW9TbmFja0JhclNlcnZpY2UgfSBmcm9tICcuL3NuYWNrLWJhcic7XG5pbXBvcnQgeyBCYW9TbmFja0JhckNvbmZpZyB9IGZyb20gJy4vc25hY2stYmFyLWNvbmZpZyc7XG5pbXBvcnQgeyBCYW9TbmFja0JhckNvbnRhaW5lckNvbXBvbmVudCB9IGZyb20gJy4vc25hY2stYmFyLWNvbnRhaW5lcic7XG5cbmNvbnN0IFNOQUNLQkFSX0RJUkVDVElWRVMgPSBbXG4gIEJhb1NpbXBsZVNuYWNrQmFyQ29tcG9uZW50LFxuICBCYW9TbmFja0JhckNvbnRhaW5lckNvbXBvbmVudFxuXTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBPdmVybGF5TW9kdWxlLFxuICAgIFBvcnRhbE1vZHVsZSxcbiAgICBCYW9CdXR0b25Nb2R1bGUsXG4gICAgQmFvSWNvbk1vZHVsZVxuICBdLFxuICBwcm92aWRlcnM6IFtCYW9TbmFja0JhclNlcnZpY2UsIEJhb1NuYWNrQmFyQ29uZmlnXSxcbiAgZGVjbGFyYXRpb25zOiBTTkFDS0JBUl9ESVJFQ1RJVkVTLFxuICBleHBvcnRzOiBTTkFDS0JBUl9ESVJFQ1RJVkVTLFxuICBlbnRyeUNvbXBvbmVudHM6IFtTTkFDS0JBUl9ESVJFQ1RJVkVTXVxufSlcbmV4cG9ydCBjbGFzcyBCYW9TbmFja0Jhck1vZHVsZSB7fVxuIl19
@@ -1,128 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, Directive, Input, ViewChild, ViewEncapsulation } from '@angular/core';
2
- import { Breakpoints } from '../core';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "../icon/icon.component";
5
- import * as i2 from "@angular/cdk/layout";
6
- /**
7
- * This component is dynamically added to replace breadcrumb when System Header is viewed on tablet or mobile screens.
8
- * Used internally by BaoSystemHeaderComponent only, not to be used by host application.
9
- */
10
- export class BaoBackNavigationComponent {
11
- constructor(renderer, elementRef) {
12
- this.renderer = renderer;
13
- this.elementRef = elementRef;
14
- }
15
- ngOnChanges(changes) {
16
- if (changes['link'] && changes['link'].currentValue) {
17
- this.renderer.setAttribute(this.elementRef.nativeElement.children[0], 'href', changes['link'].currentValue);
18
- }
19
- }
20
- }
21
- BaoBackNavigationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoBackNavigationComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
22
- BaoBackNavigationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: BaoBackNavigationComponent, selector: "bao-back-navigation-component", inputs: { link: "link" }, host: { classAttribute: "bao-system-header-back-button" }, usesOnChanges: true, ngImport: i0, template: ` <a>
23
- <bao-icon
24
- color="action"
25
- title="arrow-left"
26
- svgIcon="icon-arrow-left"
27
- size="x-small"
28
- ></bao-icon>
29
- </a>`, isInline: true, dependencies: [{ kind: "component", type: i1.BaoIconComponent, selector: "bao-icon", inputs: ["color", "size", "svgIcon", "title"], exportAs: ["baoIcon"] }] });
30
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoBackNavigationComponent, decorators: [{
31
- type: Component,
32
- args: [{
33
- selector: 'bao-back-navigation-component',
34
- template: ` <a>
35
- <bao-icon
36
- color="action"
37
- title="arrow-left"
38
- svgIcon="icon-arrow-left"
39
- size="x-small"
40
- ></bao-icon>
41
- </a>`,
42
- host: {
43
- class: 'bao-system-header-back-button'
44
- }
45
- }]
46
- }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { link: [{
47
- type: Input
48
- }] } });
49
- /**
50
- * This directive is to mark the template where the BaoBackNavigationComponent should be dynamically inserted,
51
- * when a Breadcrumb component needs to be replaced
52
- */
53
- export class BaoBackNavigationInsert {
54
- constructor(viewContainerRef) {
55
- this.viewContainerRef = viewContainerRef;
56
- }
57
- }
58
- BaoBackNavigationInsert.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoBackNavigationInsert, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
59
- BaoBackNavigationInsert.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.3", type: BaoBackNavigationInsert, selector: "[backNavigationInsert]", ngImport: i0 });
60
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoBackNavigationInsert, decorators: [{
61
- type: Directive,
62
- args: [{
63
- selector: '[backNavigationInsert]'
64
- }]
65
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
66
- export class BaoSystemHeaderComponent {
67
- constructor(breakpointObserver, renderer) {
68
- this.breakpointObserver = breakpointObserver;
69
- this.renderer = renderer;
70
- this.screenType = 'desktop';
71
- }
72
- get textContainerChildren() {
73
- return Array.from(this.textContainer.nativeElement.children);
74
- }
75
- ngOnInit() {
76
- if ([Breakpoints.XSmall, Breakpoints.Small].some(size => this.breakpointObserver.isMatched(size))) {
77
- this.screenType = 'mobile';
78
- }
79
- else if (this.breakpointObserver.isMatched(Breakpoints.Medium)) {
80
- this.screenType = 'tablet';
81
- }
82
- else if ([Breakpoints.Large, Breakpoints.XLarge].some(size => this.breakpointObserver.isMatched(size))) {
83
- this.screenType = 'desktop';
84
- }
85
- }
86
- ngAfterViewInit() {
87
- this.formatNavigation();
88
- this.applySizeClass();
89
- }
90
- formatNavigation() {
91
- // If view is rendered on a mobile/tablet screen
92
- if (this.screenType == 'mobile' || this.screenType == 'tablet') {
93
- if (this.textContainerChildren[0].className == 'bao-breadcrumb') {
94
- // Retrieve link of parent page
95
- const breadcrumbElementsList = this.textContainerChildren[0].children[0];
96
- const breadcrumbLength = breadcrumbElementsList.children.length;
97
- const parentLink = breadcrumbElementsList.children[breadcrumbLength - 2].attributes['href'].value;
98
- // Remove Breadcrumb component and replace it with back button
99
- this.renderer.removeChild(this.textContainer.nativeElement, this.textContainerChildren[0]);
100
- const viewContainerRef = this.backButtonInsert.viewContainerRef;
101
- viewContainerRef.clear();
102
- const componentRef = viewContainerRef.createComponent(BaoBackNavigationComponent);
103
- componentRef.setInput('link', parentLink);
104
- }
105
- }
106
- }
107
- applySizeClass() {
108
- const tagInfoContainer = this.textContainer.nativeElement.childNodes[this.textContainerChildren.length - 1];
109
- if (this.screenType === 'mobile') {
110
- this.renderer.addClass(tagInfoContainer, 'mobile');
111
- }
112
- }
113
- }
114
- BaoSystemHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoSystemHeaderComponent, deps: [{ token: i2.BreakpointObserver }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
115
- BaoSystemHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: BaoSystemHeaderComponent, selector: "bao-system-header", host: { classAttribute: "bao-system-header" }, viewQueries: [{ propertyName: "textContainer", first: true, predicate: ["textContainer"], descendants: true }, { propertyName: "backButtonInsert", first: true, predicate: BaoBackNavigationInsert, descendants: true, static: true }], ngImport: i0, template: "<div class=\"left-side-content\">\n <div class=\"back-navigation-container\">\n <ng-content select=\"a\"></ng-content>\n <ng-template backNavigationInsert></ng-template>\n </div>\n <div #textContainer class=\"text-content\">\n <ng-content select=\"bao-breadcrumb\"></ng-content>\n <ng-content select=\"h1\"></ng-content>\n <div class=\"tag-info-container\">\n <ng-content select=\"bao-tag\"></ng-content>\n <span class=\"additional-info\">\n <ng-content select=\"span\"></ng-content>\n </span>\n </div>\n </div>\n</div>\n<div class=\"button-container\">\n <ng-content></ng-content>\n</div>\n", styles: ["@charset \"UTF-8\";.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-system-header{display:flex;justify-content:flex-start}.bao-system-header .left-side-content{display:inline-flex;width:75%}.bao-system-header .left-side-content .back-navigation-container a{margin-right:1.25rem;border-bottom:none}.bao-system-header .left-side-content .back-navigation-container a:hover{cursor:pointer}.bao-system-header .left-side-content .text-content{width:100%}.bao-system-header .left-side-content .text-content h1{font-weight:700;color:#212529;font-size:1.5rem;line-height:2rem;margin-bottom:.5rem}.bao-system-header .left-side-content .text-content .tag-info-container{width:100%;display:block}.bao-system-header .left-side-content .text-content .tag-info-container>span:nth-child(2):before{content:\"\\b7\";margin:0 .5rem}.bao-system-header .left-side-content .text-content .tag-info-container .additional-info>*{font-weight:400;font-size:.875rem;line-height:1.25rem}.bao-system-header .left-side-content .text-content .tag-info-container.mobile .bao-tag{margin-bottom:.25rem}.bao-system-header .left-side-content .text-content .tag-info-container.mobile .additional-info{display:block}.bao-system-header .left-side-content .text-content .tag-info-container.mobile .additional-info:before{content:none}.bao-system-header .left-side-content .text-content .tag-info-container>.bao-tag{max-width:100%}.bao-system-header .left-side-content .text-content .tag-info-container>.bao-tag>span{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bao-system-header .button-container{flex-shrink:0;margin-left:auto}.bao-system-header .button-container .bao-button{margin-left:1rem}\n"], dependencies: [{ kind: "directive", type: BaoBackNavigationInsert, selector: "[backNavigationInsert]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
116
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: BaoSystemHeaderComponent, decorators: [{
117
- type: Component,
118
- args: [{ selector: 'bao-system-header', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
119
- class: 'bao-system-header'
120
- }, template: "<div class=\"left-side-content\">\n <div class=\"back-navigation-container\">\n <ng-content select=\"a\"></ng-content>\n <ng-template backNavigationInsert></ng-template>\n </div>\n <div #textContainer class=\"text-content\">\n <ng-content select=\"bao-breadcrumb\"></ng-content>\n <ng-content select=\"h1\"></ng-content>\n <div class=\"tag-info-container\">\n <ng-content select=\"bao-tag\"></ng-content>\n <span class=\"additional-info\">\n <ng-content select=\"span\"></ng-content>\n </span>\n </div>\n </div>\n</div>\n<div class=\"button-container\">\n <ng-content></ng-content>\n</div>\n", styles: ["@charset \"UTF-8\";.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-system-header{display:flex;justify-content:flex-start}.bao-system-header .left-side-content{display:inline-flex;width:75%}.bao-system-header .left-side-content .back-navigation-container a{margin-right:1.25rem;border-bottom:none}.bao-system-header .left-side-content .back-navigation-container a:hover{cursor:pointer}.bao-system-header .left-side-content .text-content{width:100%}.bao-system-header .left-side-content .text-content h1{font-weight:700;color:#212529;font-size:1.5rem;line-height:2rem;margin-bottom:.5rem}.bao-system-header .left-side-content .text-content .tag-info-container{width:100%;display:block}.bao-system-header .left-side-content .text-content .tag-info-container>span:nth-child(2):before{content:\"\\b7\";margin:0 .5rem}.bao-system-header .left-side-content .text-content .tag-info-container .additional-info>*{font-weight:400;font-size:.875rem;line-height:1.25rem}.bao-system-header .left-side-content .text-content .tag-info-container.mobile .bao-tag{margin-bottom:.25rem}.bao-system-header .left-side-content .text-content .tag-info-container.mobile .additional-info{display:block}.bao-system-header .left-side-content .text-content .tag-info-container.mobile .additional-info:before{content:none}.bao-system-header .left-side-content .text-content .tag-info-container>.bao-tag{max-width:100%}.bao-system-header .left-side-content .text-content .tag-info-container>.bao-tag>span{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bao-system-header .button-container{flex-shrink:0;margin-left:auto}.bao-system-header .button-container .bao-button{margin-left:1rem}\n"] }]
121
- }], ctorParameters: function () { return [{ type: i2.BreakpointObserver }, { type: i0.Renderer2 }]; }, propDecorators: { textContainer: [{
122
- type: ViewChild,
123
- args: ['textContainer', { static: false }]
124
- }], backButtonInsert: [{
125
- type: ViewChild,
126
- args: [BaoBackNavigationInsert, { static: true }]
127
- }] } });
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"system-header.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/system-header/system-header.component.ts","../../../../../projects/angular-ui/src/lib/system-header/system-header.component.html"],"names":[],"mappings":"AAMA,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,SAAS,EAET,KAAK,EAKL,SAAS,EAET,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;;;;AAEtC;;;GAGG;AAeH,MAAM,OAAO,0BAA0B;IAErC,YACU,QAAmB,EACnB,UAAmC;QADnC,aAAQ,GAAR,QAAQ,CAAW;QACnB,eAAU,GAAV,UAAU,CAAyB;IAC1C,CAAC;IAEJ,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC,YAAY,EAAE;YACnD,IAAI,CAAC,QAAQ,CAAC,YAAY,CACxB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,EACzC,MAAM,EACN,OAAO,CAAC,MAAM,CAAC,CAAC,YAAY,CAC7B,CAAC;SACH;IACH,CAAC;;uHAfU,0BAA0B;2GAA1B,0BAA0B,+KAZ3B;;;;;;;OAOL;2FAKM,0BAA0B;kBAdtC,SAAS;mBAAC;oBACT,QAAQ,EAAE,+BAA+B;oBACzC,QAAQ,EAAE;;;;;;;OAOL;oBACL,IAAI,EAAE;wBACJ,KAAK,EAAE,+BAA+B;qBACvC;iBACF;yHAEU,IAAI;sBAAZ,KAAK;;AAiBR;;;GAGG;AAIH,MAAM,OAAO,uBAAuB;IAClC,YAAmB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;IAAG,CAAC;;oHAD9C,uBAAuB;wGAAvB,uBAAuB;2FAAvB,uBAAuB;kBAHnC,SAAS;mBAAC;oBACT,QAAQ,EAAE,wBAAwB;iBACnC;;AAeD,MAAM,OAAO,wBAAwB;IAQnC,YACU,kBAAsC,EACtC,QAAmB;QADnB,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,aAAQ,GAAR,QAAQ,CAAW;QAJtB,eAAU,GAAoC,SAAS,CAAC;IAK5D,CAAC;IAEJ,IAAI,qBAAqB;QACvB,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IAC/D,CAAC;IAED,QAAQ;QACN,IACE,CAAC,WAAW,CAAC,MAAM,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAClD,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,IAAI,CAAC,CACxC,EACD;YACA,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC;SAC5B;aAAM,IAAI,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE;YAChE,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC;SAC5B;aAAM,IACL,CAAC,WAAW,CAAC,KAAK,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAClD,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,IAAI,CAAC,CACxC,EACD;YACA,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;SAC7B;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEO,gBAAgB;QACtB,gDAAgD;QAChD,IAAI,IAAI,CAAC,UAAU,IAAI,QAAQ,IAAI,IAAI,CAAC,UAAU,IAAI,QAAQ,EAAE;YAC9D,IAAI,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,SAAS,IAAI,gBAAgB,EAAE;gBAC/D,+BAA+B;gBAC/B,MAAM,sBAAsB,GAC1B,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;gBAC5C,MAAM,gBAAgB,GAAG,sBAAsB,CAAC,QAAQ,CAAC,MAAM,CAAC;gBAChE,MAAM,UAAU,GACd,sBAAsB,CAAC,QAAQ,CAAC,gBAAgB,GAAG,CAAC,CAAC,CAAC,UAAU,CAC9D,MAAM,CACP,CAAC,KAAK,CAAC;gBACV,8DAA8D;gBAC9D,IAAI,CAAC,QAAQ,CAAC,WAAW,CACvB,IAAI,CAAC,aAAa,CAAC,aAAa,EAChC,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAC9B,CAAC;gBACF,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC;gBAChE,gBAAgB,CAAC,KAAK,EAAE,CAAC;gBACzB,MAAM,YAAY,GAAG,gBAAgB,CAAC,eAAe,CACnD,0BAA0B,CAC3B,CAAC;gBACF,YAAY,CAAC,QAAQ,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;aAC3C;SACF;IACH,CAAC;IAEO,cAAc;QACpB,MAAM,gBAAgB,GACpB,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CACzC,IAAI,CAAC,qBAAqB,CAAC,MAAM,GAAG,CAAC,CACtC,CAAC;QACJ,IAAI,IAAI,CAAC,UAAU,KAAK,QAAQ,EAAE;YAChC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,gBAAgB,EAAE,QAAQ,CAAC,CAAC;SACpD;IACH,CAAC;;qHA3EU,wBAAwB;yGAAxB,wBAAwB,2PAGxB,uBAAuB,8DCnFpC,8nBAmBA,guED+Ca,uBAAuB;2FAcvB,wBAAwB;kBAVpC,SAAS;+BACE,mBAAmB,iBAGd,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,QACzC;wBACJ,KAAK,EAAE,mBAAmB;qBAC3B;iIAIO,aAAa;sBADpB,SAAS;uBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAGrC,gBAAgB;sBADvB,SAAS;uBAAC,uBAAuB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["/*\n * Copyright (c) 2023 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 { BreakpointObserver } from '@angular/cdk/layout';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  Directive,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnInit,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Breakpoints } from '../core';\n\n/**\n * This component is dynamically added to replace breadcrumb when System Header is viewed on tablet or mobile screens.\n * Used internally by BaoSystemHeaderComponent only, not to be used by host application.\n */\n@Component({\n  selector: 'bao-back-navigation-component',\n  template: ` <a>\n    <bao-icon\n      color=\"action\"\n      title=\"arrow-left\"\n      svgIcon=\"icon-arrow-left\"\n      size=\"x-small\"\n    ></bao-icon>\n  </a>`,\n  host: {\n    class: 'bao-system-header-back-button'\n  }\n})\nexport class BaoBackNavigationComponent implements OnChanges {\n  @Input() link: string;\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['link'] && changes['link'].currentValue) {\n      this.renderer.setAttribute(\n        this.elementRef.nativeElement.children[0],\n        'href',\n        changes['link'].currentValue\n      );\n    }\n  }\n}\n\n/**\n * This directive is to mark the template where the BaoBackNavigationComponent should be dynamically inserted,\n * when a Breadcrumb component needs to be replaced\n */\n@Directive({\n  selector: '[backNavigationInsert]'\n})\nexport class BaoBackNavigationInsert {\n  constructor(public viewContainerRef: ViewContainerRef) {}\n}\n\n@Component({\n  selector: 'bao-system-header',\n  templateUrl: './system-header.component.html',\n  styleUrls: ['./system-header.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'bao-system-header'\n  }\n})\nexport class BaoSystemHeaderComponent implements AfterViewInit, OnInit {\n  @ViewChild('textContainer', { static: false })\n  private textContainer: ElementRef<HTMLElement>;\n  @ViewChild(BaoBackNavigationInsert, { static: true })\n  private backButtonInsert: BaoBackNavigationInsert;\n\n  public screenType: 'mobile' | 'tablet' | 'desktop' = 'desktop';\n\n  constructor(\n    private breakpointObserver: BreakpointObserver,\n    private renderer: Renderer2\n  ) {}\n\n  get textContainerChildren(): Element[] {\n    return Array.from(this.textContainer.nativeElement.children);\n  }\n\n  ngOnInit() {\n    if (\n      [Breakpoints.XSmall, Breakpoints.Small].some(size =>\n        this.breakpointObserver.isMatched(size)\n      )\n    ) {\n      this.screenType = 'mobile';\n    } else if (this.breakpointObserver.isMatched(Breakpoints.Medium)) {\n      this.screenType = 'tablet';\n    } else if (\n      [Breakpoints.Large, Breakpoints.XLarge].some(size =>\n        this.breakpointObserver.isMatched(size)\n      )\n    ) {\n      this.screenType = 'desktop';\n    }\n  }\n\n  ngAfterViewInit() {\n    this.formatNavigation();\n    this.applySizeClass();\n  }\n\n  private formatNavigation() {\n    // If view is rendered on a mobile/tablet screen\n    if (this.screenType == 'mobile' || this.screenType == 'tablet') {\n      if (this.textContainerChildren[0].className == 'bao-breadcrumb') {\n        // Retrieve link of parent page\n        const breadcrumbElementsList =\n          this.textContainerChildren[0].children[0];\n        const breadcrumbLength = breadcrumbElementsList.children.length;\n        const parentLink =\n          breadcrumbElementsList.children[breadcrumbLength - 2].attributes[\n            'href'\n          ].value;\n        // Remove Breadcrumb component and replace it with back button\n        this.renderer.removeChild(\n          this.textContainer.nativeElement,\n          this.textContainerChildren[0]\n        );\n        const viewContainerRef = this.backButtonInsert.viewContainerRef;\n        viewContainerRef.clear();\n        const componentRef = viewContainerRef.createComponent(\n          BaoBackNavigationComponent\n        );\n        componentRef.setInput('link', parentLink);\n      }\n    }\n  }\n\n  private applySizeClass() {\n    const tagInfoContainer =\n      this.textContainer.nativeElement.childNodes[\n        this.textContainerChildren.length - 1\n      ];\n    if (this.screenType === 'mobile') {\n      this.renderer.addClass(tagInfoContainer, 'mobile');\n    }\n  }\n}\n","<div class=\"left-side-content\">\n  <div class=\"back-navigation-container\">\n    <ng-content select=\"a\"></ng-content>\n    <ng-template backNavigationInsert></ng-template>\n  </div>\n  <div #textContainer class=\"text-content\">\n    <ng-content select=\"bao-breadcrumb\"></ng-content>\n    <ng-content select=\"h1\"></ng-content>\n    <div class=\"tag-info-container\">\n      <ng-content select=\"bao-tag\"></ng-content>\n      <span class=\"additional-info\">\n        <ng-content select=\"span\"></ng-content>\n      </span>\n    </div>\n  </div>\n</div>\n<div class=\"button-container\">\n  <ng-content></ng-content>\n</div>\n"]}