@villedemontreal/angular-ui 2.2.1 → 3.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/esm2020/lib/alert/alert.component.mjs +24 -26
  2. package/esm2020/lib/alert/module.mjs +5 -5
  3. package/esm2020/lib/avatar/avatar.component.mjs +102 -0
  4. package/esm2020/lib/avatar/index.mjs +8 -0
  5. package/esm2020/lib/avatar/module.mjs +24 -0
  6. package/esm2020/lib/badge/badge.component.mjs +3 -3
  7. package/esm2020/lib/badge/module.mjs +5 -5
  8. package/esm2020/lib/bao.module.mjs +24 -14
  9. package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +8 -8
  10. package/esm2020/lib/breadcrumb/module.mjs +5 -5
  11. package/esm2020/lib/button/button.component.mjs +7 -7
  12. package/esm2020/lib/button/module.mjs +5 -5
  13. package/esm2020/lib/card/card.component.mjs +15 -15
  14. package/esm2020/lib/card/module.mjs +5 -5
  15. package/esm2020/lib/checkbox/checkbox-group.component.mjs +8 -9
  16. package/esm2020/lib/checkbox/checkbox.component.mjs +45 -46
  17. package/esm2020/lib/checkbox/module.mjs +5 -5
  18. package/esm2020/lib/common-components/error-text/errorText.component.mjs +3 -3
  19. package/esm2020/lib/common-components/guiding-text/guidingText.component.mjs +3 -3
  20. package/esm2020/lib/common-components/label-text/labelText.component.mjs +3 -3
  21. package/esm2020/lib/common-components/module.mjs +5 -5
  22. package/esm2020/lib/common-components/title-text/titleText.component.mjs +3 -3
  23. package/esm2020/lib/header-info/header-info.component.mjs +18 -18
  24. package/esm2020/lib/header-info/module.mjs +5 -5
  25. package/esm2020/lib/icon/bao-icon-registry.mjs +3 -3
  26. package/esm2020/lib/icon/icon.component.mjs +30 -34
  27. package/esm2020/lib/icon/icons-dictionary.mjs +3 -2
  28. package/esm2020/lib/icon/module.mjs +5 -5
  29. package/esm2020/lib/list/list.component.mjs +15 -15
  30. package/esm2020/lib/list/module.mjs +5 -5
  31. package/esm2020/lib/modal/index.mjs +12 -0
  32. package/esm2020/lib/modal/modal-animations.mjs +29 -0
  33. package/esm2020/lib/modal/modal-config.mjs +65 -0
  34. package/esm2020/lib/modal/modal-container.mjs +254 -0
  35. package/esm2020/lib/modal/modal-directives.mjs +84 -0
  36. package/esm2020/lib/modal/modal-ref.mjs +195 -0
  37. package/esm2020/lib/modal/modal.mjs +293 -0
  38. package/esm2020/lib/modal/module.mjs +44 -0
  39. package/esm2020/lib/radio/module.mjs +10 -12
  40. package/esm2020/lib/radio/radio-group.component.mjs +43 -44
  41. package/esm2020/lib/radio/radio.component.mjs +45 -46
  42. package/esm2020/lib/summary/list-summary.component.mjs +9 -16
  43. package/esm2020/lib/summary/module.mjs +5 -5
  44. package/esm2020/lib/summary/summary.component.mjs +10 -11
  45. package/esm2020/lib/tabs/index.mjs +8 -0
  46. package/esm2020/lib/tabs/module.mjs +35 -0
  47. package/esm2020/lib/tabs/tabs.component.mjs +295 -0
  48. package/esm2020/lib/tag/module.mjs +5 -5
  49. package/esm2020/lib/tag/tag.component.mjs +5 -5
  50. package/esm2020/public-api.mjs +4 -1
  51. package/fesm2015/villedemontreal-angular-ui.mjs +1778 -384
  52. package/fesm2015/villedemontreal-angular-ui.mjs.map +1 -1
  53. package/fesm2020/villedemontreal-angular-ui.mjs +1770 -384
  54. package/fesm2020/villedemontreal-angular-ui.mjs.map +1 -1
  55. package/{villedemontreal-angular-ui.d.ts → index.d.ts} +0 -0
  56. package/lib/alert/alert.component.d.ts +6 -7
  57. package/lib/avatar/avatar.component.d.ts +26 -0
  58. package/lib/avatar/index.d.ts +2 -0
  59. package/lib/avatar/module.d.ts +8 -0
  60. package/lib/badge/badge.component.d.ts +1 -1
  61. package/lib/bao.module.d.ts +4 -1
  62. package/lib/breadcrumb/breadcrumb.component.d.ts +2 -2
  63. package/lib/button/button.component.d.ts +2 -2
  64. package/lib/card/card.component.d.ts +5 -5
  65. package/lib/checkbox/checkbox-group.component.d.ts +3 -3
  66. package/lib/checkbox/checkbox.component.d.ts +28 -28
  67. package/lib/common-components/error-text/errorText.component.d.ts +1 -1
  68. package/lib/common-components/guiding-text/guidingText.component.d.ts +1 -1
  69. package/lib/common-components/label-text/labelText.component.d.ts +1 -1
  70. package/lib/common-components/title-text/titleText.component.d.ts +1 -1
  71. package/lib/header-info/header-info.component.d.ts +6 -6
  72. package/lib/icon/icon.component.d.ts +11 -11
  73. package/lib/list/list.component.d.ts +5 -5
  74. package/lib/modal/index.d.ts +6 -0
  75. package/lib/modal/modal-animations.d.ts +8 -0
  76. package/lib/modal/modal-config.d.ts +105 -0
  77. package/lib/modal/modal-container.d.ts +106 -0
  78. package/lib/modal/modal-directives.d.ts +25 -0
  79. package/lib/modal/modal-ref.d.ts +91 -0
  80. package/lib/modal/modal.d.ts +91 -0
  81. package/lib/modal/module.d.ts +12 -0
  82. package/lib/radio/radio-group.component.d.ts +19 -19
  83. package/lib/radio/radio.component.d.ts +28 -28
  84. package/lib/summary/list-summary.component.d.ts +2 -2
  85. package/lib/summary/summary.component.d.ts +7 -7
  86. package/lib/tabs/index.d.ts +2 -0
  87. package/lib/tabs/module.d.ts +8 -0
  88. package/lib/tabs/tabs.component.d.ts +95 -0
  89. package/lib/tag/tag.component.d.ts +2 -2
  90. package/package.json +7 -7
  91. package/public-api.d.ts +3 -0
