@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.
- package/{esm2020 → esm2022}/lib/alert/alert.component.mjs +17 -17
- package/{esm2020 → esm2022}/lib/alert/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/alert/module.mjs +14 -14
- package/{esm2020 → esm2022}/lib/avatar/avatar.component.mjs +8 -8
- package/{esm2020 → esm2022}/lib/avatar/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/avatar/module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/badge/badge.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/badge/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/badge/module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/bao.module.mjs +58 -58
- package/{esm2020 → esm2022}/lib/breadcrumb/breadcrumb.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/breadcrumb/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/breadcrumb/module.mjs +6 -6
- package/esm2022/lib/button/button.component.mjs +100 -0
- package/{esm2020 → esm2022}/lib/button/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/button/module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/card/card.component.mjs +17 -17
- package/{esm2020 → esm2022}/lib/card/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/card/module.mjs +14 -14
- package/{esm2020 → esm2022}/lib/checkbox/checkbox-group.component.mjs +5 -5
- package/esm2022/lib/checkbox/checkbox.component.mjs +304 -0
- package/{esm2020 → esm2022}/lib/checkbox/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/checkbox/module.mjs +10 -10
- package/{esm2020 → esm2022}/lib/common-components/error-text/errorText.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/common-components/guiding-text/guidingText.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/common-components/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/common-components/label-text/labelText.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/common-components/module.mjs +12 -12
- package/{esm2020 → esm2022}/lib/common-components/title-text/titleText.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/core/breakpoints.mjs +2 -2
- package/{esm2020 → esm2022}/lib/core/colors.mjs +1 -1
- package/{esm2020 → esm2022}/lib/core/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/dropdown-menu/dropdown-menu.component.mjs +23 -23
- package/{esm2020 → esm2022}/lib/dropdown-menu/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/dropdown-menu/module.mjs +18 -18
- package/esm2022/lib/file/file-input.component.mjs +319 -0
- package/{esm2020 → esm2022}/lib/file/file-intl.mjs +8 -8
- package/{esm2020 → esm2022}/lib/file/file-preview.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/file/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/file/module.mjs +20 -20
- package/{esm2020 → esm2022}/lib/header-info/header-info.component.mjs +20 -20
- package/{esm2020 → esm2022}/lib/header-info/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/header-info/module.mjs +16 -16
- package/{esm2020 → esm2022}/lib/hyperlink/hyperlink.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/hyperlink/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/hyperlink/module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/icon/bao-icon-registry.mjs +5 -5
- package/{esm2020 → esm2022}/lib/icon/icon.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/icon/icons-dictionary.mjs +2 -2
- package/{esm2020 → esm2022}/lib/icon/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/icon/module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/list/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/list/list.component.mjs +17 -17
- package/{esm2020 → esm2022}/lib/list/module.mjs +14 -14
- package/{esm2020 → esm2022}/lib/modal/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/modal/modal-config.mjs +2 -2
- package/{esm2020 → esm2022}/lib/modal/modal-container.mjs +7 -7
- package/{esm2020 → esm2022}/lib/modal/modal-directives.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modal/modal-ref.mjs +1 -1
- package/{esm2020 → esm2022}/lib/modal/modal.mjs +8 -8
- package/{esm2020 → esm2022}/lib/modal/module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/radio/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/radio/module.mjs +20 -20
- package/{esm2020 → esm2022}/lib/radio/radio-group.component.mjs +12 -12
- package/{esm2020 → esm2022}/lib/radio/radio.component.mjs +13 -13
- package/{esm2020 → esm2022}/lib/shared/enum/display-mode.mjs +1 -1
- package/{esm2020 → esm2022}/lib/shared/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/snack-bar/index.mjs +2 -2
- package/esm2022/lib/snack-bar/module.mjs +51 -0
- package/{esm2020 → esm2022}/lib/snack-bar/simple-snack-bar.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/snack-bar/snack-bar-animations.mjs +2 -2
- package/{esm2020 → esm2022}/lib/snack-bar/snack-bar-config.mjs +1 -1
- package/{esm2020 → esm2022}/lib/snack-bar/snack-bar-container.mjs +10 -5
- package/{esm2020 → esm2022}/lib/snack-bar/snack-bar-ref.mjs +1 -1
- package/{esm2020 → esm2022}/lib/snack-bar/snack-bar.mjs +4 -4
- package/{esm2020 → esm2022}/lib/summary/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/summary/list-summary.component.mjs +8 -8
- package/{esm2020 → esm2022}/lib/summary/module.mjs +12 -12
- package/{esm2020 → esm2022}/lib/summary/summary.component.mjs +8 -8
- package/{esm2020 → esm2022}/lib/system-header/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/system-header/module.mjs +10 -10
- package/esm2022/lib/system-header/system-header.component.mjs +130 -0
- package/{esm2020 → esm2022}/lib/tabs/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/tabs/module.mjs +12 -12
- package/{esm2020 → esm2022}/lib/tabs/tabs.component.mjs +14 -14
- package/{esm2020 → esm2022}/lib/tag/index.mjs +2 -2
- package/{esm2020 → esm2022}/lib/tag/module.mjs +6 -6
- package/{esm2020 → esm2022}/lib/tag/tag.component.mjs +5 -5
- package/{esm2020 → esm2022}/public-api.mjs +2 -2
- package/{fesm2020 → fesm2022}/villedemontreal-angular-ui.mjs +585 -578
- package/fesm2022/villedemontreal-angular-ui.mjs.map +1 -0
- package/lib/alert/alert.component.d.ts +1 -1
- package/lib/avatar/avatar.component.d.ts +1 -1
- package/lib/badge/badge.component.d.ts +1 -1
- package/lib/button/button.component.d.ts +4 -4
- package/lib/card/card.component.d.ts +1 -1
- package/lib/checkbox/checkbox-group.component.d.ts +1 -1
- package/lib/checkbox/checkbox.component.d.ts +1 -1
- package/lib/common-components/label-text/labelText.component.d.ts +1 -1
- package/lib/dropdown-menu/dropdown-menu.component.d.ts +2 -2
- package/lib/file/file-input.component.d.ts +1 -1
- package/lib/file/file-preview.component.d.ts +1 -1
- package/lib/header-info/header-info.component.d.ts +1 -1
- package/lib/hyperlink/hyperlink.component.d.ts +1 -1
- package/lib/icon/icon.component.d.ts +1 -1
- package/lib/modal/modal-directives.d.ts +1 -1
- package/lib/radio/radio-group.component.d.ts +1 -1
- package/lib/radio/radio.component.d.ts +1 -1
- package/lib/summary/summary.component.d.ts +1 -1
- package/lib/system-header/system-header.component.d.ts +4 -3
- package/lib/tabs/tabs.component.d.ts +1 -1
- package/lib/tag/tag.component.d.ts +1 -1
- package/package.json +13 -19
- package/esm2020/lib/button/button.component.mjs +0 -100
- package/esm2020/lib/checkbox/checkbox.component.mjs +0 -304
- package/esm2020/lib/file/file-input.component.mjs +0 -319
- package/esm2020/lib/snack-bar/module.mjs +0 -52
- package/esm2020/lib/system-header/system-header.component.mjs +0 -128
- package/fesm2015/villedemontreal-angular-ui.mjs +0 -6119
- package/fesm2015/villedemontreal-angular-ui.mjs.map +0 -1
- package/fesm2020/villedemontreal-angular-ui.mjs.map +0 -1
- /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":"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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 */\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"]}
|