@villedemontreal/angular-ui 3.0.0 → 3.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/bao.module.mjs +8 -4
- package/esm2020/lib/icon/icon.component.mjs +14 -18
- package/esm2020/lib/modal/index.mjs +12 -0
- package/esm2020/lib/modal/modal-animations.mjs +29 -0
- package/esm2020/lib/modal/modal-config.mjs +65 -0
- package/esm2020/lib/modal/modal-container.mjs +254 -0
- package/esm2020/lib/modal/modal-directives.mjs +84 -0
- package/esm2020/lib/modal/modal-ref.mjs +195 -0
- package/esm2020/lib/modal/modal.mjs +291 -0
- package/esm2020/lib/modal/module.mjs +46 -0
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/villedemontreal-angular-ui.mjs +972 -23
- package/fesm2015/villedemontreal-angular-ui.mjs.map +1 -1
- package/fesm2020/villedemontreal-angular-ui.mjs +962 -21
- package/fesm2020/villedemontreal-angular-ui.mjs.map +1 -1
- package/lib/bao.module.d.ts +2 -1
- package/lib/icon/icon.component.d.ts +2 -2
- package/lib/modal/index.d.ts +6 -0
- package/lib/modal/modal-animations.d.ts +8 -0
- package/lib/modal/modal-config.d.ts +105 -0
- package/lib/modal/modal-container.d.ts +106 -0
- package/lib/modal/modal-directives.d.ts +25 -0
- package/lib/modal/modal-ref.d.ts +91 -0
- package/lib/modal/modal.d.ts +91 -0
- package/lib/modal/module.d.ts +12 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -18,6 +18,7 @@ import { BaoTagModule } from './tag';
|
|
|
18
18
|
import { BaoSummaryModule } from './summary';
|
|
19
19
|
import { BaoAvatarModule } from './avatar';
|
|
20
20
|
import { BaoTabsModule } from './tabs';
|
|
21
|
+
import { BaoModalModule } from './modal/module';
|
|
21
22
|
import * as i0 from "@angular/core";
|
|
22
23
|
export class BaoModule {
|
|
23
24
|
}
|
|
@@ -39,7 +40,8 @@ BaoModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.
|
|
|
39
40
|
BaoRadioModule,
|
|
40
41
|
BaoSummaryModule,
|
|
41
42
|
BaoAvatarModule,
|
|
42
|
-
BaoTabsModule
|
|
43
|
+
BaoTabsModule,
|
|
44
|
+
BaoModalModule
|
|
43
45
|
// TODO: reactivate once component does not depend on global css BaoBadgeModule,
|
|
44
46
|
// TODO: reactivate once component does not depend on global css BaoSnackBarModule,
|
|
45
47
|
] });
|
|
@@ -62,7 +64,8 @@ BaoModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.
|
|
|
62
64
|
BaoRadioModule,
|
|
63
65
|
BaoSummaryModule,
|
|
64
66
|
BaoAvatarModule,
|
|
65
|
-
BaoTabsModule
|
|
67
|
+
BaoTabsModule,
|
|
68
|
+
BaoModalModule
|
|
66
69
|
// TODO: reactivate once component does not depend on global css BaoBadgeModule,
|
|
67
70
|
// TODO: reactivate once component does not depend on global css BaoSnackBarModule,
|
|
68
71
|
] });
|
|
@@ -90,10 +93,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
90
93
|
BaoRadioModule,
|
|
91
94
|
BaoSummaryModule,
|
|
92
95
|
BaoAvatarModule,
|
|
93
|
-
BaoTabsModule
|
|
96
|
+
BaoTabsModule,
|
|
97
|
+
BaoModalModule
|
|
94
98
|
// TODO: reactivate once component does not depend on global css BaoBadgeModule,
|
|
95
99
|
// TODO: reactivate once component does not depend on global css BaoSnackBarModule,
|
|
96
100
|
]
|
|
97
101
|
}]
|
|
98
102
|
}] });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFvLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL2xpYi9iYW8ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDekMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ25ELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDM0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUN2QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDL0MsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDaEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFDdkMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUN2QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxPQUFPLENBQUM7QUFDckMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQzdDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDM0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUN2QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBOEJoRCxNQUFNLE9BQU8sU0FBUzs7c0dBQVQsU0FBUzt1R0FBVCxTQUFTLFlBMUJsQixhQUFhO1FBQ2IsZUFBZTtRQUNmLGNBQWM7UUFDZCxhQUFhO1FBQ2IsbUJBQW1CLGFBR25CLGFBQWE7UUFDYixlQUFlO1FBQ2YsY0FBYztRQUNkLG1CQUFtQjtRQUNuQixhQUFhO1FBQ2IsWUFBWTtRQUNaLG1CQUFtQjtRQUNuQixhQUFhO1FBQ2IseUJBQXlCO1FBQ3pCLGlCQUFpQjtRQUNqQixjQUFjO1FBQ2QsZ0JBQWdCO1FBQ2hCLGVBQWU7UUFDZixhQUFhO1FBQ2IsY0FBYztRQUNkLGdGQUFnRjtRQUNoRixtRkFBbUY7O3VHQUcxRSxTQUFTLFlBM0JYO1lBQ1AsYUFBYTtZQUNiLGVBQWU7WUFDZixjQUFjO1lBQ2QsYUFBYTtZQUNiLG1CQUFtQjtTQUNwQixFQUVDLGFBQWE7UUFDYixlQUFlO1FBQ2YsY0FBYztRQUNkLG1CQUFtQjtRQUNuQixhQUFhO1FBQ2IsWUFBWTtRQUNaLG1CQUFtQjtRQUNuQixhQUFhO1FBQ2IseUJBQXlCO1FBQ3pCLGlCQUFpQjtRQUNqQixjQUFjO1FBQ2QsZ0JBQWdCO1FBQ2hCLGVBQWU7UUFDZixhQUFhO1FBQ2IsY0FBYztRQUNkLGdGQUFnRjtRQUNoRixtRkFBbUY7OzJGQUcxRSxTQUFTO2tCQTVCckIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsYUFBYTt3QkFDYixlQUFlO3dCQUNmLGNBQWM7d0JBQ2QsYUFBYTt3QkFDYixtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxtQkFBbUI7d0JBQ25CLGFBQWE7d0JBQ2IsWUFBWTt3QkFDWixtQkFBbUI7d0JBQ25CLGFBQWE7d0JBQ2IseUJBQXlCO3dCQUN6QixpQkFBaUI7d0JBQ2pCLGNBQWM7d0JBQ2QsZ0JBQWdCO3dCQUNoQixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsY0FBYzt3QkFDZCxnRkFBZ0Y7d0JBQ2hGLG1GQUFtRjtxQkFDcEY7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDIyIFZpbGxlIGRlIE1vbnRyZWFsLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogTGljZW5zZWQgdW5kZXIgdGhlIE1JVCBsaWNlbnNlLlxuICogU2VlIExJQ0VOU0UgZmlsZSBpbiB0aGUgcHJvamVjdCByb290IGZvciBmdWxsIGxpY2Vuc2UgaW5mb3JtYXRpb24uXG4gKi9cbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCYW9BbGVydE1vZHVsZSB9IGZyb20gJy4vYWxlcnQnO1xuaW1wb3J0IHsgQmFvQnJlYWRjcnVtYk1vZHVsZSB9IGZyb20gJy4vYnJlYWRjcnVtYic7XG5pbXBvcnQgeyBCYW9CdXR0b25Nb2R1bGUgfSBmcm9tICcuL2J1dHRvbic7XG5pbXBvcnQgeyBCYW9DYXJkTW9kdWxlIH0gZnJvbSAnLi9jYXJkJztcbmltcG9ydCB7IEJhb0NoZWNrYm94TW9kdWxlIH0gZnJvbSAnLi9jaGVja2JveCc7XG5pbXBvcnQgeyBCYW9Db21tb25Db21wb25lbnRzTW9kdWxlIH0gZnJvbSAnLi9jb21tb24tY29tcG9uZW50cyc7XG5pbXBvcnQgeyBCYW9IZWFkZXJJbmZvTW9kdWxlIH0gZnJvbSAnLi9oZWFkZXItaW5mbyc7XG5pbXBvcnQgeyBCYW9JY29uTW9kdWxlIH0gZnJvbSAnLi9pY29uJztcbmltcG9ydCB7IEJhb0xpc3RNb2R1bGUgfSBmcm9tICcuL2xpc3QnO1xuaW1wb3J0IHsgQmFvUmFkaW9Nb2R1bGUgfSBmcm9tICcuL3JhZGlvJztcbmltcG9ydCB7IEJhb1RhZ01vZHVsZSB9IGZyb20gJy4vdGFnJztcbmltcG9ydCB7IEJhb1N1bW1hcnlNb2R1bGUgfSBmcm9tICcuL3N1bW1hcnknO1xuaW1wb3J0IHsgQmFvQXZhdGFyTW9kdWxlIH0gZnJvbSAnLi9hdmF0YXInO1xuaW1wb3J0IHsgQmFvVGFic01vZHVsZSB9IGZyb20gJy4vdGFicyc7XG5pbXBvcnQgeyBCYW9Nb2RhbE1vZHVsZSB9IGZyb20gJy4vbW9kYWwvbW9kdWxlJztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIEJhb0ljb25Nb2R1bGUsXG4gICAgQmFvQnV0dG9uTW9kdWxlLFxuICAgIEJhb0FsZXJ0TW9kdWxlLFxuICAgIEJhb0NhcmRNb2R1bGUsXG4gICAgQmFvQnJlYWRjcnVtYk1vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgQmFvSWNvbk1vZHVsZSxcbiAgICBCYW9CdXR0b25Nb2R1bGUsXG4gICAgQmFvQWxlcnRNb2R1bGUsXG4gICAgQmFvQnJlYWRjcnVtYk1vZHVsZSxcbiAgICBCYW9DYXJkTW9kdWxlLFxuICAgIEJhb1RhZ01vZHVsZSxcbiAgICBCYW9IZWFkZXJJbmZvTW9kdWxlLFxuICAgIEJhb0xpc3RNb2R1bGUsXG4gICAgQmFvQ29tbW9uQ29tcG9uZW50c01vZHVsZSxcbiAgICBCYW9DaGVja2JveE1vZHVsZSxcbiAgICBCYW9SYWRpb01vZHVsZSxcbiAgICBCYW9TdW1tYXJ5TW9kdWxlLFxuICAgIEJhb0F2YXRhck1vZHVsZSxcbiAgICBCYW9UYWJzTW9kdWxlLFxuICAgIEJhb01vZGFsTW9kdWxlXG4gICAgLy8gVE9ETzogcmVhY3RpdmF0ZSBvbmNlIGNvbXBvbmVudCBkb2VzIG5vdCBkZXBlbmQgb24gZ2xvYmFsIGNzcyBCYW9CYWRnZU1vZHVsZSxcbiAgICAvLyBUT0RPOiByZWFjdGl2YXRlIG9uY2UgY29tcG9uZW50IGRvZXMgbm90IGRlcGVuZCBvbiBnbG9iYWwgY3NzIEJhb1NuYWNrQmFyTW9kdWxlLFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEJhb01vZHVsZSB7fVxuIl19
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
* Licensed under the MIT license.
|
|
4
4
|
* See LICENSE file in the project root for full license information.
|
|
5
5
|
*/
|
|
6
|
-
import {
|
|
6
|
+
import { ChangeDetectionStrategy, Component, Input, ViewEncapsulation } from '@angular/core';
|
|
7
7
|
import { baoColorToHex } from '../core/colors';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
import * as i1 from "./bao-icon-registry";
|
|
@@ -17,7 +17,7 @@ const TITLE = 'title';
|
|
|
17
17
|
* `<bao-icon svgIcon="heart"></bao-icon>`
|
|
18
18
|
*/
|
|
19
19
|
export class BaoIconComponent {
|
|
20
|
-
constructor(elementRef, iconRegistry, renderer
|
|
20
|
+
constructor(elementRef, iconRegistry, renderer) {
|
|
21
21
|
this.elementRef = elementRef;
|
|
22
22
|
this.iconRegistry = iconRegistry;
|
|
23
23
|
this.renderer = renderer;
|
|
@@ -25,11 +25,6 @@ export class BaoIconComponent {
|
|
|
25
25
|
* The size of the icon
|
|
26
26
|
*/
|
|
27
27
|
this.size = 'x-small';
|
|
28
|
-
// If the user has not explicitly set aria-hidden, mark the icon as hidden, as this is
|
|
29
|
-
// the right thing to do for the majority of icon use-cases.
|
|
30
|
-
if (!ariaHidden) {
|
|
31
|
-
this.elementRef.nativeElement.setAttribute('aria-hidden', 'true');
|
|
32
|
-
}
|
|
33
28
|
this._titleId = '';
|
|
34
29
|
this._title = '';
|
|
35
30
|
this._svgIcon = '';
|
|
@@ -110,6 +105,9 @@ export class BaoIconComponent {
|
|
|
110
105
|
if (title) {
|
|
111
106
|
svg = this.addTitleToSVG(svg, title);
|
|
112
107
|
}
|
|
108
|
+
if (!title) {
|
|
109
|
+
svg.setAttribute('aria-hidden', 'true');
|
|
110
|
+
}
|
|
113
111
|
this.setSvgElement(svg);
|
|
114
112
|
}
|
|
115
113
|
}
|
|
@@ -119,16 +117,19 @@ export class BaoIconComponent {
|
|
|
119
117
|
const titleText = this.renderer.createText(title);
|
|
120
118
|
this.renderer.appendChild(titleNode, titleText);
|
|
121
119
|
this.renderer.appendChild(svg, titleNode);
|
|
120
|
+
svg.setAttribute('aria-labelledby', this._titleId);
|
|
122
121
|
return svg;
|
|
123
122
|
}
|
|
124
123
|
generateUniqueTitleId() {
|
|
125
124
|
return this.title
|
|
126
|
-
? `${this.title
|
|
125
|
+
? `${this.title
|
|
126
|
+
.replace(/[^A-Z0-9]+/gi, '')
|
|
127
|
+
.toLocaleLowerCase()}-${Math.floor(Math.random() * 10000000000000000)}`
|
|
127
128
|
: '';
|
|
128
129
|
}
|
|
129
130
|
}
|
|
130
|
-
BaoIconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoIconComponent, deps: [{ token: i0.ElementRef }, { token: i1.BaoIconDictionary }, { token: i0.Renderer2 }
|
|
131
|
-
BaoIconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BaoIconComponent, selector: "bao-icon", inputs: { color: "color", size: "size", svgIcon: "svgIcon", title: "title" }, host: { attributes: { "role": "img" }, properties: { "class.bao-icon": "true", "class.notranslate": "true", "class.bao-icon-medium": "size === \"medium\"", "class.bao-icon-small": "size === \"small\"", "class.bao-icon-x-small": "size === \"x-small\"", "class.bao-icon-xx-small": "size === \"xx-small\"", "attr.data-bao-icon-type": "\"svg\"", "
|
|
131
|
+
BaoIconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoIconComponent, deps: [{ token: i0.ElementRef }, { token: i1.BaoIconDictionary }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
|
|
132
|
+
BaoIconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BaoIconComponent, selector: "bao-icon", inputs: { color: "color", size: "size", svgIcon: "svgIcon", title: "title" }, host: { attributes: { "role": "img" }, properties: { "class.bao-icon": "true", "class.notranslate": "true", "class.bao-icon-medium": "size === \"medium\"", "class.bao-icon-small": "size === \"small\"", "class.bao-icon-x-small": "size === \"x-small\"", "class.bao-icon-xx-small": "size === \"xx-small\"", "attr.data-bao-icon-type": "\"svg\"", "style.color": "hexColor" } }, exportAs: ["baoIcon"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, styles: ["bao-icon{background-repeat:no-repeat;display:inline-block;fill:currentColor;line-height:normal}bao-icon svg{height:100%;width:100%}bao-icon.bao-icon-medium{height:2.5rem;width:2.5rem}bao-icon.bao-icon-small{height:2rem;width:2rem;line-height:1.75rem}bao-icon.bao-icon-x-small{height:1.5rem;width:1.5rem;line-height:.5rem}bao-icon.bao-icon-xx-small{height:1rem;width:1rem;line-height:.85rem}bao-icon.bao-icon-spinner{animation:spin .75s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
132
133
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoIconComponent, decorators: [{
|
|
133
134
|
type: Component,
|
|
134
135
|
args: [{ template: '<ng-content></ng-content>', selector: 'bao-icon', exportAs: 'baoIcon', host: {
|
|
@@ -141,14 +142,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
141
142
|
'[class.bao-icon-x-small]': 'size === "x-small"',
|
|
142
143
|
'[class.bao-icon-xx-small]': 'size === "xx-small"',
|
|
143
144
|
'[attr.data-bao-icon-type]': '"svg"',
|
|
144
|
-
'[attr.aria-labelledby]': 'titleId',
|
|
145
|
-
'[attr.aria-hidden]': '!title',
|
|
146
145
|
'[style.color]': 'hexColor'
|
|
147
|
-
}, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, styles: ["bao-icon{background-repeat:no-repeat;display:inline-block;fill:currentColor;line-height:normal}bao-icon.bao-icon-medium{height:2.5rem;width:2.5rem}bao-icon.bao-icon-small{height:2rem;width:2rem;line-height:1.75rem}bao-icon.bao-icon-x-small{height:1.5rem;width:1.5rem;line-height:.5rem}bao-icon.bao-icon-xx-small{height:1rem;width:1rem;line-height:.85rem}bao-icon.bao-icon-spinner{animation:spin .75s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"] }]
|
|
148
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.BaoIconDictionary }, { type: i0.Renderer2 },
|
|
149
|
-
type: Attribute,
|
|
150
|
-
args: ['aria-hidden']
|
|
151
|
-
}] }]; }, propDecorators: { color: [{
|
|
146
|
+
}, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, styles: ["bao-icon{background-repeat:no-repeat;display:inline-block;fill:currentColor;line-height:normal}bao-icon svg{height:100%;width:100%}bao-icon.bao-icon-medium{height:2.5rem;width:2.5rem}bao-icon.bao-icon-small{height:2rem;width:2rem;line-height:1.75rem}bao-icon.bao-icon-x-small{height:1.5rem;width:1.5rem;line-height:.5rem}bao-icon.bao-icon-xx-small{height:1rem;width:1rem;line-height:.85rem}bao-icon.bao-icon-spinner{animation:spin .75s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"] }]
|
|
147
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.BaoIconDictionary }, { type: i0.Renderer2 }]; }, propDecorators: { color: [{
|
|
152
148
|
type: Input
|
|
153
149
|
}], size: [{
|
|
154
150
|
type: Input
|
|
@@ -157,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
157
153
|
}], title: [{
|
|
158
154
|
type: Input
|
|
159
155
|
}] } });
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/icon/icon.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2022 Ville de Montreal. All rights reserved.\n * Licensed under the MIT license.\n * See LICENSE file in the project root for full license information.\n */\nimport {\n  Attribute,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  Renderer2,\n  ViewEncapsulation\n} from '@angular/core';\nimport { BaoColors, baoColorToHex } from '../core/colors';\nimport { BaoIconDictionary as BaoIconRegistry } from './bao-icon-registry';\n\nconst SVG_NAMESPACE = 'http://www.w3.org/2000/svg';\nconst TITLE = 'title';\n\n/**\n * Component to display an icon. It can be used in the following ways:\n *\n * - Specify the svgIcon input to load an SVG icon from a preset list of icons.\n *   Examples:\n *     `<bao-icon svgIcon=\"heart\"></bao-icon>`\n */\n@Component({\n  template: '<ng-content></ng-content>',\n  selector: 'bao-icon',\n  exportAs: 'baoIcon',\n  styleUrls: ['./icon.component.scss'],\n  host: {\n    role: 'img',\n    // '[class]': \"'bao-icon notranslate ' + svgIcon\",\n    '[class.bao-icon]': 'true',\n    '[class.notranslate]': 'true',\n    '[class.bao-icon-medium]': 'size === \"medium\"',\n    '[class.bao-icon-small]': 'size === \"small\"',\n    '[class.bao-icon-x-small]': 'size === \"x-small\"',\n    '[class.bao-icon-xx-small]': 'size === \"xx-small\"',\n    '[attr.data-bao-icon-type]': '\"svg\"',\n    '[attr.aria-labelledby]': 'titleId',\n    '[attr.aria-hidden]': '!title',\n    '[style.color]': 'hexColor'\n  },\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BaoIconComponent implements OnDestroy {\n  /** The color of the icon, if not specified the icon's parent current text color will be used */\n  @Input() public color: BaoColors;\n\n  /**\n   * The size of the icon\n   */\n  @Input() public size: 'medium' | 'small' | 'x-small' | 'xx-small' = 'x-small';\n\n  private _svgIcon: string;\n  private _title: string;\n  private _titleId: string;\n\n  // Keeps track of the elements and attributes that we've prefixed with the current path.\n  private _elementsWithExternalReferences?: Map<\n    Element,\n    { name: string; value: string }[]\n  >;\n\n  constructor(\n    private elementRef: ElementRef<HTMLElement>,\n    private iconRegistry: BaoIconRegistry,\n    private renderer: Renderer2,\n    @Attribute('aria-hidden') ariaHidden: string\n  ) {\n    // If the user has not explicitly set aria-hidden, mark the icon as hidden, as this is\n    // the right thing to do for the majority of icon use-cases.\n    if (!ariaHidden) {\n      this.elementRef.nativeElement.setAttribute('aria-hidden', 'true');\n    }\n    this._titleId = '';\n    this._title = '';\n    this._svgIcon = '';\n  }\n\n  /** Name of the icon in the SVG icon set. */\n  @Input()\n  get svgIcon(): string {\n    return this._svgIcon;\n  }\n\n  /** Title that will be used as an aria-label for the icon */\n  @Input()\n  get title(): string {\n    return this._title;\n  }\n\n  get hexColor(): string | void {\n    if (this.color) {\n      return baoColorToHex(this.color);\n    }\n  }\n\n  get titleId(): string {\n    return this._titleId;\n  }\n\n  set svgIcon(value: string) {\n    if (value !== this._svgIcon) {\n      if (value) {\n        this.updateSvgIcon(value, this.title);\n      } else if (this._svgIcon) {\n        this.clearSvgElement();\n      }\n      this._svgIcon = value;\n      this.renderer.addClass(\n        this.elementRef.nativeElement,\n        `bao-${this._svgIcon}`\n      );\n    }\n  }\n\n  set title(value: string) {\n    if (value !== this._title) {\n      this._title = value;\n      this._titleId = this.generateUniqueTitleId();\n      this.updateSvgIcon(this.svgIcon, value);\n    }\n  }\n\n  public ngOnDestroy() {\n    if (this._elementsWithExternalReferences) {\n      this._elementsWithExternalReferences.clear();\n    }\n  }\n\n  private setSvgElement(svg: SVGElement) {\n    this.clearSvgElement();\n    // Workaround for IE11 and Edge ignoring `style` tags inside dynamically-created SVGs.\n    // See: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/10898469/\n    // Do this before inserting the element into the DOM, in order to avoid a style recalculation.\n    const styleTags = svg.querySelectorAll('style');\n    // eslint-disable-next-line @typescript-eslint/prefer-for-of\n    for (let i = 0; i < styleTags.length; i++) {\n      styleTags[i].textContent += ' ';\n    }\n    this.elementRef.nativeElement.appendChild(svg);\n  }\n\n  private clearSvgElement() {\n    const layoutElement: HTMLElement = this.elementRef.nativeElement;\n    let childCount = layoutElement.childNodes.length;\n\n    if (this._elementsWithExternalReferences) {\n      this._elementsWithExternalReferences.clear();\n    }\n\n    // Remove existing non-element child nodes and SVGs, and add the new SVG element. Note that\n    // we can't use innerHTML, because IE will throw if the element has a data binding.\n    while (childCount--) {\n      const child = layoutElement.childNodes[childCount];\n\n      // 1 corresponds to Node.ELEMENT_NODE. We remove all non-element nodes in order to get rid\n      // of any loose text nodes, as well as any SVG elements in order to remove any old icons.\n      if (child.nodeType !== 1 || child.nodeName.toLowerCase() === 'svg') {\n        layoutElement.removeChild(child);\n      }\n    }\n  }\n\n  // Sets a new SVG icon with a particular name.\n  private updateSvgIcon(\n    iconName: string | undefined,\n    title: string | undefined\n  ) {\n    if (iconName) {\n      let svg = this.iconRegistry.getNamedSvgIcon(iconName);\n      if (title) {\n        svg = this.addTitleToSVG(svg, title);\n      }\n      this.setSvgElement(svg);\n    }\n  }\n\n  private addTitleToSVG(svg: SVGElement, title: string) {\n    const titleNode = this.renderer.createElement(TITLE, SVG_NAMESPACE);\n    titleNode.id = this._titleId;\n    const titleText = this.renderer.createText(title);\n    this.renderer.appendChild(titleNode, titleText);\n    this.renderer.appendChild(svg, titleNode);\n    return svg;\n  }\n\n  private generateUniqueTitleId(): string {\n    return this.title\n      ? `${this.title}-${Math.random() * 10000000000000000}`\n      : '';\n  }\n}\n"]}
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/icon/icon.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2022 Ville de Montreal. All rights reserved.\n * Licensed under the MIT license.\n * See LICENSE file in the project root for full license information.\n */\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  Renderer2,\n  ViewEncapsulation\n} from '@angular/core';\nimport { BaoColors, baoColorToHex } from '../core/colors';\nimport { BaoIconDictionary as BaoIconRegistry } from './bao-icon-registry';\n\nconst SVG_NAMESPACE = 'http://www.w3.org/2000/svg';\nconst TITLE = 'title';\n\n/**\n * Component to display an icon. It can be used in the following ways:\n *\n * - Specify the svgIcon input to load an SVG icon from a preset list of icons.\n *   Examples:\n *     `<bao-icon svgIcon=\"heart\"></bao-icon>`\n */\n@Component({\n  template: '<ng-content></ng-content>',\n  selector: 'bao-icon',\n  exportAs: 'baoIcon',\n  styleUrls: ['./icon.component.scss'],\n  host: {\n    role: 'img',\n    // '[class]': \"'bao-icon notranslate ' + svgIcon\",\n    '[class.bao-icon]': 'true',\n    '[class.notranslate]': 'true',\n    '[class.bao-icon-medium]': 'size === \"medium\"',\n    '[class.bao-icon-small]': 'size === \"small\"',\n    '[class.bao-icon-x-small]': 'size === \"x-small\"',\n    '[class.bao-icon-xx-small]': 'size === \"xx-small\"',\n    '[attr.data-bao-icon-type]': '\"svg\"',\n    '[style.color]': 'hexColor'\n  },\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BaoIconComponent implements OnDestroy {\n  /** The color of the icon, if not specified the icon's parent current text color will be used */\n  @Input() public color: BaoColors;\n\n  /**\n   * The size of the icon\n   */\n  @Input() public size: 'medium' | 'small' | 'x-small' | 'xx-small' = 'x-small';\n\n  private _svgIcon: string;\n  private _title: string;\n  private _titleId: string;\n\n  // Keeps track of the elements and attributes that we've prefixed with the current path.\n  private _elementsWithExternalReferences?: Map<\n    Element,\n    { name: string; value: string }[]\n  >;\n\n  constructor(\n    private elementRef: ElementRef<HTMLElement>,\n    private iconRegistry: BaoIconRegistry,\n    private renderer: Renderer2\n  ) {\n    this._titleId = '';\n    this._title = '';\n    this._svgIcon = '';\n  }\n\n  /** Name of the icon in the SVG icon set. */\n  @Input()\n  get svgIcon(): string {\n    return this._svgIcon;\n  }\n\n  /** Title that will be used as an aria-label for the icon */\n  @Input()\n  get title(): string {\n    return this._title;\n  }\n\n  get hexColor(): string | void {\n    if (this.color) {\n      return baoColorToHex(this.color);\n    }\n  }\n\n  get titleId(): string {\n    return this._titleId;\n  }\n\n  set svgIcon(value: string) {\n    if (value !== this._svgIcon) {\n      if (value) {\n        this.updateSvgIcon(value, this.title);\n      } else if (this._svgIcon) {\n        this.clearSvgElement();\n      }\n      this._svgIcon = value;\n      this.renderer.addClass(\n        this.elementRef.nativeElement,\n        `bao-${this._svgIcon}`\n      );\n    }\n  }\n\n  set title(value: string) {\n    if (value !== this._title) {\n      this._title = value;\n      this._titleId = this.generateUniqueTitleId();\n      this.updateSvgIcon(this.svgIcon, value);\n    }\n  }\n\n  public ngOnDestroy() {\n    if (this._elementsWithExternalReferences) {\n      this._elementsWithExternalReferences.clear();\n    }\n  }\n\n  private setSvgElement(svg: SVGElement) {\n    this.clearSvgElement();\n    // Workaround for IE11 and Edge ignoring `style` tags inside dynamically-created SVGs.\n    // See: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/10898469/\n    // Do this before inserting the element into the DOM, in order to avoid a style recalculation.\n    const styleTags = svg.querySelectorAll('style');\n    // eslint-disable-next-line @typescript-eslint/prefer-for-of\n    for (let i = 0; i < styleTags.length; i++) {\n      styleTags[i].textContent += ' ';\n    }\n    this.elementRef.nativeElement.appendChild(svg);\n  }\n\n  private clearSvgElement() {\n    const layoutElement: HTMLElement = this.elementRef.nativeElement;\n    let childCount = layoutElement.childNodes.length;\n\n    if (this._elementsWithExternalReferences) {\n      this._elementsWithExternalReferences.clear();\n    }\n\n    // Remove existing non-element child nodes and SVGs, and add the new SVG element. Note that\n    // we can't use innerHTML, because IE will throw if the element has a data binding.\n    while (childCount--) {\n      const child = layoutElement.childNodes[childCount];\n\n      // 1 corresponds to Node.ELEMENT_NODE. We remove all non-element nodes in order to get rid\n      // of any loose text nodes, as well as any SVG elements in order to remove any old icons.\n      if (child.nodeType !== 1 || child.nodeName.toLowerCase() === 'svg') {\n        layoutElement.removeChild(child);\n      }\n    }\n  }\n\n  // Sets a new SVG icon with a particular name.\n  private updateSvgIcon(\n    iconName: string | undefined,\n    title: string | undefined\n  ) {\n    if (iconName) {\n      let svg = this.iconRegistry.getNamedSvgIcon(iconName);\n      if (title) {\n        svg = this.addTitleToSVG(svg, title);\n      }\n\n      if (!title) {\n        svg.setAttribute('aria-hidden', 'true');\n      }\n\n      this.setSvgElement(svg);\n    }\n  }\n\n  private addTitleToSVG(svg: SVGElement, title: string) {\n    const titleNode = this.renderer.createElement(TITLE, SVG_NAMESPACE);\n    titleNode.id = this._titleId;\n    const titleText = this.renderer.createText(title);\n    this.renderer.appendChild(titleNode, titleText);\n    this.renderer.appendChild(svg, titleNode);\n    svg.setAttribute('aria-labelledby', this._titleId);\n    return svg;\n  }\n\n  private generateUniqueTitleId(): string {\n    return this.title\n      ? `${this.title\n          .replace(/[^A-Z0-9]+/gi, '')\n          .toLocaleLowerCase()}-${Math.floor(\n          Math.random() * 10000000000000000\n        )}`\n      : '';\n  }\n}\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2022 Ville de Montreal. All rights reserved.
|
|
3
|
+
* Licensed under the MIT license.
|
|
4
|
+
* See LICENSE file in the project root for full license information.
|
|
5
|
+
*/
|
|
6
|
+
export * from './module';
|
|
7
|
+
export * from './modal';
|
|
8
|
+
export * from './modal-container';
|
|
9
|
+
export * from './modal-config';
|
|
10
|
+
export * from './modal-ref';
|
|
11
|
+
export * from './modal-directives';
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXVpL3NyYy9saWIvbW9kYWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMiBWaWxsZSBkZSBNb250cmVhbC4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZS5cbiAqIFNlZSBMSUNFTlNFIGZpbGUgaW4gdGhlIHByb2plY3Qgcm9vdCBmb3IgZnVsbCBsaWNlbnNlIGluZm9ybWF0aW9uLlxuICovXG5leHBvcnQgKiBmcm9tICcuL21vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL21vZGFsJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kYWwtY29udGFpbmVyJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kYWwtY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kYWwtcmVmJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kYWwtZGlyZWN0aXZlcyc7XG4iXX0=
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2022 Ville de Montreal. All rights reserved.
|
|
3
|
+
* Licensed under the MIT license.
|
|
4
|
+
* See LICENSE file in the project root for full license information.
|
|
5
|
+
*/
|
|
6
|
+
import { animate, state, style, transition, trigger, query, animateChild, group } from '@angular/animations';
|
|
7
|
+
/**
|
|
8
|
+
* Animations used by MatDialog.
|
|
9
|
+
* @docs-private
|
|
10
|
+
*/
|
|
11
|
+
export const baoModalAnimations = {
|
|
12
|
+
/** Animation that is applied on the modal container by default. */
|
|
13
|
+
modalContainer: trigger('modalContainer', [
|
|
14
|
+
// Note: The `enter` animation transitions to `transform: none`, because for some reason
|
|
15
|
+
// specifying the transform explicitly, causes IE both to blur the modal content and
|
|
16
|
+
// decimate the animation performance. Leaving it as `none` solves both issues.
|
|
17
|
+
state('void, exit', style({ opacity: 0, transform: 'scale(0.7)' })),
|
|
18
|
+
state('enter', style({ transform: 'none' })),
|
|
19
|
+
transition('* => enter', group([
|
|
20
|
+
animate('150ms cubic-bezier(0, 0, 0.2, 1)', style({ transform: 'none', opacity: 1 })),
|
|
21
|
+
query('@*', animateChild(), { optional: true })
|
|
22
|
+
])),
|
|
23
|
+
transition('* => void, * => exit', group([
|
|
24
|
+
animate('75ms cubic-bezier(0.4, 0.0, 0.2, 1)', style({ opacity: 0 })),
|
|
25
|
+
query('@*', animateChild(), { optional: true })
|
|
26
|
+
]))
|
|
27
|
+
])
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtYW5pbWF0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL2xpYi9tb2RhbC9tb2RhbC1hbmltYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCxPQUFPLEVBQ0wsT0FBTyxFQUNQLEtBQUssRUFDTCxLQUFLLEVBQ0wsVUFBVSxFQUNWLE9BQU8sRUFFUCxLQUFLLEVBQ0wsWUFBWSxFQUNaLEtBQUssRUFDTixNQUFNLHFCQUFxQixDQUFDO0FBRTdCOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUUzQjtJQUNGLG1FQUFtRTtJQUNuRSxjQUFjLEVBQUUsT0FBTyxDQUFDLGdCQUFnQixFQUFFO1FBQ3hDLHdGQUF3RjtRQUN4RixvRkFBb0Y7UUFDcEYsK0VBQStFO1FBQy9FLEtBQUssQ0FBQyxZQUFZLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLENBQUMsQ0FBQztRQUNuRSxLQUFLLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDO1FBQzVDLFVBQVUsQ0FDUixZQUFZLEVBQ1osS0FBSyxDQUFDO1lBQ0osT0FBTyxDQUNMLGtDQUFrQyxFQUNsQyxLQUFLLENBQUMsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUN6QztZQUNELEtBQUssQ0FBQyxJQUFJLEVBQUUsWUFBWSxFQUFFLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUM7U0FDaEQsQ0FBQyxDQUNIO1FBQ0QsVUFBVSxDQUNSLHNCQUFzQixFQUN0QixLQUFLLENBQUM7WUFDSixPQUFPLENBQUMscUNBQXFDLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDckUsS0FBSyxDQUFDLElBQUksRUFBRSxZQUFZLEVBQUUsRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQztTQUNoRCxDQUFDLENBQ0g7S0FDRixDQUFDO0NBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjIgVmlsbGUgZGUgTW9udHJlYWwuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UuXG4gKiBTZWUgTElDRU5TRSBmaWxlIGluIHRoZSBwcm9qZWN0IHJvb3QgZm9yIGZ1bGwgbGljZW5zZSBpbmZvcm1hdGlvbi5cbiAqL1xuaW1wb3J0IHtcbiAgYW5pbWF0ZSxcbiAgc3RhdGUsXG4gIHN0eWxlLFxuICB0cmFuc2l0aW9uLFxuICB0cmlnZ2VyLFxuICBBbmltYXRpb25UcmlnZ2VyTWV0YWRhdGEsXG4gIHF1ZXJ5LFxuICBhbmltYXRlQ2hpbGQsXG4gIGdyb3VwXG59IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuXG4vKipcbiAqIEFuaW1hdGlvbnMgdXNlZCBieSBNYXREaWFsb2cuXG4gKiBAZG9jcy1wcml2YXRlXG4gKi9cbmV4cG9ydCBjb25zdCBiYW9Nb2RhbEFuaW1hdGlvbnM6IHtcbiAgcmVhZG9ubHkgbW9kYWxDb250YWluZXI6IEFuaW1hdGlvblRyaWdnZXJNZXRhZGF0YTtcbn0gPSB7XG4gIC8qKiBBbmltYXRpb24gdGhhdCBpcyBhcHBsaWVkIG9uIHRoZSBtb2RhbCBjb250YWluZXIgYnkgZGVmYXVsdC4gKi9cbiAgbW9kYWxDb250YWluZXI6IHRyaWdnZXIoJ21vZGFsQ29udGFpbmVyJywgW1xuICAgIC8vIE5vdGU6IFRoZSBgZW50ZXJgIGFuaW1hdGlvbiB0cmFuc2l0aW9ucyB0byBgdHJhbnNmb3JtOiBub25lYCwgYmVjYXVzZSBmb3Igc29tZSByZWFzb25cbiAgICAvLyBzcGVjaWZ5aW5nIHRoZSB0cmFuc2Zvcm0gZXhwbGljaXRseSwgY2F1c2VzIElFIGJvdGggdG8gYmx1ciB0aGUgbW9kYWwgY29udGVudCBhbmRcbiAgICAvLyBkZWNpbWF0ZSB0aGUgYW5pbWF0aW9uIHBlcmZvcm1hbmNlLiBMZWF2aW5nIGl0IGFzIGBub25lYCBzb2x2ZXMgYm90aCBpc3N1ZXMuXG4gICAgc3RhdGUoJ3ZvaWQsIGV4aXQnLCBzdHlsZSh7IG9wYWNpdHk6IDAsIHRyYW5zZm9ybTogJ3NjYWxlKDAuNyknIH0pKSxcbiAgICBzdGF0ZSgnZW50ZXInLCBzdHlsZSh7IHRyYW5zZm9ybTogJ25vbmUnIH0pKSxcbiAgICB0cmFuc2l0aW9uKFxuICAgICAgJyogPT4gZW50ZXInLFxuICAgICAgZ3JvdXAoW1xuICAgICAgICBhbmltYXRlKFxuICAgICAgICAgICcxNTBtcyBjdWJpYy1iZXppZXIoMCwgMCwgMC4yLCAxKScsXG4gICAgICAgICAgc3R5bGUoeyB0cmFuc2Zvcm06ICdub25lJywgb3BhY2l0eTogMSB9KVxuICAgICAgICApLFxuICAgICAgICBxdWVyeSgnQConLCBhbmltYXRlQ2hpbGQoKSwgeyBvcHRpb25hbDogdHJ1ZSB9KVxuICAgICAgXSlcbiAgICApLFxuICAgIHRyYW5zaXRpb24oXG4gICAgICAnKiA9PiB2b2lkLCAqID0+IGV4aXQnLFxuICAgICAgZ3JvdXAoW1xuICAgICAgICBhbmltYXRlKCc3NW1zIGN1YmljLWJlemllcigwLjQsIDAuMCwgMC4yLCAxKScsIHN0eWxlKHsgb3BhY2l0eTogMCB9KSksXG4gICAgICAgIHF1ZXJ5KCdAKicsIGFuaW1hdGVDaGlsZCgpLCB7IG9wdGlvbmFsOiB0cnVlIH0pXG4gICAgICBdKVxuICAgIClcbiAgXSlcbn07XG4iXX0=
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2022 Ville de Montreal. All rights reserved.
|
|
3
|
+
* Licensed under the MIT license.
|
|
4
|
+
* See LICENSE file in the project root for full license information.
|
|
5
|
+
*/
|
|
6
|
+
export var eModalDesktopWidthSize;
|
|
7
|
+
(function (eModalDesktopWidthSize) {
|
|
8
|
+
eModalDesktopWidthSize["SMALL"] = "bao-modal-sm";
|
|
9
|
+
eModalDesktopWidthSize["MEDIUM"] = "bao-modal-md";
|
|
10
|
+
eModalDesktopWidthSize["LARGE"] = "bao-modal-lg"; // Full width minus 32px (global margin : left and rigth)
|
|
11
|
+
})(eModalDesktopWidthSize || (eModalDesktopWidthSize = {}));
|
|
12
|
+
export var eModalMobileWidthSize;
|
|
13
|
+
(function (eModalMobileWidthSize) {
|
|
14
|
+
eModalMobileWidthSize["FULL"] = "bao-modal-mobil-full";
|
|
15
|
+
eModalMobileWidthSize["COMPACT"] = "bao-modal-mobil-compact"; // 300px
|
|
16
|
+
})(eModalMobileWidthSize || (eModalMobileWidthSize = {}));
|
|
17
|
+
/**
|
|
18
|
+
* Configuration for opening a modal dialog with the BaoModal service.
|
|
19
|
+
*/
|
|
20
|
+
export class BaoModalInitialConfig {
|
|
21
|
+
constructor() {
|
|
22
|
+
/** The ARIA role of the dialog element. */
|
|
23
|
+
this.role = 'dialog';
|
|
24
|
+
/** Custom class for the overlay pane. */
|
|
25
|
+
this.panelClass = '';
|
|
26
|
+
/** Whether the dialog has a backdrop. */
|
|
27
|
+
this.hasBackdrop = true;
|
|
28
|
+
/** Custom class for the backdrop. */
|
|
29
|
+
this.backdropClass = '';
|
|
30
|
+
/** Whether the user can use escape or clicking on the backdrop to close the modal. */
|
|
31
|
+
this.disableClose = false;
|
|
32
|
+
/** Width of the dialog. */
|
|
33
|
+
this.width = '';
|
|
34
|
+
/** Height of the dialog. */
|
|
35
|
+
this.height = '';
|
|
36
|
+
/** Max-width of the dialog. If a number is provided, assumes pixel units. Defaults to 80vw. */
|
|
37
|
+
this.maxWidth = '80vw';
|
|
38
|
+
/** Data being injected into the child component. */
|
|
39
|
+
this.data = null;
|
|
40
|
+
/** ID of the element that describes the dialog. */
|
|
41
|
+
this.ariaDescribedBy = null;
|
|
42
|
+
/** ID of the element that labels the dialog. */
|
|
43
|
+
this.ariaLabelledBy = null;
|
|
44
|
+
/** Aria label to assign to the dialog element. */
|
|
45
|
+
this.ariaLabel = null;
|
|
46
|
+
/**
|
|
47
|
+
* Where the dialog should focus on open.
|
|
48
|
+
*/
|
|
49
|
+
this.autoFocus = 'first-tabbable';
|
|
50
|
+
/**
|
|
51
|
+
* Whether the dialog should restore focus to the
|
|
52
|
+
* previously-focused element, after it's closed.
|
|
53
|
+
*/
|
|
54
|
+
this.restoreFocus = true;
|
|
55
|
+
/** Whether to wait for the opening animation to finish before trapping focus. */
|
|
56
|
+
this.delayFocusTrap = true;
|
|
57
|
+
/**
|
|
58
|
+
* Whether the dialog should close when the user goes backwards/forwards in history.
|
|
59
|
+
* Note that this usually doesn't include clicking on links (unless the user is using
|
|
60
|
+
* the `HashLocationStrategy`).
|
|
61
|
+
*/
|
|
62
|
+
this.closeOnNavigation = true;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11aS9zcmMvbGliL21vZGFsL21vZGFsLWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBTUgsTUFBTSxDQUFOLElBQVksc0JBSVg7QUFKRCxXQUFZLHNCQUFzQjtJQUNoQyxnREFBc0IsQ0FBQTtJQUN0QixpREFBdUIsQ0FBQTtJQUN2QixnREFBc0IsQ0FBQSxDQUFDLHlEQUF5RDtBQUNsRixDQUFDLEVBSlcsc0JBQXNCLEtBQXRCLHNCQUFzQixRQUlqQztBQUVELE1BQU0sQ0FBTixJQUFZLHFCQUdYO0FBSEQsV0FBWSxxQkFBcUI7SUFDL0Isc0RBQTZCLENBQUE7SUFDN0IsNERBQW1DLENBQUEsQ0FBQyxRQUFRO0FBQzlDLENBQUMsRUFIVyxxQkFBcUIsS0FBckIscUJBQXFCLFFBR2hDO0FBOEJEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLHFCQUFxQjtJQUFsQztRQWtCRSwyQ0FBMkM7UUFDM0MsU0FBSSxHQUFlLFFBQVEsQ0FBQztRQUU1Qix5Q0FBeUM7UUFDekMsZUFBVSxHQUF1QixFQUFFLENBQUM7UUFFcEMseUNBQXlDO1FBQ3pDLGdCQUFXLEdBQWEsSUFBSSxDQUFDO1FBRTdCLHFDQUFxQztRQUNyQyxrQkFBYSxHQUF1QixFQUFFLENBQUM7UUFFdkMsc0ZBQXNGO1FBQ3RGLGlCQUFZLEdBQWEsS0FBSyxDQUFDO1FBRS9CLDJCQUEyQjtRQUMzQixVQUFLLEdBQVksRUFBRSxDQUFDO1FBRXBCLDRCQUE0QjtRQUM1QixXQUFNLEdBQVksRUFBRSxDQUFDO1FBUXJCLCtGQUErRjtRQUMvRixhQUFRLEdBQXFCLE1BQU0sQ0FBQztRQVFwQyxvREFBb0Q7UUFDcEQsU0FBSSxHQUFjLElBQUksQ0FBQztRQUt2QixtREFBbUQ7UUFDbkQsb0JBQWUsR0FBbUIsSUFBSSxDQUFDO1FBRXZDLGdEQUFnRDtRQUNoRCxtQkFBYyxHQUFtQixJQUFJLENBQUM7UUFFdEMsa0RBQWtEO1FBQ2xELGNBQVMsR0FBbUIsSUFBSSxDQUFDO1FBRWpDOztXQUVHO1FBQ0gsY0FBUyxHQUE4QixnQkFBZ0IsQ0FBQztRQUV4RDs7O1dBR0c7UUFDSCxpQkFBWSxHQUFhLElBQUksQ0FBQztRQUU5QixpRkFBaUY7UUFDakYsbUJBQWMsR0FBYSxJQUFJLENBQUM7UUFLaEM7Ozs7V0FJRztRQUNILHNCQUFpQixHQUFhLElBQUksQ0FBQztJQUNyQyxDQUFDO0NBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDIyIFZpbGxlIGRlIE1vbnRyZWFsLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogTGljZW5zZWQgdW5kZXIgdGhlIE1JVCBsaWNlbnNlLlxuICogU2VlIExJQ0VOU0UgZmlsZSBpbiB0aGUgcHJvamVjdCByb290IGZvciBmdWxsIGxpY2Vuc2UgaW5mb3JtYXRpb24uXG4gKi9cblxuaW1wb3J0IHsgVmlld0NvbnRhaW5lclJlZiwgSW5qZWN0b3IgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpcmVjdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9iaWRpJztcbmltcG9ydCB7IFNjcm9sbFN0cmF0ZWd5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuXG5leHBvcnQgZW51bSBlTW9kYWxEZXNrdG9wV2lkdGhTaXplIHtcbiAgU01BTEwgPSAnYmFvLW1vZGFsLXNtJywgLy8gNTAwcHhcbiAgTUVESVVNID0gJ2Jhby1tb2RhbC1tZCcsIC8vIDgwMHB4XG4gIExBUkdFID0gJ2Jhby1tb2RhbC1sZycgLy8gRnVsbCB3aWR0aCBtaW51cyAzMnB4IChnbG9iYWwgbWFyZ2luIDogbGVmdCBhbmQgcmlndGgpXG59XG5cbmV4cG9ydCBlbnVtIGVNb2RhbE1vYmlsZVdpZHRoU2l6ZSB7XG4gIEZVTEwgPSAnYmFvLW1vZGFsLW1vYmlsLWZ1bGwnLCAvLyBGdWxsIHdpZHRoIG9uIG1vYmlsZSBzY3JlZW5cbiAgQ09NUEFDVCA9ICdiYW8tbW9kYWwtbW9iaWwtY29tcGFjdCcgLy8gMzAwcHhcbn1cblxuZXhwb3J0IGludGVyZmFjZSBCYW9Nb2RhbENvbmZpZyB7XG4gIHNpemU/OiBlTW9kYWxEZXNrdG9wV2lkdGhTaXplO1xuICBtb2JpbGVTaXplPzogZU1vZGFsTW9iaWxlV2lkdGhTaXplO1xuICBkYXRhPzogdW5rbm93bjtcbiAgYXJpYUxhYmVsbGVkQnk/OiBzdHJpbmc7XG59XG5cbi8qKiBPcHRpb25zIGZvciB3aGVyZSB0byBzZXQgZm9jdXMgdG8gYXV0b21hdGljYWxseSBvbiBkaWFsb2cgb3BlbiAqL1xuZXhwb3J0IHR5cGUgQXV0b0ZvY3VzVGFyZ2V0ID0gJ2RpYWxvZycgfCAnZmlyc3QtdGFiYmFibGUnIHwgJ2ZpcnN0LWhlYWRpbmcnO1xuXG4vKiogVmFsaWQgQVJJQSByb2xlcyBmb3IgYSBkaWFsb2cgZWxlbWVudC4gKi9cbmV4cG9ydCB0eXBlIE1vZGFsUm9sZSA9ICdkaWFsb2cnIHwgJ2FsZXJ0ZGlhbG9nJztcblxuLyoqIFBvc3NpYmxlIG92ZXJyaWRlcyBmb3IgYSBkaWFsb2cncyBwb3NpdGlvbi4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTW9kYWxQb3NpdGlvbiB7XG4gIC8qKiBPdmVycmlkZSBmb3IgdGhlIGRpYWxvZydzIHRvcCBwb3NpdGlvbi4gKi9cbiAgdG9wPzogc3RyaW5nO1xuXG4gIC8qKiBPdmVycmlkZSBmb3IgdGhlIGRpYWxvZydzIGJvdHRvbSBwb3NpdGlvbi4gKi9cbiAgYm90dG9tPzogc3RyaW5nO1xuXG4gIC8qKiBPdmVycmlkZSBmb3IgdGhlIGRpYWxvZydzIGxlZnQgcG9zaXRpb24uICovXG4gIGxlZnQ/OiBzdHJpbmc7XG5cbiAgLyoqIE92ZXJyaWRlIGZvciB0aGUgZGlhbG9nJ3MgcmlnaHQgcG9zaXRpb24uICovXG4gIHJpZ2h0Pzogc3RyaW5nO1xufVxuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gZm9yIG9wZW5pbmcgYSBtb2RhbCBkaWFsb2cgd2l0aCB0aGUgQmFvTW9kYWwgc2VydmljZS5cbiAqL1xuZXhwb3J0IGNsYXNzIEJhb01vZGFsSW5pdGlhbENvbmZpZzxEID0gdW5rbm93bj4ge1xuICAvKipcbiAgICogV2hlcmUgdGhlIGF0dGFjaGVkIGNvbXBvbmVudCBzaG91bGQgbGl2ZSBpbiBBbmd1bGFyJ3MgKmxvZ2ljYWwqIGNvbXBvbmVudCB0cmVlLlxuICAgKiBUaGlzIGFmZmVjdHMgd2hhdCBpcyBhdmFpbGFibGUgZm9yIGluamVjdGlvbiBhbmQgdGhlIGNoYW5nZSBkZXRlY3Rpb24gb3JkZXIgZm9yIHRoZVxuICAgKiBjb21wb25lbnQgaW5zdGFudGlhdGVkIGluc2lkZSBvZiB0aGUgZGlhbG9nLiBUaGlzIGRvZXMgbm90IGFmZmVjdCB3aGVyZSB0aGUgZGlhbG9nXG4gICAqIGNvbnRlbnQgd2lsbCBiZSByZW5kZXJlZC5cbiAgICovXG4gIHZpZXdDb250YWluZXJSZWY/OiBWaWV3Q29udGFpbmVyUmVmO1xuXG4gIC8qKlxuICAgKiBJbmplY3RvciB1c2VkIGZvciB0aGUgaW5zdGFudGlhdGlvbiBvZiB0aGUgY29tcG9uZW50IHRvIGJlIGF0dGFjaGVkLiBJZiBwcm92aWRlZCxcbiAgICogdGFrZXMgcHJlY2VkZW5jZSBvdmVyIHRoZSBpbmplY3RvciBpbmRpcmVjdGx5IHByb3ZpZGVkIGJ5IGBWaWV3Q29udGFpbmVyUmVmYC5cbiAgICovXG4gIGluamVjdG9yPzogSW5qZWN0b3I7XG5cbiAgLyoqIElEIGZvciB0aGUgZGlhbG9nLiBJZiBvbWl0dGVkLCBhIHVuaXF1ZSBvbmUgd2lsbCBiZSBnZW5lcmF0ZWQuICovXG4gIGlkPzogc3RyaW5nO1xuXG4gIC8qKiBUaGUgQVJJQSByb2xlIG9mIHRoZSBkaWFsb2cgZWxlbWVudC4gKi9cbiAgcm9sZT86IE1vZGFsUm9sZSA9ICdkaWFsb2cnO1xuXG4gIC8qKiBDdXN0b20gY2xhc3MgZm9yIHRoZSBvdmVybGF5IHBhbmUuICovXG4gIHBhbmVsQ2xhc3M/OiBzdHJpbmcgfCBzdHJpbmdbXSA9ICcnO1xuXG4gIC8qKiBXaGV0aGVyIHRoZSBkaWFsb2cgaGFzIGEgYmFja2Ryb3AuICovXG4gIGhhc0JhY2tkcm9wPzogYm9vbGVhbiA9IHRydWU7XG5cbiAgLyoqIEN1c3RvbSBjbGFzcyBmb3IgdGhlIGJhY2tkcm9wLiAqL1xuICBiYWNrZHJvcENsYXNzPzogc3RyaW5nIHwgc3RyaW5nW10gPSAnJztcblxuICAvKiogV2hldGhlciB0aGUgdXNlciBjYW4gdXNlIGVzY2FwZSBvciBjbGlja2luZyBvbiB0aGUgYmFja2Ryb3AgdG8gY2xvc2UgdGhlIG1vZGFsLiAqL1xuICBkaXNhYmxlQ2xvc2U/OiBib29sZWFuID0gZmFsc2U7XG5cbiAgLyoqIFdpZHRoIG9mIHRoZSBkaWFsb2cuICovXG4gIHdpZHRoPzogc3RyaW5nID0gJyc7XG5cbiAgLyoqIEhlaWdodCBvZiB0aGUgZGlhbG9nLiAqL1xuICBoZWlnaHQ/OiBzdHJpbmcgPSAnJztcblxuICAvKiogTWluLXdpZHRoIG9mIHRoZSBkaWFsb2cuIElmIGEgbnVtYmVyIGlzIHByb3ZpZGVkLCBhc3N1bWVzIHBpeGVsIHVuaXRzLiAqL1xuICBtaW5XaWR0aD86IG51bWJlciB8IHN0cmluZztcblxuICAvKiogTWluLWhlaWdodCBvZiB0aGUgZGlhbG9nLiBJZiBhIG51bWJlciBpcyBwcm92aWRlZCwgYXNzdW1lcyBwaXhlbCB1bml0cy4gKi9cbiAgbWluSGVpZ2h0PzogbnVtYmVyIHwgc3RyaW5nO1xuXG4gIC8qKiBNYXgtd2lkdGggb2YgdGhlIGRpYWxvZy4gSWYgYSBudW1iZXIgaXMgcHJvdmlkZWQsIGFzc3VtZXMgcGl4ZWwgdW5pdHMuIERlZmF1bHRzIHRvIDgwdncuICovXG4gIG1heFdpZHRoPzogbnVtYmVyIHwgc3RyaW5nID0gJzgwdncnO1xuXG4gIC8qKiBNYXgtaGVpZ2h0IG9mIHRoZSBkaWFsb2cuIElmIGEgbnVtYmVyIGlzIHByb3ZpZGVkLCBhc3N1bWVzIHBpeGVsIHVuaXRzLiAqL1xuICBtYXhIZWlnaHQ/OiBudW1iZXIgfCBzdHJpbmc7XG5cbiAgLyoqIFBvc2l0aW9uIG92ZXJyaWRlcy4gKi9cbiAgcG9zaXRpb24/OiBNb2RhbFBvc2l0aW9uO1xuXG4gIC8qKiBEYXRhIGJlaW5nIGluamVjdGVkIGludG8gdGhlIGNoaWxkIGNvbXBvbmVudC4gKi9cbiAgZGF0YT86IEQgfCBudWxsID0gbnVsbDtcblxuICAvKiogTGF5b3V0IGRpcmVjdGlvbiBmb3IgdGhlIGRpYWxvZydzIGNvbnRlbnQuICovXG4gIGRpcmVjdGlvbj86IERpcmVjdGlvbjtcblxuICAvKiogSUQgb2YgdGhlIGVsZW1lbnQgdGhhdCBkZXNjcmliZXMgdGhlIGRpYWxvZy4gKi9cbiAgYXJpYURlc2NyaWJlZEJ5Pzogc3RyaW5nIHwgbnVsbCA9IG51bGw7XG5cbiAgLyoqIElEIG9mIHRoZSBlbGVtZW50IHRoYXQgbGFiZWxzIHRoZSBkaWFsb2cuICovXG4gIGFyaWFMYWJlbGxlZEJ5Pzogc3RyaW5nIHwgbnVsbCA9IG51bGw7XG5cbiAgLyoqIEFyaWEgbGFiZWwgdG8gYXNzaWduIHRvIHRoZSBkaWFsb2cgZWxlbWVudC4gKi9cbiAgYXJpYUxhYmVsPzogc3RyaW5nIHwgbnVsbCA9IG51bGw7XG5cbiAgLyoqXG4gICAqIFdoZXJlIHRoZSBkaWFsb2cgc2hvdWxkIGZvY3VzIG9uIG9wZW4uXG4gICAqL1xuICBhdXRvRm9jdXM/OiBBdXRvRm9jdXNUYXJnZXQgfCBzdHJpbmcgPSAnZmlyc3QtdGFiYmFibGUnO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRoZSBkaWFsb2cgc2hvdWxkIHJlc3RvcmUgZm9jdXMgdG8gdGhlXG4gICAqIHByZXZpb3VzbHktZm9jdXNlZCBlbGVtZW50LCBhZnRlciBpdCdzIGNsb3NlZC5cbiAgICovXG4gIHJlc3RvcmVGb2N1cz86IGJvb2xlYW4gPSB0cnVlO1xuXG4gIC8qKiBXaGV0aGVyIHRvIHdhaXQgZm9yIHRoZSBvcGVuaW5nIGFuaW1hdGlvbiB0byBmaW5pc2ggYmVmb3JlIHRyYXBwaW5nIGZvY3VzLiAqL1xuICBkZWxheUZvY3VzVHJhcD86IGJvb2xlYW4gPSB0cnVlO1xuXG4gIC8qKiBTY3JvbGwgc3RyYXRlZ3kgdG8gYmUgdXNlZCBmb3IgdGhlIGRpYWxvZy4gKi9cbiAgc2Nyb2xsU3RyYXRlZ3k/OiBTY3JvbGxTdHJhdGVneTtcblxuICAvKipcbiAgICogV2hldGhlciB0aGUgZGlhbG9nIHNob3VsZCBjbG9zZSB3aGVuIHRoZSB1c2VyIGdvZXMgYmFja3dhcmRzL2ZvcndhcmRzIGluIGhpc3RvcnkuXG4gICAqIE5vdGUgdGhhdCB0aGlzIHVzdWFsbHkgZG9lc24ndCBpbmNsdWRlIGNsaWNraW5nIG9uIGxpbmtzICh1bmxlc3MgdGhlIHVzZXIgaXMgdXNpbmdcbiAgICogdGhlIGBIYXNoTG9jYXRpb25TdHJhdGVneWApLlxuICAgKi9cbiAgY2xvc2VPbk5hdmlnYXRpb24/OiBib29sZWFuID0gdHJ1ZTtcbn1cbiJdfQ==
|