@villedemontreal/angular-ui 2.0.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 (99) hide show
  1. package/README.md +25 -0
  2. package/esm2020/lib/alert/alert.component.mjs +164 -0
  3. package/esm2020/lib/alert/index.mjs +8 -0
  4. package/esm2020/lib/alert/module.mjs +41 -0
  5. package/esm2020/lib/badge/badge.component.mjs +27 -0
  6. package/esm2020/lib/badge/index.mjs +8 -0
  7. package/esm2020/lib/badge/module.mjs +24 -0
  8. package/esm2020/lib/bao.module.mjs +87 -0
  9. package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +36 -0
  10. package/esm2020/lib/breadcrumb/index.mjs +8 -0
  11. package/esm2020/lib/breadcrumb/module.mjs +25 -0
  12. package/esm2020/lib/button/button.component.mjs +100 -0
  13. package/esm2020/lib/button/index.mjs +8 -0
  14. package/esm2020/lib/button/module.mjs +25 -0
  15. package/esm2020/lib/card/card.component.mjs +94 -0
  16. package/esm2020/lib/card/index.mjs +8 -0
  17. package/esm2020/lib/card/module.mjs +38 -0
  18. package/esm2020/lib/checkbox/checkbox-group.component.mjs +59 -0
  19. package/esm2020/lib/checkbox/checkbox.component.mjs +305 -0
  20. package/esm2020/lib/checkbox/index.mjs +9 -0
  21. package/esm2020/lib/checkbox/module.mjs +35 -0
  22. package/esm2020/lib/common-components/error-text/errorText.component.mjs +16 -0
  23. package/esm2020/lib/common-components/guiding-text/guidingText.component.mjs +16 -0
  24. package/esm2020/lib/common-components/index.mjs +10 -0
  25. package/esm2020/lib/common-components/legend-text/legendText.component.mjs +22 -0
  26. package/esm2020/lib/common-components/module.mjs +32 -0
  27. package/esm2020/lib/core/colors.mjs +42 -0
  28. package/esm2020/lib/header-info/header-info.component.mjs +104 -0
  29. package/esm2020/lib/header-info/index.mjs +8 -0
  30. package/esm2020/lib/header-info/module.mjs +41 -0
  31. package/esm2020/lib/icon/bao-icon-registry.mjs +44 -0
  32. package/esm2020/lib/icon/icon.component.mjs +160 -0
  33. package/esm2020/lib/icon/icons-dictionary.mjs +123 -0
  34. package/esm2020/lib/icon/index.mjs +8 -0
  35. package/esm2020/lib/icon/module.mjs +24 -0
  36. package/esm2020/lib/list/index.mjs +8 -0
  37. package/esm2020/lib/list/list.component.mjs +73 -0
  38. package/esm2020/lib/list/module.mjs +38 -0
  39. package/esm2020/lib/radio/index.mjs +9 -0
  40. package/esm2020/lib/radio/module.mjs +56 -0
  41. package/esm2020/lib/radio/radio-group.component.mjs +250 -0
  42. package/esm2020/lib/radio/radio.component.mjs +292 -0
  43. package/esm2020/lib/tag/index.mjs +8 -0
  44. package/esm2020/lib/tag/module.mjs +24 -0
  45. package/esm2020/lib/tag/tag.component.mjs +75 -0
  46. package/esm2020/public-api.mjs +19 -0
  47. package/esm2020/villedemontreal-angular-ui.mjs +5 -0
  48. package/fesm2015/villedemontreal-angular-ui.mjs +2461 -0
  49. package/fesm2015/villedemontreal-angular-ui.mjs.map +1 -0
  50. package/fesm2020/villedemontreal-angular-ui.mjs +2455 -0
  51. package/fesm2020/villedemontreal-angular-ui.mjs.map +1 -0
  52. package/global.scss +6 -0
  53. package/lib/alert/alert.component.d.ts +77 -0
  54. package/lib/alert/index.d.ts +2 -0
  55. package/lib/alert/module.d.ts +10 -0
  56. package/lib/badge/badge.component.d.ts +6 -0
  57. package/lib/badge/index.d.ts +2 -0
  58. package/lib/badge/module.d.ts +8 -0
  59. package/lib/bao.module.d.ts +17 -0
  60. package/lib/breadcrumb/breadcrumb.component.d.ts +12 -0
  61. package/lib/breadcrumb/index.d.ts +2 -0
  62. package/lib/breadcrumb/module.d.ts +9 -0
  63. package/lib/button/button.component.d.ts +47 -0
  64. package/lib/button/index.d.ts +2 -0
  65. package/lib/button/module.d.ts +9 -0
  66. package/lib/card/card.component.d.ts +44 -0
  67. package/lib/card/index.d.ts +2 -0
  68. package/lib/card/module.d.ts +8 -0
  69. package/lib/checkbox/checkbox-group.component.d.ts +25 -0
  70. package/lib/checkbox/checkbox.component.d.ts +152 -0
  71. package/lib/checkbox/index.d.ts +3 -0
  72. package/lib/checkbox/module.d.ts +11 -0
  73. package/lib/common-components/error-text/errorText.component.d.ts +5 -0
  74. package/lib/common-components/guiding-text/guidingText.component.d.ts +5 -0
  75. package/lib/common-components/index.d.ts +4 -0
  76. package/lib/common-components/legend-text/legendText.component.d.ts +6 -0
  77. package/lib/common-components/module.d.ts +10 -0
  78. package/lib/core/colors.d.ts +12 -0
  79. package/lib/header-info/header-info.component.d.ts +39 -0
  80. package/lib/header-info/index.d.ts +2 -0
  81. package/lib/header-info/module.d.ts +8 -0
  82. package/lib/icon/bao-icon-registry.d.ts +12 -0
  83. package/lib/icon/icon.component.d.ts +43 -0
  84. package/lib/icon/icons-dictionary.d.ts +3 -0
  85. package/lib/icon/index.d.ts +2 -0
  86. package/lib/icon/module.d.ts +8 -0
  87. package/lib/list/index.d.ts +2 -0
  88. package/lib/list/list.component.d.ts +21 -0
  89. package/lib/list/module.d.ts +8 -0
  90. package/lib/radio/index.d.ts +3 -0
  91. package/lib/radio/module.d.ts +13 -0
  92. package/lib/radio/radio-group.component.d.ts +110 -0
  93. package/lib/radio/radio.component.d.ts +112 -0
  94. package/lib/tag/index.d.ts +2 -0
  95. package/lib/tag/module.d.ts +8 -0
  96. package/lib/tag/tag.component.d.ts +25 -0
  97. package/package.json +33 -0
  98. package/public-api.d.ts +13 -0
  99. package/villedemontreal-angular-ui.d.ts +5 -0
