@villedemontreal/angular-ui 13.2.1 → 13.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/bao.module.mjs +12 -7
- package/esm2020/lib/button/button.component.mjs +2 -2
- package/esm2020/lib/core/breakpoints.mjs +13 -0
- package/esm2020/lib/core/index.mjs +8 -0
- package/esm2020/lib/dropdown-menu/dropdown-menu.component.mjs +10 -3
- package/esm2020/lib/modal/modal-container.mjs +2 -2
- package/esm2020/lib/snack-bar/index.mjs +12 -0
- package/esm2020/lib/snack-bar/module.mjs +54 -0
- package/esm2020/lib/snack-bar/simple-snack-bar.component.mjs +92 -0
- package/esm2020/lib/snack-bar/snack-bar-animations.mjs +28 -0
- package/esm2020/lib/snack-bar/snack-bar-config.mjs +37 -0
- package/esm2020/lib/snack-bar/snack-bar-container.mjs +272 -0
- package/esm2020/lib/snack-bar/snack-bar-ref.mjs +75 -0
- package/esm2020/lib/snack-bar/snack-bar.mjs +251 -0
- package/esm2020/lib/system-header/index.mjs +8 -0
- package/esm2020/lib/system-header/module.mjs +33 -0
- package/esm2020/lib/system-header/system-header.component.mjs +128 -0
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/villedemontreal-angular-ui.mjs +982 -16
- package/fesm2015/villedemontreal-angular-ui.mjs.map +1 -1
- package/fesm2020/villedemontreal-angular-ui.mjs +978 -16
- package/fesm2020/villedemontreal-angular-ui.mjs.map +1 -1
- package/lib/bao.module.d.ts +3 -1
- package/lib/button/button.component.d.ts +3 -3
- package/lib/core/breakpoints.d.ts +7 -0
- package/lib/core/index.d.ts +2 -0
- package/lib/snack-bar/index.d.ts +6 -0
- package/lib/snack-bar/module.d.ts +13 -0
- package/lib/snack-bar/simple-snack-bar.component.d.ts +51 -0
- package/lib/snack-bar/snack-bar-animations.d.ts +8 -0
- package/lib/snack-bar/snack-bar-config.d.ts +51 -0
- package/lib/snack-bar/snack-bar-container.d.ts +111 -0
- package/lib/snack-bar/snack-bar-ref.d.ts +51 -0
- package/lib/snack-bar/snack-bar.d.ts +89 -0
- package/lib/system-header/index.d.ts +2 -0
- package/lib/system-header/module.d.ts +9 -0
- package/lib/system-header/system-header.component.d.ts +41 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -22,6 +22,8 @@ import { BaoModalModule } from './modal/module';
|
|
|
22
22
|
import { BaoHyperlinkModule } from './hyperlink';
|
|
23
23
|
import { BaoDropdownMenuModule } from './dropdown-menu';
|
|
24
24
|
import { BaoFileModule } from './file/module';
|
|
25
|
+
import { BaoSnackBarModule } from './snack-bar/module';
|
|
26
|
+
import { BaoSystemHeaderModule } from './system-header';
|
|
25
27
|
import * as i0 from "@angular/core";
|
|
26
28
|
export class BaoModule {
|
|
27
29
|
}
|
|
@@ -48,9 +50,10 @@ BaoModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.
|
|
|
48
50
|
BaoModalModule,
|
|
49
51
|
BaoHyperlinkModule,
|
|
50
52
|
BaoDropdownMenuModule,
|
|
51
|
-
BaoFileModule
|
|
53
|
+
BaoFileModule,
|
|
54
|
+
BaoSnackBarModule,
|
|
55
|
+
BaoSystemHeaderModule
|
|
52
56
|
// TODO: reactivate once component does not depend on global css BaoBadgeModule,
|
|
53
|
-
// TODO: reactivate once component does not depend on global css BaoSnackBarModule,
|
|
54
57
|
] });
|
|
55
58
|
BaoModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaoModule, imports: [[
|
|
56
59
|
BaoIconModule,
|
|
@@ -76,9 +79,10 @@ BaoModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.
|
|
|
76
79
|
BaoModalModule,
|
|
77
80
|
BaoHyperlinkModule,
|
|
78
81
|
BaoDropdownMenuModule,
|
|
79
|
-
BaoFileModule
|
|
82
|
+
BaoFileModule,
|
|
83
|
+
BaoSnackBarModule,
|
|
84
|
+
BaoSystemHeaderModule
|
|
80
85
|
// TODO: reactivate once component does not depend on global css BaoBadgeModule,
|
|
81
|
-
// TODO: reactivate once component does not depend on global css BaoSnackBarModule,
|
|
82
86
|
] });
|
|
83
87
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaoModule, decorators: [{
|
|
84
88
|
type: NgModule,
|
|
@@ -109,10 +113,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
|
|
|
109
113
|
BaoModalModule,
|
|
110
114
|
BaoHyperlinkModule,
|
|
111
115
|
BaoDropdownMenuModule,
|
|
112
|
-
BaoFileModule
|
|
116
|
+
BaoFileModule,
|
|
117
|
+
BaoSnackBarModule,
|
|
118
|
+
BaoSystemHeaderModule
|
|
113
119
|
// TODO: reactivate once component does not depend on global css BaoBadgeModule,
|
|
114
|
-
// TODO: reactivate once component does not depend on global css BaoSnackBarModule,
|
|
115
120
|
]
|
|
116
121
|
}]
|
|
117
122
|
}] });
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFvLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL2xpYi9iYW8ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDekMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ25ELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDM0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUN2QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDL0MsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDaEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFDdkMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUN2QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxPQUFPLENBQUM7QUFDckMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQzdDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDM0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUN2QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDdkQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBbUN4RCxNQUFNLE9BQU8sU0FBUzs7dUdBQVQsU0FBUzt3R0FBVCxTQUFTLFlBL0JsQixhQUFhO1FBQ2IsZUFBZTtRQUNmLGNBQWM7UUFDZCxhQUFhO1FBQ2IsbUJBQW1CO1FBQ25CLGNBQWMsYUFHZCxhQUFhO1FBQ2IsZUFBZTtRQUNmLGNBQWM7UUFDZCxtQkFBbUI7UUFDbkIsYUFBYTtRQUNiLFlBQVk7UUFDWixtQkFBbUI7UUFDbkIsYUFBYTtRQUNiLHlCQUF5QjtRQUN6QixpQkFBaUI7UUFDakIsY0FBYztRQUNkLGdCQUFnQjtRQUNoQixlQUFlO1FBQ2YsYUFBYTtRQUNiLGNBQWM7UUFDZCxrQkFBa0I7UUFDbEIscUJBQXFCO1FBQ3JCLGFBQWE7UUFDYixpQkFBaUI7UUFDakIscUJBQXFCO1FBQ3JCLGdGQUFnRjs7d0dBR3ZFLFNBQVMsWUFoQ1g7WUFDUCxhQUFhO1lBQ2IsZUFBZTtZQUNmLGNBQWM7WUFDZCxhQUFhO1lBQ2IsbUJBQW1CO1lBQ25CLGNBQWM7U0FDZixFQUVDLGFBQWE7UUFDYixlQUFlO1FBQ2YsY0FBYztRQUNkLG1CQUFtQjtRQUNuQixhQUFhO1FBQ2IsWUFBWTtRQUNaLG1CQUFtQjtRQUNuQixhQUFhO1FBQ2IseUJBQXlCO1FBQ3pCLGlCQUFpQjtRQUNqQixjQUFjO1FBQ2QsZ0JBQWdCO1FBQ2hCLGVBQWU7UUFDZixhQUFhO1FBQ2IsY0FBYztRQUNkLGtCQUFrQjtRQUNsQixxQkFBcUI7UUFDckIsYUFBYTtRQUNiLGlCQUFpQjtRQUNqQixxQkFBcUI7UUFDckIsZ0ZBQWdGOzs0RkFHdkUsU0FBUztrQkFqQ3JCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixjQUFjO3dCQUNkLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixjQUFjO3FCQUNmO29CQUNELE9BQU8sRUFBRTt3QkFDUCxhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxtQkFBbUI7d0JBQ25CLGFBQWE7d0JBQ2IsWUFBWTt3QkFDWixtQkFBbUI7d0JBQ25CLGFBQWE7d0JBQ2IseUJBQXlCO3dCQUN6QixpQkFBaUI7d0JBQ2pCLGNBQWM7d0JBQ2QsZ0JBQWdCO3dCQUNoQixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsY0FBYzt3QkFDZCxrQkFBa0I7d0JBQ2xCLHFCQUFxQjt3QkFDckIsYUFBYTt3QkFDYixpQkFBaUI7d0JBQ2pCLHFCQUFxQjt3QkFDckIsZ0ZBQWdGO3FCQUNqRjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjMgVmlsbGUgZGUgTW9udHJlYWwuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UuXG4gKiBTZWUgTElDRU5TRSBmaWxlIGluIHRoZSBwcm9qZWN0IHJvb3QgZm9yIGZ1bGwgbGljZW5zZSBpbmZvcm1hdGlvbi5cbiAqL1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhb0FsZXJ0TW9kdWxlIH0gZnJvbSAnLi9hbGVydCc7XG5pbXBvcnQgeyBCYW9CcmVhZGNydW1iTW9kdWxlIH0gZnJvbSAnLi9icmVhZGNydW1iJztcbmltcG9ydCB7IEJhb0J1dHRvbk1vZHVsZSB9IGZyb20gJy4vYnV0dG9uJztcbmltcG9ydCB7IEJhb0NhcmRNb2R1bGUgfSBmcm9tICcuL2NhcmQnO1xuaW1wb3J0IHsgQmFvQ2hlY2tib3hNb2R1bGUgfSBmcm9tICcuL2NoZWNrYm94JztcbmltcG9ydCB7IEJhb0NvbW1vbkNvbXBvbmVudHNNb2R1bGUgfSBmcm9tICcuL2NvbW1vbi1jb21wb25lbnRzJztcbmltcG9ydCB7IEJhb0hlYWRlckluZm9Nb2R1bGUgfSBmcm9tICcuL2hlYWRlci1pbmZvJztcbmltcG9ydCB7IEJhb0ljb25Nb2R1bGUgfSBmcm9tICcuL2ljb24nO1xuaW1wb3J0IHsgQmFvTGlzdE1vZHVsZSB9IGZyb20gJy4vbGlzdCc7XG5pbXBvcnQgeyBCYW9SYWRpb01vZHVsZSB9IGZyb20gJy4vcmFkaW8nO1xuaW1wb3J0IHsgQmFvVGFnTW9kdWxlIH0gZnJvbSAnLi90YWcnO1xuaW1wb3J0IHsgQmFvU3VtbWFyeU1vZHVsZSB9IGZyb20gJy4vc3VtbWFyeSc7XG5pbXBvcnQgeyBCYW9BdmF0YXJNb2R1bGUgfSBmcm9tICcuL2F2YXRhcic7XG5pbXBvcnQgeyBCYW9UYWJzTW9kdWxlIH0gZnJvbSAnLi90YWJzJztcbmltcG9ydCB7IEJhb01vZGFsTW9kdWxlIH0gZnJvbSAnLi9tb2RhbC9tb2R1bGUnO1xuaW1wb3J0IHsgQmFvSHlwZXJsaW5rTW9kdWxlIH0gZnJvbSAnLi9oeXBlcmxpbmsnO1xuaW1wb3J0IHsgQmFvRHJvcGRvd25NZW51TW9kdWxlIH0gZnJvbSAnLi9kcm9wZG93bi1tZW51JztcbmltcG9ydCB7IEJhb0ZpbGVNb2R1bGUgfSBmcm9tICcuL2ZpbGUvbW9kdWxlJztcbmltcG9ydCB7IEJhb1NuYWNrQmFyTW9kdWxlIH0gZnJvbSAnLi9zbmFjay1iYXIvbW9kdWxlJztcbmltcG9ydCB7IEJhb1N5c3RlbUhlYWRlck1vZHVsZSB9IGZyb20gJy4vc3lzdGVtLWhlYWRlcic7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBCYW9JY29uTW9kdWxlLFxuICAgIEJhb0J1dHRvbk1vZHVsZSxcbiAgICBCYW9BbGVydE1vZHVsZSxcbiAgICBCYW9DYXJkTW9kdWxlLFxuICAgIEJhb0JyZWFkY3J1bWJNb2R1bGUsXG4gICAgQmFvTW9kYWxNb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEJhb0ljb25Nb2R1bGUsXG4gICAgQmFvQnV0dG9uTW9kdWxlLFxuICAgIEJhb0FsZXJ0TW9kdWxlLFxuICAgIEJhb0JyZWFkY3J1bWJNb2R1bGUsXG4gICAgQmFvQ2FyZE1vZHVsZSxcbiAgICBCYW9UYWdNb2R1bGUsXG4gICAgQmFvSGVhZGVySW5mb01vZHVsZSxcbiAgICBCYW9MaXN0TW9kdWxlLFxuICAgIEJhb0NvbW1vbkNvbXBvbmVudHNNb2R1bGUsXG4gICAgQmFvQ2hlY2tib3hNb2R1bGUsXG4gICAgQmFvUmFkaW9Nb2R1bGUsXG4gICAgQmFvU3VtbWFyeU1vZHVsZSxcbiAgICBCYW9BdmF0YXJNb2R1bGUsXG4gICAgQmFvVGFic01vZHVsZSxcbiAgICBCYW9Nb2RhbE1vZHVsZSxcbiAgICBCYW9IeXBlcmxpbmtNb2R1bGUsXG4gICAgQmFvRHJvcGRvd25NZW51TW9kdWxlLFxuICAgIEJhb0ZpbGVNb2R1bGUsXG4gICAgQmFvU25hY2tCYXJNb2R1bGUsXG4gICAgQmFvU3lzdGVtSGVhZGVyTW9kdWxlXG4gICAgLy8gVE9ETzogcmVhY3RpdmF0ZSBvbmNlIGNvbXBvbmVudCBkb2VzIG5vdCBkZXBlbmQgb24gZ2xvYmFsIGNzcyBCYW9CYWRnZU1vZHVsZSxcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBCYW9Nb2R1bGUge31cbiJdfQ==
|
|
@@ -53,7 +53,7 @@ export class BaoButtonComponent {
|
|
|
53
53
|
get nativeElement() {
|
|
54
54
|
return this.elementRef.nativeElement;
|
|
55
55
|
}
|
|
56
|
-
|
|
56
|
+
ngAfterContentInit() {
|
|
57
57
|
const childNodes = Array.from(this.nativeElement.childNodes);
|
|
58
58
|
const textIndex = childNodes.findIndex(c => c.nodeType === Node.TEXT_NODE);
|
|
59
59
|
this.noText = textIndex === -1;
|
|
@@ -97,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
|
|
|
97
97
|
}], fullWidth: [{
|
|
98
98
|
type: Input
|
|
99
99
|
}] } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/button/button.component.ts","../../../../../projects/angular-ui/src/lib/button/button.component.html"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EAET,KAAK,EACL,iBAAiB,EAClB,MAAM,eAAe,CAAC;;;;AAEvB,MAAM,kBAAkB,GAAG,UAAU,CAAC;AACtC,MAAM,qBAAqB,GAAG,iBAAiB,CAAC;AA+BhD,MAAM,OAAO,kBAAkB;IAwC7B,YACU,UAAmC,EACnC,GAAsB;QADtB,eAAU,GAAV,UAAU,CAAyB;QACnC,QAAG,GAAH,GAAG,CAAmB;QAzChC;;WAEG;QACa,gBAAW,GAA4B,SAAS,CAAC;QACjE;;WAEG;QACa,UAAK,GAAyC,SAAS,CAAC;QACxE;;WAEG;QACa,SAAI,GAAiC,QAAQ,CAAC;QAC9D;;WAEG;QACa,YAAO,GAAG,KAAK,CAAC;QAChC;;WAEG;QACa,aAAQ,GAAG,KAAK,CAAC;QACjC;;WAEG;QACa,4BAAuB,GAAG,YAAY,CAAC;QACvD;;WAEG;QACa,cAAS,GAAG,KAAK,CAAC;QAElC;;WAEG;QACI,WAAM,GAAG,KAAK,CAAC;QAEtB;;WAEG;QACI,cAAS,GAAG,KAAK,CAAC;IAKtB,CAAC;IAEJ,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;IACvC,CAAC;IAEM,kBAAkB;QACvB,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAC7D,MAAM,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3E,IAAI,CAAC,MAAM,GAAG,SAAS,KAAK,CAAC,CAAC,CAAC;QAC/B,MAAM,QAAQ,GAAG,UAAU,CAAC,SAAS,CACnC,CAAC,CAAC,EAAE,CACF,CAAC,CAAC,QAAQ,KAAK,kBAAkB;YACjC,CAAE,CAAiB,CAAC,SAAS,CAAC,QAAQ,CAAC,qBAAqB,CAAC,CAChE,CAAC;QACF,IAAI,CAAC,SAAS,GAAG,QAAQ,GAAG,SAAS,CAAC;QACtC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;;gHA5DU,kBAAkB;oGAAlB,kBAAkB,q6BC/C/B,0WAaA;4FDkCa,kBAAkB;kBA7B9B,SAAS;+BAQE,oBAAoB,iBAGf,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,QACzC;wBACJ,KAAK,EAAE,YAAY;wBACnB,4BAA4B,EAAE,2BAA2B;wBACzD,8BAA8B,EAAE,6BAA6B;wBAC7D,4BAA4B,EAAE,qBAAqB;wBACnD,8BAA8B,EAAE,uBAAuB;wBACvD,6BAA6B,EAAE,sBAAsB;wBACrD,0BAA0B,EAAE,kBAAkB;wBAC9C,2BAA2B,EAAE,mBAAmB;wBAChD,0BAA0B,EAAE,kBAAkB;wBAC9C,6BAA6B,EAAE,mBAAmB;wBAClD,4BAA4B,EAAE,kBAAkB;wBAChD,4BAA4B,EAAE,iBAAiB;wBAC/C,+BAA+B,EAAE,oBAAoB;qBACtD;iIAMe,WAAW;sBAA1B,KAAK;gBAIU,KAAK;sBAApB,KAAK;gBAIU,IAAI;sBAAnB,KAAK;gBAIU,OAAO;sBAAtB,KAAK;gBAIU,QAAQ;sBAAvB,KAAK;gBAIU,uBAAuB;sBAAtC,KAAK;gBAIU,SAAS;sBAAxB,KAAK","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 {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  ViewEncapsulation\n} from '@angular/core';\n\nconst BAO_ICON_NODE_NAME = 'BAO-ICON';\nconst LOADING_SPINNER_CLASS = 'loading-spinner';\n\n@Component({\n  /**\n   * There are a few cases where you give a component an attribute, such as\n   * when you want to augment a built-in element. For example, Material Design\n   * uses this technique with <button mat-button>. However, you wouldn't\n   * use this technique on a custom element.\n   */\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'button[bao-button]',\n  styleUrls: ['./button.component.scss'],\n  templateUrl: './button.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'bao-button',\n    '[class.bao-button-utility]': 'displayType === \"utility\"',\n    '[class.bao-button-editorial]': 'displayType === \"editorial\"',\n    '[class.bao-button-primary]': 'level === \"primary\"',\n    '[class.bao-button-secondary]': 'level === \"secondary\"',\n    '[class.bao-button-tertiary]': 'level === \"tertiary\"',\n    '[class.bao-button-large]': 'size === \"large\"',\n    '[class.bao-button-medium]': 'size === \"medium\"',\n    '[class.bao-button-small]': 'size === \"small\"',\n    '[class.bao-button-reversed]': 'reversed === true',\n    '[class.bao-button-loading]': 'loading === true',\n    '[class.bao-button-no-text]': 'noText === true',\n    '[class.bao-button-full-width]': 'fullWidth === true'\n  }\n})\nexport class BaoButtonComponent implements AfterContentInit {\n  /**\n   * The display type of the button\n   */\n  @Input() public displayType: 'utility' | 'editorial' = 'utility';\n  /**\n   * The hierarchy level of the button\n   */\n  @Input() public level: 'primary' | 'secondary' | 'tertiary' = 'primary';\n  /**\n   * The size of the button\n   */\n  @Input() public size: 'large' | 'medium' | 'small' = 'medium';\n  /**\n   * Flag to set the button in loading state\n   */\n  @Input() public loading = false;\n  /**\n   * Flag to set the button reversed color mode\n   */\n  @Input() public reversed = false;\n  /**\n   * The aria-label of the loading spinner if it displayed alone\n   */\n  @Input() public loadingSpinnerAriaLabel = 'chargement';\n  /**\n   * Allows the button to grow to the width of it's container\n   */\n  @Input() public fullWidth = false;\n\n  /**\n   * If there is no text, some margin/padding will be different, i.e. for the spinner\n   */\n  public noText = false;\n\n  /**\n   * If the icon is on the right of the label, the loading spinner will need to be on the right of the label\n   */\n  public rightIcon = false;\n\n  constructor(\n    private elementRef: ElementRef<HTMLElement>,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  public ngAfterContentInit() {\n    const childNodes = Array.from(this.nativeElement.childNodes);\n    const textIndex = childNodes.findIndex(c => c.nodeType === Node.TEXT_NODE);\n    this.noText = textIndex === -1;\n    const iconIdex = childNodes.findIndex(\n      c =>\n        c.nodeName === BAO_ICON_NODE_NAME &&\n        !(c as HTMLElement).classList.contains(LOADING_SPINNER_CLASS)\n    );\n    this.rightIcon = iconIdex > textIndex;\n    this.cdr.detectChanges();\n  }\n}\n","<bao-icon\n  *ngIf=\"loading && !rightIcon\"\n  class=\"loading-spinner\"\n  svgIcon=\"icon-spinner\"\n  [title]=\"loadingSpinnerAriaLabel\"\n></bao-icon>\n<ng-content></ng-content>\n<bao-icon\n  *ngIf=\"loading && rightIcon\"\n  class=\"loading-spinner loading-spinner-right\"\n  svgIcon=\"icon-spinner\"\n  [title]=\"loadingSpinnerAriaLabel\"\n></bao-icon>\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
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
|
+
export const Breakpoints = {
|
|
7
|
+
XSmall: '(max-width: 575.98px)',
|
|
8
|
+
Small: '(min-width: 576px) and (max-width: 767.98px)',
|
|
9
|
+
Medium: '(min-width: 768px) and (max-width: 991.98px)',
|
|
10
|
+
Large: '(min-width: 992px) and (max-width: 1199.98px)',
|
|
11
|
+
XLarge: '(min-width: 1200px)'
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWtwb2ludHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXVpL3NyYy9saWIvY29yZS9icmVha3BvaW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHO0lBQ3pCLE1BQU0sRUFBRSx1QkFBdUI7SUFDL0IsS0FBSyxFQUFFLDhDQUE4QztJQUNyRCxNQUFNLEVBQUUsOENBQThDO0lBQ3RELEtBQUssRUFBRSwrQ0FBK0M7SUFDdEQsTUFBTSxFQUFFLHFCQUFxQjtDQUM5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMyBWaWxsZSBkZSBNb250cmVhbC4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZS5cbiAqIFNlZSBMSUNFTlNFIGZpbGUgaW4gdGhlIHByb2plY3Qgcm9vdCBmb3IgZnVsbCBsaWNlbnNlIGluZm9ybWF0aW9uLlxuICovXG5leHBvcnQgY29uc3QgQnJlYWtwb2ludHMgPSB7XG4gIFhTbWFsbDogJyhtYXgtd2lkdGg6IDU3NS45OHB4KScsXG4gIFNtYWxsOiAnKG1pbi13aWR0aDogNTc2cHgpIGFuZCAobWF4LXdpZHRoOiA3NjcuOThweCknLFxuICBNZWRpdW06ICcobWluLXdpZHRoOiA3NjhweCkgYW5kIChtYXgtd2lkdGg6IDk5MS45OHB4KScsXG4gIExhcmdlOiAnKG1pbi13aWR0aDogOTkycHgpIGFuZCAobWF4LXdpZHRoOiAxMTk5Ljk4cHgpJyxcbiAgWExhcmdlOiAnKG1pbi13aWR0aDogMTIwMHB4KSdcbn07XG4iXX0=
|
|
@@ -0,0 +1,8 @@
|
|
|
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
|
+
export * from './colors';
|
|
7
|
+
export * from './breakpoints';
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXVpL3NyYy9saWIvY29yZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBQ0gsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDIzIFZpbGxlIGRlIE1vbnRyZWFsLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogTGljZW5zZWQgdW5kZXIgdGhlIE1JVCBsaWNlbnNlLlxuICogU2VlIExJQ0VOU0UgZmlsZSBpbiB0aGUgcHJvamVjdCByb290IGZvciBmdWxsIGxpY2Vuc2UgaW5mb3JtYXRpb24uXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vY29sb3JzJztcbmV4cG9ydCAqIGZyb20gJy4vYnJlYWtwb2ludHMnO1xuIl19
|
|
@@ -420,11 +420,18 @@ export class BaoDropdownMenuTrigger {
|
|
|
420
420
|
overlayY: 'bottom'
|
|
421
421
|
},
|
|
422
422
|
{
|
|
423
|
-
// top-right of the overlay is connected to bottom-
|
|
424
|
-
originX: '
|
|
423
|
+
// top-right of the overlay is connected to bottom-right of the origin;
|
|
424
|
+
originX: 'end',
|
|
425
425
|
originY: 'bottom',
|
|
426
426
|
overlayX: 'end',
|
|
427
427
|
overlayY: 'top'
|
|
428
|
+
},
|
|
429
|
+
{
|
|
430
|
+
// bottom-right of the overlay is connected to top-right of the origin;
|
|
431
|
+
originX: 'end',
|
|
432
|
+
originY: 'top',
|
|
433
|
+
overlayX: 'end',
|
|
434
|
+
overlayY: 'bottom'
|
|
428
435
|
}
|
|
429
436
|
]),
|
|
430
437
|
backdropClass: 'bao-overlay-transparent-backdrop',
|
|
@@ -542,4 +549,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
|
|
|
542
549
|
host: { class: 'bao-dropdown-menu-divider' }
|
|
543
550
|
}]
|
|
544
551
|
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; } });
|
|
545
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-menu.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/dropdown-menu/dropdown-menu.component.ts","../../../../../projects/angular-ui/src/lib/dropdown-menu/dropdown-menu.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  ConnectedPosition,\n  Overlay,\n  OverlayConfig,\n  OverlayRef\n} from '@angular/cdk/overlay';\nimport { DomPortal } from '@angular/cdk/portal';\nimport {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\n/**\n * Unique ID for each dropdown menu\n */\nlet dropdownMenuUniqueId = 0;\n@Directive({\n  selector: 'bao-dropdown-menu-item, [bao-dropdown-menu-item]',\n  host: {\n    class: 'bao-dropdown-menu-item',\n    '[class.bao-dropdown-menu-item-disabled]': 'disabled===true'\n  }\n})\nexport class BaoDropdownMenuItem implements AfterViewInit, OnChanges {\n  /**\n   * Is the list item disabled\n   */\n  @Input() public disabled = false;\n\n  /**\n   * Emits when menu item is clicked\n   */\n  @Output() public itemClicked = new EventEmitter();\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>,\n    private _parent: BaoDropdownMenuComponent\n  ) {}\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  @HostListener('window:keyup.space')\n  spaceKeyEvent() {\n    if (document.activeElement == this.nativeElement) {\n      this.nativeElement.click();\n    }\n  }\n\n  @HostListener('click', ['$event.target'])\n  onClick(el: HTMLElement) {\n    if (this.nativeElement.attributes['href']) {\n      this._parent.setNavigationAttribute(this.nativeElement);\n    }\n    // Prevent double-click on checkbox input that undoes the toggle\n    if (!el.classList.contains('bao-checkbox-content-container')) {\n      this.propagateClick();\n    }\n  }\n\n  @HostListener('window:keyup.enter')\n  enterKeyEvent() {\n    if (document.activeElement == this.nativeElement) {\n      if (this.nativeElement.attributes['href']) {\n        this._parent.setNavigationAttribute(this.nativeElement);\n      }\n      this.propagateClick();\n    }\n  }\n\n  public ngAfterViewInit(): void {\n    this.addContentDiv();\n    if (!this.disabled) {\n      this.renderer.setAttribute(this.nativeElement, 'tabIndex', '0');\n    }\n    this.addPaddingClass();\n    // Remove input element inside item from keyboard navigation sequence\n    if (this.nativeElement.classList.contains('has-element-left')) {\n      this.renderer.setAttribute(\n        this.nativeElement.children.item(0).firstElementChild,\n        'tabIndex',\n        '-1'\n      );\n    }\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes['disabled'] && changes['disabled'].currentValue == true) {\n      this.disableItem();\n    }\n  }\n\n  /** Regroups label and description in a new div to help with layout */\n  private addContentDiv(): void {\n    const children = Array.from(this.nativeElement.children);\n    const labelIndex = children.findIndex(\n      c => c.localName === 'bao-dropdown-menu-item-label'\n    );\n    const labelElement = children[labelIndex];\n    this.renderer.removeChild(this.nativeElement, children[labelIndex]);\n    const contentDiv = this.renderer.createElement('div');\n    this.renderer.addClass(contentDiv, 'bao-dropdown-menu-item-content');\n    this.renderer.appendChild(this.nativeElement, contentDiv);\n    this.renderer.appendChild(contentDiv, labelElement);\n    const descriptionIndex = children.findIndex(\n      c => c.localName === 'bao-dropdown-menu-item-description'\n    );\n    if (descriptionIndex > 0) {\n      const descriptionElement = children[descriptionIndex];\n      this.renderer.removeChild(this.nativeElement, children[descriptionIndex]);\n      this.renderer.appendChild(contentDiv, descriptionElement);\n    }\n  }\n\n  private addPaddingClass(): void {\n    const children = Array.from(this.nativeElement.children);\n    // Menu item has extra element next to label\n    if (children.length > 1) {\n      // Only toggle element can be on the right\n      if (children.findIndex(c => c.localName === 'bao-toggle') > 0) {\n        this.renderer.addClass(this.nativeElement, 'has-element-right');\n      }\n      // Icon, checkbox, radio button or avatar must be on the left\n      else {\n        this.renderer.addClass(this.nativeElement, 'has-element-left');\n      }\n    }\n  }\n\n  private disableItem(): void {\n    if (this.disabled) {\n      this.renderer.setAttribute(this.nativeElement, 'aria-disabled', 'true');\n      this.renderer.setAttribute(this.nativeElement, 'tabIndex', '-1');\n    }\n  }\n\n  /**\n   * This method propagates a click event to menu item children with inputs (checkbox, radio button).\n   * It emits event to close menu if item does not contain an input.\n   */\n  private propagateClick(): void {\n    let closeMenu = true;\n    for (let i = 0; i < this.nativeElement.children.length; i++) {\n      if (\n        this.nativeElement.children.item(i).firstElementChild.localName ==\n        'input'\n      ) {\n        (\n          this.nativeElement.children.item(i).firstElementChild as HTMLElement\n        ).click();\n        closeMenu = false;\n      }\n    }\n    if (closeMenu) {\n      this.itemClicked.emit();\n    }\n  }\n}\n@Component({\n  selector: 'bao-dropdown-menu',\n  templateUrl: './dropdown-menu.component.html',\n  styleUrls: ['./dropdown-menu.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'bao-dropdown-menu-container',\n    '[class.bao-overlay-transparent-backdrop]': 'isOpen===false',\n    '[class.bao-dropdown-menu-closed]': 'isOpen===false',\n    '[attr.aria-expanded]': 'isOpen'\n  }\n})\nexport class BaoDropdownMenuComponent\n  implements AfterContentInit, AfterViewInit\n{\n  /**\n   * Fired when the dropdown-menu changes its 'isOpen' value\n   */\n  @Output() public isOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * Fired when menu is closed by key event triggered from menu item\n   */\n  @Output() public isClosedByKeyEvent = new EventEmitter();\n\n  /**\n   * Content of menu to be loaded inside Overlay\n   */\n  @ViewChild('menuContent') _menuContent: ElementRef<HTMLElement>;\n\n  /**\n   * All list items inside menu\n   */\n  @ContentChildren(BaoDropdownMenuItem, { descendants: true })\n  _listItems: QueryList<BaoDropdownMenuItem>;\n\n  /**\n   * Unique identifier of the dropdown menu\n   */\n  readonly menuId = `bao-dropdown-menu-${++dropdownMenuUniqueId}`;\n\n  /**\n   * Is the dropwdown menu currently open\n   */\n  private _isOpen = false;\n\n  /**\n   * Reference to portal which is attached to Overlay\n   */\n  private _menuPortal: DomPortal;\n\n  /**\n   * Index of currently active list item\n   */\n  private _activeItemIndex: number;\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>\n  ) {}\n\n  get isOpen(): boolean {\n    return this._isOpen;\n  }\n  get activeItemIndex(): number {\n    return this._activeItemIndex;\n  }\n  get menuPortal(): DomPortal {\n    return this._menuPortal;\n  }\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n  set isOpen(isOpen: boolean) {\n    this._isOpen = isOpen;\n    this.cdr.detectChanges();\n    this.isOpenChange.emit(isOpen);\n  }\n  set activeItemIndex(index: number) {\n    this._activeItemIndex = index;\n  }\n\n  @HostListener('window:keyup.arrowup')\n  upKeyEvent() {\n    if (this.isOpen) {\n      const index = isNaN(this._activeItemIndex) ? 0 : this._activeItemIndex;\n      const nextIndex = this.getNextActivableItemIndex(index, false);\n      this.focusNextItem(nextIndex);\n    }\n  }\n\n  @HostListener('window:keyup.arrowdown')\n  downKeyEvent() {\n    if (this.isOpen) {\n      const index = isNaN(this._activeItemIndex) ? 0 : this._activeItemIndex;\n      const nextIndex = this.getNextActivableItemIndex(index, true);\n      this.focusNextItem(nextIndex);\n    }\n  }\n\n  /** Prevents focus to be lost when TAB has reached end of menu  */\n  @HostListener('window:keydown.tab')\n  tabKeyEvent() {\n    if (this.isOpen) {\n      if (document.activeElement === this._listItems.last.nativeElement) {\n        this.isClosedByKeyEvent.emit();\n      }\n    }\n  }\n\n  /** Prevents focus to be lost when SHIFT + TAB has reached beginning of menu  */\n  @HostListener('window:keydown.shift.tab')\n  shiftTabKeyEvent() {\n    if (this.isOpen) {\n      if (document.activeElement === this._listItems.first.nativeElement) {\n        this.isClosedByKeyEvent.emit();\n      }\n    }\n  }\n\n  public ngAfterViewInit(): void {\n    this.renderer.setAttribute(this.nativeElement, 'id', this.menuId);\n    this._menuPortal = new DomPortal(this._menuContent);\n  }\n\n  public ngAfterContentInit(): void {\n    this._listItems.forEach(\n      (item: BaoDropdownMenuItem): Subscription =>\n        item.itemClicked.subscribe(() => this.isClosedByKeyEvent.emit())\n    );\n  }\n\n  public focusFirstItem(): void {\n    this._activeItemIndex = 0;\n    this._listItems.first.nativeElement.focus();\n  }\n\n  public open(): void {\n    this.isOpen = true;\n  }\n\n  public close(): void {\n    this.isOpen = false;\n  }\n\n  /** Move the aria-current attribute to new active page */\n  public setNavigationAttribute(activePageElement: HTMLElement): void {\n    const previousActivePage = this._listItems.find(\n      (item: BaoDropdownMenuItem) => {\n        return item.nativeElement.attributes['aria-current'] === 'page';\n      }\n    );\n    if (previousActivePage) {\n      this.renderer.removeAttribute(\n        previousActivePage.nativeElement,\n        'aria-current'\n      );\n      this.renderer.removeClass(\n        previousActivePage.nativeElement,\n        'active-link'\n      );\n    }\n    this.renderer.setAttribute(activePageElement, 'aria-current', 'page');\n    this.renderer.addClass(activePageElement, 'active-link');\n  }\n\n  private focusNextItem(nextIndex: number): void {\n    this._activeItemIndex = nextIndex;\n    this._listItems.get(nextIndex).nativeElement.focus();\n  }\n\n  /**\n   * Finds the next activable tab index when navigating with up and down arrow or TAB keys\n   * @param currentIndex List item index which currently has focus\n   * @param isDown Whether the navigation is going in the down direction or not\n   * @param isBackward If recursive function is going backward looking for last activable item in list\n   * @returns Index of the next item that will receive focus\n   */\n  private getNextActivableItemIndex(\n    currentIndex: number,\n    isDown: boolean,\n    isBackward = false\n  ): number {\n    if (!this._listItems.get(currentIndex).disabled) {\n      if (!this.canMove(currentIndex, isDown)) {\n        return currentIndex;\n      }\n    } else {\n      if (!this.canMove(currentIndex, isDown)) {\n        const previousIndex = isDown ? currentIndex - 1 : currentIndex + 1;\n        return this.getNextActivableItemIndex(previousIndex, isDown, true);\n      }\n    }\n    const nextIndex = isDown ? currentIndex + 1 : currentIndex - 1;\n    if (this._listItems.get(nextIndex).disabled) {\n      if (isBackward) {\n        return currentIndex;\n      }\n      return this.getNextActivableItemIndex(nextIndex, isDown);\n    }\n    return nextIndex;\n  }\n\n  /**\n   * Finds if focus has reached end or beginning of list\n   * @param currentIndex List item index which currently has focus\n   * @param isDown Whether the navigation is going in the down direction or not\n   * @returns Can focus move to next item or not\n   */\n  private canMove(currentIndex: number, isDown: boolean): boolean {\n    return !(\n      (currentIndex == 0 && !isDown) ||\n      (currentIndex == this._listItems.length - 1 && isDown)\n    );\n  }\n}\n/**\n * Directive to be applied on element that will trigger the opening and closing of menu.\n */\n@Directive({\n  selector:\n    'bao-dropdown-menu-trigger, [bao-dropdown-menu-trigger], [baoDropdownMenuTriggerFor]',\n  host: { class: 'bao-dropdown-menu-trigger' }\n})\nexport class BaoDropdownMenuTrigger implements AfterViewInit, OnDestroy {\n  @Input('baoDropdownMenuTriggerFor') menu: BaoDropdownMenuComponent | null;\n  private _overlayRef: OverlayRef | null = null;\n  private _isMenuOpen = false;\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>,\n    private overlay: Overlay\n  ) {}\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  @HostListener('window:keyup.escape')\n  escapeKeyEvent() {\n    if (this._isMenuOpen) {\n      this.closeMenu();\n      this.nativeElement.focus();\n    }\n  }\n\n  /** Enter key event triggers click event which opens menu,\n   *  then focus is put on first item in the menu */\n  @HostListener('window:keyup.enter', ['$event'])\n  enterKeyEvent(event: KeyboardEvent) {\n    if (this._isMenuOpen && document.activeElement === this.nativeElement) {\n      event.stopImmediatePropagation();\n      this.menu.focusFirstItem();\n    }\n  }\n\n  @HostListener('click')\n  onClick() {\n    this.toggleMenu();\n  }\n\n  public ngAfterViewInit(): void {\n    this.renderer.setAttribute(this.nativeElement, 'role', 'button');\n    this.renderer.setAttribute(\n      this.nativeElement,\n      'aria-controls',\n      `bao-dropdown-menu-${dropdownMenuUniqueId}`\n    );\n    this.menu.isClosedByKeyEvent.subscribe(() => {\n      this.closeMenu();\n      this.nativeElement.focus();\n    });\n  }\n\n  public ngOnDestroy(): void {\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n    }\n  }\n\n  private toggleMenu(): void {\n    return this._isMenuOpen ? this.closeMenu() : this.openMenu();\n  }\n\n  private closeMenu(): void {\n    this._isMenuOpen = false;\n    this.menu.close();\n    if (this._overlayRef) {\n      this._overlayRef.detach();\n    }\n  }\n\n  private openMenu(): void {\n    if (!this.menu) {\n      return;\n    }\n    const overlayRef = this.createOverlay();\n    overlayRef.attach(this.menu.menuPortal);\n    this._isMenuOpen = true;\n    this.menu.open();\n  }\n\n  private createOverlay(): OverlayRef {\n    if (!this._overlayRef) {\n      const config = this.getOverlayConfig();\n      this._overlayRef = this.overlay.create(config);\n    }\n    this._overlayRef.backdropClick().subscribe(() => {\n      this.closeMenu();\n    });\n    return this._overlayRef;\n  }\n\n  private getOverlayConfig(): OverlayConfig {\n    return new OverlayConfig({\n      positionStrategy: this.overlay\n        .position()\n        .flexibleConnectedTo(this.elementRef)\n        .withLockedPosition()\n        .withGrowAfterOpen()\n        .withPositions([\n          {\n            // top-left of the overlay is connected to bottom-left of the origin;\n            originX: 'start',\n            originY: 'bottom',\n            overlayX: 'start',\n            overlayY: 'top'\n          } as ConnectedPosition,\n          {\n            // bottom-left of the overlay is connected to top-left of the origin;\n            originX: 'start',\n            originY: 'top',\n            overlayX: 'start',\n            overlayY: 'bottom'\n          } as ConnectedPosition,\n          {\n            // top-right of the overlay is connected to bottom-left of the origin;\n            originX: 'start',\n            originY: 'bottom',\n            overlayX: 'end',\n            overlayY: 'top'\n          } as ConnectedPosition\n        ]),\n      backdropClass: 'bao-overlay-transparent-backdrop',\n      hasBackdrop: true,\n      scrollStrategy: this.overlay.scrollStrategies.block()\n    });\n  }\n}\n/**\n * Sections of list items in menu. Apply proper styling to section's title if there is one.\n */\n@Directive({\n  selector: 'bao-dropdown-menu-section, [bao-dropdown-menu-section]',\n  host: { class: 'bao-dropdown-menu-section' }\n})\nexport class BaoDropdownMenuSection implements AfterViewInit {\n  constructor(\n    private elementRef: ElementRef<HTMLElement>,\n    private renderer: Renderer2\n  ) {}\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  public ngAfterViewInit(): void {\n    const children = Array.from(this.nativeElement.childNodes);\n    const textIndex = children.findIndex(\n      (c: ChildNode) => c.nodeName === '#text'\n    );\n    if (textIndex > -1) {\n      this.insertTitle(children, textIndex);\n    }\n  }\n\n  private insertTitle(children: ChildNode[], txtIdx: number): void {\n    const titleElement = this.renderer.createElement('h5');\n    this.renderer.setProperty(\n      titleElement,\n      'textContent',\n      children[txtIdx].nodeValue\n    );\n    this.renderer.removeChild(this.nativeElement, children[txtIdx]);\n    const listIndex = children.findIndex((c: ChildNode) => c.nodeName === 'UL');\n    this.renderer.insertBefore(\n      this.nativeElement,\n      titleElement,\n      children[listIndex]\n    );\n  }\n}\n/**\n * Label of a list item, add css class to apply proper styling.\n */\n@Directive({\n  selector: 'bao-dropdown-menu-item-label, [bao-dropdown-menu-item-label]',\n  host: { class: 'bao-dropdown-menu-item-label' }\n})\nexport class BaoDropdownMenuItemLabel {}\n/**\n * Description of a list item, add css class to apply proper styling.\n */\n@Directive({\n  selector:\n    'bao-dropdown-menu-item-description, [bao-dropdown-menu-item-description]',\n  host: { class: 'bao-dropdown-menu-item-description' }\n})\nexport class BaoDropdownMenuItemDescription {}\n/**\n * Divider to separate sections.\n */\n@Component({\n  template: `<hr />`,\n  selector: 'bao-dropdown-menu-divider, [bao-dropdown-menu-divider]',\n  host: { class: 'bao-dropdown-menu-divider' }\n})\nexport class BaoDropdownMenuDivider 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  public ngAfterContentInit(): void {\n    this.renderer.setAttribute(this.nativeElement, 'role', 'separator');\n  }\n}\n","<div #menuContent class=\"bao-dropdown-menu\" tabindex=\"-1\">\n  <ng-content></ng-content>\n</div>\n"]}
|
|
552
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-menu.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/dropdown-menu/dropdown-menu.component.ts","../../../../../projects/angular-ui/src/lib/dropdown-menu/dropdown-menu.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  ConnectedPosition,\n  Overlay,\n  OverlayConfig,\n  OverlayRef\n} from '@angular/cdk/overlay';\nimport { DomPortal } from '@angular/cdk/portal';\nimport {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\n/**\n * Unique ID for each dropdown menu\n */\nlet dropdownMenuUniqueId = 0;\n@Directive({\n  selector: 'bao-dropdown-menu-item, [bao-dropdown-menu-item]',\n  host: {\n    class: 'bao-dropdown-menu-item',\n    '[class.bao-dropdown-menu-item-disabled]': 'disabled===true'\n  }\n})\nexport class BaoDropdownMenuItem implements AfterViewInit, OnChanges {\n  /**\n   * Is the list item disabled\n   */\n  @Input() public disabled = false;\n\n  /**\n   * Emits when menu item is clicked\n   */\n  @Output() public itemClicked = new EventEmitter();\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>,\n    private _parent: BaoDropdownMenuComponent\n  ) {}\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  @HostListener('window:keyup.space')\n  spaceKeyEvent() {\n    if (document.activeElement == this.nativeElement) {\n      this.nativeElement.click();\n    }\n  }\n\n  @HostListener('click', ['$event.target'])\n  onClick(el: HTMLElement) {\n    if (this.nativeElement.attributes['href']) {\n      this._parent.setNavigationAttribute(this.nativeElement);\n    }\n    // Prevent double-click on checkbox input that undoes the toggle\n    if (!el.classList.contains('bao-checkbox-content-container')) {\n      this.propagateClick();\n    }\n  }\n\n  @HostListener('window:keyup.enter')\n  enterKeyEvent() {\n    if (document.activeElement == this.nativeElement) {\n      if (this.nativeElement.attributes['href']) {\n        this._parent.setNavigationAttribute(this.nativeElement);\n      }\n      this.propagateClick();\n    }\n  }\n\n  public ngAfterViewInit(): void {\n    this.addContentDiv();\n    if (!this.disabled) {\n      this.renderer.setAttribute(this.nativeElement, 'tabIndex', '0');\n    }\n    this.addPaddingClass();\n    // Remove input element inside item from keyboard navigation sequence\n    if (this.nativeElement.classList.contains('has-element-left')) {\n      this.renderer.setAttribute(\n        this.nativeElement.children.item(0).firstElementChild,\n        'tabIndex',\n        '-1'\n      );\n    }\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes['disabled'] && changes['disabled'].currentValue == true) {\n      this.disableItem();\n    }\n  }\n\n  /** Regroups label and description in a new div to help with layout */\n  private addContentDiv(): void {\n    const children = Array.from(this.nativeElement.children);\n    const labelIndex = children.findIndex(\n      c => c.localName === 'bao-dropdown-menu-item-label'\n    );\n    const labelElement = children[labelIndex];\n    this.renderer.removeChild(this.nativeElement, children[labelIndex]);\n    const contentDiv = this.renderer.createElement('div');\n    this.renderer.addClass(contentDiv, 'bao-dropdown-menu-item-content');\n    this.renderer.appendChild(this.nativeElement, contentDiv);\n    this.renderer.appendChild(contentDiv, labelElement);\n    const descriptionIndex = children.findIndex(\n      c => c.localName === 'bao-dropdown-menu-item-description'\n    );\n    if (descriptionIndex > 0) {\n      const descriptionElement = children[descriptionIndex];\n      this.renderer.removeChild(this.nativeElement, children[descriptionIndex]);\n      this.renderer.appendChild(contentDiv, descriptionElement);\n    }\n  }\n\n  private addPaddingClass(): void {\n    const children = Array.from(this.nativeElement.children);\n    // Menu item has extra element next to label\n    if (children.length > 1) {\n      // Only toggle element can be on the right\n      if (children.findIndex(c => c.localName === 'bao-toggle') > 0) {\n        this.renderer.addClass(this.nativeElement, 'has-element-right');\n      }\n      // Icon, checkbox, radio button or avatar must be on the left\n      else {\n        this.renderer.addClass(this.nativeElement, 'has-element-left');\n      }\n    }\n  }\n\n  private disableItem(): void {\n    if (this.disabled) {\n      this.renderer.setAttribute(this.nativeElement, 'aria-disabled', 'true');\n      this.renderer.setAttribute(this.nativeElement, 'tabIndex', '-1');\n    }\n  }\n\n  /**\n   * This method propagates a click event to menu item children with inputs (checkbox, radio button).\n   * It emits event to close menu if item does not contain an input.\n   */\n  private propagateClick(): void {\n    let closeMenu = true;\n    for (let i = 0; i < this.nativeElement.children.length; i++) {\n      if (\n        this.nativeElement.children.item(i).firstElementChild.localName ==\n        'input'\n      ) {\n        (\n          this.nativeElement.children.item(i).firstElementChild as HTMLElement\n        ).click();\n        closeMenu = false;\n      }\n    }\n    if (closeMenu) {\n      this.itemClicked.emit();\n    }\n  }\n}\n@Component({\n  selector: 'bao-dropdown-menu',\n  templateUrl: './dropdown-menu.component.html',\n  styleUrls: ['./dropdown-menu.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'bao-dropdown-menu-container',\n    '[class.bao-overlay-transparent-backdrop]': 'isOpen===false',\n    '[class.bao-dropdown-menu-closed]': 'isOpen===false',\n    '[attr.aria-expanded]': 'isOpen'\n  }\n})\nexport class BaoDropdownMenuComponent\n  implements AfterContentInit, AfterViewInit\n{\n  /**\n   * Fired when the dropdown-menu changes its 'isOpen' value\n   */\n  @Output() public isOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * Fired when menu is closed by key event triggered from menu item\n   */\n  @Output() public isClosedByKeyEvent = new EventEmitter();\n\n  /**\n   * Content of menu to be loaded inside Overlay\n   */\n  @ViewChild('menuContent') _menuContent: ElementRef<HTMLElement>;\n\n  /**\n   * All list items inside menu\n   */\n  @ContentChildren(BaoDropdownMenuItem, { descendants: true })\n  _listItems: QueryList<BaoDropdownMenuItem>;\n\n  /**\n   * Unique identifier of the dropdown menu\n   */\n  readonly menuId = `bao-dropdown-menu-${++dropdownMenuUniqueId}`;\n\n  /**\n   * Is the dropwdown menu currently open\n   */\n  private _isOpen = false;\n\n  /**\n   * Reference to portal which is attached to Overlay\n   */\n  private _menuPortal: DomPortal;\n\n  /**\n   * Index of currently active list item\n   */\n  private _activeItemIndex: number;\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>\n  ) {}\n\n  get isOpen(): boolean {\n    return this._isOpen;\n  }\n  get activeItemIndex(): number {\n    return this._activeItemIndex;\n  }\n  get menuPortal(): DomPortal {\n    return this._menuPortal;\n  }\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n  set isOpen(isOpen: boolean) {\n    this._isOpen = isOpen;\n    this.cdr.detectChanges();\n    this.isOpenChange.emit(isOpen);\n  }\n  set activeItemIndex(index: number) {\n    this._activeItemIndex = index;\n  }\n\n  @HostListener('window:keyup.arrowup')\n  upKeyEvent() {\n    if (this.isOpen) {\n      const index = isNaN(this._activeItemIndex) ? 0 : this._activeItemIndex;\n      const nextIndex = this.getNextActivableItemIndex(index, false);\n      this.focusNextItem(nextIndex);\n    }\n  }\n\n  @HostListener('window:keyup.arrowdown')\n  downKeyEvent() {\n    if (this.isOpen) {\n      const index = isNaN(this._activeItemIndex) ? 0 : this._activeItemIndex;\n      const nextIndex = this.getNextActivableItemIndex(index, true);\n      this.focusNextItem(nextIndex);\n    }\n  }\n\n  /** Prevents focus to be lost when TAB has reached end of menu  */\n  @HostListener('window:keydown.tab')\n  tabKeyEvent() {\n    if (this.isOpen) {\n      if (document.activeElement === this._listItems.last.nativeElement) {\n        this.isClosedByKeyEvent.emit();\n      }\n    }\n  }\n\n  /** Prevents focus to be lost when SHIFT + TAB has reached beginning of menu  */\n  @HostListener('window:keydown.shift.tab')\n  shiftTabKeyEvent() {\n    if (this.isOpen) {\n      if (document.activeElement === this._listItems.first.nativeElement) {\n        this.isClosedByKeyEvent.emit();\n      }\n    }\n  }\n\n  public ngAfterViewInit(): void {\n    this.renderer.setAttribute(this.nativeElement, 'id', this.menuId);\n    this._menuPortal = new DomPortal(this._menuContent);\n  }\n\n  public ngAfterContentInit(): void {\n    this._listItems.forEach(\n      (item: BaoDropdownMenuItem): Subscription =>\n        item.itemClicked.subscribe(() => this.isClosedByKeyEvent.emit())\n    );\n  }\n\n  public focusFirstItem(): void {\n    this._activeItemIndex = 0;\n    this._listItems.first.nativeElement.focus();\n  }\n\n  public open(): void {\n    this.isOpen = true;\n  }\n\n  public close(): void {\n    this.isOpen = false;\n  }\n\n  /** Move the aria-current attribute to new active page */\n  public setNavigationAttribute(activePageElement: HTMLElement): void {\n    const previousActivePage = this._listItems.find(\n      (item: BaoDropdownMenuItem) => {\n        return item.nativeElement.attributes['aria-current'] === 'page';\n      }\n    );\n    if (previousActivePage) {\n      this.renderer.removeAttribute(\n        previousActivePage.nativeElement,\n        'aria-current'\n      );\n      this.renderer.removeClass(\n        previousActivePage.nativeElement,\n        'active-link'\n      );\n    }\n    this.renderer.setAttribute(activePageElement, 'aria-current', 'page');\n    this.renderer.addClass(activePageElement, 'active-link');\n  }\n\n  private focusNextItem(nextIndex: number): void {\n    this._activeItemIndex = nextIndex;\n    this._listItems.get(nextIndex).nativeElement.focus();\n  }\n\n  /**\n   * Finds the next activable tab index when navigating with up and down arrow or TAB keys\n   * @param currentIndex List item index which currently has focus\n   * @param isDown Whether the navigation is going in the down direction or not\n   * @param isBackward If recursive function is going backward looking for last activable item in list\n   * @returns Index of the next item that will receive focus\n   */\n  private getNextActivableItemIndex(\n    currentIndex: number,\n    isDown: boolean,\n    isBackward = false\n  ): number {\n    if (!this._listItems.get(currentIndex).disabled) {\n      if (!this.canMove(currentIndex, isDown)) {\n        return currentIndex;\n      }\n    } else {\n      if (!this.canMove(currentIndex, isDown)) {\n        const previousIndex = isDown ? currentIndex - 1 : currentIndex + 1;\n        return this.getNextActivableItemIndex(previousIndex, isDown, true);\n      }\n    }\n    const nextIndex = isDown ? currentIndex + 1 : currentIndex - 1;\n    if (this._listItems.get(nextIndex).disabled) {\n      if (isBackward) {\n        return currentIndex;\n      }\n      return this.getNextActivableItemIndex(nextIndex, isDown);\n    }\n    return nextIndex;\n  }\n\n  /**\n   * Finds if focus has reached end or beginning of list\n   * @param currentIndex List item index which currently has focus\n   * @param isDown Whether the navigation is going in the down direction or not\n   * @returns Can focus move to next item or not\n   */\n  private canMove(currentIndex: number, isDown: boolean): boolean {\n    return !(\n      (currentIndex == 0 && !isDown) ||\n      (currentIndex == this._listItems.length - 1 && isDown)\n    );\n  }\n}\n/**\n * Directive to be applied on element that will trigger the opening and closing of menu.\n */\n@Directive({\n  selector:\n    'bao-dropdown-menu-trigger, [bao-dropdown-menu-trigger], [baoDropdownMenuTriggerFor]',\n  host: { class: 'bao-dropdown-menu-trigger' }\n})\nexport class BaoDropdownMenuTrigger implements AfterViewInit, OnDestroy {\n  @Input('baoDropdownMenuTriggerFor') menu: BaoDropdownMenuComponent | null;\n  private _overlayRef: OverlayRef | null = null;\n  private _isMenuOpen = false;\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>,\n    private overlay: Overlay\n  ) {}\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  @HostListener('window:keyup.escape')\n  escapeKeyEvent() {\n    if (this._isMenuOpen) {\n      this.closeMenu();\n      this.nativeElement.focus();\n    }\n  }\n\n  /** Enter key event triggers click event which opens menu,\n   *  then focus is put on first item in the menu */\n  @HostListener('window:keyup.enter', ['$event'])\n  enterKeyEvent(event: KeyboardEvent) {\n    if (this._isMenuOpen && document.activeElement === this.nativeElement) {\n      event.stopImmediatePropagation();\n      this.menu.focusFirstItem();\n    }\n  }\n\n  @HostListener('click')\n  onClick() {\n    this.toggleMenu();\n  }\n\n  public ngAfterViewInit(): void {\n    this.renderer.setAttribute(this.nativeElement, 'role', 'button');\n    this.renderer.setAttribute(\n      this.nativeElement,\n      'aria-controls',\n      `bao-dropdown-menu-${dropdownMenuUniqueId}`\n    );\n    this.menu.isClosedByKeyEvent.subscribe(() => {\n      this.closeMenu();\n      this.nativeElement.focus();\n    });\n  }\n\n  public ngOnDestroy(): void {\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n    }\n  }\n\n  private toggleMenu(): void {\n    return this._isMenuOpen ? this.closeMenu() : this.openMenu();\n  }\n\n  private closeMenu(): void {\n    this._isMenuOpen = false;\n    this.menu.close();\n    if (this._overlayRef) {\n      this._overlayRef.detach();\n    }\n  }\n\n  private openMenu(): void {\n    if (!this.menu) {\n      return;\n    }\n    const overlayRef = this.createOverlay();\n    overlayRef.attach(this.menu.menuPortal);\n    this._isMenuOpen = true;\n    this.menu.open();\n  }\n\n  private createOverlay(): OverlayRef {\n    if (!this._overlayRef) {\n      const config = this.getOverlayConfig();\n      this._overlayRef = this.overlay.create(config);\n    }\n    this._overlayRef.backdropClick().subscribe(() => {\n      this.closeMenu();\n    });\n    return this._overlayRef;\n  }\n\n  private getOverlayConfig(): OverlayConfig {\n    return new OverlayConfig({\n      positionStrategy: this.overlay\n        .position()\n        .flexibleConnectedTo(this.elementRef)\n        .withLockedPosition()\n        .withGrowAfterOpen()\n        .withPositions([\n          {\n            // top-left of the overlay is connected to bottom-left of the origin;\n            originX: 'start',\n            originY: 'bottom',\n            overlayX: 'start',\n            overlayY: 'top'\n          } as ConnectedPosition,\n          {\n            // bottom-left of the overlay is connected to top-left of the origin;\n            originX: 'start',\n            originY: 'top',\n            overlayX: 'start',\n            overlayY: 'bottom'\n          } as ConnectedPosition,\n          {\n            // top-right of the overlay is connected to bottom-right of the origin;\n            originX: 'end',\n            originY: 'bottom',\n            overlayX: 'end',\n            overlayY: 'top'\n          } as ConnectedPosition,\n          {\n            // bottom-right of the overlay is connected to top-right of the origin;\n            originX: 'end',\n            originY: 'top',\n            overlayX: 'end',\n            overlayY: 'bottom'\n          } as ConnectedPosition\n        ]),\n      backdropClass: 'bao-overlay-transparent-backdrop',\n      hasBackdrop: true,\n      scrollStrategy: this.overlay.scrollStrategies.block()\n    });\n  }\n}\n/**\n * Sections of list items in menu. Apply proper styling to section's title if there is one.\n */\n@Directive({\n  selector: 'bao-dropdown-menu-section, [bao-dropdown-menu-section]',\n  host: { class: 'bao-dropdown-menu-section' }\n})\nexport class BaoDropdownMenuSection implements AfterViewInit {\n  constructor(\n    private elementRef: ElementRef<HTMLElement>,\n    private renderer: Renderer2\n  ) {}\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  public ngAfterViewInit(): void {\n    const children = Array.from(this.nativeElement.childNodes);\n    const textIndex = children.findIndex(\n      (c: ChildNode) => c.nodeName === '#text'\n    );\n    if (textIndex > -1) {\n      this.insertTitle(children, textIndex);\n    }\n  }\n\n  private insertTitle(children: ChildNode[], txtIdx: number): void {\n    const titleElement = this.renderer.createElement('h5');\n    this.renderer.setProperty(\n      titleElement,\n      'textContent',\n      children[txtIdx].nodeValue\n    );\n    this.renderer.removeChild(this.nativeElement, children[txtIdx]);\n    const listIndex = children.findIndex((c: ChildNode) => c.nodeName === 'UL');\n    this.renderer.insertBefore(\n      this.nativeElement,\n      titleElement,\n      children[listIndex]\n    );\n  }\n}\n/**\n * Label of a list item, add css class to apply proper styling.\n */\n@Directive({\n  selector: 'bao-dropdown-menu-item-label, [bao-dropdown-menu-item-label]',\n  host: { class: 'bao-dropdown-menu-item-label' }\n})\nexport class BaoDropdownMenuItemLabel {}\n/**\n * Description of a list item, add css class to apply proper styling.\n */\n@Directive({\n  selector:\n    'bao-dropdown-menu-item-description, [bao-dropdown-menu-item-description]',\n  host: { class: 'bao-dropdown-menu-item-description' }\n})\nexport class BaoDropdownMenuItemDescription {}\n/**\n * Divider to separate sections.\n */\n@Component({\n  template: `<hr />`,\n  selector: 'bao-dropdown-menu-divider, [bao-dropdown-menu-divider]',\n  host: { class: 'bao-dropdown-menu-divider' }\n})\nexport class BaoDropdownMenuDivider 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  public ngAfterContentInit(): void {\n    this.renderer.setAttribute(this.nativeElement, 'role', 'separator');\n  }\n}\n","<div #menuContent class=\"bao-dropdown-menu\" tabindex=\"-1\">\n  <ng-content></ng-content>\n</div>\n"]}
|
|
@@ -223,7 +223,7 @@ export class BaoModalContainer extends _BaoModalContainerBase {
|
|
|
223
223
|
}
|
|
224
224
|
}
|
|
225
225
|
BaoModalContainer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaoModalContainer, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
226
|
-
BaoModalContainer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: BaoModalContainer, selector: "bao-modal-container", host: { attributes: { "tabindex": "-1", "aria-modal": "true" }, properties: { "id": "_id", "attr.role": "_config.role", "attr.aria-labelledby": "_config.ariaLabel ? null : _ariaLabelledBy", "attr.aria-label": "_config.ariaLabel", "attr.aria-describedby": "_config.ariaDescribedBy || null" }, classAttribute: "bao-modal-container" }, usesInheritance: true, ngImport: i0, template: "<ng-template cdkPortalOutlet></ng-template>\n", styles: [".bao-container{padding-right:16px;padding-left:16px;margin-right:auto;margin-left:auto;width:100%}@media (min-width: 576px){.bao-container{max-width:576px}}@media (min-width: 768px){.bao-container{max-width:768px}}@media (min-width: 992px){.bao-container{max-width:992px}}@media (min-width: 1200px){.bao-container{max-width:1200px}}.bao-row{display:flex;flex-wrap:wrap;margin-right:-16px;margin-left:-16px}.bao-col-12,.bao-col-lg-7{position:relative;width:100%;padding-right:1rem;padding-left:1rem}@media (min-width: 992px){.bao-col-lg-7{flex:0 0 58.33333%;max-width:58.33333%}}.cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed;z-index:1000}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute;z-index:1000}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;z-index:1000;display:flex}.cdk-overlay-pane.bao-modal-mobil-full{width:100%;height:100%}.cdk-overlay-pane.bao-modal-mobil-compact{width:300px;height:100%}@media (min-width: 768px){.cdk-overlay-pane{width:500px;height:auto}.cdk-overlay-pane.bao-modal-lg{width:calc(100% - 4rem);height:calc(100% - 4rem)}.cdk-overlay-pane.bao-modal-md,.cdk-overlay-pane.bao-modal-sm{width:500px;height:auto}}@media (min-width: 992px){.cdk-overlay-pane{width:500px;height:auto}.cdk-overlay-pane.bao-modal-lg{width:calc(100% - 4rem);height:calc(100% - 4rem)}.cdk-overlay-pane.bao-modal-md{width:800px;height:auto}.cdk-overlay-pane.bao-modal-sm{width:500px;height:auto}}.cdk-overlay-backdrop{position:absolute;inset:0;z-index:1000;pointer-events:auto;-webkit-tap-highlight-color:transparent;transition:opacity .4s cubic-bezier(.25,.8,.25,1);opacity:0}.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.5}.cdk-high-contrast-active .cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.6}.cdk-overlay-dark-backdrop{background:black}.cdk-overlay-transparent-backdrop,.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing{opacity:.5}.cdk-overlay-connected-position-bounding-box{position:absolute;z-index:1000;display:flex;flex-direction:column;min-width:1px;min-height:1px}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}.bao-modal-container{display:block;overflow:auto;
|
|
226
|
+
BaoModalContainer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: BaoModalContainer, selector: "bao-modal-container", host: { attributes: { "tabindex": "-1", "aria-modal": "true" }, properties: { "id": "_id", "attr.role": "_config.role", "attr.aria-labelledby": "_config.ariaLabel ? null : _ariaLabelledBy", "attr.aria-label": "_config.ariaLabel", "attr.aria-describedby": "_config.ariaDescribedBy || null" }, classAttribute: "bao-modal-container" }, usesInheritance: true, ngImport: i0, template: "<ng-template cdkPortalOutlet></ng-template>\n", styles: [".bao-container{padding-right:16px;padding-left:16px;margin-right:auto;margin-left:auto;width:100%}@media (min-width: 576px){.bao-container{max-width:576px}}@media (min-width: 768px){.bao-container{max-width:768px}}@media (min-width: 992px){.bao-container{max-width:992px}}@media (min-width: 1200px){.bao-container{max-width:1200px}}.bao-row{display:flex;flex-wrap:wrap;margin-right:-16px;margin-left:-16px}.bao-col-12,.bao-col-lg-7{position:relative;width:100%;padding-right:1rem;padding-left:1rem}@media (min-width: 992px){.bao-col-lg-7{flex:0 0 58.33333%;max-width:58.33333%}}.cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed;z-index:1000}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute;z-index:1000}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;z-index:1000;display:flex}.cdk-overlay-pane.bao-modal-mobil-full{width:100%;height:100%}.cdk-overlay-pane.bao-modal-mobil-compact{width:300px;height:100%}@media (min-width: 768px){.cdk-overlay-pane{width:500px;height:auto}.cdk-overlay-pane.bao-modal-lg{width:calc(100% - 4rem);height:calc(100% - 4rem)}.cdk-overlay-pane.bao-modal-md,.cdk-overlay-pane.bao-modal-sm{width:500px;height:auto;max-height:calc(100% - 4rem)}}@media (min-width: 992px){.cdk-overlay-pane{width:500px;height:auto}.cdk-overlay-pane.bao-modal-lg{width:calc(100% - 4rem);height:calc(100% - 4rem)}.cdk-overlay-pane.bao-modal-md{width:800px;height:auto;max-height:calc(100% - 4rem)}.cdk-overlay-pane.bao-modal-sm{width:500px;height:auto;max-height:calc(100% - 4rem)}}.cdk-overlay-backdrop{position:absolute;inset:0;z-index:1000;pointer-events:auto;-webkit-tap-highlight-color:transparent;transition:opacity .4s cubic-bezier(.25,.8,.25,1);opacity:0}.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.5}.cdk-high-contrast-active .cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.6}.cdk-overlay-dark-backdrop{background:black}.cdk-overlay-transparent-backdrop,.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing{opacity:.5}.cdk-overlay-connected-position-bounding-box{position:absolute;z-index:1000;display:flex;flex-direction:column;min-width:1px;min-height:1px}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}.bao-modal-container{display:block;overflow:auto;min-height:inherit;max-height:inherit;background-color:#fff;background-clip:padding-box;border:0 solid rgba(0,0,0,.2);border-radius:.5rem;outline:0}.bao-modal-content{display:flex;flex-direction:column;height:100%}.bao-modal-header{flex:0 0 auto;display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid #ced4da;border-top-left-radius:.5rem;border-top-right-radius:.5rem}.bao-modal-header .bao-modal-title{font-size:1rem;line-height:1.5rem;margin:1rem 0 1rem 1rem}.bao-modal-header button{margin:.5rem}.bao-modal-body{display:block;padding:1rem;overflow:auto;flex-grow:1}@media (min-width: 768px){.bao-modal-body{padding:2rem}}.bao-modal-footer{display:flex;flex-wrap:wrap;padding:1rem;border-top:1px solid #ced4da;border-bottom-right-radius:.5rem;border-bottom-left-radius:.5rem}.bao-modal-footer.bao-modal-footer-order{justify-content:unset;flex-direction:column-reverse}.bao-modal-footer button{text-align:center}.bao-modal-footer .bao-button-primary,.bao-modal-footer .bao-button-secondary{width:100%;display:block}.bao-modal-footer .bao-button-secondary{margin-bottom:.5rem}.bao-modal-footer .bao-button-tertiary{display:none}@media (min-width: 768px){.bao-modal-footer{justify-content:flex-end}.bao-modal-footer.bao-modal-footer-order{flex-direction:row-reverse}.bao-modal-footer .bao-button-primary{margin-left:1rem}.bao-modal-footer .bao-button-secondary{margin-bottom:0}.bao-modal-footer .bao-button-primary,.bao-modal-footer .bao-button-secondary{width:auto}.bao-modal-footer .bao-button-tertiary{display:block}}\n"], directives: [{ type: i3.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None });
|
|
227
227
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaoModalContainer, decorators: [{
|
|
228
228
|
type: Component,
|
|
229
229
|
args: [{ selector: 'bao-modal-container', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.Default, host: {
|
|
@@ -235,6 +235,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
|
|
|
235
235
|
'[attr.aria-labelledby]': '_config.ariaLabel ? null : _ariaLabelledBy',
|
|
236
236
|
'[attr.aria-label]': '_config.ariaLabel',
|
|
237
237
|
'[attr.aria-describedby]': '_config.ariaDescribedBy || null'
|
|
238
|
-
}, template: "<ng-template cdkPortalOutlet></ng-template>\n", styles: [".bao-container{padding-right:16px;padding-left:16px;margin-right:auto;margin-left:auto;width:100%}@media (min-width: 576px){.bao-container{max-width:576px}}@media (min-width: 768px){.bao-container{max-width:768px}}@media (min-width: 992px){.bao-container{max-width:992px}}@media (min-width: 1200px){.bao-container{max-width:1200px}}.bao-row{display:flex;flex-wrap:wrap;margin-right:-16px;margin-left:-16px}.bao-col-12,.bao-col-lg-7{position:relative;width:100%;padding-right:1rem;padding-left:1rem}@media (min-width: 992px){.bao-col-lg-7{flex:0 0 58.33333%;max-width:58.33333%}}.cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed;z-index:1000}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute;z-index:1000}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;z-index:1000;display:flex}.cdk-overlay-pane.bao-modal-mobil-full{width:100%;height:100%}.cdk-overlay-pane.bao-modal-mobil-compact{width:300px;height:100%}@media (min-width: 768px){.cdk-overlay-pane{width:500px;height:auto}.cdk-overlay-pane.bao-modal-lg{width:calc(100% - 4rem);height:calc(100% - 4rem)}.cdk-overlay-pane.bao-modal-md,.cdk-overlay-pane.bao-modal-sm{width:500px;height:auto}}@media (min-width: 992px){.cdk-overlay-pane{width:500px;height:auto}.cdk-overlay-pane.bao-modal-lg{width:calc(100% - 4rem);height:calc(100% - 4rem)}.cdk-overlay-pane.bao-modal-md{width:800px;height:auto}.cdk-overlay-pane.bao-modal-sm{width:500px;height:auto}}.cdk-overlay-backdrop{position:absolute;inset:0;z-index:1000;pointer-events:auto;-webkit-tap-highlight-color:transparent;transition:opacity .4s cubic-bezier(.25,.8,.25,1);opacity:0}.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.5}.cdk-high-contrast-active .cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.6}.cdk-overlay-dark-backdrop{background:black}.cdk-overlay-transparent-backdrop,.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing{opacity:.5}.cdk-overlay-connected-position-bounding-box{position:absolute;z-index:1000;display:flex;flex-direction:column;min-width:1px;min-height:1px}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}.bao-modal-container{display:block;overflow:auto;
|
|
238
|
+
}, template: "<ng-template cdkPortalOutlet></ng-template>\n", styles: [".bao-container{padding-right:16px;padding-left:16px;margin-right:auto;margin-left:auto;width:100%}@media (min-width: 576px){.bao-container{max-width:576px}}@media (min-width: 768px){.bao-container{max-width:768px}}@media (min-width: 992px){.bao-container{max-width:992px}}@media (min-width: 1200px){.bao-container{max-width:1200px}}.bao-row{display:flex;flex-wrap:wrap;margin-right:-16px;margin-left:-16px}.bao-col-12,.bao-col-lg-7{position:relative;width:100%;padding-right:1rem;padding-left:1rem}@media (min-width: 992px){.bao-col-lg-7{flex:0 0 58.33333%;max-width:58.33333%}}.cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed;z-index:1000}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute;z-index:1000}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;z-index:1000;display:flex}.cdk-overlay-pane.bao-modal-mobil-full{width:100%;height:100%}.cdk-overlay-pane.bao-modal-mobil-compact{width:300px;height:100%}@media (min-width: 768px){.cdk-overlay-pane{width:500px;height:auto}.cdk-overlay-pane.bao-modal-lg{width:calc(100% - 4rem);height:calc(100% - 4rem)}.cdk-overlay-pane.bao-modal-md,.cdk-overlay-pane.bao-modal-sm{width:500px;height:auto;max-height:calc(100% - 4rem)}}@media (min-width: 992px){.cdk-overlay-pane{width:500px;height:auto}.cdk-overlay-pane.bao-modal-lg{width:calc(100% - 4rem);height:calc(100% - 4rem)}.cdk-overlay-pane.bao-modal-md{width:800px;height:auto;max-height:calc(100% - 4rem)}.cdk-overlay-pane.bao-modal-sm{width:500px;height:auto;max-height:calc(100% - 4rem)}}.cdk-overlay-backdrop{position:absolute;inset:0;z-index:1000;pointer-events:auto;-webkit-tap-highlight-color:transparent;transition:opacity .4s cubic-bezier(.25,.8,.25,1);opacity:0}.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.5}.cdk-high-contrast-active .cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.6}.cdk-overlay-dark-backdrop{background:black}.cdk-overlay-transparent-backdrop,.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing{opacity:.5}.cdk-overlay-connected-position-bounding-box{position:absolute;z-index:1000;display:flex;flex-direction:column;min-width:1px;min-height:1px}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}.bao-modal-container{display:block;overflow:auto;min-height:inherit;max-height:inherit;background-color:#fff;background-clip:padding-box;border:0 solid rgba(0,0,0,.2);border-radius:.5rem;outline:0}.bao-modal-content{display:flex;flex-direction:column;height:100%}.bao-modal-header{flex:0 0 auto;display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid #ced4da;border-top-left-radius:.5rem;border-top-right-radius:.5rem}.bao-modal-header .bao-modal-title{font-size:1rem;line-height:1.5rem;margin:1rem 0 1rem 1rem}.bao-modal-header button{margin:.5rem}.bao-modal-body{display:block;padding:1rem;overflow:auto;flex-grow:1}@media (min-width: 768px){.bao-modal-body{padding:2rem}}.bao-modal-footer{display:flex;flex-wrap:wrap;padding:1rem;border-top:1px solid #ced4da;border-bottom-right-radius:.5rem;border-bottom-left-radius:.5rem}.bao-modal-footer.bao-modal-footer-order{justify-content:unset;flex-direction:column-reverse}.bao-modal-footer button{text-align:center}.bao-modal-footer .bao-button-primary,.bao-modal-footer .bao-button-secondary{width:100%;display:block}.bao-modal-footer .bao-button-secondary{margin-bottom:.5rem}.bao-modal-footer .bao-button-tertiary{display:none}@media (min-width: 768px){.bao-modal-footer{justify-content:flex-end}.bao-modal-footer.bao-modal-footer-order{flex-direction:row-reverse}.bao-modal-footer .bao-button-primary{margin-left:1rem}.bao-modal-footer .bao-button-secondary{margin-bottom:0}.bao-modal-footer .bao-button-primary,.bao-modal-footer .bao-button-secondary{width:auto}.bao-modal-footer .bao-button-tertiary{display:block}}\n"] }]
|
|
239
239
|
}] });
|
|
240
240
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-container.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/modal/modal-container.ts","../../../../../projects/angular-ui/src/lib/modal/modal-container.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 {\n  FocusMonitor,\n  FocusOrigin,\n  ConfigurableFocusTrap,\n  ConfigurableFocusTrapFactory,\n  InteractivityChecker\n} from '@angular/cdk/a11y';\nimport { _getFocusedElementPierceShadowDom } from '@angular/cdk/platform';\nimport {\n  BasePortalOutlet,\n  CdkPortalOutlet,\n  ComponentPortal,\n  TemplatePortal\n} from '@angular/cdk/portal';\nimport { DOCUMENT } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EmbeddedViewRef,\n  EventEmitter,\n  Inject,\n  NgZone,\n  Optional,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { BaoModalInitialConfig } from './modal-config';\n\n/** Event that captures the state of modal container animations. */\ninterface DialogAnimationEvent {\n  state: 'opened' | 'opening' | 'closing' | 'closed';\n  totalTime: number;\n}\n\n/**\n * Throws an exception for the case when a ComponentPortal is\n * attached to a DomPortalOutlet without an origin.\n * @docs-private\n */\nexport function throwBaoModalContentAlreadyAttachedError() {\n  throw Error(\n    'Attempting to attach modal content after content is already attached'\n  );\n}\n\n/**\n * Base class for the `BaoModalContainer`. The base class does not implement\n * animations as these are left to implementers of the modal container.\n */\n@Directive()\nexport abstract class _BaoModalContainerBase extends BasePortalOutlet {\n  /** The portal outlet inside of this container into which the modal content will be loaded. */\n  @ViewChild(CdkPortalOutlet, { static: true }) _portalOutlet: CdkPortalOutlet;\n\n  /** Emits when an animation state changes. */\n  public _animationStateChanged = new EventEmitter<DialogAnimationEvent>();\n\n  /**\n   * Type of interaction that led to the modal being closed. This is used to determine\n   * whether the focus style will be applied when returning focus to its original location\n   * after the modal is closed.\n   */\n  public _closeInteractionType: FocusOrigin | null = null;\n\n  /** ID of the element that should be considered as the modal's label. */\n  public _ariaLabelledBy: string | null;\n\n  /** ID for the container DOM element. */\n  public _id: string;\n\n  protected _document: Document;\n\n  /** The class that traps and manages focus within the modal. */\n  private _focusTrap: ConfigurableFocusTrap;\n\n  /** Element that was focused before the modal was opened. Save this to restore upon close. */\n  private _elementFocusedBeforeDialogWasOpened: HTMLElement | null = null;\n\n  constructor(\n    protected _elementRef: ElementRef,\n    protected _focusTrapFactory: ConfigurableFocusTrapFactory,\n    protected _changeDetectorRef: ChangeDetectorRef,\n    @Optional() @Inject(DOCUMENT) _document: any,\n    /** The modal configuration. */\n    public _config: BaoModalInitialConfig,\n    private readonly _interactivityChecker: InteractivityChecker,\n    private readonly _ngZone: NgZone,\n    private _focusMonitor?: FocusMonitor\n  ) {\n    super();\n    this._ariaLabelledBy = _config.ariaLabelledBy || null;\n    this._document = _document;\n  }\n\n  /** Initializes the modal container with the attached content. */\n  public _initializeWithAttachedContent() {\n    this._setupFocusTrap();\n    // Save the previously focused element. This element will be re-focused\n    // when the modal closes.\n    this._capturePreviouslyFocusedElement();\n  }\n\n  /**\n   * Attach a ComponentPortal as content to this modal container.\n   */\n  public attachComponentPortal<T>(portal: ComponentPortal<T>): ComponentRef<T> {\n    return this._portalOutlet.attachComponentPortal(portal);\n  }\n\n  /**\n   * Attach a TemplatePortal as content to this modal container.\n   */\n  public attachTemplatePortal<C>(\n    portal: TemplatePortal<C>\n  ): EmbeddedViewRef<C> {\n    return this._portalOutlet.attachTemplatePortal(portal);\n  }\n\n  /** Moves focus back into the modal if it was moved out. */\n  public async _recaptureFocus() {\n    if (!this._containsFocus()) {\n      await this._trapFocus();\n    }\n  }\n\n  /**\n   * Moves the focus inside the focus trap. When autoFocus is not set to 'modal', if focus\n   * cannot be moved then focus will go to the modal container.\n   */\n  protected async _trapFocus() {\n    const element = this._elementRef.nativeElement;\n    // If were to attempt to focus immediately, then the content of the modal would not yet be\n    // ready in instances where change detection has to run first. To deal with this, we simply\n    // wait for the microtask queue to be empty when setting focus when autoFocus isn't set to\n    // modal. If the element inside the modal can't be focused, then the container is focused\n    // so the user can't tab into other elements behind it.\n    switch (this._config.autoFocus) {\n      case 'modal':\n        // Ensure that focus is on the modal container. It's possible that a different\n        // component tried to move focus while the open animation was running. See:\n        // https://github.com/angular/components/issues/16215. Note that we only want to do this\n        // if the focus isn't inside the modal already, because it's possible that the consumer\n        // turned off `autoFocus` in order to move focus themselves.\n        if (!this._containsFocus()) {\n          element.focus();\n        }\n        break;\n      case 'first-tabbable':\n        // If we weren't able to find a focusable element in the modal, then focus the modal\n        // container instead.\n        const focusedSuccessfully =\n          await this._focusTrap.focusInitialElementWhenReady();\n        if (!focusedSuccessfully) {\n          this._focusDialogContainer();\n        }\n        break;\n      case 'first-heading':\n        this._focusByCssSelector('h1, h2, h3, h4, h5, h6, [role=\"heading\"]');\n        break;\n      default:\n        this._focusByCssSelector(this._config.autoFocus);\n        break;\n    }\n  }\n\n  /** Restores focus to the element that was focused before the modal opened. */\n  protected _restoreFocus() {\n    const previousElement = this._elementFocusedBeforeDialogWasOpened;\n\n    // We need the extra check, because IE can set the `activeElement` to null in some cases.\n    if (\n      this._config.restoreFocus &&\n      previousElement &&\n      typeof previousElement.focus === 'function'\n    ) {\n      const activeElement = _getFocusedElementPierceShadowDom();\n      const element = this._elementRef.nativeElement;\n\n      // Make sure that focus is still inside the modal or is on the body (usually because a\n      // non-focusable element like the backdrop was clicked) before moving it. It's possible that\n      // the consumer moved it themselves before the animation was done, in which case we shouldn't\n      // do anything.\n      if (\n        !activeElement ||\n        activeElement === this._document.body ||\n        activeElement === element ||\n        element.contains(activeElement)\n      ) {\n        if (this._focusMonitor) {\n          this._focusMonitor.focusVia(\n            previousElement,\n            this._closeInteractionType\n          );\n          this._closeInteractionType = null;\n        } else {\n          previousElement.focus();\n        }\n      }\n    }\n\n    if (this._focusTrap) {\n      this._focusTrap.destroy();\n    }\n  }\n\n  /**\n   * Focuses the provided element. If the element is not focusable, it will add a tabIndex\n   * attribute to forcefully focus it. The attribute is removed after focus is moved.\n   */\n  private _forceFocus(element: HTMLElement, options?: FocusOptions) {\n    if (!this._interactivityChecker.isFocusable(element)) {\n      element.tabIndex = -1;\n      // The tabindex attribute should be removed to avoid navigating to that element again\n      this._ngZone.runOutsideAngular(() => {\n        element.addEventListener('blur', () =>\n          element.removeAttribute('tabindex')\n        );\n        element.addEventListener('mousedown', () =>\n          element.removeAttribute('tabindex')\n        );\n      });\n    }\n    element.focus(options);\n  }\n\n  /**\n   * Focuses the first element that matches the given selector within the focus trap.\n   */\n  private _focusByCssSelector(selector: string, options?: FocusOptions) {\n    const elementToFocus = this._elementRef.nativeElement.querySelector(\n      selector\n    ) as HTMLElement | null;\n    if (elementToFocus) {\n      this._forceFocus(elementToFocus, options);\n    }\n  }\n\n  /** Sets up the focus trap. */\n  private _setupFocusTrap() {\n    this._focusTrap = this._focusTrapFactory.create(\n      this._elementRef.nativeElement\n    );\n  }\n\n  /** Captures the element that was focused before the modal was opened. */\n  private _capturePreviouslyFocusedElement() {\n    if (this._document) {\n      this._elementFocusedBeforeDialogWasOpened =\n        _getFocusedElementPierceShadowDom();\n    }\n  }\n\n  /** Focuses the modal container. */\n  private _focusDialogContainer() {\n    // Note that there is no focus method when rendering on the server.\n    if (this._elementRef.nativeElement.focus) {\n      this._elementRef.nativeElement.focus();\n    }\n  }\n\n  /** Returns whether focus is inside the modal. */\n  private _containsFocus() {\n    const element = this._elementRef.nativeElement as HTMLElement;\n    const activeElement = _getFocusedElementPierceShadowDom();\n    return element === activeElement || element.contains(activeElement);\n  }\n\n  /** Starts the modal exit animation. */\n  abstract _startExitAnimation(): void;\n  abstract _startOpenAnimation(): void;\n}\n\n@Component({\n  selector: 'bao-modal-container',\n  templateUrl: 'modal-container.component.html',\n  styleUrls: ['modal-container.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.Default,\n  host: {\n    class: 'bao-modal-container',\n    tabindex: '-1',\n    'aria-modal': 'true',\n    '[id]': '_id',\n    '[attr.role]': '_config.role',\n    '[attr.aria-labelledby]': '_config.ariaLabel ? null : _ariaLabelledBy',\n    '[attr.aria-label]': '_config.ariaLabel',\n    '[attr.aria-describedby]': '_config.ariaDescribedBy || null'\n  }\n})\nexport class BaoModalContainer extends _BaoModalContainerBase {\n  /** State of the modal animation. */\n  _state: 'void' | 'enter' | 'exit' = 'enter';\n\n  public _startOpenAnimation() {\n    this._animationStateChanged.emit({ state: 'opening', totalTime: 20 });\n    void Promise.resolve().then(() => this._finishDialogOpen());\n  }\n\n  /** Starts the modal exit animation. */\n  public _startExitAnimation(): void {\n    this._animationStateChanged.emit({ state: 'closed', totalTime: 20 });\n  }\n\n  private _finishDialogOpen() {\n    this._openAnimationDone(20);\n  }\n\n  private _openAnimationDone(totalTime: number) {\n    if (this._config.delayFocusTrap) {\n      void this._trapFocus();\n    }\n    this._animationStateChanged.next({ state: 'opened', totalTime });\n  }\n}\n","<ng-template cdkPortalOutlet></ng-template>\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
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
|
+
export * from './module';
|
|
7
|
+
export * from './snack-bar';
|
|
8
|
+
export * from './snack-bar-config';
|
|
9
|
+
export * from './snack-bar-ref';
|
|
10
|
+
export * from './snack-bar-container';
|
|
11
|
+
export * from './simple-snack-bar.component';
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXVpL3NyYy9saWIvc25hY2stYmFyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLDhCQUE4QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMyBWaWxsZSBkZSBNb250cmVhbC4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZS5cbiAqIFNlZSBMSUNFTlNFIGZpbGUgaW4gdGhlIHByb2plY3Qgcm9vdCBmb3IgZnVsbCBsaWNlbnNlIGluZm9ybWF0aW9uLlxuICovXG5leHBvcnQgKiBmcm9tICcuL21vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3NuYWNrLWJhcic7XG5leHBvcnQgKiBmcm9tICcuL3NuYWNrLWJhci1jb25maWcnO1xuZXhwb3J0ICogZnJvbSAnLi9zbmFjay1iYXItcmVmJztcbmV4cG9ydCAqIGZyb20gJy4vc25hY2stYmFyLWNvbnRhaW5lcic7XG5leHBvcnQgKiBmcm9tICcuL3NpbXBsZS1zbmFjay1iYXIuY29tcG9uZW50JztcbiJdfQ==
|
|
@@ -0,0 +1,54 @@
|
|
|
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: "13.3.12", ngImport: i0, type: BaoSnackBarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
24
|
+
BaoSnackBarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.12", 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: "13.3.12", ngImport: i0, type: BaoSnackBarModule, providers: [BaoSnackBarService, BaoSnackBarConfig], imports: [[
|
|
32
|
+
CommonModule,
|
|
33
|
+
OverlayModule,
|
|
34
|
+
PortalModule,
|
|
35
|
+
BaoButtonModule,
|
|
36
|
+
BaoIconModule
|
|
37
|
+
]] });
|
|
38
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaoSnackBarModule, decorators: [{
|
|
39
|
+
type: NgModule,
|
|
40
|
+
args: [{
|
|
41
|
+
imports: [
|
|
42
|
+
CommonModule,
|
|
43
|
+
OverlayModule,
|
|
44
|
+
PortalModule,
|
|
45
|
+
BaoButtonModule,
|
|
46
|
+
BaoIconModule
|
|
47
|
+
],
|
|
48
|
+
providers: [BaoSnackBarService, BaoSnackBarConfig],
|
|
49
|
+
declarations: SNACKBAR_DIRECTIVES,
|
|
50
|
+
exports: SNACKBAR_DIRECTIVES,
|
|
51
|
+
entryComponents: [SNACKBAR_DIRECTIVES]
|
|
52
|
+
}]
|
|
53
|
+
}] });
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11aS9zcmMvbGliL3NuYWNrLWJhci9tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUMxRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDakQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDdkQsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBRXRFLE1BQU0sbUJBQW1CLEdBQUc7SUFDMUIsMEJBQTBCO0lBQzFCLDZCQUE2QjtDQUM5QixDQUFDO0FBZUYsTUFBTSxPQUFPLGlCQUFpQjs7K0dBQWpCLGlCQUFpQjtnSEFBakIsaUJBQWlCLGlCQWpCNUIsMEJBQTBCO1FBQzFCLDZCQUE2QixhQUszQixZQUFZO1FBQ1osYUFBYTtRQUNiLFlBQVk7UUFDWixlQUFlO1FBQ2YsYUFBYSxhQVZmLDBCQUEwQjtRQUMxQiw2QkFBNkI7Z0hBZ0JsQixpQkFBaUIsYUFMakIsQ0FBQyxrQkFBa0IsRUFBRSxpQkFBaUIsQ0FBQyxZQVB6QztZQUNQLFlBQVk7WUFDWixhQUFhO1lBQ2IsWUFBWTtZQUNaLGVBQWU7WUFDZixhQUFhO1NBQ2Q7NEZBTVUsaUJBQWlCO2tCQWI3QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsWUFBWTt3QkFDWixlQUFlO3dCQUNmLGFBQWE7cUJBQ2Q7b0JBQ0QsU0FBUyxFQUFFLENBQUMsa0JBQWtCLEVBQUUsaUJBQWlCLENBQUM7b0JBQ2xELFlBQVksRUFBRSxtQkFBbUI7b0JBQ2pDLE9BQU8sRUFBRSxtQkFBbUI7b0JBQzVCLGVBQWUsRUFBRSxDQUFDLG1CQUFtQixDQUFDO2lCQUN2QyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjMgVmlsbGUgZGUgTW9udHJlYWwuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UuXG4gKiBTZWUgTElDRU5TRSBmaWxlIGluIHRoZSBwcm9qZWN0IHJvb3QgZm9yIGZ1bGwgbGljZW5zZSBpbmZvcm1hdGlvbi5cbiAqL1xuaW1wb3J0IHsgT3ZlcmxheU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IFBvcnRhbE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCYW9CdXR0b25Nb2R1bGUgfSBmcm9tICcuLi9idXR0b24vbW9kdWxlJztcbmltcG9ydCB7IEJhb0ljb25Nb2R1bGUgfSBmcm9tICcuLi9pY29uL21vZHVsZSc7XG5pbXBvcnQgeyBCYW9TaW1wbGVTbmFja0JhckNvbXBvbmVudCB9IGZyb20gJy4vc2ltcGxlLXNuYWNrLWJhci5jb21wb25lbnQnO1xuaW1wb3J0IHsgQmFvU25hY2tCYXJTZXJ2aWNlIH0gZnJvbSAnLi9zbmFjay1iYXInO1xuaW1wb3J0IHsgQmFvU25hY2tCYXJDb25maWcgfSBmcm9tICcuL3NuYWNrLWJhci1jb25maWcnO1xuaW1wb3J0IHsgQmFvU25hY2tCYXJDb250YWluZXJDb21wb25lbnQgfSBmcm9tICcuL3NuYWNrLWJhci1jb250YWluZXInO1xuXG5jb25zdCBTTkFDS0JBUl9ESVJFQ1RJVkVTID0gW1xuICBCYW9TaW1wbGVTbmFja0JhckNvbXBvbmVudCxcbiAgQmFvU25hY2tCYXJDb250YWluZXJDb21wb25lbnRcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgT3ZlcmxheU1vZHVsZSxcbiAgICBQb3J0YWxNb2R1bGUsXG4gICAgQmFvQnV0dG9uTW9kdWxlLFxuICAgIEJhb0ljb25Nb2R1bGVcbiAgXSxcbiAgcHJvdmlkZXJzOiBbQmFvU25hY2tCYXJTZXJ2aWNlLCBCYW9TbmFja0JhckNvbmZpZ10sXG4gIGRlY2xhcmF0aW9uczogU05BQ0tCQVJfRElSRUNUSVZFUyxcbiAgZXhwb3J0czogU05BQ0tCQVJfRElSRUNUSVZFUyxcbiAgZW50cnlDb21wb25lbnRzOiBbU05BQ0tCQVJfRElSRUNUSVZFU11cbn0pXG5leHBvcnQgY2xhc3MgQmFvU25hY2tCYXJNb2R1bGUge31cbiJdfQ==
|