@@ -20,17 +20,6 @@ let radioGroupNextUniqueId = 0;
20
20
  export class BaoRadioButtonGroupComponent {
21
21
  constructor(cdr) {
22
22
  this.cdr = cdr;
23
- this._value = null;
24
- this._name = null;
25
- this._selected = null;
26
- this._isInitialized = false;
27
- this._disabled = false;
28
- this._required = false;
29
- this._uniqueId = `bao-checkbox-group-${++radioGroupNextUniqueId}`;
30
- /**
31
- * The checkbox group ID. It is set dynamically with an unique ID by default
32
- */
33
- this.id = this._uniqueId;
34
23
  /**
35
24
  * Emit the value of the selected radio button
36
25
  */
@@ -39,8 +28,18 @@ export class BaoRadioButtonGroupComponent {
39
28
  * The aria-describedby for web accessibilty
40
29
  */
41
30
  this.ariaDescribedby = null;
31
+ this._value = null;
32
+ this._name = null;
33
+ this._selected = null;
34
+ this._isInitialized = false;
35
+ this._disabled = false;
36
+ this._required = false;
37
+ this._uniqueId = `bao-checkbox-group-${++radioGroupNextUniqueId}`;
42
38
  this.onModelChange = () => undefined;
43
39
  this.onTouch = () => undefined;
40
+ if (!this.id) {
41
+ this.id = this._uniqueId;
42
+ }
44
43
  }
45
44
  /**
46
45
  * Define the name property of all radio buttons. Default : null
@@ -48,50 +47,50 @@ export class BaoRadioButtonGroupComponent {
48
47
  get name() {
49
48
  return this._name;
50
49
  }
51
- set name(value) {
52
- this._name = value;
53
- this.updateRadioButtonNames();
54
- }
55
50
  /**
56
51
  * Define the value of the selected radio button. Default : null
57
52
  */
58
53
  get value() {
59
54
  return this._value;
60
55
  }
61
- set value(newValue) {
62
- if (this._value !== newValue) {
63
- this._value = newValue;
64
- this.updateSelectedRadioFromValue();
65
- this.checkSelectedRadioButton();
66
- }
67
- }
68
56
  /**
69
57
  * Define which radio button is selected. Default : null
70
58
  */
71
59
  get selected() {
72
60
  return this._selected;
73
61
  }
74
- set selected(selected) {
75
- this._selected = selected;
76
- this.value = selected ? selected.value : null;
77
- this.checkSelectedRadioButton();
78
- }
79
62
  /**
80
63
  * Whether the radio button groupd is disabled. Default : false
81
64
  */
82
65
  get disabled() {
83
66
  return this._disabled;
84
67
  }
85
- set disabled(value) {
86
- this._disabled = coerceBooleanProperty(value);
87
- this.markRadiosForCheck();
88
- }
89
68
  /**
90
69
  * Whether the radio button groupd is required. Default : false
91
70
  */
92
71
  get required() {
93
72
  return this._required;
94
73
  }
74
+ set name(value) {
75
+ this._name = value;
76
+ this.updateRadioButtonNames();
77
+ }
78
+ set value(newValue) {
79
+ if (this._value !== newValue) {
80
+ this._value = newValue;
81
+ this.updateSelectedRadioFromValue();
82
+ this.checkSelectedRadioButton();
83
+ }
84
+ }
85
+ set selected(selected) {
86
+ this._selected = selected;
87
+ this.value = selected ? selected.value : null;
88
+ this.checkSelectedRadioButton();
89
+ }
90
+ set disabled(value) {
91
+ this._disabled = coerceBooleanProperty(value);
92
+ this.markRadiosForCheck();
93
+ }
95
94
  set required(value) {
96
95
  this._required = coerceBooleanProperty(value);
97
96
  this.markRadiosForCheck();
@@ -205,16 +204,16 @@ export class BaoRadioButtonGroupComponent {
205
204
  this.ariaDescribedby = value ? `${this.id}-ariadescribedby` : null;
206
205
  }
207
206
  }
208
- BaoRadioButtonGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoRadioButtonGroupComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
209
- BaoRadioButtonGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BaoRadioButtonGroupComponent, selector: "bao-radio-button-group, [bao-radio-button-group], [baoRadioButtonGroup]", inputs: { id: "id", name: "name", value: "value", selected: "selected", disabled: "disabled", required: "required" }, outputs: { change: "change" }, providers: [
207
+ BaoRadioButtonGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoRadioButtonGroupComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
208
+ BaoRadioButtonGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.1", type: BaoRadioButtonGroupComponent, selector: "bao-radio-button-group, [bao-radio-button-group], [baoRadioButtonGroup]", inputs: { id: "id", name: "name", value: "value", selected: "selected", disabled: "disabled", required: "required" }, outputs: { change: "change" }, providers: [
210
209
  {
211
210
  provide: NG_VALUE_ACCESSOR,
212
211
  useExisting: forwardRef(() => BaoRadioButtonGroupComponent),
213
212
  multi: true
214
213
  },
215
214
  { provide: BAO_RADIO_GROUP, useExisting: BaoRadioButtonGroupComponent }
216
- ], queries: [{ propertyName: "_radios", predicate: i0.forwardRef(function () { return BaoRadioButtonComponent; }), descendants: true }], viewQueries: [{ propertyName: "staticContainer", first: true, predicate: ["container"], descendants: true }], exportAs: ["baoRadioGroup"], ngImport: i0, template: "<fieldset\n role=\"radiogroup\"\n class=\"bao-radio-button-group\"\n [id]=\"id\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n>\n <ng-content></ng-content>\n <div\n class=\"bao-radio-button-group-description\"\n [attr.id]=\"ariaDescribedby\"\n #container\n (cdkObserveContent)=\"onContentChange()\"\n >\n <ng-content\n select=\"bao-error, [bao-error], bao-guiding-text, [bao-guiding-text]\"\n ></ng-content>\n </div>\n</fieldset>\n", styles: [".bao-radio-button-group .bao-legend{margin-bottom:.5rem}.bao-radio-button-group .bao-error,.bao-radio-button-group .bao-guiding-text{margin-top:.5rem}\n"], directives: [{ type: i1.CdkObserveContent, selector: "[cdkObserveContent]", inputs: ["cdkObserveContentDisabled", "debounce"], outputs: ["cdkObserveContent"], exportAs: ["cdkObserveContent"] }], encapsulation: i0.ViewEncapsulation.None });
217
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoRadioButtonGroupComponent, decorators: [{
215
+ ], queries: [{ propertyName: "staticContainer", predicate: i0.forwardRef(function () { return BaoRadioButtonComponent; }), descendants: true }], viewQueries: [{ propertyName: "staticContainer", first: true, predicate: ["container"], descendants: true }], exportAs: ["baoRadioGroup"], ngImport: i0, template: "<fieldset\n role=\"radiogroup\"\n class=\"bao-radio-button-group\"\n [id]=\"id\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n>\n <ng-content></ng-content>\n <div\n class=\"bao-radio-button-group-description\"\n [attr.id]=\"ariaDescribedby\"\n #container\n (cdkObserveContent)=\"onContentChange()\"\n >\n <ng-content\n select=\"bao-error, [bao-error], bao-guiding-text, [bao-guiding-text]\"\n ></ng-content>\n </div>\n</fieldset>\n", styles: [".bao-radio-button-group .bao-legend{margin-bottom:.5rem}.bao-radio-button-group .bao-error,.bao-radio-button-group .bao-guiding-text{margin-top:.5rem}\n"], dependencies: [{ kind: "directive", type: i1.CdkObserveContent, selector: "[cdkObserveContent]", inputs: ["cdkObserveContentDisabled", "debounce"], outputs: ["cdkObserveContent"], exportAs: ["cdkObserveContent"] }], encapsulation: i0.ViewEncapsulation.None });
216
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoRadioButtonGroupComponent, decorators: [{
218
217
  type: Component,
219
218
  args: [{ selector: 'bao-radio-button-group, [bao-radio-button-group], [baoRadioButtonGroup]', exportAs: 'baoRadioGroup', encapsulation: ViewEncapsulation.None, providers: [
220
219
  {
@@ -224,13 +223,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
224
223
  },
225
224
  { provide: BAO_RADIO_GROUP, useExisting: BaoRadioButtonGroupComponent }
226
225
  ], template: "<fieldset\n role=\"radiogroup\"\n class=\"bao-radio-button-group\"\n [id]=\"id\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n>\n <ng-content></ng-content>\n <div\n class=\"bao-radio-button-group-description\"\n [attr.id]=\"ariaDescribedby\"\n #container\n (cdkObserveContent)=\"onContentChange()\"\n >\n <ng-content\n select=\"bao-error, [bao-error], bao-guiding-text, [bao-guiding-text]\"\n ></ng-content>\n </div>\n</fieldset>\n", styles: [".bao-radio-button-group .bao-legend{margin-bottom:.5rem}.bao-radio-button-group .bao-error,.bao-radio-button-group .bao-guiding-text{margin-top:.5rem}\n"] }]
227
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { _radios: [{
226
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { id: [{
227
+ type: Input
228
+ }], change: [{
229
+ type: Output
230
+ }], staticContainer: [{
228
231
  type: ContentChildren,
229
232
  args: [forwardRef(() => BaoRadioButtonComponent), {
230
233
  descendants: true
231
234
  }]
232
- }], id: [{
233
- type: Input
235
+ }, {
236
+ type: ViewChild,
237
+ args: ['container', { static: false }]
234
238
  }], name: [{
235
239
  type: Input
236
240
  }], value: [{
@@ -241,10 +245,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
241
245
  type: Input
242
246
  }], required: [{
243
247
  type: Input
244
- }], change: [{
245
- type: Output
246
- }], staticContainer: [{
247
- type: ViewChild,
248
- args: ['container', { static: false }]
249
248
  }] } });
250
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/radio/radio-group.component.ts","../../../../../projects/angular-ui/src/lib/radio/radio-group.component.html"],"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 { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  InjectionToken,\n  Input,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { BaoRadioButtonComponent } from '.';\n\n/**\n * We have to inject the radio button group and all its children to each child.\n */\nexport const BAO_RADIO_GROUP = new InjectionToken<BaoRadioButtonGroupComponent>(\n  'BaoRadioButtonGroup'\n);\n/**\n * Unique ID for each radio group counter\n */\nlet radioGroupNextUniqueId = 0;\n\n@Component({\n  selector:\n    'bao-radio-button-group, [bao-radio-button-group], [baoRadioButtonGroup]',\n  exportAs: 'baoRadioGroup',\n  templateUrl: './radio-group.component.html',\n  styleUrls: ['./radio-group.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => BaoRadioButtonGroupComponent),\n      multi: true\n    },\n    { provide: BAO_RADIO_GROUP, useExisting: BaoRadioButtonGroupComponent }\n  ]\n})\nexport class BaoRadioButtonGroupComponent\n  implements AfterContentInit, ControlValueAccessor, AfterViewInit\n{\n  @ContentChildren(forwardRef(() => BaoRadioButtonComponent), {\n    descendants: true\n  })\n  private _radios: QueryList<BaoRadioButtonComponent>;\n  private _value: string | null = null;\n  private _name: string | null = null;\n  private _selected: BaoRadioButtonComponent | null = null;\n  private _isInitialized = false;\n  private _disabled = false;\n  private _required = false;\n\n  private _uniqueId = `bao-checkbox-group-${++radioGroupNextUniqueId}`;\n\n  /**\n   * The checkbox group ID. It is set dynamically with an unique ID by default\n   */\n  @Input() public id: string = this._uniqueId;\n\n  /**\n   * Define the name property of all radio buttons. Default : null\n   */\n  @Input()\n  get name(): string | null {\n    return this._name;\n  }\n  set name(value: string | null) {\n    this._name = value;\n    this.updateRadioButtonNames();\n  }\n\n  /**\n   * Define the value of the selected radio button. Default : null\n   */\n  @Input()\n  get value(): string | null {\n    return this._value;\n  }\n  set value(newValue: string | null) {\n    if (this._value !== newValue) {\n      this._value = newValue;\n      this.updateSelectedRadioFromValue();\n      this.checkSelectedRadioButton();\n    }\n  }\n\n  /**\n   * Define which radio button is selected. Default : null\n   */\n  @Input()\n  get selected() {\n    return this._selected;\n  }\n  set selected(selected: BaoRadioButtonComponent | null) {\n    this._selected = selected;\n    this.value = selected ? selected.value : null;\n    this.checkSelectedRadioButton();\n  }\n\n  /**\n   * Whether the radio button groupd is disabled. Default : false\n   */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value) {\n    this._disabled = coerceBooleanProperty(value);\n    this.markRadiosForCheck();\n  }\n\n  /**\n   * Whether the radio button groupd is required. Default : false\n   */\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n  set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n    this.markRadiosForCheck();\n  }\n\n  /**\n   * Emit the value of the selected radio button\n   */\n  @Output() public readonly change: EventEmitter<string> =\n    new EventEmitter<string>();\n\n  /**\n   * The aria-describedby for web accessibilty\n   */\n  public ariaDescribedby: string | null = null;\n\n  @ViewChild('container', { static: false })\n  private staticContainer: ElementRef;\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  public ngAfterContentInit() {\n    this._isInitialized = true;\n  }\n\n  public ngAfterViewInit() {\n    this.setAriaDescribedByToDescription();\n    this.cdr.detectChanges();\n  }\n\n  /**\n   * Implement ControlValueAccessor\n   */\n  public writeValue(value: string) {\n    this.value = value;\n    this.cdr.markForCheck();\n  }\n\n  /**\n   * Implement ControlValueAccessor\n   */\n  public registerOnChange(fn: (value: any) => void) {\n    this.onModelChange = fn;\n  }\n\n  /**\n   * Implement ControlValueAccessor\n   */\n  public registerOnTouched(fn: any) {\n    this.onTouch = fn;\n  }\n\n  /**\n   * Implement ControlValueAccessor\n   */\n  public setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  /**\n   * onTouch() called from the button children\n   */\n  public onGroupTouch() {\n    if (this.onTouch) {\n      this.onTouch();\n    }\n  }\n\n  /**\n   * Update all radio button name\n   */\n  public updateRadioButtonNames(): void {\n    if (this._radios) {\n      this._radios.forEach((radio: BaoRadioButtonComponent) => {\n        radio.name = this.name;\n        radio.markForCheck();\n      });\n    }\n  }\n\n  /**\n   * Define which radio button is selected.\n   */\n  public updateSelectedRadioFromValue(): void {\n    const isAlreadySelected =\n      this._selected !== null && this._selected.value === this._value;\n    if (this._radios && !isAlreadySelected) {\n      this._selected = null;\n      this._radios.forEach((radio: BaoRadioButtonComponent) => {\n        radio.checked = this.value === radio.value;\n        if (radio.checked) {\n          this._selected = radio;\n        }\n      });\n    }\n  }\n\n  /**\n   * Update checked property on selected radio button\n   */\n  public checkSelectedRadioButton() {\n    if (this._selected && !this._selected.checked) {\n      this._selected.checked = true;\n    }\n  }\n\n  /**\n   * Emit the value of the new selected radio button\n   */\n  public emitChangeEvent(): void {\n    if (this._isInitialized) {\n      this.change.emit(this.value);\n    }\n  }\n\n  /**\n   * Call markForCheck function on all radio buttons since one of the parent inputs could't have change meanwhile. Prevent change detection error.\n   */\n  public markRadiosForCheck() {\n    if (this._radios) {\n      this._radios.forEach((radio: BaoRadioButtonComponent) =>\n        radio.markForCheck()\n      );\n    }\n  }\n\n  public onContentChange() {\n    this.setAriaDescribedByToDescription();\n  }\n\n  public onModelChange: (value: any) => void = () => undefined;\n\n  /**\n   * Set the aria-describedby property to bao-guiding-text if available\n   */\n  private setAriaDescribedByToDescription() {\n    const children = Array.from(this.staticContainer.nativeElement.children);\n    if (children.length === 0) {\n      this.showAriaDescribedBy(false);\n      return;\n    }\n\n    this.showAriaDescribedBy(true);\n  }\n\n  private showAriaDescribedBy(value: boolean) {\n    this.ariaDescribedby = value ? `${this.id}-ariadescribedby` : null;\n  }\n\n  private onTouch: () => any = () => undefined;\n}\n","<fieldset\n  role=\"radiogroup\"\n  class=\"bao-radio-button-group\"\n  [id]=\"id\"\n  [attr.aria-describedby]=\"ariaDescribedby\"\n>\n  <ng-content></ng-content>\n  <div\n    class=\"bao-radio-button-group-description\"\n    [attr.id]=\"ariaDescribedby\"\n    #container\n    (cdkObserveContent)=\"onContentChange()\"\n  >\n    <ng-content\n      select=\"bao-error, [bao-error], bao-guiding-text, [bao-guiding-text]\"\n    ></ng-content>\n  </div>\n</fieldset>\n"]}
249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/radio/radio-group.component.ts","../../../../../projects/angular-ui/src/lib/radio/radio-group.component.html"],"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 { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  InjectionToken,\n  Input,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { BaoRadioButtonComponent } from '.';\n\n/**\n * We have to inject the radio button group and all its children to each child.\n */\nexport const BAO_RADIO_GROUP = new InjectionToken<BaoRadioButtonGroupComponent>(\n  'BaoRadioButtonGroup'\n);\n/**\n * Unique ID for each radio group counter\n */\nlet radioGroupNextUniqueId = 0;\n\n@Component({\n  selector:\n    'bao-radio-button-group, [bao-radio-button-group], [baoRadioButtonGroup]',\n  exportAs: 'baoRadioGroup',\n  templateUrl: './radio-group.component.html',\n  styleUrls: ['./radio-group.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => BaoRadioButtonGroupComponent),\n      multi: true\n    },\n    { provide: BAO_RADIO_GROUP, useExisting: BaoRadioButtonGroupComponent }\n  ]\n})\nexport class BaoRadioButtonGroupComponent\n  implements AfterContentInit, ControlValueAccessor, AfterViewInit\n{\n  /**\n   * The checkbox group ID. It is set dynamically with an unique ID by default\n   */\n  @Input() public id: string;\n\n  /**\n   * Emit the value of the selected radio button\n   */\n  @Output() public readonly change: EventEmitter<string> =\n    new EventEmitter<string>();\n\n  @ContentChildren(forwardRef(() => BaoRadioButtonComponent), {\n    descendants: true\n  })\n  @ViewChild('container', { static: false })\n  private staticContainer: ElementRef;\n\n  /**\n   * The aria-describedby for web accessibilty\n   */\n  public ariaDescribedby: string | null = null;\n\n  private _radios: QueryList<BaoRadioButtonComponent>;\n  private _value: string | null = null;\n  private _name: string | null = null;\n  private _selected: BaoRadioButtonComponent | null = null;\n  private _isInitialized = false;\n  private _disabled = false;\n  private _required = false;\n\n  private _uniqueId = `bao-checkbox-group-${++radioGroupNextUniqueId}`;\n\n  constructor(private cdr: ChangeDetectorRef) {\n    if (!this.id) {\n      this.id = this._uniqueId;\n    }\n  }\n\n  /**\n   * Define the name property of all radio buttons. Default : null\n   */\n  @Input()\n  get name(): string | null {\n    return this._name;\n  }\n\n  /**\n   * Define the value of the selected radio button. Default : null\n   */\n  @Input()\n  get value(): string | null {\n    return this._value;\n  }\n\n  /**\n   * Define which radio button is selected. Default : null\n   */\n  @Input()\n  get selected() {\n    return this._selected;\n  }\n\n  /**\n   * Whether the radio button groupd is disabled. Default : false\n   */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  /**\n   * Whether the radio button groupd is required. Default : false\n   */\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n\n  set name(value: string | null) {\n    this._name = value;\n    this.updateRadioButtonNames();\n  }\n\n  set value(newValue: string | null) {\n    if (this._value !== newValue) {\n      this._value = newValue;\n      this.updateSelectedRadioFromValue();\n      this.checkSelectedRadioButton();\n    }\n  }\n\n  set selected(selected: BaoRadioButtonComponent | null) {\n    this._selected = selected;\n    this.value = selected ? selected.value : null;\n    this.checkSelectedRadioButton();\n  }\n\n  set disabled(value) {\n    this._disabled = coerceBooleanProperty(value);\n    this.markRadiosForCheck();\n  }\n\n  set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n    this.markRadiosForCheck();\n  }\n\n  public ngAfterContentInit() {\n    this._isInitialized = true;\n  }\n\n  public ngAfterViewInit() {\n    this.setAriaDescribedByToDescription();\n    this.cdr.detectChanges();\n  }\n\n  /**\n   * Implement ControlValueAccessor\n   */\n  public writeValue(value: string) {\n    this.value = value;\n    this.cdr.markForCheck();\n  }\n\n  /**\n   * Implement ControlValueAccessor\n   */\n  public registerOnChange(fn: (value: any) => void) {\n    this.onModelChange = fn;\n  }\n\n  /**\n   * Implement ControlValueAccessor\n   */\n  public registerOnTouched(fn: any) {\n    this.onTouch = fn;\n  }\n\n  /**\n   * Implement ControlValueAccessor\n   */\n  public setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  /**\n   * onTouch() called from the button children\n   */\n  public onGroupTouch() {\n    if (this.onTouch) {\n      this.onTouch();\n    }\n  }\n\n  /**\n   * Update all radio button name\n   */\n  public updateRadioButtonNames(): void {\n    if (this._radios) {\n      this._radios.forEach((radio: BaoRadioButtonComponent) => {\n        radio.name = this.name;\n        radio.markForCheck();\n      });\n    }\n  }\n\n  /**\n   * Define which radio button is selected.\n   */\n  public updateSelectedRadioFromValue(): void {\n    const isAlreadySelected =\n      this._selected !== null && this._selected.value === this._value;\n    if (this._radios && !isAlreadySelected) {\n      this._selected = null;\n      this._radios.forEach((radio: BaoRadioButtonComponent) => {\n        radio.checked = this.value === radio.value;\n        if (radio.checked) {\n          this._selected = radio;\n        }\n      });\n    }\n  }\n\n  /**\n   * Update checked property on selected radio button\n   */\n  public checkSelectedRadioButton() {\n    if (this._selected && !this._selected.checked) {\n      this._selected.checked = true;\n    }\n  }\n\n  /**\n   * Emit the value of the new selected radio button\n   */\n  public emitChangeEvent(): void {\n    if (this._isInitialized) {\n      this.change.emit(this.value);\n    }\n  }\n\n  /**\n   * Call markForCheck function on all radio buttons since one of the parent inputs could't have change meanwhile. Prevent change detection error.\n   */\n  public markRadiosForCheck() {\n    if (this._radios) {\n      this._radios.forEach((radio: BaoRadioButtonComponent) =>\n        radio.markForCheck()\n      );\n    }\n  }\n\n  public onContentChange() {\n    this.setAriaDescribedByToDescription();\n  }\n\n  public onModelChange: (value: any) => void = () => undefined;\n\n  /**\n   * Set the aria-describedby property to bao-guiding-text if available\n   */\n  private setAriaDescribedByToDescription() {\n    const children = Array.from(this.staticContainer.nativeElement.children);\n    if (children.length === 0) {\n      this.showAriaDescribedBy(false);\n      return;\n    }\n\n    this.showAriaDescribedBy(true);\n  }\n\n  private showAriaDescribedBy(value: boolean) {\n    this.ariaDescribedby = value ? `${this.id}-ariadescribedby` : null;\n  }\n\n  private onTouch: () => any = () => undefined;\n}\n","<fieldset\n  role=\"radiogroup\"\n  class=\"bao-radio-button-group\"\n  [id]=\"id\"\n  [attr.aria-describedby]=\"ariaDescribedby\"\n>\n  <ng-content></ng-content>\n  <div\n    class=\"bao-radio-button-group-description\"\n    [attr.id]=\"ariaDescribedby\"\n    #container\n    (cdkObserveContent)=\"onContentChange()\"\n  >\n    <ng-content\n      select=\"bao-error, [bao-error], bao-guiding-text, [bao-guiding-text]\"\n    ></ng-content>\n  </div>\n</fieldset>\n"]}
@@ -16,15 +16,6 @@ export class BaoRadioButtonComponent {
16
16
  this.cdr = cdr;
17
17
  this.focusMonitor = focusMonitor;
18
18
  this.radioDispatcher = radioDispatcher;
19
- this._checked = false;
20
- this._disabled = false;
21
- this._required = false;
22
- this._value = null;
23
- this._uniqueId = `bao-radio-button-${++radioNextUniqueId}`;
24
- /**
25
- * The radio button ID. It is set dynamically with an unique ID by default
26
- */
27
- this.id = this._uniqueId;
28
19
  /**
29
20
  * The aria-label for web accessibility
30
21
  */
@@ -57,6 +48,11 @@ export class BaoRadioButtonComponent {
57
48
  * The aria-labeledby id for web accessibilty
58
49
  */
59
50
  this.ariaLabelledby = null;
51
+ this._checked = false;
52
+ this._disabled = false;
53
+ this._required = false;
54
+ this._value = null;
55
+ this._uniqueId = `bao-radio-button-${++radioNextUniqueId}`;
60
56
  /** Unregister function for radioDispatcher */
61
57
  this._removeUniqueSelectionListener = () => undefined;
62
58
  this.radioGroup = radioGroup;
@@ -65,6 +61,9 @@ export class BaoRadioButtonComponent {
65
61
  this.checked = false;
66
62
  }
67
63
  });
64
+ if (!this.id) {
65
+ this.id = this._uniqueId;
66
+ }
68
67
  }
69
68
  /**
70
69
  * Whether the radio button is checked. Default : false
@@ -72,6 +71,27 @@ export class BaoRadioButtonComponent {
72
71
  get checked() {
73
72
  return this._checked;
74
73
  }
74
+ /**
75
+ * Define the radio button value. Default : null
76
+ */
77
+ get value() {
78
+ return this._value;
79
+ }
80
+ /**
81
+ * Whether the radio button is disabled. Default : false
82
+ */
83
+ get disabled() {
84
+ return this._disabled || (this.radioGroup && this.radioGroup.disabled);
85
+ }
86
+ /**
87
+ * Whether the radio button is required. Default : false
88
+ */
89
+ get required() {
90
+ return this._required || (this.radioGroup && this.radioGroup.required);
91
+ }
92
+ get nativeElement() {
93
+ return this.elementRef.nativeElement;
94
+ }
75
95
  set checked(value) {
76
96
  const newCheckedState = coerceBooleanProperty(value);
77
97
  if (this._checked !== newCheckedState) {
@@ -92,12 +112,6 @@ export class BaoRadioButtonComponent {
92
112
  this.cdr.markForCheck();
93
113
  }
94
114
  }
95
- /**
96
- * Define the radio button value. Default : null
97
- */
98
- get value() {
99
- return this._value;
100
- }
101
115
  set value(value) {
102
116
  if (value !== this._value) {
103
117
  this._value = value;
@@ -111,27 +125,12 @@ export class BaoRadioButtonComponent {
111
125
  }
112
126
  }
113
127
  }
114
- /**
115
- * Whether the radio button is disabled. Default : false
116
- */
117
- get disabled() {
118
- return this._disabled || (this.radioGroup && this.radioGroup.disabled);
119
- }
120
128
  set disabled(value) {
121
129
  this.setDisabled(coerceBooleanProperty(value));
122
130
  }
123
- /**
124
- * Whether the radio button is required. Default : false
125
- */
126
- get required() {
127
- return this._required || (this.radioGroup && this.radioGroup.required);
128
- }
129
131
  set required(value) {
130
132
  this._required = coerceBooleanProperty(value);
131
133
  }
132
- get nativeElement() {
133
- return this.elementRef.nativeElement;
134
- }
135
134
  focus(options, origin) {
136
135
  if (origin) {
137
136
  this.focusMonitor.focusVia(this.inputElement, origin, options);
@@ -222,15 +221,15 @@ export class BaoRadioButtonComponent {
222
221
  }
223
222
  }
224
223
  }
225
- BaoRadioButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoRadioButtonComponent, deps: [{ token: BAO_RADIO_GROUP, optional: true }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.FocusMonitor }, { token: i2.UniqueSelectionDispatcher }], target: i0.ɵɵFactoryTarget.Component });
226
- BaoRadioButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BaoRadioButtonComponent, selector: "bao-radio-button, [bao-radio-button]", inputs: { id: "id", ariaLabel: ["aria-label", "ariaLabel"], brandBorder: "brandBorder", inline: "inline", name: "name", checked: "checked", value: "value", disabled: "disabled", required: "required", hiddenLabel: "hiddenLabel" }, outputs: { change: "change" }, host: { properties: { "class.bao-radio-button-inline": "inline", "class.bao-radio-button-checked": "checked", "class.bao-radio-button-disabled": "disabled", "class.bao-radio-button-card": "brandBorder", "class.bao-radio-button-hidden-label": "hiddenLabel" }, classAttribute: "bao-radio-button" }, providers: [
224
+ BaoRadioButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoRadioButtonComponent, deps: [{ token: BAO_RADIO_GROUP, optional: true }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.FocusMonitor }, { token: i2.UniqueSelectionDispatcher }], target: i0.ɵɵFactoryTarget.Component });
225
+ BaoRadioButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.1", type: BaoRadioButtonComponent, selector: "bao-radio-button, [bao-radio-button]", inputs: { id: "id", ariaLabel: ["aria-label", "ariaLabel"], brandBorder: "brandBorder", inline: "inline", name: "name", hiddenLabel: "hiddenLabel", checked: "checked", value: "value", disabled: "disabled", required: "required" }, outputs: { change: "change" }, host: { properties: { "class.bao-radio-button-inline": "inline", "class.bao-radio-button-checked": "checked", "class.bao-radio-button-disabled": "disabled", "class.bao-radio-button-card": "brandBorder", "class.bao-radio-button-hidden-label": "hiddenLabel" }, classAttribute: "bao-radio-button" }, providers: [
227
226
  {
228
227
  provide: NG_VALUE_ACCESSOR,
229
228
  useExisting: forwardRef(() => BaoRadioButtonComponent),
230
229
  multi: true
231
230
  }
