@villedemontreal/angular-ui 2.2.1 → 3.0.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.
Files changed (42) hide show
  1. package/esm2020/lib/alert/alert.component.mjs +7 -9
  2. package/esm2020/lib/avatar/avatar.component.mjs +102 -0
  3. package/esm2020/lib/avatar/index.mjs +8 -0
  4. package/esm2020/lib/avatar/module.mjs +24 -0
  5. package/esm2020/lib/bao.module.mjs +12 -4
  6. package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +5 -5
  7. package/esm2020/lib/button/button.component.mjs +3 -3
  8. package/esm2020/lib/checkbox/checkbox-group.component.mjs +5 -6
  9. package/esm2020/lib/checkbox/checkbox.component.mjs +38 -39
  10. package/esm2020/lib/icon/icon.component.mjs +19 -19
  11. package/esm2020/lib/icon/icons-dictionary.mjs +3 -2
  12. package/esm2020/lib/radio/radio-group.component.mjs +40 -41
  13. package/esm2020/lib/radio/radio.component.mjs +38 -39
  14. package/esm2020/lib/summary/summary.component.mjs +4 -5
  15. package/esm2020/lib/tabs/index.mjs +8 -0
  16. package/esm2020/lib/tabs/module.mjs +35 -0
  17. package/esm2020/lib/tabs/tabs.component.mjs +295 -0
  18. package/esm2020/lib/tag/tag.component.mjs +3 -3
  19. package/esm2020/public-api.mjs +3 -1
  20. package/fesm2015/villedemontreal-angular-ui.mjs +627 -171
  21. package/fesm2015/villedemontreal-angular-ui.mjs.map +1 -1
  22. package/fesm2020/villedemontreal-angular-ui.mjs +627 -171
  23. package/fesm2020/villedemontreal-angular-ui.mjs.map +1 -1
  24. package/lib/alert/alert.component.d.ts +2 -3
  25. package/lib/avatar/avatar.component.d.ts +26 -0
  26. package/lib/avatar/index.d.ts +2 -0
  27. package/lib/avatar/module.d.ts +8 -0
  28. package/lib/bao.module.d.ts +3 -1
  29. package/lib/breadcrumb/breadcrumb.component.d.ts +1 -1
  30. package/lib/button/button.component.d.ts +1 -1
  31. package/lib/checkbox/checkbox-group.component.d.ts +2 -2
  32. package/lib/checkbox/checkbox.component.d.ts +27 -27
  33. package/lib/icon/icon.component.d.ts +9 -9
  34. package/lib/radio/radio-group.component.d.ts +19 -19
  35. package/lib/radio/radio.component.d.ts +27 -27
  36. package/lib/summary/summary.component.d.ts +5 -5
  37. package/lib/tabs/index.d.ts +2 -0
  38. package/lib/tabs/module.d.ts +8 -0
  39. package/lib/tabs/tabs.component.d.ts +95 -0
  40. package/lib/tag/tag.component.d.ts +1 -1
  41. package/package.json +1 -1
  42. package/public-api.d.ts +2 -0
@@ -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);
@@ -223,7 +222,7 @@ export class BaoRadioButtonComponent {
223
222
  }
224
223
  }
225
224
  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: [
225
+ 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", 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),
@@ -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,13 +276,6 @@ 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
  }
@@ -289,4 +288,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
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"]}
@@ -19,10 +19,9 @@ export class BaoSummaryComponent {
19
19
  * Initialize the ID for summary
20
20
  */
21
21
  this._uniqueId = `bao-summary-${++summaryUniqueId}`;
22
- /**
23
- * Set value of unique ID for bao-label
24
- */
25
- this.id = this._uniqueId;
22
+ if (!this.id) {
23
+ this.id = this._uniqueId;
24
+ }
26
25
  }
27
26
  get nativeElement() {
28
27
  return this.elementRef.nativeElement;
@@ -91,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
91
90
  host: { class: 'bao-summary-description' }
92
91
  }]