@@ -0,0 +1,56 @@
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 { ObserversModule } from '@angular/cdk/observers';
7
+ import { CommonModule } from '@angular/common';
8
+ import { NgModule } from '@angular/core';
9
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
10
+ import { BaoButtonModule } from '../button';
11
+ import { BaoCommonComponentsModule } from '../common-components/module';
12
+ import { BaoRadioButtonGroupComponent } from './radio-group.component';
13
+ import { BaoRadioButtonComponent, BaoRadioDescription } from './radio.component';
14
+ import * as i0 from "@angular/core";
15
+ const RADIO_DIRECTIVES = [
16
+ BaoRadioButtonComponent,
17
+ BaoRadioDescription,
18
+ BaoRadioButtonGroupComponent
19
+ ];
20
+ export class BaoRadioModule {
21
+ }
22
+ BaoRadioModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoRadioModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
23
+ BaoRadioModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoRadioModule, declarations: [BaoRadioButtonComponent,
24
+ BaoRadioDescription,
25
+ BaoRadioButtonGroupComponent], imports: [CommonModule,
26
+ FormsModule,
27
+ ReactiveFormsModule,
28
+ BaoCommonComponentsModule,
29
+ BaoButtonModule,
30
+ ObserversModule], exports: [BaoRadioButtonComponent,
31
+ BaoRadioDescription,
32
+ BaoRadioButtonGroupComponent] });
33
+ BaoRadioModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoRadioModule, imports: [[
34
+ CommonModule,
35
+ FormsModule,
36
+ ReactiveFormsModule,
37
+ BaoCommonComponentsModule,
38
+ BaoButtonModule,
39
+ ObserversModule
40
+ ]] });
41
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BaoRadioModule, decorators: [{
42
+ type: NgModule,
43
+ args: [{
44
+ imports: [
45
+ CommonModule,
46
+ FormsModule,
47
+ ReactiveFormsModule,
48
+ BaoCommonComponentsModule,
49
+ BaoButtonModule,
50
+ ObserversModule
51
+ ],
52
+ declarations: RADIO_DIRECTIVES,
53
+ exports: RADIO_DIRECTIVES
54
+ }]
55
+ }] });
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11aS9zcmMvbGliL3JhZGlvL21vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBQ0gsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQzVDLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3hFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3ZFLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsbUJBQW1CLEVBQ3BCLE1BQU0sbUJBQW1CLENBQUM7O0FBRTNCLE1BQU0sZ0JBQWdCLEdBQUc7SUFDdkIsdUJBQXVCO0lBQ3ZCLG1CQUFtQjtJQUNuQiw0QkFBNEI7Q0FDN0IsQ0FBQztBQWNGLE1BQU0sT0FBTyxjQUFjOzsyR0FBZCxjQUFjOzRHQUFkLGNBQWMsaUJBakJ6Qix1QkFBdUI7UUFDdkIsbUJBQW1CO1FBQ25CLDRCQUE0QixhQUsxQixZQUFZO1FBQ1osV0FBVztRQUNYLG1CQUFtQjtRQUNuQix5QkFBeUI7UUFDekIsZUFBZTtRQUNmLGVBQWUsYUFaakIsdUJBQXVCO1FBQ3ZCLG1CQUFtQjtRQUNuQiw0QkFBNEI7NEdBZWpCLGNBQWMsWUFYaEI7WUFDUCxZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUNuQix5QkFBeUI7WUFDekIsZUFBZTtZQUNmLGVBQWU7U0FDaEI7MkZBSVUsY0FBYztrQkFaMUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLG1CQUFtQjt3QkFDbkIseUJBQXlCO3dCQUN6QixlQUFlO3dCQUNmLGVBQWU7cUJBQ2hCO29CQUNELFlBQVksRUFBRSxnQkFBZ0I7b0JBQzlCLE9BQU8sRUFBRSxnQkFBZ0I7aUJBQzFCIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMiBWaWxsZSBkZSBNb250cmVhbC4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZS5cbiAqIFNlZSBMSUNFTlNFIGZpbGUgaW4gdGhlIHByb2plY3Qgcm9vdCBmb3IgZnVsbCBsaWNlbnNlIGluZm9ybWF0aW9uLlxuICovXG5pbXBvcnQgeyBPYnNlcnZlcnNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvb2JzZXJ2ZXJzJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBCYW9CdXR0b25Nb2R1bGUgfSBmcm9tICcuLi9idXR0b24nO1xuaW1wb3J0IHsgQmFvQ29tbW9uQ29tcG9uZW50c01vZHVsZSB9IGZyb20gJy4uL2NvbW1vbi1jb21wb25lbnRzL21vZHVsZSc7XG5pbXBvcnQgeyBCYW9SYWRpb0J1dHRvbkdyb3VwQ29tcG9uZW50IH0gZnJvbSAnLi9yYWRpby1ncm91cC5jb21wb25lbnQnO1xuaW1wb3J0IHtcbiAgQmFvUmFkaW9CdXR0b25Db21wb25lbnQsXG4gIEJhb1JhZGlvRGVzY3JpcHRpb25cbn0gZnJvbSAnLi9yYWRpby5jb21wb25lbnQnO1xuXG5jb25zdCBSQURJT19ESVJFQ1RJVkVTID0gW1xuICBCYW9SYWRpb0J1dHRvbkNvbXBvbmVudCxcbiAgQmFvUmFkaW9EZXNjcmlwdGlvbixcbiAgQmFvUmFkaW9CdXR0b25Hcm91cENvbXBvbmVudFxuXTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgIEJhb0NvbW1vbkNvbXBvbmVudHNNb2R1bGUsXG4gICAgQmFvQnV0dG9uTW9kdWxlLFxuICAgIE9ic2VydmVyc01vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFJBRElPX0RJUkVDVElWRVMsXG4gIGV4cG9ydHM6IFJBRElPX0RJUkVDVElWRVNcbn0pXG5leHBvcnQgY2xhc3MgQmFvUmFkaW9Nb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,250 @@
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 { coerceBooleanProperty } from '@angular/cdk/coercion';
7
+ import { Component, ContentChildren, EventEmitter, forwardRef, InjectionToken, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
8
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
9
+ import { BaoRadioButtonComponent } from '.';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "@angular/cdk/observers";
12
+ /**
13
+ * We have to inject the radio button group and all its children to each child.
14
+ */
15
+ export const BAO_RADIO_GROUP = new InjectionToken('BaoRadioButtonGroup');
16
+ /**
17
+ * Unique ID for each radio group counter
18
+ */
19
+ let radioGroupNextUniqueId = 0;
20
+ export class BaoRadioButtonGroupComponent {
21
+ constructor(cdr) {
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
+ /**
35
+ * Emit the value of the selected radio button
36
+ */
37
+ this.change = new EventEmitter();
38
+ /**
39
+ * The aria-describedby for web accessibilty
40
+ */
41
+ this.ariaDescribedby = null;
42
+ this.onModelChange = () => undefined;
43
+ this.onTouch = () => undefined;
44
+ }
45
+ /**
46
+ * Define the name property of all radio buttons. Default : null
47
+ */
48
+ get name() {
49
+ return this._name;
50
+ }
51
+ set name(value) {
52
+ this._name = value;
53
+ this.updateRadioButtonNames();
54
+ }
55
+ /**
56
+ * Define the value of the selected radio button. Default : null
57
+ */
58
+ get value() {
59
+ return this._value;
60
+ }
61
+ set value(newValue) {
62
+ if (this._value !== newValue) {
63
+ this._value = newValue;
64
+ this.updateSelectedRadioFromValue();
65
+ this.checkSelectedRadioButton();
66
+ }
67
+ }
68
+ /**
69
+ * Define which radio button is selected. Default : null
70
+ */
71
+ get selected() {
72
+ return this._selected;
73
+ }
74
+ set selected(selected) {
75
+ this._selected = selected;
76
+ this.value = selected ? selected.value : null;
77
+ this.checkSelectedRadioButton();
78
+ }
79
+ /**
80
+ * Whether the radio button groupd is disabled. Default : false
81
+ */
82
+ get disabled() {
83
+ return this._disabled;
84
+ }
85
+ set disabled(value) {
86
+ this._disabled = coerceBooleanProperty(value);
87
+ this.markRadiosForCheck();
88
+ }
89
+ /**
90
+ * Whether the radio button groupd is required. Default : false
91
+ */
92
+ get required() {
93
+ return this._required;
94
+ }
95
+ set required(value) {
96
+ this._required = coerceBooleanProperty(value);
97
+ this.markRadiosForCheck();
98
+ }
99
+ ngAfterContentInit() {
100
+ this._isInitialized = true;
101
+ }
102
+ ngAfterViewInit() {
103
+ this.setAriaDescribedByToDescription();
104
+ this.cdr.detectChanges();
105
+ }
106
+ /**
107
+ * Implement ControlValueAccessor
108
+ */
109
+ writeValue(value) {
110
+ this.value = value;
111
+ this.cdr.markForCheck();
112
+ }
113
+ /**
114
+ * Implement ControlValueAccessor
115
+ */
116
+ registerOnChange(fn) {
117
+ this.onModelChange = fn;
118
+ }
119
+ /**
120
+ * Implement ControlValueAccessor
121
+ */
122
+ registerOnTouched(fn) {
123
+ this.onTouch = fn;
124
+ }
125
+ /**
126
+ * Implement ControlValueAccessor
127
+ */
128
+ setDisabledState(isDisabled) {
129
+ this.disabled = isDisabled;
130
+ this.cdr.markForCheck();
131
+ }
132
+ /**
133
+ * onTouch() called from the button children
134
+ */
135
+ onGroupTouch() {
136
+ if (this.onTouch) {
137
+ this.onTouch();
138
+ }
139
+ }
140
+ /**
141
+ * Update all radio button name
142
+ */
143
+ updateRadioButtonNames() {
144
+ if (this._radios) {
145
+ this._radios.forEach((radio) => {
146
+ radio.name = this.name;
147
+ radio.markForCheck();
148
+ });
149
+ }
150
+ }
151
+ /**
152
+ * Define which radio button is selected.
153
+ */
154
+ updateSelectedRadioFromValue() {
155
+ const isAlreadySelected = this._selected !== null && this._selected.value === this._value;
156
+ if (this._radios && !isAlreadySelected) {
157
+ this._selected = null;
158
+ this._radios.forEach((radio) => {
159
+ radio.checked = this.value === radio.value;
160
+ if (radio.checked) {
161
+ this._selected = radio;
162
+ }
163
+ });
164
+ }
165
+ }
166
+ /**
167
+ * Update checked property on selected radio button
168
+ */
169
+ checkSelectedRadioButton() {
170
+ if (this._selected && !this._selected.checked) {
171
+ this._selected.checked = true;
172
+ }
173
+ }
174
+ /**
175
+ * Emit the value of the new selected radio button
176
+ */
177
+ emitChangeEvent() {
178
+ if (this._isInitialized) {
179
+ this.change.emit(this.value);
180
+ }
181
+ }
182
+ /**
183
+ * Call markForCheck function on all radio buttons since one of the parent inputs could't have change meanwhile. Prevent change detection error.
184
+ */
185
+ markRadiosForCheck() {
186
+ if (this._radios) {
187
+ this._radios.forEach((radio) => radio.markForCheck());
188
+ }
189
+ }
190
+ onContentChange() {
191
+ this.setAriaDescribedByToDescription();
192
+ }
193
+ /**
194
+ * Set the aria-describedby property to bao-guiding-text if available
195
+ */
196
+ setAriaDescribedByToDescription() {
197
+ const children = Array.from(this.staticContainer.nativeElement.children);
198
+ if (children.length === 0) {
199
+ this.showAriaDescribedBy(false);
200
+ return;
201
+ }
202
+ this.showAriaDescribedBy(true);
203
+ }
204
+ showAriaDescribedBy(value) {
205
+ this.ariaDescribedby = value ? `${this.id}-ariadescribedby` : null;
206
+ }
207
+ }
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: [
210
+ {
211
+ provide: NG_VALUE_ACCESSOR,
212
+ useExisting: forwardRef(() => BaoRadioButtonGroupComponent),
213
+ multi: true
214
+ },
215
+ { 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: [{
218
+ type: Component,
219
+ args: [{ selector: 'bao-radio-button-group, [bao-radio-button-group], [baoRadioButtonGroup]', exportAs: 'baoRadioGroup', encapsulation: ViewEncapsulation.None, providers: [
220
+ {
221
+ provide: NG_VALUE_ACCESSOR,
222
+ useExisting: forwardRef(() => BaoRadioButtonGroupComponent),
223
+ multi: true
224
+ },
225
+ { provide: BAO_RADIO_GROUP, useExisting: BaoRadioButtonGroupComponent }
226
+ ], 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: [{
228
+ type: ContentChildren,
229
+ args: [forwardRef(() => BaoRadioButtonComponent), {
230
+ descendants: true
231
+ }]
232
+ }], id: [{
233
+ type: Input
234
+ }], name: [{
235
+ type: Input
236
+ }], value: [{
237
+ type: Input
238
+ }], selected: [{
239
+ type: Input
240
+ }], disabled: [{
241
+ type: Input
242
+ }], required: [{
243
+ type: Input
244
+ }], change: [{
245
+ type: Output
246
+ }], staticContainer: [{
247
+ type: ViewChild,
248
+ args: ['container', { static: false }]
249
+ }] } });
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"]}