@villedemontreal/angular-ui 3.0.0 → 3.1.0

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