93
92
  }] });
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"summary.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/summary/summary.component.ts","../../../../../projects/angular-ui/src/lib/summary/summary.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 {\n  ChangeDetectionStrategy,\n  Component,\n  Directive,\n  ElementRef,\n  Input,\n  ViewEncapsulation,\n  AfterViewInit,\n  OnInit\n} from '@angular/core';\nimport { EDisplayMode } from '../shared';\n\nlet summaryUniqueId = 0;\n@Component({\n  selector: 'bao-summary, [bao-summary], [baoSummary]',\n  templateUrl: './summary.component.html',\n  styleUrls: ['./summary.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'bao-summary',\n    '[class.bao-displaymode-compact]': 'displayMode === \"compact\"'\n  }\n})\nexport class BaoSummaryComponent implements OnInit, AfterViewInit {\n  /**\n   * Set display mode\n   * RESPONSIVE (viewport width <=> is 576px)\n   * COMPACT (viewport width < 576px)\n   */\n  @Input() public displayMode = EDisplayMode.RESPONSIVE;\n\n  /**\n   * Initialize the ID for summary\n   */\n  private _uniqueId = `bao-summary-${++summaryUniqueId}`;\n\n  /**\n   * Set value of unique ID for bao-label\n   */\n  @Input() public id: string = this._uniqueId;\n\n  /**\n   * The aria-describebdy-error id for web accessibility\n   * only when error section appears\n   */\n  public ariaDescribedbyError?: string;\n\n  /**\n   * The aria-describebdy-text id for web accessibility\n   * only when we have de guidance text\n   */\n  public ariaDescribedbyGuidingText?: string;\n\n  /**\n   * The aria-labelledby id for web accessibility\n   */\n  public ariaLabelledby?: string;\n\n  private attribues: string;\n\n  constructor(private elementRef: ElementRef) {}\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  public ngOnInit() {\n    this.ariaDescribedbyError = `${this.id}-ariadescribedby-error`;\n    this.ariaDescribedbyGuidingText = `${this.id}-ariadescribedby-guiding-text`;\n\n    this.ariaLabelledby = `${this.id}-arialabelledby`;\n  }\n\n  public ngAfterViewInit() {\n    this.setAriaDescribedByToDescription();\n  }\n\n  public setAriaDescribedByToDescription() {\n    const baoLabel = this.elementNode('BAO-LABEL');\n    const baoError = this.elementNode('BAO-ERROR');\n    const baoGuidingText = this.elementNode('BAO-GUIDING-TEXT');\n    const summaryDiv = this.elementNode('DIV');\n\n    if (summaryDiv) {\n      const summaryText = this.elementNode('DIV', summaryDiv);\n\n      if (summaryText && baoLabel) {\n        (baoLabel as HTMLElement).setAttribute('id', this.ariaLabelledby);\n        (summaryText as HTMLElement).setAttribute(\n          'aria-labelledby',\n          this.ariaLabelledby\n        );\n      }\n\n      if (summaryText && baoGuidingText) {\n        (baoGuidingText as HTMLElement).setAttribute(\n          'id',\n          this.ariaDescribedbyGuidingText\n        );\n        (summaryText as HTMLElement).setAttribute(\n          'aria-describedby',\n          this.ariaDescribedbyGuidingText\n        );\n      }\n\n      if (summaryText && baoError) {\n        (baoError as HTMLElement).setAttribute('id', this.ariaDescribedbyError);\n        this.attribues = baoGuidingText\n          ? `${this.ariaDescribedbyError}, ${this.ariaDescribedbyGuidingText}`\n          : this.ariaDescribedbyError;\n        (summaryText as HTMLElement).setAttribute(\n          'aria-describedby',\n          this.attribues\n        );\n      }\n    }\n  }\n\n  private elementNode(name: string, nativeElt?: Node): Node {\n    const childNodes = nativeElt\n      ? Array.from(nativeElt.childNodes)\n      : Array.from(this.nativeElement.childNodes);\n    const element = childNodes.find(x => x.nodeName === name);\n\n    return element;\n  }\n}\n\n@Directive({\n  selector:\n    'bao-summary-description, [bao-summary-description], [baoSummaryDescription]',\n  host: { class: 'bao-summary-description' }\n})\nexport class BaoSummaryDescription {}\n","<ng-content select=\"bao-label\"></ng-content>\n<ng-content select=\"bao-guiding-text, [bao-guiding-text]\"></ng-content>\n\n<div class=\"bao-summary-content\">\n  <div class=\"bao-summary-text\">\n    <ng-content select=\"bao-title-text, [bao-title-text]\"></ng-content>\n    <ng-content select=\"bao-summary-description\"></ng-content>\n    <ng-content\n      select=\"bao-list-summary, [bao-list-summary], [baoListSummary]\"\n    ></ng-content>\n  </div>\n  <ng-content select=\"button[bao-button]\"></ng-content>\n</div>\n<ng-content select=\"bao-error, [bao-error]\"></ng-content>\n"]}
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"summary.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/summary/summary.component.ts","../../../../../projects/angular-ui/src/lib/summary/summary.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 {\n  ChangeDetectionStrategy,\n  Component,\n  Directive,\n  ElementRef,\n  Input,\n  ViewEncapsulation,\n  AfterViewInit,\n  OnInit\n} from '@angular/core';\nimport { EDisplayMode } from '../shared';\n\nlet summaryUniqueId = 0;\n@Component({\n  selector: 'bao-summary, [bao-summary], [baoSummary]',\n  templateUrl: './summary.component.html',\n  styleUrls: ['./summary.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'bao-summary',\n    '[class.bao-displaymode-compact]': 'displayMode === \"compact\"'\n  }\n})\nexport class BaoSummaryComponent implements OnInit, AfterViewInit {\n  /**\n   * Set display mode\n   * RESPONSIVE (viewport width <=> is 576px)\n   * COMPACT (viewport width < 576px)\n   */\n  @Input() public displayMode = EDisplayMode.RESPONSIVE;\n\n  /**\n   * Set value of unique ID for bao-label\n   */\n  @Input() public id: string;\n\n  /**\n   * The aria-describebdy-error id for web accessibility\n   * only when error section appears\n   */\n  public ariaDescribedbyError?: string;\n\n  /**\n   * The aria-describebdy-text id for web accessibility\n   * only when we have de guidance text\n   */\n  public ariaDescribedbyGuidingText?: string;\n\n  /**\n   * The aria-labelledby id for web accessibility\n   */\n  public ariaLabelledby?: string;\n\n  /**\n   * Initialize the ID for summary\n   */\n  private _uniqueId = `bao-summary-${++summaryUniqueId}`;\n\n  private attribues: string;\n\n  constructor(private elementRef: ElementRef<HTMLElement>) {\n    if (!this.id) {\n      this.id = this._uniqueId;\n    }\n  }\n\n  get nativeElement(): HTMLElement {\n    return this.elementRef.nativeElement;\n  }\n\n  public ngOnInit() {\n    this.ariaDescribedbyError = `${this.id}-ariadescribedby-error`;\n    this.ariaDescribedbyGuidingText = `${this.id}-ariadescribedby-guiding-text`;\n\n    this.ariaLabelledby = `${this.id}-arialabelledby`;\n  }\n\n  public ngAfterViewInit() {\n    this.setAriaDescribedByToDescription();\n  }\n\n  public setAriaDescribedByToDescription() {\n    const baoLabel = this.elementNode('BAO-LABEL');\n    const baoError = this.elementNode('BAO-ERROR');\n    const baoGuidingText = this.elementNode('BAO-GUIDING-TEXT');\n    const summaryDiv = this.elementNode('DIV');\n\n    if (summaryDiv) {\n      const summaryText = this.elementNode('DIV', summaryDiv);\n\n      if (summaryText && baoLabel) {\n        (baoLabel as HTMLElement).setAttribute('id', this.ariaLabelledby);\n        (summaryText as HTMLElement).setAttribute(\n          'aria-labelledby',\n          this.ariaLabelledby\n        );\n      }\n\n      if (summaryText && baoGuidingText) {\n        (baoGuidingText as HTMLElement).setAttribute(\n          'id',\n          this.ariaDescribedbyGuidingText\n        );\n        (summaryText as HTMLElement).setAttribute(\n          'aria-describedby',\n          this.ariaDescribedbyGuidingText\n        );\n      }\n\n      if (summaryText && baoError) {\n        (baoError as HTMLElement).setAttribute('id', this.ariaDescribedbyError);\n        this.attribues = baoGuidingText\n          ? `${this.ariaDescribedbyError}, ${this.ariaDescribedbyGuidingText}`\n          : this.ariaDescribedbyError;\n        (summaryText as HTMLElement).setAttribute(\n          'aria-describedby',\n          this.attribues\n        );\n      }\n    }\n  }\n\n  private elementNode(name: string, nativeElt?: Node): Node {\n    const childNodes = nativeElt\n      ? Array.from(nativeElt.childNodes)\n      : Array.from(this.nativeElement.childNodes);\n    const element = childNodes.find(x => x.nodeName === name);\n\n    return element;\n  }\n}\n\n@Directive({\n  selector:\n    'bao-summary-description, [bao-summary-description], [baoSummaryDescription]',\n  host: { class: 'bao-summary-description' }\n})\nexport class BaoSummaryDescription {}\n","<ng-content select=\"bao-label\"></ng-content>\n<ng-content select=\"bao-guiding-text, [bao-guiding-text]\"></ng-content>\n\n<div class=\"bao-summary-content\">\n  <div class=\"bao-summary-text\">\n    <ng-content select=\"bao-title-text, [bao-title-text]\"></ng-content>\n    <ng-content select=\"bao-summary-description\"></ng-content>\n    <ng-content\n      select=\"bao-list-summary, [bao-list-summary], [baoListSummary]\"\n    ></ng-content>\n  </div>\n  <ng-content select=\"button[bao-button]\"></ng-content>\n</div>\n<ng-content select=\"bao-error, [bao-error]\"></ng-content>\n"]}
@@ -0,0 +1,8 @@
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 './tabs.component';
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXVpL3NyYy9saWIvdGFicy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBQ0gsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjIgVmlsbGUgZGUgTW9udHJlYWwuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UuXG4gKiBTZWUgTElDRU5TRSBmaWxlIGluIHRoZSBwcm9qZWN0IHJvb3QgZm9yIGZ1bGwgbGljZW5zZSBpbmZvcm1hdGlvbi5cbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJzLmNvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,35 @@
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 { CommonModule } from '@angular/common';
7
+ import { NgModule } from '@angular/core';
8
+ import { BaoTablistComponent, BaoTabHeader, BaoTabPanel, BaoTabsContainer } from './tabs.component';
9
+ import * as i0 from "@angular/core";
10
+ const TABS_DIRECTIVES = [
11
+ BaoTabsContainer,
12
+ BaoTablistComponent,
13
+ BaoTabHeader,
14
+ BaoTabPanel
15
+ ];
16
+ export class BaoTabsModule {
17
+ }
18
+ BaoTabsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTabsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
19
+ BaoTabsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTabsModule, declarations: [BaoTabsContainer,
20
+ BaoTablistComponent,
21
+ BaoTabHeader,
22
+ BaoTabPanel], imports: [CommonModule], exports: [BaoTabsContainer,
23
+ BaoTablistComponent,
24
+ BaoTabHeader,
25
+ BaoTabPanel] });
26
+ BaoTabsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTabsModule, imports: [[CommonModule]] });
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoTabsModule, decorators: [{
28
+ type: NgModule,
29
+ args: [{
30
+ imports: [CommonModule],
31
+ declarations: [TABS_DIRECTIVES],
32
+ exports: [TABS_DIRECTIVES]
33
+ }]
34
+ }] });
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11aS9zcmMvbGliL3RhYnMvbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQ0wsbUJBQW1CLEVBQ25CLFlBQVksRUFDWixXQUFXLEVBQ1gsZ0JBQWdCLEVBQ2pCLE1BQU0sa0JBQWtCLENBQUM7O0FBRTFCLE1BQU0sZUFBZSxHQUFHO0lBQ3RCLGdCQUFnQjtJQUNoQixtQkFBbUI7SUFDbkIsWUFBWTtJQUNaLFdBQVc7Q0FDWixDQUFDO0FBT0YsTUFBTSxPQUFPLGFBQWE7OzBHQUFiLGFBQWE7MkdBQWIsYUFBYSxpQkFYeEIsZ0JBQWdCO1FBQ2hCLG1CQUFtQjtRQUNuQixZQUFZO1FBQ1osV0FBVyxhQUlELFlBQVksYUFQdEIsZ0JBQWdCO1FBQ2hCLG1CQUFtQjtRQUNuQixZQUFZO1FBQ1osV0FBVzsyR0FRQSxhQUFhLFlBSmYsQ0FBQyxZQUFZLENBQUM7MkZBSVosYUFBYTtrQkFMekIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLFlBQVksRUFBRSxDQUFDLGVBQWUsQ0FBQztvQkFDL0IsT0FBTyxFQUFFLENBQUMsZUFBZSxDQUFDO2lCQUMzQiIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjIgVmlsbGUgZGUgTW9udHJlYWwuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UuXG4gKiBTZWUgTElDRU5TRSBmaWxlIGluIHRoZSBwcm9qZWN0IHJvb3QgZm9yIGZ1bGwgbGljZW5zZSBpbmZvcm1hdGlvbi5cbiAqL1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBCYW9UYWJsaXN0Q29tcG9uZW50LFxuICBCYW9UYWJIZWFkZXIsXG4gIEJhb1RhYlBhbmVsLFxuICBCYW9UYWJzQ29udGFpbmVyXG59IGZyb20gJy4vdGFicy5jb21wb25lbnQnO1xuXG5jb25zdCBUQUJTX0RJUkVDVElWRVMgPSBbXG4gIEJhb1RhYnNDb250YWluZXIsXG4gIEJhb1RhYmxpc3RDb21wb25lbnQsXG4gIEJhb1RhYkhlYWRlcixcbiAgQmFvVGFiUGFuZWxcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFtUQUJTX0RJUkVDVElWRVNdLFxuICBleHBvcnRzOiBbVEFCU19ESVJFQ1RJVkVTXVxufSlcbmV4cG9ydCBjbGFzcyBCYW9UYWJzTW9kdWxlIHt9XG4iXX0=