232
- ], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["input"], descendants: true }], ngImport: i0, template: "<input\n #input\n type=\"radio\"\n [id]=\"inputID\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [attr.name]=\"name\"\n [attr.value]=\"value\"\n [required]=\"required\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n (change)=\"onInputInteraction($event)\"\n role=\"radio\"\n/>\n<label class=\"bao-radio-button-content-container\" [attr.for]=\"inputID\">\n <div class=\"bao-radio-button-label\" [id]=\"ariaLabelledby\">\n <ng-content></ng-content>\n </div>\n <ng-content\n select=\"bao-radio-button-description, [bao-radio-button-description], [baoRadioButtonDescription]\"\n ></ng-content>\n</label>\n", styles: [".bao-radio-button{display:block;font-size:1rem;line-height:1.5rem;min-height:1.5rem;padding-top:.5rem;padding-bottom:.5rem;padding-left:2rem;position:relative;z-index:1}.bao-radio-button input{box-sizing:border-box;left:0;opacity:0;overflow:visible;padding:0;position:absolute;z-index:-1}.bao-radio-button input:focus~.bao-radio-button-content-container:before{box-shadow:0 0 0 .1875rem #0079c480}.bao-radio-button label.bao-radio-button-content-container{color:#212529;font-weight:400;font-size:1rem;line-height:1.5rem;margin-bottom:0;position:relative;vertical-align:top}.bao-radio-button label.bao-radio-button-content-container:before{border-radius:50%;box-sizing:border-box;position:absolute;top:0;left:-2rem;display:block;margin:.125rem;width:1.25rem;height:1.25rem;pointer-events:none;content:\"\";background-color:#fff;border:#ced4da solid 1px;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}.bao-radio-button label.bao-radio-button-content-container:after{box-sizing:border-box;background:no-repeat 50%/1.5rem;content:\"\";display:block;height:1.5rem;left:-2rem;margin:0;position:absolute;top:0;width:1.5rem}.bao-radio-button label.bao-radio-button-content-container .bao-radio-button-label{color:#212529;display:block}.bao-radio-button label.bao-radio-button-content-container .bao-radio-button-description{color:#637381;display:block;margin-top:.5rem}.bao-radio-button.bao-radio-button-inline{display:inline-flex;margin-right:1rem}.bao-radio-button.bao-radio-button-card{padding:0;margin-bottom:1rem}.bao-radio-button.bao-radio-button-card:last-of-type{margin-bottom:0}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container{display:flex;flex-direction:column;flex:1;justify-content:center;padding:1rem 1rem 1rem 3.5rem;position:relative;border:1px solid #ced4da;border-radius:.25rem;color:#637381;min-height:3.5rem}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container:before{top:1rem;left:0;margin-left:1.125rem}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container:after{top:1rem;left:0;margin-left:1rem}.bao-radio-button input:checked~.bao-radio-button-content-container:before{border-color:#097d6c;background-color:#097d6c}.bao-radio-button input:checked~.bao-radio-button-content-container:after{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3e%3ccircle cx='12' cy='12' r='4' fill='%23ffffff'/%3e%3c/svg%3e\")}.bao-radio-button input:disabled~.bao-radio-button-content-container{color:#adb2bd;border-color:#dee2e6}.bao-radio-button input:disabled~.bao-radio-button-content-container:before{border-color:#ced4da;background-color:#ced4da}.bao-radio-button input:disabled~.bao-radio-button-content-container .bao-radio-button-label,.bao-radio-button input:disabled~.bao-radio-button-content-container .bao-radio-button-description{color:#adb2bd}.bao-radio-button.bao-radio-button-hidden-label .bao-radio-button-label{clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;width:1px;margin:-1px;overflow:hidden;padding:0;position:absolute}.bao-radio-button.bao-radio-button-hidden-label label.bao-radio-button-content-container .bao-radio-button-description{margin-top:0}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
233
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoRadioButtonComponent, decorators: [{
231
+ ], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["input"], descendants: true }], ngImport: i0, template: "<input\n #input\n type=\"radio\"\n [id]=\"inputID\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [attr.name]=\"name\"\n [attr.value]=\"value\"\n [required]=\"required\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n (change)=\"onInputInteraction($event)\"\n role=\"radio\"\n/>\n<label class=\"bao-radio-button-content-container\" [attr.for]=\"inputID\">\n <div class=\"bao-radio-button-label\" [id]=\"ariaLabelledby\">\n <ng-content></ng-content>\n </div>\n <ng-content\n select=\"bao-radio-button-description, [bao-radio-button-description], [baoRadioButtonDescription]\"\n ></ng-content>\n</label>\n", styles: [".bao-radio-button{display:block;font-size:1rem;line-height:1.5rem;min-height:1.5rem;padding-top:.5rem;padding-bottom:.5rem;padding-left:2rem;position:relative;z-index:1}.bao-radio-button input{box-sizing:border-box;left:0;opacity:0;overflow:visible;padding:0;position:absolute;z-index:-1}.bao-radio-button input:focus~.bao-radio-button-content-container:before{box-shadow:0 0 0 .1875rem #0079c480}.bao-radio-button label.bao-radio-button-content-container{color:#212529;font-weight:400;font-size:1rem;line-height:1.5rem;margin-bottom:0;position:relative;vertical-align:top}.bao-radio-button label.bao-radio-button-content-container:before{border-radius:50%;box-sizing:border-box;position:absolute;top:0;left:-2rem;display:block;margin:.125rem;width:1.25rem;height:1.25rem;pointer-events:none;content:\"\";background-color:#fff;border:#ced4da solid 1px;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}.bao-radio-button label.bao-radio-button-content-container:after{box-sizing:border-box;background:no-repeat 50%/1.5rem;content:\"\";display:block;height:1.5rem;left:-2rem;margin:0;position:absolute;top:0;width:1.5rem}.bao-radio-button label.bao-radio-button-content-container .bao-radio-button-label{color:#212529;display:block}.bao-radio-button label.bao-radio-button-content-container .bao-radio-button-description{color:#637381;display:block;margin-top:.5rem}.bao-radio-button.bao-radio-button-inline{display:inline-flex;margin-right:1rem}.bao-radio-button.bao-radio-button-card{padding:0;margin-bottom:1rem}.bao-radio-button.bao-radio-button-card:last-of-type{margin-bottom:0}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container{display:flex;flex-direction:column;flex:1;justify-content:center;padding:1rem 1rem 1rem 3.5rem;position:relative;border:1px solid #ced4da;border-radius:.25rem;color:#637381;min-height:3.5rem}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container:before{top:1rem;left:0;margin-left:1.125rem}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container:after{top:1rem;left:0;margin-left:1rem}.bao-radio-button input:checked~.bao-radio-button-content-container:before{border-color:#097d6c;background-color:#097d6c}.bao-radio-button input:checked~.bao-radio-button-content-container:after{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3e%3ccircle cx='12' cy='12' r='4' fill='%23ffffff'/%3e%3c/svg%3e\")}.bao-radio-button input:disabled~.bao-radio-button-content-container{color:#adb2bd;border-color:#dee2e6}.bao-radio-button input:disabled~.bao-radio-button-content-container:before{border-color:#ced4da;background-color:#ced4da}.bao-radio-button input:disabled~.bao-radio-button-content-container .bao-radio-button-label,.bao-radio-button input:disabled~.bao-radio-button-content-container .bao-radio-button-description{color:#adb2bd}.bao-radio-button.bao-radio-button-hidden-label .bao-radio-button-label{clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;width:1px;margin:-1px;overflow:hidden;padding:0;position:absolute}.bao-radio-button.bao-radio-button-hidden-label label.bao-radio-button-content-container .bao-radio-button-description{margin-top:0}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
232
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoRadioButtonComponent, decorators: [{
234
233
  type: Component,
235
234
  args: [{ selector: 'bao-radio-button, [bao-radio-button]', providers: [
236
235
  {
@@ -245,7 +244,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
245
244
  '[class.bao-radio-button-disabled]': 'disabled',
246
245
  '[class.bao-radio-button-card]': 'brandBorder',
247
246
  '[class.bao-radio-button-hidden-label]': 'hiddenLabel'
248
- }, template: "<input\n #input\n type=\"radio\"\n [id]=\"inputID\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [attr.name]=\"name\"\n [attr.value]=\"value\"\n [required]=\"required\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n (change)=\"onInputInteraction($event)\"\n role=\"radio\"\n/>\n<label class=\"bao-radio-button-content-container\" [attr.for]=\"inputID\">\n <div class=\"bao-radio-button-label\" [id]=\"ariaLabelledby\">\n <ng-content></ng-content>\n </div>\n <ng-content\n select=\"bao-radio-button-description, [bao-radio-button-description], [baoRadioButtonDescription]\"\n ></ng-content>\n</label>\n", styles: [".bao-radio-button{display:block;font-size:1rem;line-height:1.5rem;min-height:1.5rem;padding-top:.5rem;padding-bottom:.5rem;padding-left:2rem;position:relative;z-index:1}.bao-radio-button input{box-sizing:border-box;left:0;opacity:0;overflow:visible;padding:0;position:absolute;z-index:-1}.bao-radio-button input:focus~.bao-radio-button-content-container:before{box-shadow:0 0 0 .1875rem #0079c480}.bao-radio-button label.bao-radio-button-content-container{color:#212529;font-weight:400;font-size:1rem;line-height:1.5rem;margin-bottom:0;position:relative;vertical-align:top}.bao-radio-button label.bao-radio-button-content-container:before{border-radius:50%;box-sizing:border-box;position:absolute;top:0;left:-2rem;display:block;margin:.125rem;width:1.25rem;height:1.25rem;pointer-events:none;content:\"\";background-color:#fff;border:#ced4da solid 1px;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}.bao-radio-button label.bao-radio-button-content-container:after{box-sizing:border-box;background:no-repeat 50%/1.5rem;content:\"\";display:block;height:1.5rem;left:-2rem;margin:0;position:absolute;top:0;width:1.5rem}.bao-radio-button label.bao-radio-button-content-container .bao-radio-button-label{color:#212529;display:block}.bao-radio-button label.bao-radio-button-content-container .bao-radio-button-description{color:#637381;display:block;margin-top:.5rem}.bao-radio-button.bao-radio-button-inline{display:inline-flex;margin-right:1rem}.bao-radio-button.bao-radio-button-card{padding:0;margin-bottom:1rem}.bao-radio-button.bao-radio-button-card:last-of-type{margin-bottom:0}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container{display:flex;flex-direction:column;flex:1;justify-content:center;padding:1rem 1rem 1rem 3.5rem;position:relative;border:1px solid #ced4da;border-radius:.25rem;color:#637381;min-height:3.5rem}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container:before{top:1rem;left:0;margin-left:1.125rem}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container:after{top:1rem;left:0;margin-left:1rem}.bao-radio-button input:checked~.bao-radio-button-content-container:before{border-color:#097d6c;background-color:#097d6c}.bao-radio-button input:checked~.bao-radio-button-content-container:after{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3e%3ccircle cx='12' cy='12' r='4' fill='%23ffffff'/%3e%3c/svg%3e\")}.bao-radio-button input:disabled~.bao-radio-button-content-container{color:#adb2bd;border-color:#dee2e6}.bao-radio-button input:disabled~.bao-radio-button-content-container:before{border-color:#ced4da;background-color:#ced4da}.bao-radio-button input:disabled~.bao-radio-button-content-container .bao-radio-button-label,.bao-radio-button input:disabled~.bao-radio-button-content-container .bao-radio-button-description{color:#adb2bd}.bao-radio-button.bao-radio-button-hidden-label .bao-radio-button-label{clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;width:1px;margin:-1px;overflow:hidden;padding:0;position:absolute}.bao-radio-button.bao-radio-button-hidden-label label.bao-radio-button-content-container .bao-radio-button-description{margin-top:0}\n"] }]
247
+ }, template: "<input\n #input\n type=\"radio\"\n [id]=\"inputID\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [attr.name]=\"name\"\n [attr.value]=\"value\"\n [required]=\"required\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n (change)=\"onInputInteraction($event)\"\n role=\"radio\"\n/>\n<label class=\"bao-radio-button-content-container\" [attr.for]=\"inputID\">\n <div class=\"bao-radio-button-label\" [id]=\"ariaLabelledby\">\n <ng-content></ng-content>\n </div>\n <ng-content\n select=\"bao-radio-button-description, [bao-radio-button-description], [baoRadioButtonDescription]\"\n ></ng-content>\n</label>\n", styles: [".bao-radio-button{display:block;font-size:1rem;line-height:1.5rem;min-height:1.5rem;padding-top:.5rem;padding-bottom:.5rem;padding-left:2rem;position:relative;z-index:1}.bao-radio-button input{box-sizing:border-box;left:0;opacity:0;overflow:visible;padding:0;position:absolute;z-index:-1}.bao-radio-button input:focus~.bao-radio-button-content-container:before{box-shadow:0 0 0 .1875rem #0079c480}.bao-radio-button label.bao-radio-button-content-container{color:#212529;font-weight:400;font-size:1rem;line-height:1.5rem;margin-bottom:0;position:relative;vertical-align:top}.bao-radio-button label.bao-radio-button-content-container:before{border-radius:50%;box-sizing:border-box;position:absolute;top:0;left:-2rem;display:block;margin:.125rem;width:1.25rem;height:1.25rem;pointer-events:none;content:\"\";background-color:#fff;border:#ced4da solid 1px;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}.bao-radio-button label.bao-radio-button-content-container:after{box-sizing:border-box;background:no-repeat 50%/1.5rem;content:\"\";display:block;height:1.5rem;left:-2rem;margin:0;position:absolute;top:0;width:1.5rem}.bao-radio-button label.bao-radio-button-content-container .bao-radio-button-label{color:#212529;display:block}.bao-radio-button label.bao-radio-button-content-container .bao-radio-button-description{color:#637381;display:block;margin-top:.5rem}.bao-radio-button.bao-radio-button-inline{display:inline-flex;margin-right:1rem}.bao-radio-button.bao-radio-button-card{padding:0;margin-bottom:1rem}.bao-radio-button.bao-radio-button-card:last-of-type{margin-bottom:0}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container{display:flex;flex-direction:column;flex:1;justify-content:center;padding:1rem 1rem 1rem 3.5rem;position:relative;border:1px solid #ced4da;border-radius:.25rem;color:#637381;min-height:3.5rem}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container:before{top:1rem;left:0;margin-left:1.125rem}.bao-radio-button.bao-radio-button-card label.bao-radio-button-content-container:after{top:1rem;left:0;margin-left:1rem}.bao-radio-button input:checked~.bao-radio-button-content-container:before{border-color:#097d6c;background-color:#097d6c}.bao-radio-button input:checked~.bao-radio-button-content-container:after{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3e%3ccircle cx='12' cy='12' r='4' fill='%23ffffff'/%3e%3c/svg%3e\")}.bao-radio-button input:disabled~.bao-radio-button-content-container{color:#adb2bd;border-color:#dee2e6}.bao-radio-button input:disabled~.bao-radio-button-content-container:before{border-color:#ced4da;background-color:#ced4da}.bao-radio-button input:disabled~.bao-radio-button-content-container .bao-radio-button-label,.bao-radio-button input:disabled~.bao-radio-button-content-container .bao-radio-button-description{color:#adb2bd}.bao-radio-button.bao-radio-button-hidden-label .bao-radio-button-label{clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;width:1px;margin:-1px;overflow:hidden;padding:0;position:absolute}.bao-radio-button.bao-radio-button-hidden-label label.bao-radio-button-content-container .bao-radio-button-description{margin-top:0}\n"] }]
249
248
  }], ctorParameters: function () { return [{ type: i3.BaoRadioButtonGroupComponent, decorators: [{
250
249
  type: Optional
251
250
  }, {
@@ -262,6 +261,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
262
261
  type: Input
263
262
  }], name: [{
264
263
  type: Input
264
+ }], hiddenLabel: [{
265
+ type: Input
266
+ }], change: [{
267
+ type: Output
268
+ }], inputElement: [{
269
+ type: ViewChild,
270
+ args: ['input', { static: false }]
265
271
  }], checked: [{
266
272
  type: Input
267
273
  }], value: [{
@@ -270,23 +276,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
270
276
  type: Input
271
277
  }], required: [{
272
278
  type: Input
273
- }], hiddenLabel: [{
274
- type: Input
275
- }], change: [{
276
- type: Output
277
- }], inputElement: [{
278
- type: ViewChild,
279
- args: ['input', { static: false }]
280
279
  }] } });
