master-control 0.3.74 → 0.3.75
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.
- package/esm2022/lib/multiple-select/multiple-select.component.mjs +33 -3
- package/fesm2022/master-control.mjs +32 -2
- package/fesm2022/master-control.mjs.map +1 -1
- package/lib/multiple-select/multiple-select.component.d.ts +2 -2
- package/master-control-0.3.75.tgz +0 -0
- package/package.json +1 -1
- package/master-control-0.3.74.tgz +0 -0
|
@@ -30,10 +30,40 @@ export class MultipleSelectComponent {
|
|
|
30
30
|
onChange = () => { };
|
|
31
31
|
onTouched = () => { };
|
|
32
32
|
ngOnInit() {
|
|
33
|
-
// Initialize
|
|
33
|
+
// Initialize empty arrays to ensure proper initialization
|
|
34
|
+
if (!this.inputValue) {
|
|
35
|
+
this.inputValue = [];
|
|
36
|
+
}
|
|
37
|
+
if (!this.selectedValues) {
|
|
38
|
+
this.selectedValues = [];
|
|
39
|
+
}
|
|
40
|
+
if (!this.visibleChip) {
|
|
41
|
+
this.visibleChip = [];
|
|
42
|
+
}
|
|
34
43
|
}
|
|
35
44
|
writeValue(value) {
|
|
36
|
-
|
|
45
|
+
console.log('Multiple select writeValue called with:', value); // Debug log
|
|
46
|
+
if (value !== null && value !== undefined && Array.isArray(value)) {
|
|
47
|
+
// Create new arrays to trigger change detection
|
|
48
|
+
this.inputValue = [...value];
|
|
49
|
+
this.selectedValues = [...value];
|
|
50
|
+
// Calculate visible chips and remaining count
|
|
51
|
+
const maxVisible = 2;
|
|
52
|
+
this.visibleChip = this.selectedValues.slice(0, maxVisible);
|
|
53
|
+
this.remainingCount = Math.max(0, this.selectedValues.length - maxVisible);
|
|
54
|
+
console.log('Set values:', {
|
|
55
|
+
inputValue: this.inputValue,
|
|
56
|
+
selectedValues: this.selectedValues,
|
|
57
|
+
visibleChip: this.visibleChip,
|
|
58
|
+
remainingCount: this.remainingCount
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
this.inputValue = [];
|
|
63
|
+
this.selectedValues = [];
|
|
64
|
+
this.visibleChip = [];
|
|
65
|
+
this.remainingCount = 0;
|
|
66
|
+
}
|
|
37
67
|
}
|
|
38
68
|
registerOnChange(fn) {
|
|
39
69
|
this.onChange = fn;
|
|
@@ -124,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
124
154
|
}], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { selectionChange: [{
|
|
125
155
|
type: Output
|
|
126
156
|
}] } });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiple-select.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/multiple-select/multiple-select.component.ts","../../../../../projects/master-control/src/lib/multiple-select/multiple-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, input, Output, EventEmitter } from '@angular/core';\r\nimport { MatChipsModule } from '@angular/material/chips';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatSelectChange, MatSelectModule } from '@angular/material/select';\r\nimport { MasterControlService } from '../master-control.service';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'lib-multiple-select',\r\n  standalone: true,\r\n  imports: [\r\n    MatSelectModule,\r\n    MatFormFieldModule,\r\n    CommonModule,\r\n    MatChipsModule,\r\n    MatIconModule,\r\n    ReactiveFormsModule\r\n  ],\r\n  templateUrl: './multiple-select.component.html',\r\n  styleUrl: './multiple-select.component.css',\r\n  providers: [\r\n        {\r\n          provide: NG_VALUE_ACCESSOR,\r\n          useExisting: MultipleSelectComponent,\r\n          multi: true\r\n        }\r\n      ]\r\n})\r\nexport class MultipleSelectComponent implements ControlValueAccessor {\r\n  constructor(public masterService : MasterControlService) {}\r\n  field: any = input.required<any>();\r\n  selectedValues: any = [];\r\n  visibleChip: any = [];\r\n  remainingCount: any = 0;\r\n  inputValue: any = null;\r\n  reactiveFormControlobject : any = input<any>();\r\n  // Output events for parent component communication\r\n  @Output() selectionChange = new EventEmitter<any>();\r\n  onChange: any = () => {};\r\n    onTouched: any = () => {};\r\n\r\n    ngOnInit(): void {\r\n      // Initialize inputValue with a default or initial value if needed\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n      this.inputValue = value;\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n      this.onChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n      this.onTouched = fn;\r\n    }\r\n\r\n    onValueChange(newValue: any): void {\r\n      this.inputValue = newValue;\r\n      this.onChange(newValue);\r\n      this.onTouched();\r\n    }\r\n\r\n    selectionChanged(event: MatSelectChange) {\r\n      this.inputValue = event.value;\r\n      this.visibleChip = event.value;\r\n      this.onChange(event.value);\r\n      this.onTouched();\r\n      this.onSelectionChange();\r\n      this.selectionChange.emit(event.value);\r\n    }\r\n\r\n  removeItem(item: any) {\r\n     const maxVisible = 2;\r\n    this.visibleChip = this.visibleChip.filter(\r\n      (element: any) => element !== item\r\n    );\r\n     this.selectedValues = this.selectedValues.filter(\r\n      (element: any) => element !== item\r\n    );\r\n    this.inputValue = this.inputValue.filter(\r\n      (element: any) => element !== item\r\n    );\r\n    const found = this.field().options.find((i:any) => i.label === item);\r\n    if (found) {\r\n      found.value = false;\r\n    }\r\n    this.visibleChip = this.selectedValues.slice(0, maxVisible);\r\n    this.remainingCount = this.selectedValues.length - maxVisible;\r\n    this.onChange(this.inputValue);\r\n    this.onTouched();\r\n  }\r\n   onSelectionChange() {\r\n    const maxVisible = 2;\r\n    this.visibleChip = this.selectedValues.slice(0, maxVisible);\r\n    this.remainingCount = this.selectedValues.length - maxVisible;\r\n  }\r\n     onSelectOpened(opened: boolean) {\r\n  const css = this.field()?.controlStyle;\r\n  if (opened) {\r\n    document.body.style.setProperty('--custom-select-option-background-color', css?.dropdownOptionBgColor || '#fff');\r\n    document.body.style.setProperty('--custom-select-option-font-color', css?.dropdownOptionColor || '#444');\r\n    document.body.style.setProperty('--custom-select-option-font-weight', css?.dropdownOptionFontWeight || '400');\r\n    document.body.style.setProperty('--custom-select-option-background-color-focus', css?.focusDropdownOptionBgColor || '#fff');\r\n    document.body.style.setProperty('--custom-select-option-font-color-focus', css?.focusDropdownOptionColor || '#444');\r\n    document.body.style.setProperty('--custom-select-option-font-weight-focus', css?.focusDropdownOptionFontWeight || '400');\r\n    document.body.style.setProperty('--custom-select-option-border-left-focus', css?.focusDropdownOptionBorderLeft || '#ffbb00');\r\n    document.body.style.setProperty('--custom-select-option-border-radius-focus', css?.focusDropdownOptionBorderRadius || '#ffbb00');\r\n  } else {\r\n    document.body.style.removeProperty('--custom-select-option-background-color');\r\n    document.body.style.removeProperty('--custom-select-option-font-color');\r\n    document.body.style.removeProperty('--custom-select-option-font-weight');\r\n    document.body.style.removeProperty('--custom-select-option-background-color-focus');\r\n    document.body.style.removeProperty('--custom-select-option-font-color-focus');\r\n    document.body.style.removeProperty('--custom-select-option-font-weight-focus');\r\n    document.body.style.removeProperty('--custom-select-option-border-left-focus');\r\n    document.body.style.removeProperty('--custom-select-option-border-radius-focus');\r\n  }\r\n}\r\n\r\n}\r\n","<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field().isShowLabel\">{{field()?.label}}<span style=\"color: red;\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\r\n<mat-form-field\r\n  appearance=\"outline\"\r\n  class=\"input-full-width full-width w-100 multi-select\"\r\n  *ngIf=\"field() && field()?.isVisible\"\r\n   [ngStyle]=\"{\r\n'--custom-border-color': field()?.controlStyle?.borderColor ,\r\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\r\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\r\n'--custom-bg-color': field()?.controlStyle?.background ,\r\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\r\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\r\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\r\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\r\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\r\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\r\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\r\n'--custom-font-size': field()?.controlStyle?.fontSize ,\r\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\r\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\r\n'--custom-font-color': field()?.controlStyle?.color ,\r\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\r\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\r\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\r\n}\"\r\n>\r\n @if(reactiveFormControlobject()) {\r\n   <mat-select\r\n    multiple\r\n    [id]=\"field()?.fieldName\"\r\n    [attr.name]=\"field()?.fieldName\"\r\n    [value]=\"inputValue\"\r\n    [required]=\"field()?.validators?.isRequired\"\r\n    [placeholder]=\"field()?.placeHolder\"\r\n    [disabled]=\"field()?.isDisable\"\r\n    (openedChange)=\"onSelectOpened($event)\"\r\n    (selectionChange)=\"selectionChanged($event)\"\r\n    [formControl]=\"reactiveFormControlobject()\"\r\n  >\r\n    <mat-select-trigger>\r\n      <mat-chip-grid>\r\n        @for (option of inputValue; track option) {\r\n        <mat-chip-row [removable]=\"true\" (removed)=\"removeItem(option)\">\r\n          {{ option.label }}\r\n          <mat-icon matChipRemove>close</mat-icon>\r\n        </mat-chip-row>\r\n        }\r\n        <mat-chip *ngIf=\"remainingCount > 0\"> +{{ remainingCount }} </mat-chip>\r\n      </mat-chip-grid>\r\n    </mat-select-trigger>\r\n    @for (option of field()?.options; track option.label) {\r\n    <mat-option [value]=\"option\">\r\n      {{ option.label }}  <img *ngIf=\"option.image\" [src]=\"option.image\" alt=\"\" style=\"width:20px; height:20px; float: inline-end;\" />\r\n    </mat-option>\r\n    }\r\n  </mat-select>\r\n }@else {\r\n   <mat-select\r\n    multiple\r\n    [id]=\"field()?.fieldName\"\r\n    [attr.name]=\"field()?.fieldName\"\r\n    [value]=\"inputValue\"\r\n    [required]=\"field()?.validators?.isRequired\"\r\n    [placeholder]=\"field()?.placeHolder\"\r\n    [disabled]=\"field()?.isDisable\"\r\n    (openedChange)=\"onSelectOpened($event)\"\r\n    (selectionChange)=\"selectionChanged($event)\"\r\n  >\r\n    <mat-select-trigger>\r\n      <mat-chip-grid>\r\n        @for (option of inputValue; track option) {\r\n        <mat-chip-row [removable]=\"true\" (removed)=\"removeItem(option)\">\r\n          {{ option.label }}\r\n          <mat-icon matChipRemove>close</mat-icon>\r\n        </mat-chip-row>\r\n        }\r\n        <mat-chip *ngIf=\"remainingCount > 0\"> +{{ remainingCount }} </mat-chip>\r\n      </mat-chip-grid>\r\n    </mat-select-trigger>\r\n    @for (option of field()?.options; track option.label) {\r\n    <mat-option [value]=\"option\">\r\n      {{ option.label }}  <img *ngIf=\"option.image\" [src]=\"option.image\" alt=\"\" style=\"width:20px; height:20px; float: inline-end;\" />\r\n    </mat-option>\r\n    }\r\n  </mat-select>\r\n }\r\n\r\n  <mat-error *ngIf=\"false\">\r\n    {{ field()?.validators?.requiredMessage }}\r\n  </mat-error>\r\n</mat-form-field>\r\n"]}
|
|
157
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiple-select.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/multiple-select/multiple-select.component.ts","../../../../../projects/master-control/src/lib/multiple-select/multiple-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, input, Output, EventEmitter, OnInit } from '@angular/core';\r\nimport { MatChipsModule } from '@angular/material/chips';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatSelectChange, MatSelectModule } from '@angular/material/select';\r\nimport { MasterControlService } from '../master-control.service';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'lib-multiple-select',\r\n  standalone: true,\r\n  imports: [\r\n    MatSelectModule,\r\n    MatFormFieldModule,\r\n    CommonModule,\r\n    MatChipsModule,\r\n    MatIconModule,\r\n    ReactiveFormsModule\r\n  ],\r\n  templateUrl: './multiple-select.component.html',\r\n  styleUrl: './multiple-select.component.css',\r\n  providers: [\r\n        {\r\n          provide: NG_VALUE_ACCESSOR,\r\n          useExisting: MultipleSelectComponent,\r\n          multi: true\r\n        }\r\n      ]\r\n})\r\nexport class MultipleSelectComponent implements OnInit, ControlValueAccessor {\r\n  constructor(public masterService : MasterControlService) {}\r\n  field: any = input.required<any>();\r\n  selectedValues: any = [];\r\n  visibleChip: any = [];\r\n  remainingCount: any = 0;\r\n  inputValue: any = null;\r\n  reactiveFormControlobject : any = input<any>();\r\n  // Output events for parent component communication\r\n  @Output() selectionChange = new EventEmitter<any>();\r\n  onChange: any = () => {};\r\n    onTouched: any = () => {};\r\n\r\n    ngOnInit(): void {\r\n      // Initialize empty arrays to ensure proper initialization\r\n      if (!this.inputValue) {\r\n        this.inputValue = [];\r\n      }\r\n      if (!this.selectedValues) {\r\n        this.selectedValues = [];\r\n      }\r\n      if (!this.visibleChip) {\r\n        this.visibleChip = [];\r\n      }\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n      console.log('Multiple select writeValue called with:', value); // Debug log\r\n      if (value !== null && value !== undefined && Array.isArray(value)) {\r\n        // Create new arrays to trigger change detection\r\n        this.inputValue = [...value];\r\n        this.selectedValues = [...value];\r\n        \r\n        // Calculate visible chips and remaining count\r\n        const maxVisible = 2;\r\n        this.visibleChip = this.selectedValues.slice(0, maxVisible);\r\n        this.remainingCount = Math.max(0, this.selectedValues.length - maxVisible);\r\n        \r\n        console.log('Set values:', {\r\n          inputValue: this.inputValue,\r\n          selectedValues: this.selectedValues,\r\n          visibleChip: this.visibleChip,\r\n          remainingCount: this.remainingCount\r\n        });\r\n      } else {\r\n        this.inputValue = [];\r\n        this.selectedValues = [];\r\n        this.visibleChip = [];\r\n        this.remainingCount = 0;\r\n      }\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n      this.onChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n      this.onTouched = fn;\r\n    }\r\n\r\n    onValueChange(newValue: any): void {\r\n      this.inputValue = newValue;\r\n      this.onChange(newValue);\r\n      this.onTouched();\r\n    }\r\n\r\n    selectionChanged(event: MatSelectChange) {\r\n      this.inputValue = event.value;\r\n      this.visibleChip = event.value;\r\n      this.onChange(event.value);\r\n      this.onTouched();\r\n      this.onSelectionChange();\r\n      this.selectionChange.emit(event.value);\r\n    }\r\n\r\n  removeItem(item: any) {\r\n     const maxVisible = 2;\r\n    this.visibleChip = this.visibleChip.filter(\r\n      (element: any) => element !== item\r\n    );\r\n     this.selectedValues = this.selectedValues.filter(\r\n      (element: any) => element !== item\r\n    );\r\n    this.inputValue = this.inputValue.filter(\r\n      (element: any) => element !== item\r\n    );\r\n    const found = this.field().options.find((i:any) => i.label === item);\r\n    if (found) {\r\n      found.value = false;\r\n    }\r\n    this.visibleChip = this.selectedValues.slice(0, maxVisible);\r\n    this.remainingCount = this.selectedValues.length - maxVisible;\r\n    this.onChange(this.inputValue);\r\n    this.onTouched();\r\n  }\r\n   onSelectionChange() {\r\n    const maxVisible = 2;\r\n    this.visibleChip = this.selectedValues.slice(0, maxVisible);\r\n    this.remainingCount = this.selectedValues.length - maxVisible;\r\n  }\r\n     onSelectOpened(opened: boolean) {\r\n  const css = this.field()?.controlStyle;\r\n  if (opened) {\r\n    document.body.style.setProperty('--custom-select-option-background-color', css?.dropdownOptionBgColor || '#fff');\r\n    document.body.style.setProperty('--custom-select-option-font-color', css?.dropdownOptionColor || '#444');\r\n    document.body.style.setProperty('--custom-select-option-font-weight', css?.dropdownOptionFontWeight || '400');\r\n    document.body.style.setProperty('--custom-select-option-background-color-focus', css?.focusDropdownOptionBgColor || '#fff');\r\n    document.body.style.setProperty('--custom-select-option-font-color-focus', css?.focusDropdownOptionColor || '#444');\r\n    document.body.style.setProperty('--custom-select-option-font-weight-focus', css?.focusDropdownOptionFontWeight || '400');\r\n    document.body.style.setProperty('--custom-select-option-border-left-focus', css?.focusDropdownOptionBorderLeft || '#ffbb00');\r\n    document.body.style.setProperty('--custom-select-option-border-radius-focus', css?.focusDropdownOptionBorderRadius || '#ffbb00');\r\n  } else {\r\n    document.body.style.removeProperty('--custom-select-option-background-color');\r\n    document.body.style.removeProperty('--custom-select-option-font-color');\r\n    document.body.style.removeProperty('--custom-select-option-font-weight');\r\n    document.body.style.removeProperty('--custom-select-option-background-color-focus');\r\n    document.body.style.removeProperty('--custom-select-option-font-color-focus');\r\n    document.body.style.removeProperty('--custom-select-option-font-weight-focus');\r\n    document.body.style.removeProperty('--custom-select-option-border-left-focus');\r\n    document.body.style.removeProperty('--custom-select-option-border-radius-focus');\r\n  }\r\n}\r\n\r\n}\r\n","<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field().isShowLabel\">{{field()?.label}}<span style=\"color: red;\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\r\n<mat-form-field\r\n  appearance=\"outline\"\r\n  class=\"input-full-width full-width w-100 multi-select\"\r\n  *ngIf=\"field() && field()?.isVisible\"\r\n   [ngStyle]=\"{\r\n'--custom-border-color': field()?.controlStyle?.borderColor ,\r\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\r\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\r\n'--custom-bg-color': field()?.controlStyle?.background ,\r\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\r\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\r\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\r\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\r\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\r\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\r\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\r\n'--custom-font-size': field()?.controlStyle?.fontSize ,\r\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\r\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\r\n'--custom-font-color': field()?.controlStyle?.color ,\r\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\r\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\r\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\r\n}\"\r\n>\r\n @if(reactiveFormControlobject()) {\r\n   <mat-select\r\n    multiple\r\n    [id]=\"field()?.fieldName\"\r\n    [attr.name]=\"field()?.fieldName\"\r\n    [value]=\"inputValue\"\r\n    [required]=\"field()?.validators?.isRequired\"\r\n    [placeholder]=\"field()?.placeHolder\"\r\n    [disabled]=\"field()?.isDisable\"\r\n    (openedChange)=\"onSelectOpened($event)\"\r\n    (selectionChange)=\"selectionChanged($event)\"\r\n    [formControl]=\"reactiveFormControlobject()\"\r\n  >\r\n    <mat-select-trigger>\r\n      <mat-chip-grid>\r\n        @for (option of inputValue; track option) {\r\n        <mat-chip-row [removable]=\"true\" (removed)=\"removeItem(option)\">\r\n          {{ option.label }}\r\n          <mat-icon matChipRemove>close</mat-icon>\r\n        </mat-chip-row>\r\n        }\r\n        <mat-chip *ngIf=\"remainingCount > 0\"> +{{ remainingCount }} </mat-chip>\r\n      </mat-chip-grid>\r\n    </mat-select-trigger>\r\n    @for (option of field()?.options; track option.label) {\r\n    <mat-option [value]=\"option\">\r\n      {{ option.label }}  <img *ngIf=\"option.image\" [src]=\"option.image\" alt=\"\" style=\"width:20px; height:20px; float: inline-end;\" />\r\n    </mat-option>\r\n    }\r\n  </mat-select>\r\n }@else {\r\n   <mat-select\r\n    multiple\r\n    [id]=\"field()?.fieldName\"\r\n    [attr.name]=\"field()?.fieldName\"\r\n    [value]=\"inputValue\"\r\n    [required]=\"field()?.validators?.isRequired\"\r\n    [placeholder]=\"field()?.placeHolder\"\r\n    [disabled]=\"field()?.isDisable\"\r\n    (openedChange)=\"onSelectOpened($event)\"\r\n    (selectionChange)=\"selectionChanged($event)\"\r\n  >\r\n    <mat-select-trigger>\r\n      <mat-chip-grid>\r\n        @for (option of inputValue; track option) {\r\n        <mat-chip-row [removable]=\"true\" (removed)=\"removeItem(option)\">\r\n          {{ option.label }}\r\n          <mat-icon matChipRemove>close</mat-icon>\r\n        </mat-chip-row>\r\n        }\r\n        <mat-chip *ngIf=\"remainingCount > 0\"> +{{ remainingCount }} </mat-chip>\r\n      </mat-chip-grid>\r\n    </mat-select-trigger>\r\n    @for (option of field()?.options; track option.label) {\r\n    <mat-option [value]=\"option\">\r\n      {{ option.label }}  <img *ngIf=\"option.image\" [src]=\"option.image\" alt=\"\" style=\"width:20px; height:20px; float: inline-end;\" />\r\n    </mat-option>\r\n    }\r\n  </mat-select>\r\n }\r\n\r\n  <mat-error *ngIf=\"false\">\r\n    {{ field()?.validators?.requiredMessage }}\r\n  </mat-error>\r\n</mat-form-field>\r\n"]}
|
|
@@ -1624,10 +1624,40 @@ class MultipleSelectComponent {
|
|
|
1624
1624
|
onChange = () => { };
|
|
1625
1625
|
onTouched = () => { };
|
|
1626
1626
|
ngOnInit() {
|
|
1627
|
-
// Initialize
|
|
1627
|
+
// Initialize empty arrays to ensure proper initialization
|
|
1628
|
+
if (!this.inputValue) {
|
|
1629
|
+
this.inputValue = [];
|
|
1630
|
+
}
|
|
1631
|
+
if (!this.selectedValues) {
|
|
1632
|
+
this.selectedValues = [];
|
|
1633
|
+
}
|
|
1634
|
+
if (!this.visibleChip) {
|
|
1635
|
+
this.visibleChip = [];
|
|
1636
|
+
}
|
|
1628
1637
|
}
|
|
1629
1638
|
writeValue(value) {
|
|
1630
|
-
|
|
1639
|
+
console.log('Multiple select writeValue called with:', value); // Debug log
|
|
1640
|
+
if (value !== null && value !== undefined && Array.isArray(value)) {
|
|
1641
|
+
// Create new arrays to trigger change detection
|
|
1642
|
+
this.inputValue = [...value];
|
|
1643
|
+
this.selectedValues = [...value];
|
|
1644
|
+
// Calculate visible chips and remaining count
|
|
1645
|
+
const maxVisible = 2;
|
|
1646
|
+
this.visibleChip = this.selectedValues.slice(0, maxVisible);
|
|
1647
|
+
this.remainingCount = Math.max(0, this.selectedValues.length - maxVisible);
|
|
1648
|
+
console.log('Set values:', {
|
|
1649
|
+
inputValue: this.inputValue,
|
|
1650
|
+
selectedValues: this.selectedValues,
|
|
1651
|
+
visibleChip: this.visibleChip,
|
|
1652
|
+
remainingCount: this.remainingCount
|
|
1653
|
+
});
|
|
1654
|
+
}
|
|
1655
|
+
else {
|
|
1656
|
+
this.inputValue = [];
|
|
1657
|
+
this.selectedValues = [];
|
|
1658
|
+
this.visibleChip = [];
|
|
1659
|
+
this.remainingCount = 0;
|
|
1660
|
+
}
|
|
1631
1661
|
}
|
|
1632
1662
|
registerOnChange(fn) {
|
|
1633
1663
|
this.onChange = fn;
|