checkbox-selection-input 15.0.4 → 15.0.5

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.
@@ -0,0 +1,151 @@
1
+ import * as i0 from '@angular/core';
2
+ import { PipeTransform, OnInit, EventEmitter } from '@angular/core';
3
+ import * as _angular_forms from '@angular/forms';
4
+ import { FormBuilder, ControlValueAccessor, AbstractControl, ValidationErrors } from '@angular/forms';
5
+ import * as i3 from '@angular/common';
6
+ import * as i5 from '@angular/material/slider';
7
+ import * as i6 from '@angular/material/button';
8
+ import * as i7 from '@angular/material/icon';
9
+ import * as i8 from '@angular/material/form-field';
10
+ import * as i9 from '@angular/material/toolbar';
11
+ import * as i10 from '@angular/material/checkbox';
12
+ import * as i11 from '@angular/material/menu';
13
+ import * as i12 from '@angular/material/button-toggle';
14
+ import * as i13 from '@angular/material/divider';
15
+ import * as i14 from '@angular/material/radio';
16
+ import * as i15 from '@angular/material/input';
17
+ import * as i16 from '@angular/material/autocomplete';
18
+ import * as i18 from '@angular/material/select';
19
+ import * as i19 from '@angular/material/core';
20
+ import * as i20 from '@angular/material/slide-toggle';
21
+
22
+ interface SelectionBasicInterface {
23
+ id: number | string;
24
+ value: string;
25
+ }
26
+ declare class SelectionBasic implements SelectionBasicInterface {
27
+ id: number;
28
+ value: string;
29
+ constructor(id?: number, value?: string);
30
+ static adapt(item?: any): SelectionBasic;
31
+ }
32
+
33
+ interface SelectionItemInterface {
34
+ id: number | string;
35
+ value: string;
36
+ disabled?: boolean;
37
+ selected?: boolean;
38
+ }
39
+ declare class SelectionItem implements SelectionItemInterface {
40
+ id: `${string}-${string}-${string}-${string}-${string}`;
41
+ value: string;
42
+ disabled?: boolean | undefined;
43
+ selected?: boolean | undefined;
44
+ constructor(id?: `${string}-${string}-${string}-${string}-${string}`, value?: string, disabled?: boolean | undefined, selected?: boolean | undefined);
45
+ static adapt(item?: any): SelectionItem;
46
+ }
47
+
48
+ declare class RemoveUnderscorePipe implements PipeTransform {
49
+ transform(value: string): string;
50
+ static ɵfac: i0.ɵɵFactoryDeclaration<RemoveUnderscorePipe, never>;
51
+ static ɵpipe: i0.ɵɵPipeDeclaration<RemoveUnderscorePipe, "removeUnderscore", true>;
52
+ }
53
+
54
+ declare class CheckboxSelectionDemoComponent implements OnInit {
55
+ fb: FormBuilder;
56
+ data_1: ({
57
+ id: number;
58
+ value: string;
59
+ selected: boolean;
60
+ disabled?: undefined;
61
+ } | {
62
+ id: number;
63
+ value: string;
64
+ disabled: boolean;
65
+ selected?: undefined;
66
+ })[];
67
+ data_2: string[];
68
+ data: any;
69
+ selectionControl_1: _angular_forms.FormControl<any[] | null>;
70
+ selectionControl_2: _angular_forms.FormControl<any[] | null>;
71
+ selectionControl_3: _angular_forms.FormControl<any[] | null>;
72
+ selectionControl_4: _angular_forms.FormControl<any[] | null>;
73
+ selectionControl_5: _angular_forms.FormControl<any[] | null>;
74
+ selectionControl_6: _angular_forms.FormControl<any[] | null>;
75
+ changeDetection_1: _angular_forms.FormControl<any[] | null>;
76
+ changeDetection_2: _angular_forms.FormControl<any[] | null>;
77
+ changeDetection_3: _angular_forms.FormControl<any[] | null>;
78
+ changeDetection_4: _angular_forms.FormControl<any[] | null>;
79
+ changeDetection_5: _angular_forms.FormControl<any[] | null>;
80
+ changeDetection_6: _angular_forms.FormControl<any[] | null>;
81
+ constructor();
82
+ ngOnInit(): void;
83
+ onDisabled_1(disable: boolean): void;
84
+ onDisabled_2(disable: boolean): void;
85
+ onDisabled_3(disable: boolean): void;
86
+ onDisabled_4(disable: boolean): void;
87
+ onDisabled_5(disable: boolean): void;
88
+ onDisabled_6(disable: boolean): void;
89
+ onPerformPatch(): void;
90
+ onChangeDataType(type: string): void;
91
+ static ɵfac: i0.ɵɵFactoryDeclaration<CheckboxSelectionDemoComponent, never>;
92
+ static ɵcmp: i0.ɵɵComponentDeclaration<CheckboxSelectionDemoComponent, "app-checkbox-selection-demo", never, {}, {}, never, never, false, never>;
93
+ }
94
+
95
+ declare class CheckboxSelectionInputComponent implements OnInit, ControlValueAccessor {
96
+ fb: FormBuilder;
97
+ selectionControl: _angular_forms.FormGroup<{
98
+ [x: string]: _angular_forms.FormControl<unknown>;
99
+ }>;
100
+ label?: string;
101
+ placeholder?: string;
102
+ error?: string;
103
+ disableMax: boolean;
104
+ useDefaultReset: boolean;
105
+ private _minSelection;
106
+ set minSelection(value: number);
107
+ get minSelection(): number;
108
+ _maxSelection: number;
109
+ set maxSelection(value: number);
110
+ get maxSelection(): number;
111
+ isObjects: boolean;
112
+ formInitialized: boolean;
113
+ raw: any[];
114
+ private _data;
115
+ set data(value: any[]);
116
+ get data(): any[];
117
+ selectionChange: EventEmitter<string[]>;
118
+ onChange: any;
119
+ onTouch: any;
120
+ disabled: boolean;
121
+ isArray: (obj: any) => obj is any[];
122
+ isObject: (obj: any) => boolean;
123
+ hasObjects: (obj: any) => boolean;
124
+ objectIsEmpty: (obj: any) => boolean;
125
+ selectedCheckboxes: (obj: any) => string[];
126
+ constructor();
127
+ ngOnInit(): void;
128
+ ngAfterViewInit(): void;
129
+ initSelection(): void;
130
+ writeValue(value: string[]): void;
131
+ validate(control: AbstractControl): ValidationErrors | null;
132
+ registerOnChange(fn: any): void;
133
+ registerOnTouched(fn: any): void;
134
+ setDisabledState(isDisabled: boolean): void;
135
+ onSelectionChange(): void;
136
+ selectedValues(obj: any, state?: boolean): string[];
137
+ removeLast(obj: any, index: number): {
138
+ [k: string]: unknown;
139
+ };
140
+ static ɵfac: i0.ɵɵFactoryDeclaration<CheckboxSelectionInputComponent, never>;
141
+ static ɵcmp: i0.ɵɵComponentDeclaration<CheckboxSelectionInputComponent, "app-checkbox-selection-input", never, { "label": { "alias": "label"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "error": { "alias": "error"; "required": false; }; "disableMax": { "alias": "disableMax"; "required": false; }; "useDefaultReset": { "alias": "useDefaultReset"; "required": false; }; "minSelection": { "alias": "minSelection"; "required": false; }; "maxSelection": { "alias": "maxSelection"; "required": false; }; "data": { "alias": "data"; "required": false; }; }, { "selectionChange": "selectionChange"; }, never, ["*"], false, never>;
142
+ }
143
+
144
+ declare class CheckboxSelectionInputModule {
145
+ static ɵfac: i0.ɵɵFactoryDeclaration<CheckboxSelectionInputModule, never>;
146
+ static ɵmod: i0.ɵɵNgModuleDeclaration<CheckboxSelectionInputModule, [typeof CheckboxSelectionInputComponent, typeof CheckboxSelectionDemoComponent], [typeof i3.CommonModule, typeof _angular_forms.FormsModule, typeof _angular_forms.ReactiveFormsModule, typeof i5.MatSliderModule, typeof i6.MatButtonModule, typeof i7.MatIconModule, typeof i8.MatFormFieldModule, typeof i9.MatToolbarModule, typeof i10.MatCheckboxModule, typeof i11.MatMenuModule, typeof i12.MatButtonToggleModule, typeof i13.MatDividerModule, typeof i14.MatRadioModule, typeof i15.MatInputModule, typeof i16.MatAutocompleteModule, typeof RemoveUnderscorePipe, typeof i18.MatSelectModule, typeof i19.MatOptionModule, typeof i20.MatSlideToggleModule], [typeof CheckboxSelectionInputComponent, typeof CheckboxSelectionDemoComponent]>;
147
+ static ɵinj: i0.ɵɵInjectorDeclaration<CheckboxSelectionInputModule>;
148
+ }
149
+
150
+ export { CheckboxSelectionDemoComponent, CheckboxSelectionInputComponent, CheckboxSelectionInputModule, RemoveUnderscorePipe, SelectionBasic, SelectionItem };
151
+ export type { SelectionBasicInterface, SelectionItemInterface };
Binary file
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public-api';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gtc2VsZWN0aW9uLWlucHV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvY2hlY2tib3gtc2VsZWN0aW9uLWlucHV0L3NyYy9jaGVja2JveC1zZWxlY3Rpb24taW5wdXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -1,137 +0,0 @@
1
- import { Component, inject } from '@angular/core';
2
- import { FormBuilder, Validators } from '@angular/forms';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/common";
5
- import * as i2 from "@angular/forms";
6
- import * as i3 from "@angular/material/button";
7
- import * as i4 from "@angular/material/form-field";
8
- import * as i5 from "@angular/material/button-toggle";
9
- import * as i6 from "@angular/material/divider";
10
- import * as i7 from "@angular/material/slide-toggle";
11
- import * as i8 from "../checkbox-selection-input/checkbox-selection-input.component";
12
- export class CheckboxSelectionDemoComponent {
13
- constructor() {
14
- this.fb = inject(FormBuilder);
15
- this.data_1 = [
16
- { id: 11, value: 'Telus', selected: true },
17
- { id: 12, value: 'AT&T', disabled: true },
18
- { id: 14, value: 'Bell', selected: true },
19
- { id: 63, value: 'Rogers', selected: true }
20
- ];
21
- this.data_2 = ['Telus', 'AT&T', 'Bell', 'Rogers'];
22
- this.data = this.data_2;
23
- // CHECKBOX
24
- this.selectionControl_1 = this.fb.control(null);
25
- this.selectionControl_2 = this.fb.control(null, Validators.required);
26
- this.selectionControl_3 = this.fb.control(null, Validators.required);
27
- this.selectionControl_4 = this.fb.control(null, Validators.required);
28
- this.selectionControl_5 = this.fb.control(null, Validators.required);
29
- this.selectionControl_6 = this.fb.control(null, Validators.required);
30
- //CHANGE
31
- this.changeDetection_1 = this.fb.control(null);
32
- this.changeDetection_2 = this.fb.control(null);
33
- this.changeDetection_3 = this.fb.control(null);
34
- this.changeDetection_4 = this.fb.control(null);
35
- this.changeDetection_5 = this.fb.control(null);
36
- this.changeDetection_6 = this.fb.control(null);
37
- }
38
- ngOnInit() {
39
- // CHECKBOX
40
- this.selectionControl_1.valueChanges.subscribe(data => {
41
- if (this.changeDetection_1.value)
42
- console.log('CHANGE:', data);
43
- });
44
- this.selectionControl_2.valueChanges.subscribe(data => {
45
- if (this.changeDetection_2.value)
46
- console.log('CHANGE:', data);
47
- });
48
- this.selectionControl_3.valueChanges.subscribe(data => {
49
- if (this.changeDetection_3.value)
50
- console.log('CHANGE:', data);
51
- });
52
- this.selectionControl_4.valueChanges.subscribe(data => {
53
- if (this.changeDetection_4.value)
54
- console.log('CHANGE:', data);
55
- });
56
- this.selectionControl_5.valueChanges.subscribe(data => {
57
- if (this.changeDetection_5.value)
58
- console.log('CHANGE:', data);
59
- });
60
- this.selectionControl_6.valueChanges.subscribe(data => {
61
- if (this.changeDetection_6.value)
62
- console.log('CHANGE:', data);
63
- });
64
- }
65
- // DISABLE
66
- onDisabled_1(disable) {
67
- if (disable) {
68
- this.selectionControl_1.disable();
69
- }
70
- else {
71
- this.selectionControl_1.enable();
72
- }
73
- }
74
- onDisabled_2(disable) {
75
- if (disable) {
76
- this.selectionControl_2.disable();
77
- }
78
- else {
79
- this.selectionControl_2.enable();
80
- }
81
- }
82
- onDisabled_3(disable) {
83
- if (disable) {
84
- this.selectionControl_3.disable();
85
- }
86
- else {
87
- this.selectionControl_3.enable();
88
- }
89
- }
90
- onDisabled_4(disable) {
91
- if (disable) {
92
- this.selectionControl_4.disable();
93
- }
94
- else {
95
- this.selectionControl_4.enable();
96
- }
97
- }
98
- onDisabled_5(disable) {
99
- if (disable) {
100
- this.selectionControl_5.disable();
101
- }
102
- else {
103
- this.selectionControl_5.enable();
104
- }
105
- }
106
- onDisabled_6(disable) {
107
- if (disable) {
108
- this.selectionControl_6.disable();
109
- }
110
- else {
111
- this.selectionControl_6.enable();
112
- }
113
- }
114
- onPerformPatch() {
115
- this.selectionControl_1.patchValue(['Bell', 'Rogers']);
116
- this.selectionControl_2.patchValue(['Bell', 'Telus']);
117
- this.selectionControl_3.patchValue(['Telus', 'Bell']);
118
- this.selectionControl_4.patchValue(['Rogers']);
119
- this.selectionControl_5.patchValue(['Rogers']);
120
- this.selectionControl_6.patchValue(['Telus', 'Bell', 'Rogers']);
121
- }
122
- onChangeDataType(type) {
123
- if (type === 'strings') {
124
- this.data = this.data_2;
125
- }
126
- else {
127
- this.data = this.data_1;
128
- }
129
- }
130
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CheckboxSelectionDemoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
131
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CheckboxSelectionDemoComponent, selector: "app-checkbox-selection-demo", ngImport: i0, template: "<div style=\"display: flex;\">\n <h1>Checkbox FormControl</h1>\n <div style=\"flex:1; text-align: right;\">\n <div style=\"display: flex; gap: 2rem; flex-direction: row-reverse;\">\n <mat-button-toggle (click)=\"onPerformPatch()\">Patch</mat-button-toggle>\n <mat-button-toggle-group #varTypes=\"matButtonToggleGroup\" (change)=\"onChangeDataType(varTypes.value)\">\n <mat-button-toggle value=\"strings\" checked=\"true\">Strings</mat-button-toggle>\n <mat-button-toggle value=\"objects\" checked=\"false\">Objects</mat-button-toggle>\n </mat-button-toggle-group>\n </div>\n </div>\n</div>\n\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n </div>\n <app-checkbox-selection-input error=\"No Data Provided\">\n <h3 style=\"color: red; margin-top: 0; margin-bottom: 0;\">No Data</h3>\n </app-checkbox-selection-input>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n<div>\n <h3 style=\"margin-bottom: 0;\">Checkbox Selection - {{ varTypes.value | uppercase }}</h3>\n\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_1.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n [formControl]=\"selectionControl_1\"\n ></app-checkbox-selection-input>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_1\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #disable1 (change)=\"onDisabled_1(disable1.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n No Label and Placeholder<br>\n Not Required<br>\n Valid {{ selectionControl_1.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_2.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n label=\"Selections\"\n placeholder=\"My placeholder\"\n [formControl]=\"selectionControl_2\"\n ></app-checkbox-selection-input>\n <div *ngIf=\"error2.checked\">\n <mat-error *ngIf=\"selectionControl_2.hasError('required')\">This field is Required</mat-error>\n </div>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_2\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #error2>Display Error</mat-slide-toggle>\n <mat-slide-toggle #disable2 (change)=\"onDisabled_2(disable2.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n Label and Placeholder<br>\n Required<br>\n Valid {{ selectionControl_2.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_3.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n label=\"Providers\"\n [formControl]=\"selectionControl_3\"\n [minSelection]=\"2\"\n ></app-checkbox-selection-input>\n <div *ngIf=\"error3.checked\">\n <mat-error *ngIf=\"selectionControl_3.hasError('minRequired')\">Minimum of 1 required</mat-error>\n <mat-error *ngIf=\"selectionControl_3.hasError('required')\">This field is Required</mat-error>\n </div>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_3\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #error3>Display Error</mat-slide-toggle>\n <mat-slide-toggle #disable3 (change)=\"onDisabled_3(disable3.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n Label<br>\n Minimum of 2 Required<br>\n Valid {{ selectionControl_3.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_4.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n label=\"Providers\"\n [formControl]=\"selectionControl_4\"\n [maxSelection]=\"2\"\n [disableMax]=\"false\"\n ></app-checkbox-selection-input>\n <div *ngIf=\"error4.checked\">\n <mat-error *ngIf=\"selectionControl_4.hasError('maxExceeded')\">Maximum reached</mat-error>\n <mat-error *ngIf=\"selectionControl_4.hasError('required')\">This field is Required</mat-error>\n </div>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_4\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #error4>Display Error</mat-slide-toggle>\n <mat-slide-toggle #disable4 (change)=\"onDisabled_4(disable4.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n Label<br>\n Maximum of 2 Required<br>\n Valid {{ selectionControl_4.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_5.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n label=\"Providers\"\n [formControl]=\"selectionControl_5\"\n [maxSelection]=\"2\"\n [disableMax]=\"true\"\n ></app-checkbox-selection-input>\n <div *ngIf=\"error5.checked\">\n <mat-error *ngIf=\"selectionControl_5.hasError('maxExceeded')\">Maximum reached</mat-error>\n <mat-error *ngIf=\"selectionControl_5.hasError('required')\">This field is Required</mat-error>\n </div>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_5\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #error5>Display Error</mat-slide-toggle>\n <mat-slide-toggle #disable5 (change)=\"onDisabled_5(disable5.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n Label<br>\n Maximum of 2 Required<br>\n Disable if Max Reached<br>\n Valid {{ selectionControl_5.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_6.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n label=\"Providers\"\n [formControl]=\"selectionControl_6\"\n [minSelection]=\"1\"\n [maxSelection]=\"2\"\n [disableMax]=\"true\"\n ></app-checkbox-selection-input>\n <div *ngIf=\"error6.checked\">\n <mat-error *ngIf=\"selectionControl_6.hasError('minRequired')\">Minimum of 1 required</mat-error>\n <mat-error *ngIf=\"selectionControl_6.hasError('maxExceeded')\">Maximum reached</mat-error>\n </div>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_6\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #error6>Display Error</mat-slide-toggle>\n <mat-slide-toggle #disable6 (change)=\"onDisabled_6(disable6.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n Label<br>\n Minimum of 1 Required<br>\n Maximum of 2 Required<br>\n Disable if Max Reached<br>\n Valid {{ selectionControl_6.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i5.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }, { kind: "component", type: i5.MatButtonToggle, selector: "mat-button-toggle", inputs: ["disableRipple", "aria-label", "aria-labelledby", "id", "name", "value", "tabIndex", "appearance", "checked", "disabled"], outputs: ["change"], exportAs: ["matButtonToggle"] }, { kind: "component", type: i6.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i7.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["disabled", "disableRipple", "color", "tabIndex"], exportAs: ["matSlideToggle"] }, { kind: "component", type: i8.CheckboxSelectionInputComponent, selector: "app-checkbox-selection-input", inputs: ["label", "placeholder", "error", "disableMax", "useDefaultReset", "minSelection", "maxSelection", "data"], outputs: ["selectionChange"] }, { kind: "pipe", type: i1.UpperCasePipe, name: "uppercase" }] }); }
132
- }
133
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CheckboxSelectionDemoComponent, decorators: [{
134
- type: Component,
135
- args: [{ selector: 'app-checkbox-selection-demo', template: "<div style=\"display: flex;\">\n <h1>Checkbox FormControl</h1>\n <div style=\"flex:1; text-align: right;\">\n <div style=\"display: flex; gap: 2rem; flex-direction: row-reverse;\">\n <mat-button-toggle (click)=\"onPerformPatch()\">Patch</mat-button-toggle>\n <mat-button-toggle-group #varTypes=\"matButtonToggleGroup\" (change)=\"onChangeDataType(varTypes.value)\">\n <mat-button-toggle value=\"strings\" checked=\"true\">Strings</mat-button-toggle>\n <mat-button-toggle value=\"objects\" checked=\"false\">Objects</mat-button-toggle>\n </mat-button-toggle-group>\n </div>\n </div>\n</div>\n\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n </div>\n <app-checkbox-selection-input error=\"No Data Provided\">\n <h3 style=\"color: red; margin-top: 0; margin-bottom: 0;\">No Data</h3>\n </app-checkbox-selection-input>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n<div>\n <h3 style=\"margin-bottom: 0;\">Checkbox Selection - {{ varTypes.value | uppercase }}</h3>\n\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_1.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n [formControl]=\"selectionControl_1\"\n ></app-checkbox-selection-input>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_1\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #disable1 (change)=\"onDisabled_1(disable1.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n No Label and Placeholder<br>\n Not Required<br>\n Valid {{ selectionControl_1.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_2.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n label=\"Selections\"\n placeholder=\"My placeholder\"\n [formControl]=\"selectionControl_2\"\n ></app-checkbox-selection-input>\n <div *ngIf=\"error2.checked\">\n <mat-error *ngIf=\"selectionControl_2.hasError('required')\">This field is Required</mat-error>\n </div>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_2\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #error2>Display Error</mat-slide-toggle>\n <mat-slide-toggle #disable2 (change)=\"onDisabled_2(disable2.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n Label and Placeholder<br>\n Required<br>\n Valid {{ selectionControl_2.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_3.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n label=\"Providers\"\n [formControl]=\"selectionControl_3\"\n [minSelection]=\"2\"\n ></app-checkbox-selection-input>\n <div *ngIf=\"error3.checked\">\n <mat-error *ngIf=\"selectionControl_3.hasError('minRequired')\">Minimum of 1 required</mat-error>\n <mat-error *ngIf=\"selectionControl_3.hasError('required')\">This field is Required</mat-error>\n </div>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_3\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #error3>Display Error</mat-slide-toggle>\n <mat-slide-toggle #disable3 (change)=\"onDisabled_3(disable3.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n Label<br>\n Minimum of 2 Required<br>\n Valid {{ selectionControl_3.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_4.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n label=\"Providers\"\n [formControl]=\"selectionControl_4\"\n [maxSelection]=\"2\"\n [disableMax]=\"false\"\n ></app-checkbox-selection-input>\n <div *ngIf=\"error4.checked\">\n <mat-error *ngIf=\"selectionControl_4.hasError('maxExceeded')\">Maximum reached</mat-error>\n <mat-error *ngIf=\"selectionControl_4.hasError('required')\">This field is Required</mat-error>\n </div>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_4\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #error4>Display Error</mat-slide-toggle>\n <mat-slide-toggle #disable4 (change)=\"onDisabled_4(disable4.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n Label<br>\n Maximum of 2 Required<br>\n Valid {{ selectionControl_4.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_5.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n label=\"Providers\"\n [formControl]=\"selectionControl_5\"\n [maxSelection]=\"2\"\n [disableMax]=\"true\"\n ></app-checkbox-selection-input>\n <div *ngIf=\"error5.checked\">\n <mat-error *ngIf=\"selectionControl_5.hasError('maxExceeded')\">Maximum reached</mat-error>\n <mat-error *ngIf=\"selectionControl_5.hasError('required')\">This field is Required</mat-error>\n </div>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_5\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #error5>Display Error</mat-slide-toggle>\n <mat-slide-toggle #disable5 (change)=\"onDisabled_5(disable5.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n Label<br>\n Maximum of 2 Required<br>\n Disable if Max Reached<br>\n Valid {{ selectionControl_5.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n\n\n<div>\n <div style=\"display: flex;\">\n <span style=\"flex:1\"></span>\n <button mat-button (click)=\"selectionControl_6.reset()\">Reset</button>\n </div>\n <app-checkbox-selection-input\n [data]=\"data\"\n label=\"Providers\"\n [formControl]=\"selectionControl_6\"\n [minSelection]=\"1\"\n [maxSelection]=\"2\"\n [disableMax]=\"true\"\n ></app-checkbox-selection-input>\n <div *ngIf=\"error6.checked\">\n <mat-error *ngIf=\"selectionControl_6.hasError('minRequired')\">Minimum of 1 required</mat-error>\n <mat-error *ngIf=\"selectionControl_6.hasError('maxExceeded')\">Maximum reached</mat-error>\n </div>\n <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n <mat-slide-toggle [formControl]=\"changeDetection_6\">Change Detection</mat-slide-toggle>\n <mat-slide-toggle #error6>Display Error</mat-slide-toggle>\n <mat-slide-toggle #disable6 (change)=\"onDisabled_6(disable6.checked)\">Disable</mat-slide-toggle>\n <span style=\"flex:1\"></span>\n </div>\n <div style=\"margin-top: 2rem;\">\n Label<br>\n Minimum of 1 Required<br>\n Maximum of 2 Required<br>\n Disable if Max Reached<br>\n Valid {{ selectionControl_6.valid }}<br>\n </div>\n <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n <mat-divider></mat-divider>\n </div>\n</div>\n" }]
136
- }], ctorParameters: function () { return []; } });
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox-demo.component.js","sourceRoot":"","sources":["../../../../../projects/checkbox-selection-input/src/lib/checkbox-demo/checkbox-demo.component.ts","../../../../../projects/checkbox-selection-input/src/lib/checkbox-demo/checkbox-demo.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, inject } from '@angular/core';\nimport { FormBuilder, Validators } from '@angular/forms';\n\n@Component({\n  selector: 'app-checkbox-selection-demo',\n  templateUrl: './checkbox-demo.component.html',\n  styleUrls: ['./checkbox-demo.component.css'],\n})\nexport class CheckboxSelectionDemoComponent implements OnInit {\n\n  fb = inject(FormBuilder)\n\n  data_1 = [\n    { id: 11, value: 'Telus', selected: true },\n    { id: 12, value: 'AT&T', disabled: true },\n    { id: 14, value: 'Bell', selected: true},\n    { id: 63, value: 'Rogers', selected: true }\n   ]\n\n   data_2 = ['Telus', 'AT&T', 'Bell', 'Rogers']\n\n   data: any = this.data_2\n\n  //  CHECKBOX\n  selectionControl_1 = this.fb.control<any[]|null>(null)\n  selectionControl_2 = this.fb.control<any[]|null>(null, Validators.required)\n  selectionControl_3 = this.fb.control<any[]|null>(null, Validators.required)\n  selectionControl_4 = this.fb.control<any[]|null>(null, Validators.required)\n  selectionControl_5 = this.fb.control<any[]|null>(null, Validators.required)\n  selectionControl_6 = this.fb.control<any[]|null>(null, Validators.required)\n\n  //CHANGE\n  changeDetection_1 = this.fb.control<any[]|null>(null)\n  changeDetection_2 = this.fb.control<any[]|null>(null)\n  changeDetection_3 = this.fb.control<any[]|null>(null)\n  changeDetection_4 = this.fb.control<any[]|null>(null)\n  changeDetection_5 = this.fb.control<any[]|null>(null)\n  changeDetection_6 = this.fb.control<any[]|null>(null)\n\n\n  constructor() { }\n\n  ngOnInit() {\n\n    // CHECKBOX\n    this.selectionControl_1.valueChanges.subscribe(data => {\n      if(this.changeDetection_1.value) console.log('CHANGE:',data)\n    })\n\n    this.selectionControl_2.valueChanges.subscribe(data => {\n      if(this.changeDetection_2.value) console.log('CHANGE:',data)\n    })\n\n    this.selectionControl_3.valueChanges.subscribe(data => {\n      if(this.changeDetection_3.value) console.log('CHANGE:',data)\n    })\n\n    this.selectionControl_4.valueChanges.subscribe(data => {\n      if(this.changeDetection_4.value) console.log('CHANGE:',data)\n    })\n\n    this.selectionControl_5.valueChanges.subscribe(data => {\n      if(this.changeDetection_5.value) console.log('CHANGE:',data)\n    })\n\n    this.selectionControl_6.valueChanges.subscribe(data => {\n      if(this.changeDetection_6.value) console.log('CHANGE:',data)\n    })\n  }\n\n  // DISABLE\n  onDisabled_1(disable: boolean) {\n\n    if(disable) {\n      this.selectionControl_1.disable()\n    } else {\n      this.selectionControl_1.enable()\n    }\n\n  }\n\n  onDisabled_2(disable: boolean) {\n\n    if(disable) {\n      this.selectionControl_2.disable()\n    } else {\n      this.selectionControl_2.enable()\n    }\n\n  }\n\n  onDisabled_3(disable: boolean) {\n\n    if(disable) {\n      this.selectionControl_3.disable()\n    } else {\n      this.selectionControl_3.enable()\n    }\n\n  }\n\n  onDisabled_4(disable: boolean) {\n\n    if(disable) {\n      this.selectionControl_4.disable()\n    } else {\n      this.selectionControl_4.enable()\n    }\n\n  }\n\n  onDisabled_5(disable: boolean) {\n\n    if(disable) {\n      this.selectionControl_5.disable()\n    } else {\n      this.selectionControl_5.enable()\n    }\n\n  }\n\n  onDisabled_6(disable: boolean) {\n\n    if(disable) {\n      this.selectionControl_6.disable()\n    } else {\n      this.selectionControl_6.enable()\n    }\n\n  }\n\n  onPerformPatch() {\n    this.selectionControl_1.patchValue(['Bell', 'Rogers'])\n    this.selectionControl_2.patchValue(['Bell', 'Telus'])\n    this.selectionControl_3.patchValue(['Telus', 'Bell'])\n    this.selectionControl_4.patchValue(['Rogers'])\n    this.selectionControl_5.patchValue(['Rogers'])\n    this.selectionControl_6.patchValue(['Telus', 'Bell', 'Rogers'])\n  }\n\n  onChangeDataType(type: string) {\n    if(type === 'strings') {\n      this.data = this.data_2\n    } else {\n      this.data = this.data_1\n    }\n  }\n\n}\n","<div style=\"display: flex;\">\n  <h1>Checkbox FormControl</h1>\n  <div style=\"flex:1; text-align: right;\">\n    <div style=\"display: flex; gap: 2rem; flex-direction: row-reverse;\">\n      <mat-button-toggle (click)=\"onPerformPatch()\">Patch</mat-button-toggle>\n      <mat-button-toggle-group #varTypes=\"matButtonToggleGroup\" (change)=\"onChangeDataType(varTypes.value)\">\n        <mat-button-toggle value=\"strings\" checked=\"true\">Strings</mat-button-toggle>\n        <mat-button-toggle value=\"objects\" checked=\"false\">Objects</mat-button-toggle>\n      </mat-button-toggle-group>\n    </div>\n  </div>\n</div>\n\n\n<div>\n  <div style=\"display: flex;\">\n    <span style=\"flex:1\"></span>\n  </div>\n  <app-checkbox-selection-input error=\"No Data Provided\">\n    <h3 style=\"color: red; margin-top: 0; margin-bottom: 0;\">No Data</h3>\n  </app-checkbox-selection-input>\n  <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n    <mat-divider></mat-divider>\n  </div>\n</div>\n\n<div>\n  <h3 style=\"margin-bottom: 0;\">Checkbox Selection - {{ varTypes.value | uppercase }}</h3>\n\n  <div style=\"display: flex;\">\n    <span style=\"flex:1\"></span>\n    <button mat-button (click)=\"selectionControl_1.reset()\">Reset</button>\n  </div>\n  <app-checkbox-selection-input\n    [data]=\"data\"\n    [formControl]=\"selectionControl_1\"\n    ></app-checkbox-selection-input>\n  <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n    <mat-slide-toggle [formControl]=\"changeDetection_1\">Change Detection</mat-slide-toggle>\n    <mat-slide-toggle #disable1 (change)=\"onDisabled_1(disable1.checked)\">Disable</mat-slide-toggle>\n    <span style=\"flex:1\"></span>\n  </div>\n  <div style=\"margin-top: 2rem;\">\n    No Label and Placeholder<br>\n    Not Required<br>\n    Valid {{ selectionControl_1.valid }}<br>\n  </div>\n  <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n    <mat-divider></mat-divider>\n  </div>\n</div>\n\n<div>\n  <div style=\"display: flex;\">\n    <span style=\"flex:1\"></span>\n    <button mat-button (click)=\"selectionControl_2.reset()\">Reset</button>\n  </div>\n  <app-checkbox-selection-input\n    [data]=\"data\"\n    label=\"Selections\"\n    placeholder=\"My placeholder\"\n    [formControl]=\"selectionControl_2\"\n    ></app-checkbox-selection-input>\n  <div *ngIf=\"error2.checked\">\n    <mat-error *ngIf=\"selectionControl_2.hasError('required')\">This field is Required</mat-error>\n  </div>\n  <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n    <mat-slide-toggle [formControl]=\"changeDetection_2\">Change Detection</mat-slide-toggle>\n    <mat-slide-toggle #error2>Display Error</mat-slide-toggle>\n    <mat-slide-toggle #disable2 (change)=\"onDisabled_2(disable2.checked)\">Disable</mat-slide-toggle>\n    <span style=\"flex:1\"></span>\n  </div>\n  <div style=\"margin-top: 2rem;\">\n    Label and Placeholder<br>\n    Required<br>\n    Valid {{ selectionControl_2.valid }}<br>\n  </div>\n  <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n    <mat-divider></mat-divider>\n  </div>\n</div>\n\n<div>\n  <div style=\"display: flex;\">\n    <span style=\"flex:1\"></span>\n    <button mat-button (click)=\"selectionControl_3.reset()\">Reset</button>\n  </div>\n  <app-checkbox-selection-input\n    [data]=\"data\"\n    label=\"Providers\"\n    [formControl]=\"selectionControl_3\"\n    [minSelection]=\"2\"\n  ></app-checkbox-selection-input>\n  <div *ngIf=\"error3.checked\">\n    <mat-error *ngIf=\"selectionControl_3.hasError('minRequired')\">Minimum of 1 required</mat-error>\n    <mat-error *ngIf=\"selectionControl_3.hasError('required')\">This field is Required</mat-error>\n  </div>\n  <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n    <mat-slide-toggle [formControl]=\"changeDetection_3\">Change Detection</mat-slide-toggle>\n    <mat-slide-toggle #error3>Display Error</mat-slide-toggle>\n    <mat-slide-toggle #disable3 (change)=\"onDisabled_3(disable3.checked)\">Disable</mat-slide-toggle>\n    <span style=\"flex:1\"></span>\n  </div>\n  <div style=\"margin-top: 2rem;\">\n    Label<br>\n    Minimum of 2 Required<br>\n    Valid {{ selectionControl_3.valid }}<br>\n  </div>\n  <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n    <mat-divider></mat-divider>\n  </div>\n</div>\n\n\n<div>\n  <div style=\"display: flex;\">\n    <span style=\"flex:1\"></span>\n    <button mat-button (click)=\"selectionControl_4.reset()\">Reset</button>\n  </div>\n  <app-checkbox-selection-input\n    [data]=\"data\"\n    label=\"Providers\"\n    [formControl]=\"selectionControl_4\"\n    [maxSelection]=\"2\"\n    [disableMax]=\"false\"\n  ></app-checkbox-selection-input>\n  <div *ngIf=\"error4.checked\">\n    <mat-error *ngIf=\"selectionControl_4.hasError('maxExceeded')\">Maximum reached</mat-error>\n    <mat-error *ngIf=\"selectionControl_4.hasError('required')\">This field is Required</mat-error>\n  </div>\n  <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n    <mat-slide-toggle [formControl]=\"changeDetection_4\">Change Detection</mat-slide-toggle>\n    <mat-slide-toggle #error4>Display Error</mat-slide-toggle>\n    <mat-slide-toggle #disable4 (change)=\"onDisabled_4(disable4.checked)\">Disable</mat-slide-toggle>\n    <span style=\"flex:1\"></span>\n  </div>\n  <div style=\"margin-top: 2rem;\">\n    Label<br>\n    Maximum of 2 Required<br>\n    Valid {{ selectionControl_4.valid }}<br>\n  </div>\n  <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n    <mat-divider></mat-divider>\n  </div>\n</div>\n\n<div>\n  <div style=\"display: flex;\">\n    <span style=\"flex:1\"></span>\n    <button mat-button (click)=\"selectionControl_5.reset()\">Reset</button>\n  </div>\n  <app-checkbox-selection-input\n    [data]=\"data\"\n    label=\"Providers\"\n    [formControl]=\"selectionControl_5\"\n    [maxSelection]=\"2\"\n    [disableMax]=\"true\"\n  ></app-checkbox-selection-input>\n  <div *ngIf=\"error5.checked\">\n    <mat-error *ngIf=\"selectionControl_5.hasError('maxExceeded')\">Maximum reached</mat-error>\n    <mat-error *ngIf=\"selectionControl_5.hasError('required')\">This field is Required</mat-error>\n  </div>\n  <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n    <mat-slide-toggle [formControl]=\"changeDetection_5\">Change Detection</mat-slide-toggle>\n    <mat-slide-toggle #error5>Display Error</mat-slide-toggle>\n    <mat-slide-toggle #disable5 (change)=\"onDisabled_5(disable5.checked)\">Disable</mat-slide-toggle>\n    <span style=\"flex:1\"></span>\n  </div>\n  <div style=\"margin-top: 2rem;\">\n    Label<br>\n    Maximum of 2 Required<br>\n    Disable if Max Reached<br>\n    Valid {{ selectionControl_5.valid }}<br>\n  </div>\n  <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n    <mat-divider></mat-divider>\n  </div>\n</div>\n\n\n<div>\n  <div style=\"display: flex;\">\n    <span style=\"flex:1\"></span>\n    <button mat-button (click)=\"selectionControl_6.reset()\">Reset</button>\n  </div>\n  <app-checkbox-selection-input\n    [data]=\"data\"\n    label=\"Providers\"\n    [formControl]=\"selectionControl_6\"\n    [minSelection]=\"1\"\n    [maxSelection]=\"2\"\n    [disableMax]=\"true\"\n  ></app-checkbox-selection-input>\n  <div *ngIf=\"error6.checked\">\n    <mat-error *ngIf=\"selectionControl_6.hasError('minRequired')\">Minimum of 1 required</mat-error>\n    <mat-error *ngIf=\"selectionControl_6.hasError('maxExceeded')\">Maximum reached</mat-error>\n  </div>\n  <div style=\"display: flex; gap: 2rem; margin-top: 2rem;\">\n    <mat-slide-toggle [formControl]=\"changeDetection_6\">Change Detection</mat-slide-toggle>\n    <mat-slide-toggle #error6>Display Error</mat-slide-toggle>\n    <mat-slide-toggle #disable6 (change)=\"onDisabled_6(disable6.checked)\">Disable</mat-slide-toggle>\n    <span style=\"flex:1\"></span>\n  </div>\n  <div style=\"margin-top: 2rem;\">\n    Label<br>\n    Minimum of 1 Required<br>\n    Maximum of 2 Required<br>\n    Disable if Max Reached<br>\n    Valid {{ selectionControl_6.valid }}<br>\n  </div>\n  <div style=\"margin-top: .5rem; margin-bottom: 1rem;\">\n    <mat-divider></mat-divider>\n  </div>\n</div>\n"]}