281
280
  export class BaoRadioDescription {
282
281
  }
283
- BaoRadioDescription.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoRadioDescription, deps: [], target: i0.ɵɵFactoryTarget.Directive });
284
- BaoRadioDescription.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.1.1", type: BaoRadioDescription, selector: "bao-radio-button-description, [bao-radio-button-description], [baoRadioButtonDescription]", host: { classAttribute: "bao-radio-button-description" }, ngImport: i0 });
285
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoRadioDescription, decorators: [{
282
+ BaoRadioDescription.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoRadioDescription, deps: [], target: i0.ɵɵFactoryTarget.Directive });
283
+ BaoRadioDescription.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.1", type: BaoRadioDescription, selector: "bao-radio-button-description, [bao-radio-button-description], [baoRadioButtonDescription]", host: { classAttribute: "bao-radio-button-description" }, ngImport: i0 });
284
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoRadioDescription, decorators: [{
286
285
  type: Directive,
287
286
  args: [{
288
287
  selector: 'bao-radio-button-description, [bao-radio-button-description], [baoRadioButtonDescription]',
289
288
  host: { class: 'bao-radio-button-description' }
290
289
  }]
291
290
  }] });
292
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/radio/radio.component.ts","../../../../../projects/angular-ui/src/lib/radio/radio.component.html"],"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 { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { UniqueSelectionDispatcher } from '@angular/cdk/collections';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport {\n  BAO_RADIO_GROUP,\n  BaoRadioButtonGroupComponent\n} from './radio-group.component';\n\n/**\n * Unique ID for each radio button\n */\nlet radioNextUniqueId = 0;\n\n@Component({\n  selector: 'bao-radio-button, [bao-radio-button]',\n  templateUrl: 'radio.component.html',\n  styleUrls: ['./radio.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => BaoRadioButtonComponent),\n      multi: true\n    }\n  ],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'bao-radio-button',\n    '[class.bao-radio-button-inline]': 'inline',\n    '[class.bao-radio-button-checked]': 'checked',\n    '[class.bao-radio-button-disabled]': 'disabled',\n    '[class.bao-radio-button-card]': 'brandBorder',\n    '[class.bao-radio-button-hidden-label]': 'hiddenLabel'\n  }\n})\nexport class BaoRadioButtonComponent\n  implements AfterViewInit, OnInit, OnDestroy\n{\n  private _checked = false;\n  private _disabled = false;\n  private _required = false;\n  private _value: string | null = null;\n  private _uniqueId = `bao-radio-button-${++radioNextUniqueId}`;\n\n  /**\n   * The radio button ID. It is set dynamically with an unique ID by default\n   */\n  @Input() public id: string = this._uniqueId;\n\n  /**\n   * The aria-label for web accessibility\n   */\n  @Input('aria-label') public ariaLabel: string | null = null;\n\n  /**\n   * Whether the radio button has a border and is considered as a card.\n   */\n  @Input() public brandBorder = false;\n\n  /**\n   * Whether the radio button is inline.\n   */\n  @Input() public inline = false;\n\n  /**\n   * The name property of the radio button\n   */\n  @Input() public name: string | null = null;\n\n  /**\n   * Whether the radio button is checked. Default : false\n   */\n  @Input()\n  get checked(): boolean {\n    return this._checked;\n  }\n  set checked(value: boolean) {\n    const newCheckedState = coerceBooleanProperty(value);\n    if (this._checked !== newCheckedState) {\n      this._checked = newCheckedState;\n      if (\n        newCheckedState &&\n        this.radioGroup &&\n        this.radioGroup.value !== this.value\n      ) {\n        this.radioGroup.selected = this;\n      } else if (\n        !newCheckedState &&\n        this.radioGroup &&\n        this.radioGroup.value === this.value\n      ) {\n        this.radioGroup.selected = null;\n      }\n\n      if (newCheckedState) {\n        this.radioDispatcher.notify(this.id, this.name);\n      }\n      this.cdr.markForCheck();\n    }\n  }\n\n  /**\n   * Define the radio button value. Default : null\n   */\n  @Input()\n  get value(): string {\n    return this._value;\n  }\n  set value(value: string) {\n    if (value !== this._value) {\n      this._value = value;\n      if (this.radioGroup) {\n        if (!this.checked) {\n          this.checked = this.radioGroup.value === value;\n        }\n        if (this.checked) {\n          this.radioGroup.selected = this;\n        }\n      }\n    }\n  }\n\n  /**\n   * Whether the radio button is disabled. Default : false\n   */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled || (this.radioGroup && this.radioGroup.disabled);\n  }\n  set disabled(value: boolean) {\n    this.setDisabled(coerceBooleanProperty(value));\n  }\n\n  /**\n   * Whether the radio button is required. Default : false\n   */\n  @Input()\n  get required(): boolean {\n    return this._required || (this.radioGroup && this.radioGroup.required);\n  }\n  set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n  }\n\n  /**\n   * The visible state of the label\n   */\n  @Input() public hiddenLabel = false;\n\n  /**\n   * Emitted boolean on change\n   */\n  @Output() public readonly change: EventEmitter<string> =\n    new EventEmitter<string>();\n\n  /**\n   * Reference to the input html element\n   */\n  @ViewChild('input', { static: false })\n  private inputElement: ElementRef<HTMLInputElement>;\n\n  /**\n   * The radio buttons group\n   */\n  public radioGroup: BaoRadioButtonGroupComponent;\n\n  /**\n   * The aria-describedby id for web accessibilty\n   */\n  public ariaDescribedby: string | null = null;\n\n  /**\n   * The aria-labeledby id for web accessibilty\n   */\n  public ariaLabelledby: string | null = null;\n\n  /**\n   * The ID of the input html element\n   */\n  public inputID: string;\n\n  constructor(\n    @Optional()\n    @Inject(BAO_RADIO_GROUP)\n    radioGroup: BaoRadioButtonGroupComponent,\n    private elementRef: ElementRef,\n    private cdr: ChangeDetectorRef,\n    private focusMonitor: FocusMonitor,\n    private radioDispatcher: UniqueSelectionDispatcher\n  ) {\n    this.radioGroup = radioGroup;\n    this._removeUniqueSelectionListener = radioDispatcher.listen(\n      (id: string, name: string) => {\n        if (id !== this.id && name === this.name) {\n          this.checked = false;\n        }\n      }\n    );\n  }\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  public focus(options?: FocusOptions, origin?: FocusOrigin): void {\n    if (origin) {\n      this.focusMonitor.focusVia(this.inputElement, origin, options);\n    } else {\n      this.inputElement.nativeElement.focus(options);\n    }\n  }\n\n  /**\n   * Method called from the parent as one of the parent input has changed. Prevent change detection error.\n   */\n  public markForCheck() {\n    this.cdr.markForCheck();\n  }\n\n  public ngOnInit() {\n    // Set all unique ids for the html elements\n    this.inputID = `${this.id}-input`;\n    this.ariaLabelledby = `${this.id}-arialabelledby`;\n\n    if (this.radioGroup) {\n      this.checked = this.radioGroup.value === this._value;\n\n      if (this.checked) {\n        this.radioGroup.selected = this;\n      }\n\n      this.name = this.radioGroup.name;\n    }\n  }\n\n  public ngAfterViewInit() {\n    this.focusMonitor\n      .monitor(this.inputElement, true)\n      .subscribe(focusOrigin => {\n        if (!focusOrigin && this.radioGroup) {\n          this.radioGroup.onGroupTouch();\n        }\n      });\n\n    this.setAriaDescribedByToDescription();\n  }\n\n  public ngOnDestroy() {\n    this.focusMonitor.stopMonitoring(this.inputElement);\n    this._removeUniqueSelectionListener;\n  }\n\n  /**\n   * Emit the new value from the selected radio-button and the parent\n   */\n  public onInputInteraction(event: Event) {\n    event.stopPropagation();\n    if (!this.checked && !this.disabled) {\n      const groupValueChanged =\n        this.radioGroup && this.value !== this.radioGroup.value;\n      this.checked = true;\n      this.emitChangeEvent();\n\n      if (this.radioGroup) {\n        this.radioGroup.onModelChange(this.value);\n        if (groupValueChanged) {\n          this.radioGroup.emitChangeEvent();\n        }\n      }\n    }\n  }\n\n  private emitChangeEvent(): void {\n    this.change.emit(this.value);\n  }\n\n  private setDisabled(value: boolean) {\n    if (this._disabled !== value) {\n      this._disabled = value;\n      this.cdr.markForCheck();\n    }\n  }\n\n  /**\n   * Set the id property to bao-radio-button-description as a description to the input\n   */\n  private setAriaDescribedByToDescription() {\n    const childNodes = Array.from(this.nativeElement.childNodes);\n    const labelNode = childNodes.find(x => {\n      return x.nodeName === 'LABEL';\n    });\n    if (labelNode) {\n      const labelChildNodes = Array.from(labelNode.childNodes);\n      const descriptionNode = labelChildNodes.find(x => {\n        return x.nodeName === 'BAO-RADIO-BUTTON-DESCRIPTION';\n      });\n\n      if (descriptionNode) {\n        this.ariaDescribedby = `${this.id}-ariadescribedby`;\n        (descriptionNode as HTMLElement).setAttribute(\n          'id',\n          this.ariaDescribedby\n        );\n      } else {\n        this.ariaDescribedby = null;\n      }\n\n      this.cdr.detectChanges();\n    }\n  }\n\n  /** Unregister function for radioDispatcher */\n  private _removeUniqueSelectionListener: () => void = () => undefined;\n}\n\n@Directive({\n  selector:\n    'bao-radio-button-description, [bao-radio-button-description],  [baoRadioButtonDescription]',\n  host: { class: 'bao-radio-button-description' }\n})\nexport class BaoRadioDescription {}\n","<input\n  #input\n  type=\"radio\"\n  [id]=\"inputID\"\n  [checked]=\"checked\"\n  [disabled]=\"disabled\"\n  [attr.name]=\"name\"\n  [attr.value]=\"value\"\n  [required]=\"required\"\n  [attr.aria-label]=\"ariaLabel\"\n  [attr.aria-labelledby]=\"ariaLabelledby\"\n  [attr.aria-describedby]=\"ariaDescribedby\"\n  (change)=\"onInputInteraction($event)\"\n  role=\"radio\"\n/>\n<label class=\"bao-radio-button-content-container\" [attr.for]=\"inputID\">\n  <div class=\"bao-radio-button-label\" [id]=\"ariaLabelledby\">\n    <ng-content></ng-content>\n  </div>\n  <ng-content\n    select=\"bao-radio-button-description, [bao-radio-button-description], [baoRadioButtonDescription]\"\n  ></ng-content>\n</label>\n"]}
291
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/radio/radio.component.ts","../../../../../projects/angular-ui/src/lib/radio/radio.component.html"],"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 { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { UniqueSelectionDispatcher } from '@angular/cdk/collections';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport {\n  BAO_RADIO_GROUP,\n  BaoRadioButtonGroupComponent\n} from './radio-group.component';\n\n/**\n * Unique ID for each radio button\n */\nlet radioNextUniqueId = 0;\n\n@Component({\n  selector: 'bao-radio-button, [bao-radio-button]',\n  templateUrl: 'radio.component.html',\n  styleUrls: ['./radio.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => BaoRadioButtonComponent),\n      multi: true\n    }\n  ],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'bao-radio-button',\n    '[class.bao-radio-button-inline]': 'inline',\n    '[class.bao-radio-button-checked]': 'checked',\n    '[class.bao-radio-button-disabled]': 'disabled',\n    '[class.bao-radio-button-card]': 'brandBorder',\n    '[class.bao-radio-button-hidden-label]': 'hiddenLabel'\n  }\n})\nexport class BaoRadioButtonComponent\n  implements AfterViewInit, OnInit, OnDestroy\n{\n  /**\n   * The radio button ID. It is set dynamically with an unique ID by default\n   */\n  @Input() public id: string;\n\n  /**\n   * The aria-label for web accessibility\n   */\n  @Input('aria-label') public ariaLabel: string | null = null;\n\n  /**\n   * Whether the radio button has a border and is considered as a card.\n   */\n  @Input() public brandBorder = false;\n\n  /**\n   * Whether the radio button is inline.\n   */\n  @Input() public inline = false;\n\n  /**\n   * The name property of the radio button\n   */\n  @Input() public name: string | null = null;\n\n  /**\n   * The visible state of the label\n   */\n  @Input() public hiddenLabel = false;\n\n  /**\n   * Emitted boolean on change\n   */\n  @Output() public readonly change: EventEmitter<string> =\n    new EventEmitter<string>();\n\n  /**\n   * Reference to the input html element\n   */\n  @ViewChild('input', { static: false })\n  private inputElement: ElementRef<HTMLInputElement>;\n\n  /**\n   * The radio buttons group\n   */\n  public radioGroup: BaoRadioButtonGroupComponent;\n\n  /**\n   * The aria-describedby id for web accessibilty\n   */\n  public ariaDescribedby: string | null = null;\n\n  /**\n   * The aria-labeledby id for web accessibilty\n   */\n  public ariaLabelledby: string | null = null;\n\n  /**\n   * The ID of the input html element\n   */\n  public inputID: string;\n\n  private _checked = false;\n  private _disabled = false;\n  private _required = false;\n  private _value: string | null = null;\n  private _uniqueId = `bao-radio-button-${++radioNextUniqueId}`;\n\n  constructor(\n    @Optional()\n    @Inject(BAO_RADIO_GROUP)\n    radioGroup: BaoRadioButtonGroupComponent,\n    private elementRef: ElementRef<HTMLElement>,\n    private cdr: ChangeDetectorRef,\n    private focusMonitor: FocusMonitor,\n    private radioDispatcher: UniqueSelectionDispatcher\n  ) {\n    this.radioGroup = radioGroup;\n    this._removeUniqueSelectionListener = radioDispatcher.listen(\n      (id: string, name: string) => {\n        if (id !== this.id && name === this.name) {\n          this.checked = false;\n        }\n      }\n    );\n    if (!this.id) {\n      this.id = this._uniqueId;\n    }\n  }\n\n  /**\n   * Whether the radio button is checked. Default : false\n   */\n  @Input()\n  get checked(): boolean {\n    return this._checked;\n  }\n\n  /**\n   * Define the radio button value. Default : null\n   */\n  @Input()\n  get value(): string {\n    return this._value;\n  }\n\n  /**\n   * Whether the radio button is disabled. Default : false\n   */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled || (this.radioGroup && this.radioGroup.disabled);\n  }\n\n  /**\n   * Whether the radio button is required. Default : false\n   */\n  @Input()\n  get required(): boolean {\n    return this._required || (this.radioGroup && this.radioGroup.required);\n  }\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  set checked(value: boolean) {\n    const newCheckedState = coerceBooleanProperty(value);\n    if (this._checked !== newCheckedState) {\n      this._checked = newCheckedState;\n      if (\n        newCheckedState &&\n        this.radioGroup &&\n        this.radioGroup.value !== this.value\n      ) {\n        this.radioGroup.selected = this;\n      } else if (\n        !newCheckedState &&\n        this.radioGroup &&\n        this.radioGroup.value === this.value\n      ) {\n        this.radioGroup.selected = null;\n      }\n\n      if (newCheckedState) {\n        this.radioDispatcher.notify(this.id, this.name);\n      }\n      this.cdr.markForCheck();\n    }\n  }\n\n  set value(value: string) {\n    if (value !== this._value) {\n      this._value = value;\n      if (this.radioGroup) {\n        if (!this.checked) {\n          this.checked = this.radioGroup.value === value;\n        }\n        if (this.checked) {\n          this.radioGroup.selected = this;\n        }\n      }\n    }\n  }\n\n  set disabled(value: boolean) {\n    this.setDisabled(coerceBooleanProperty(value));\n  }\n\n  set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n  }\n\n  public focus(options?: FocusOptions, origin?: FocusOrigin): void {\n    if (origin) {\n      this.focusMonitor.focusVia(this.inputElement, origin, options);\n    } else {\n      this.inputElement.nativeElement.focus(options);\n    }\n  }\n\n  /**\n   * Method called from the parent as one of the parent input has changed. Prevent change detection error.\n   */\n  public markForCheck() {\n    this.cdr.markForCheck();\n  }\n\n  public ngOnInit() {\n    // Set all unique ids for the html elements\n    this.inputID = `${this.id}-input`;\n    this.ariaLabelledby = `${this.id}-arialabelledby`;\n\n    if (this.radioGroup) {\n      this.checked = this.radioGroup.value === this._value;\n\n      if (this.checked) {\n        this.radioGroup.selected = this;\n      }\n\n      this.name = this.radioGroup.name;\n    }\n  }\n\n  public ngAfterViewInit() {\n    this.focusMonitor\n      .monitor(this.inputElement, true)\n      .subscribe(focusOrigin => {\n        if (!focusOrigin && this.radioGroup) {\n          this.radioGroup.onGroupTouch();\n        }\n      });\n\n    this.setAriaDescribedByToDescription();\n  }\n\n  public ngOnDestroy() {\n    this.focusMonitor.stopMonitoring(this.inputElement);\n    this._removeUniqueSelectionListener;\n  }\n\n  /**\n   * Emit the new value from the selected radio-button and the parent\n   */\n  public onInputInteraction(event: Event) {\n    event.stopPropagation();\n    if (!this.checked && !this.disabled) {\n      const groupValueChanged =\n        this.radioGroup && this.value !== this.radioGroup.value;\n      this.checked = true;\n      this.emitChangeEvent();\n\n      if (this.radioGroup) {\n        this.radioGroup.onModelChange(this.value);\n        if (groupValueChanged) {\n          this.radioGroup.emitChangeEvent();\n        }\n      }\n    }\n  }\n\n  private emitChangeEvent(): void {\n    this.change.emit(this.value);\n  }\n\n  private setDisabled(value: boolean) {\n    if (this._disabled !== value) {\n      this._disabled = value;\n      this.cdr.markForCheck();\n    }\n  }\n\n  /**\n   * Set the id property to bao-radio-button-description as a description to the input\n   */\n  private setAriaDescribedByToDescription() {\n    const childNodes = Array.from(this.nativeElement.childNodes);\n    const labelNode = childNodes.find(x => {\n      return x.nodeName === 'LABEL';\n    });\n    if (labelNode) {\n      const labelChildNodes = Array.from(labelNode.childNodes);\n      const descriptionNode = labelChildNodes.find(x => {\n        return x.nodeName === 'BAO-RADIO-BUTTON-DESCRIPTION';\n      });\n\n      if (descriptionNode) {\n        this.ariaDescribedby = `${this.id}-ariadescribedby`;\n        (descriptionNode as HTMLElement).setAttribute(\n          'id',\n          this.ariaDescribedby\n        );\n      } else {\n        this.ariaDescribedby = null;\n      }\n\n      this.cdr.detectChanges();\n    }\n  }\n\n  /** Unregister function for radioDispatcher */\n  private _removeUniqueSelectionListener: () => void = () => undefined;\n}\n\n@Directive({\n  selector:\n    'bao-radio-button-description, [bao-radio-button-description],  [baoRadioButtonDescription]',\n  host: { class: 'bao-radio-button-description' }\n})\nexport class BaoRadioDescription {}\n","<input\n  #input\n  type=\"radio\"\n  [id]=\"inputID\"\n  [checked]=\"checked\"\n  [disabled]=\"disabled\"\n  [attr.name]=\"name\"\n  [attr.value]=\"value\"\n  [required]=\"required\"\n  [attr.aria-label]=\"ariaLabel\"\n  [attr.aria-labelledby]=\"ariaLabelledby\"\n  [attr.aria-describedby]=\"ariaDescribedby\"\n  (change)=\"onInputInteraction($event)\"\n  role=\"radio\"\n/>\n<label class=\"bao-radio-button-content-container\" [attr.for]=\"inputID\">\n  <div class=\"bao-radio-button-label\" [id]=\"ariaLabelledby\">\n    <ng-content></ng-content>\n  </div>\n  <ng-content\n    select=\"bao-radio-button-description, [bao-radio-button-description], [baoRadioButtonDescription]\"\n  ></ng-content>\n</label>\n"]}
@@ -7,9 +7,9 @@ import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/
7
7
  import * as i0 from "@angular/core";
8
8
  export class BaoListSummaryItem {
9
9
  }
10
- BaoListSummaryItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoListSummaryItem, deps: [], target: i0.ɵɵFactoryTarget.Component });
11
- BaoListSummaryItem.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BaoListSummaryItem, selector: "bao-list-summary-item, [bao-list-summary-item], [baoListSummaryItem]", host: { attributes: { "role": "listitem" }, classAttribute: "bao-list-summary-item" }, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: ["@charset \"UTF-8\";.bao-list-summary-item{font-weight:600;color:#000}.bao-list-summary-item:before{content:\"\\2022\";color:#d3310a;font-weight:700;display:inline-block;width:1em;margin-left:-1em}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
12
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoListSummaryItem, decorators: [{
10
+ BaoListSummaryItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoListSummaryItem, deps: [], target: i0.ɵɵFactoryTarget.Component });
11
+ BaoListSummaryItem.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.1", type: BaoListSummaryItem, selector: "bao-list-summary-item, [bao-list-summary-item], [baoListSummaryItem]", host: { attributes: { "role": "listitem" }, classAttribute: "bao-list-summary-item" }, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: ["@charset \"UTF-8\";.bao-list-summary-item{font-weight:600;color:#000}.bao-list-summary-item:before{content:\"\\2022\";color:#d3310a;font-weight:700;display:inline-block;width:1em;margin-left:-1em}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
12
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoListSummaryItem, decorators: [{
13
13
  type: Component,
14
14
  args: [{ selector: 'bao-list-summary-item, [bao-list-summary-item], [baoListSummaryItem]', template: `<ng-content></ng-content>`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
15
15
  class: 'bao-list-summary-item',
@@ -18,20 +18,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
18
18
  }] });
19
19
  export class BaoListSummary {
20
20
  }
21
- BaoListSummary.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoListSummary, deps: [], target: i0.ɵɵFactoryTarget.Component });
22
- BaoListSummary.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BaoListSummary, selector: "bao-list-summary, [bao-list-summary], [baoListSummary]", host: { attributes: { "role": "list" }, classAttribute: "bao-list-summary" }, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: [".bao-list-summary{padding-left:2rem}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
23
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoListSummary, decorators: [{
21
+ BaoListSummary.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoListSummary, deps: [], target: i0.ɵɵFactoryTarget.Component });
22
+ BaoListSummary.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.1", type: BaoListSummary, selector: "bao-list-summary, [bao-list-summary], [baoListSummary]", host: { attributes: { "role": "list" }, classAttribute: "bao-list-summary" }, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: [".bao-list-summary{padding-left:2rem}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
23
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: BaoListSummary, decorators: [{
24
24
  type: Component,
25
- args: [{
26
- selector: 'bao-list-summary, [bao-list-summary], [baoListSummary]',
27
- template: `<ng-content></ng-content>`,
28
- styles: ['.bao-list-summary { padding-left:2rem }'],
29
- encapsulation: ViewEncapsulation.None,
30
- changeDetection: ChangeDetectionStrategy.OnPush,
31
- host: {
25
+ args: [{ selector: 'bao-list-summary, [bao-list-summary], [baoListSummary]', template: `<ng-content></ng-content>`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
32
26
  class: 'bao-list-summary',
33
27
  role: 'list'
34
- }
35
- }]
28
+ }, styles: [".bao-list-summary{padding-left:2rem}\n"] }]
36
29
  }] });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1zdW1tYXJ5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL2xpYi9zdW1tYXJ5L2xpc3Qtc3VtbWFyeS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULGlCQUFpQixFQUNsQixNQUFNLGVBQWUsQ0FBQzs7QUFjdkIsTUFBTSxPQUFPLGtCQUFrQjs7K0dBQWxCLGtCQUFrQjttR0FBbEIsa0JBQWtCLG1NQVRuQiwyQkFBMkI7MkZBUzFCLGtCQUFrQjtrQkFaOUIsU0FBUzsrQkFFTixzRUFBc0UsWUFDOUQsMkJBQTJCLGlCQUV0QixpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLFFBQ3pDO3dCQUNKLEtBQUssRUFBRSx1QkFBdUI7d0JBQzlCLElBQUksRUFBRSxVQUFVO3FCQUNqQjs7QUFlSCxNQUFNLE9BQU8sY0FBYzs7MkdBQWQsY0FBYzsrRkFBZCxjQUFjLDRLQVRmLDJCQUEyQjsyRkFTMUIsY0FBYztrQkFYMUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsd0RBQXdEO29CQUNsRSxRQUFRLEVBQUUsMkJBQTJCO29CQUNyQyxNQUFNLEVBQUUsQ0FBQyx5Q0FBeUMsQ0FBQztvQkFDbkQsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7b0JBQ3JDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxJQUFJLEVBQUU7d0JBQ0osS0FBSyxFQUFFLGtCQUFrQjt3QkFDekIsSUFBSSxFQUFFLE1BQU07cUJBQ2I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDIyIFZpbGxlIGRlIE1vbnRyZWFsLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogTGljZW5zZWQgdW5kZXIgdGhlIE1JVCBsaWNlbnNlLlxuICogU2VlIExJQ0VOU0UgZmlsZSBpbiB0aGUgcHJvamVjdCByb290IGZvciBmdWxsIGxpY2Vuc2UgaW5mb3JtYXRpb24uXG4gKi9cbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6XG4gICAgJ2Jhby1saXN0LXN1bW1hcnktaXRlbSwgW2Jhby1saXN0LXN1bW1hcnktaXRlbV0sIFtiYW9MaXN0U3VtbWFyeUl0ZW1dJyxcbiAgdGVtcGxhdGU6IGA8bmctY29udGVudD48L25nLWNvbnRlbnQ+YCxcbiAgc3R5bGVVcmxzOiBbJy4vbGlzdC1zdW1tYXJ5LmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdiYW8tbGlzdC1zdW1tYXJ5LWl0ZW0nLFxuICAgIHJvbGU6ICdsaXN0aXRlbSdcbiAgfVxufSlcbmV4cG9ydCBjbGFzcyBCYW9MaXN0U3VtbWFyeUl0ZW0ge31cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYmFvLWxpc3Qtc3VtbWFyeSwgW2Jhby1saXN0LXN1bW1hcnldLCBbYmFvTGlzdFN1bW1hcnldJyxcbiAgdGVtcGxhdGU6IGA8bmctY29udGVudD48L25nLWNvbnRlbnQ+YCxcbiAgc3R5bGVzOiBbJy5iYW8tbGlzdC1zdW1tYXJ5IHsgcGFkZGluZy1sZWZ0OjJyZW0gfSddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnYmFvLWxpc3Qtc3VtbWFyeScsXG4gICAgcm9sZTogJ2xpc3QnXG4gIH1cbn0pXG5leHBvcnQgY2xhc3MgQmFvTGlzdFN1bW1hcnkge31cbiJdfQ==
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1zdW1tYXJ5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL2xpYi9zdW1tYXJ5L2xpc3Qtc3VtbWFyeS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULGlCQUFpQixFQUNsQixNQUFNLGVBQWUsQ0FBQzs7QUFjdkIsTUFBTSxPQUFPLGtCQUFrQjs7K0dBQWxCLGtCQUFrQjttR0FBbEIsa0JBQWtCLG1NQVRuQiwyQkFBMkI7MkZBUzFCLGtCQUFrQjtrQkFaOUIsU0FBUzsrQkFFTixzRUFBc0UsWUFDOUQsMkJBQTJCLGlCQUV0QixpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLFFBQ3pDO3dCQUNKLEtBQUssRUFBRSx1QkFBdUI7d0JBQzlCLElBQUksRUFBRSxVQUFVO3FCQUNqQjs7QUFlSCxNQUFNLE9BQU8sY0FBYzs7MkdBQWQsY0FBYzsrRkFBZCxjQUFjLDRLQVRmLDJCQUEyQjsyRkFTMUIsY0FBYztrQkFYMUIsU0FBUzsrQkFDRSx3REFBd0QsWUFDeEQsMkJBQTJCLGlCQUV0QixpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLFFBQ3pDO3dCQUNKLEtBQUssRUFBRSxrQkFBa0I7d0JBQ3pCLElBQUksRUFBRSxNQUFNO3FCQUNiIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMiBWaWxsZSBkZSBNb250cmVhbC4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZS5cbiAqIFNlZSBMSUNFTlNFIGZpbGUgaW4gdGhlIHByb2plY3Qgcm9vdCBmb3IgZnVsbCBsaWNlbnNlIGluZm9ybWF0aW9uLlxuICovXG5pbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBWaWV3RW5jYXBzdWxhdGlvblxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOlxuICAgICdiYW8tbGlzdC1zdW1tYXJ5LWl0ZW0sIFtiYW8tbGlzdC1zdW1tYXJ5LWl0ZW1dLCBbYmFvTGlzdFN1bW1hcnlJdGVtXScsXG4gIHRlbXBsYXRlOiBgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PmAsXG4gIHN0eWxlVXJsczogWycuL2xpc3Qtc3VtbWFyeS5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnYmFvLWxpc3Qtc3VtbWFyeS1pdGVtJyxcbiAgICByb2xlOiAnbGlzdGl0ZW0nXG4gIH1cbn0pXG5leHBvcnQgY2xhc3MgQmFvTGlzdFN1bW1hcnlJdGVtIHt9XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2Jhby1saXN0LXN1bW1hcnksIFtiYW8tbGlzdC1zdW1tYXJ5XSwgW2Jhb0xpc3RTdW1tYXJ5XScsXG4gIHRlbXBsYXRlOiBgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PmAsXG4gIHN0eWxlczogWycuYmFvLWxpc3Qtc3VtbWFyeSB7IHBhZGRpbmctbGVmdDoycmVtIH0nXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2Jhby1saXN0LXN1bW1hcnknLFxuICAgIHJvbGU6ICdsaXN0J1xuICB9XG59KVxuZXhwb3J0IGNsYXNzIEJhb0xpc3RTdW1tYXJ5IHt9XG4iXX0=