@arsedizioni/ars-utils 18.2.172 → 18.2.174
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/ui.application/ui/components/chips-selector/chips-selector.component.mjs +26 -2
- package/fesm2022/arsedizioni-ars-utils-ui.application.mjs +25 -1
- package/fesm2022/arsedizioni-ars-utils-ui.application.mjs.map +1 -1
- package/package.json +12 -12
- package/ui.application/ui/components/chips-selector/chips-selector.component.d.ts +7 -0
|
@@ -27,7 +27,9 @@ export class ChipsSelectorComponent {
|
|
|
27
27
|
this._value = value;
|
|
28
28
|
this.propagateChange(this._value);
|
|
29
29
|
this.stateChanges.next();
|
|
30
|
-
this.
|
|
30
|
+
if (!this.isEqual(this._value, value)) {
|
|
31
|
+
this.changed.emit(this._value);
|
|
32
|
+
}
|
|
31
33
|
if (this.multiple() || (this.collapsed() && this.collapsedDisplayMode() === "button")) {
|
|
32
34
|
this.selection = [];
|
|
33
35
|
if (this._value) {
|
|
@@ -143,6 +145,28 @@ export class ChipsSelectorComponent {
|
|
|
143
145
|
this.changeDetector.markForCheck();
|
|
144
146
|
}, 250);
|
|
145
147
|
}
|
|
148
|
+
/**
|
|
149
|
+
* Checks if two values are equal
|
|
150
|
+
* @param a : value a
|
|
151
|
+
* @param b : value b
|
|
152
|
+
* @returns true if the two values are equal
|
|
153
|
+
*/
|
|
154
|
+
isEqual(a, b) {
|
|
155
|
+
if (a?.length !== b?.length)
|
|
156
|
+
return false;
|
|
157
|
+
if (a && b) {
|
|
158
|
+
let v1 = "";
|
|
159
|
+
let v2 = "";
|
|
160
|
+
for (let i = 0; i < a.length; i++) {
|
|
161
|
+
v1 += a[i].value?.toString() ?? "";
|
|
162
|
+
}
|
|
163
|
+
for (let i = 0; i < b.length; i++) {
|
|
164
|
+
v2 += b[i].value?.toString() ?? "";
|
|
165
|
+
}
|
|
166
|
+
return v1 !== v2;
|
|
167
|
+
}
|
|
168
|
+
return true;
|
|
169
|
+
}
|
|
146
170
|
/**
|
|
147
171
|
* Update container width
|
|
148
172
|
*/
|
|
@@ -252,4 +276,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImpor
|
|
|
252
276
|
type: HostBinding,
|
|
253
277
|
args: ['attr.aria-describedBy']
|
|
254
278
|
}] } });
|
|
255
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chips-selector.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/components/chips-selector/chips-selector.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/components/chips-selector/chips-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\r\nimport { NgClass, NgStyle } from '@angular/common';\r\nimport { AfterContentInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, computed, EventEmitter, HostBinding, inject, Input, input, OnDestroy, OnInit, Optional, Output, Renderer2, Self, Signal, signal } from '@angular/core';\r\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\r\nimport { MatBadgeModule } from '@angular/material/badge';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatChipsModule } from '@angular/material/chips';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatSelectModule } from '@angular/material/select';\r\nimport { NameValueItem, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\nimport { debounceTime, fromEvent, Subject, takeUntil } from 'rxjs';\r\nimport { ButtonSelectorComponent } from '../button-selector/button-selector.component';\r\n\r\n\r\n@Component({\r\n  selector: 'chips-selector',\r\n  standalone: true,\r\n  imports: [NgStyle, NgClass, FlexLayoutModule, FormsModule, MatFormFieldModule, MatSelectModule,\r\n    MatChipsModule, MatIconModule, MatButtonModule, MatBadgeModule,\r\n    ButtonSelectorComponent\r\n  ],\r\n  templateUrl: './chips-selector.component.html',\r\n  styleUrl: './chips-selector.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ChipsSelectorComponent implements OnInit, OnDestroy, AfterContentInit, ControlValueAccessor {\r\n\r\n  @Output() changed = new EventEmitter<NameValueItem<any>[] | null>();\r\n  protected containerId: string = `chips-selector-container--${SystemUtils.generateUUID()}`;\r\n  protected containerWidth = signal(-6);\r\n  private stateChanges = new Subject<void>();\r\n  private focused = false;\r\n  private unsubscribe: Subject<void> = new Subject<void>();\r\n  private changeDetector = inject(ChangeDetectorRef);\r\n\r\n  options = input<NameValueItem<any>[]>();\r\n  collapsedWidth = input<number>(-1);\r\n  collapsedDisplayMode = input<'dropdown' | 'button'>('dropdown');\r\n  collapseAt = input<number>(-1);\r\n  collapseAtContainer = input<boolean>(false);\r\n  label = input<string>();\r\n  multiple = input<boolean>(false);\r\n  mode = input<'collapsed' | 'dinamyc'>('dinamyc');\r\n  collapsed: Signal<boolean> = computed(() => {\r\n    const cw = this.containerWidth();\r\n    const mw = this.collapseAt();\r\n    return this.mode() === 'collapsed' || (mw === -1 || (cw > 0 && mw > 0 && cw < mw));\r\n  })\r\n\r\n\r\n\r\n  private _value: NameValueItem<any>[] | null = []\r\n  set value(value: NameValueItem<any>[] | null) {\r\n    this._value = value;\r\n    this.propagateChange(this._value);\r\n    this.stateChanges.next();\r\n    this.changed.emit(this._value);\r\n    if (this.multiple() || (this.collapsed() && this.collapsedDisplayMode() === \"button\")) {\r\n      this.selection = [];\r\n      if (this._value) {\r\n        (this.options() ?? []).forEach(n => {\r\n          if (this._value?.findIndex((x: any) => x.value === n.value) !== -1) {\r\n            this.selection.push(n);\r\n          }\r\n        })\r\n      }\r\n    } else {\r\n      (this.options() ?? []).forEach(n => {\r\n        if (this._value?.findIndex((x: any) => x.value === n.value) !== -1) {\r\n          this.selection = n;\r\n          return;\r\n        }\r\n      })\r\n    }\r\n  }\r\n  get value() {\r\n    return this._value;\r\n  }\r\n  get empty(): boolean {\r\n    return !this._value || this._value?.length === 0;\r\n  }\r\n  get errorState() {\r\n    return this.ngControl.errors != null && this.ngControl.touched;\r\n  }\r\n\r\n  private _required: boolean = false;\r\n  @Input()\r\n  get required() {\r\n    return this._required;\r\n  }\r\n  set required(value: boolean) {\r\n    this._required = coerceBooleanProperty(value);\r\n    this.stateChanges.next();\r\n  }\r\n\r\n  private _disabled: boolean = false;\r\n  @Input()\r\n  get disabled() {\r\n    if (this.ngControl && this.ngControl.disabled != null) {\r\n      return this.ngControl.disabled;\r\n    }\r\n    return this._disabled;\r\n  }\r\n  set disabled(value: boolean) {\r\n    this._disabled = coerceBooleanProperty(value);\r\n    if (this.focused) {\r\n      this.focused = false;\r\n      this.stateChanges.next();\r\n    }\r\n  }\r\n  private _placeholder: string = '';\r\n  @Input()\r\n  get placeholder() {\r\n    return this._placeholder;\r\n  }\r\n  set placeholder(value: string) {\r\n    this._placeholder = value;\r\n    this.stateChanges.next();\r\n  }\r\n\r\n\r\n  private propagateChange: (_: any) => void = (_: any) => { };\r\n  private propagateTouched: () => void = () => { };\r\n\r\n  @HostBinding() id = `chips-selector--${SystemUtils.generateUUID()}`;\r\n  @HostBinding('class.floating')\r\n  get shouldLabelFloat() {\r\n    return this.focused || !this.empty;\r\n  }\r\n  @HostBinding('attr.aria-describedBy') describedBy = '';\r\n\r\n  private renderer = inject(Renderer2);\r\n\r\n  protected selection: any;\r\n\r\n  constructor(\r\n    @Optional() @Self() public ngControl: NgControl,\r\n  ) {\r\n    if (this.ngControl != null) {\r\n      this.ngControl.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // React to window size change\r\n    fromEvent(window, 'resize')\r\n      .pipe(takeUntil(this.unsubscribe), debounceTime(250))\r\n      .subscribe(() => {\r\n        if (this.collapseAt() > 0) {\r\n          // Close the options menu if open\r\n          this.updateContainerWidth();\r\n        }\r\n      });\r\n\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.unsubscribe.next();\r\n    this.unsubscribe.complete();\r\n    this.stateChanges.complete();\r\n  }\r\n\r\n  ngAfterContentInit(): void {\r\n    setTimeout(() => {\r\n      this.updateContainerWidth();\r\n      this.changeDetector.markForCheck();\r\n    }, 250);\r\n  }\r\n\r\n  /**\r\n   * Update container width\r\n   */\r\n  private updateContainerWidth() {\r\n    const elem = document.getElementById(this.containerId);\r\n    if (elem && elem.clientWidth > 0) {\r\n      this.containerWidth.set(\r\n        this.collapseAtContainer()\r\n          ? (elem?.clientWidth ?? -1)\r\n          : (window.innerWidth ?? -1));\r\n    } else {\r\n      setTimeout(() => {\r\n        this.updateContainerWidth();\r\n      }, 100)\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Update current value with a little delay\r\n   */\r\n  updateValue() {\r\n    setTimeout(() => {\r\n      if (!this.multiple() || (this.collapsed() && this.collapsedDisplayMode() === \"button\")) {\r\n        this.writeValue([this.selection]);\r\n      } else {\r\n        this.writeValue(this.selection);\r\n      }\r\n    }, 250);\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    if (this.value !== value) {\r\n      this.value = value;\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.propagateTouched = fn;\r\n  }\r\n\r\n  setDescribedByIds(ids: string[]) {\r\n    this.describedBy = ids.join(' ');\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean) {\r\n    if (!SystemUtils.isBrowser()) return;\r\n    let elem = document.getElementById(this.id);\r\n    if (elem) {\r\n      this.renderer.setProperty(elem, 'disabled', isDisabled);\r\n    }\r\n  }\r\n\r\n  onContainerClick() {\r\n    if (!this.focused) {\r\n      if (!SystemUtils.isBrowser()) return;\r\n      let elem = document.getElementById(this.id);\r\n      if (elem) {\r\n        elem.focus();\r\n        this.propagateTouched();\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Clear selection\r\n   * @param e : the click event\r\n   */\r\n  clear(e: Event) {\r\n    this.value = [];\r\n    e.stopPropagation();\r\n  }\r\n\r\n  /**\r\n   * Select single element\r\n   * @param item : the item to select\r\n   */\r\n  select(item: NameValueItem<any> | null) {\r\n    if (item) {\r\n      this.value = [item];\r\n    }\r\n  }\r\n\r\n}\r\n","<div [id]=\"containerId\" class=\"chips-container\">\r\n    @if(containerWidth() > 0) {\r\n    @if(collapsed()) {\r\n    @if(collapsedDisplayMode() === 'dropdown') {\r\n    <mat-form-field [ngStyle]=\"{'min-width': collapsedWidth() > 0 ? collapsedWidth()+'.px' : '100%'}\"\r\n        subscriptSizing=\"dynamic\">\r\n        @if(label()) {\r\n        <mat-label>{{label()}}</mat-label>\r\n        }\r\n        <mat-select [(ngModel)]=\"selection\" [multiple]=\"multiple()\" (selectionChange)=\"updateValue()\">\r\n            <mat-select-trigger>\r\n                @if (value && (value.length || 0) > 0) {\r\n                {{value[0].shortName ?? value[0].name}}\r\n                }\r\n                @if (value && (value.length || 0) > 1) {\r\n                <span class=\"collapsed-additional-selection\">\r\n                    (+{{(value.length || 0) - 1}} {{value.length === 2 ? 'altro' : 'altri'}})\r\n                </span>\r\n                }\r\n            </mat-select-trigger>\r\n            @for (o of options(); track o.value) {\r\n            <mat-option [value]=\"o\" [disabled]=\"o.disabled\">\r\n                {{o.name}}\r\n                @if(o.bag) {\r\n                &nbsp; ({{o.bag}});\r\n                }\r\n            </mat-option>\r\n            }\r\n        </mat-select>\r\n        @if (value && (value.length || 0) > 0) {\r\n        <button matSuffix tabindex=\"-1\" mat-icon-button aria-label=\"Pulisci\" (click)=\"clear($event)\">\r\n            <mat-icon>close</mat-icon>\r\n        </button>\r\n        }\r\n    </mat-form-field>\r\n    } @else  {\r\n    <button-selector [label]=\"label()\" [options]=\"options()\" [width]=\"collapsedWidth()\" [(ngModel)]=\"selection\"\r\n        name=\"value\" (selected)=\"updateValue()\"></button-selector>\r\n\r\n    }\r\n    } @else {\r\n    <mat-chip-listbox [multiple]=\"multiple()\" [(ngModel)]=\"selection\" (change)=\"updateValue()\">\r\n        @for (o of options(); track o.value) {\r\n        <mat-chip-option [matBadge]=\"o.bag\" [value]=\"o\" [disabled]=\"o.disabled\">{{o.shortName ??\r\n            o.name}}</mat-chip-option>\r\n        }\r\n    </mat-chip-listbox>\r\n    }\r\n    }\r\n</div>"]}
|
|
279
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chips-selector.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/components/chips-selector/chips-selector.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/components/chips-selector/chips-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\r\nimport { NgClass, NgStyle } from '@angular/common';\r\nimport { AfterContentInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, computed, EventEmitter, HostBinding, inject, Input, input, OnDestroy, OnInit, Optional, Output, Renderer2, Self, Signal, signal } from '@angular/core';\r\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\r\nimport { MatBadgeModule } from '@angular/material/badge';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatChipsModule } from '@angular/material/chips';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatSelectModule } from '@angular/material/select';\r\nimport { NameValueItem, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\nimport { debounceTime, fromEvent, Subject, takeUntil } from 'rxjs';\r\nimport { ButtonSelectorComponent } from '../button-selector/button-selector.component';\r\n\r\n\r\n@Component({\r\n  selector: 'chips-selector',\r\n  standalone: true,\r\n  imports: [NgStyle, NgClass, FlexLayoutModule, FormsModule, MatFormFieldModule, MatSelectModule,\r\n    MatChipsModule, MatIconModule, MatButtonModule, MatBadgeModule,\r\n    ButtonSelectorComponent\r\n  ],\r\n  templateUrl: './chips-selector.component.html',\r\n  styleUrl: './chips-selector.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ChipsSelectorComponent implements OnInit, OnDestroy, AfterContentInit, ControlValueAccessor {\r\n\r\n  @Output() changed = new EventEmitter<NameValueItem<any>[] | null>();\r\n  protected containerId: string = `chips-selector-container--${SystemUtils.generateUUID()}`;\r\n  protected containerWidth = signal(-6);\r\n  private stateChanges = new Subject<void>();\r\n  private focused = false;\r\n  private unsubscribe: Subject<void> = new Subject<void>();\r\n  private changeDetector = inject(ChangeDetectorRef);\r\n\r\n  options = input<NameValueItem<any>[]>();\r\n  collapsedWidth = input<number>(-1);\r\n  collapsedDisplayMode = input<'dropdown' | 'button'>('dropdown');\r\n  collapseAt = input<number>(-1);\r\n  collapseAtContainer = input<boolean>(false);\r\n  label = input<string>();\r\n  multiple = input<boolean>(false);\r\n  mode = input<'collapsed' | 'dinamyc'>('dinamyc');\r\n  collapsed: Signal<boolean> = computed(() => {\r\n    const cw = this.containerWidth();\r\n    const mw = this.collapseAt();\r\n    return this.mode() === 'collapsed' || (mw === -1 || (cw > 0 && mw > 0 && cw < mw));\r\n  })\r\n\r\n\r\n\r\n  private _value: NameValueItem<any>[] | null = []\r\n  set value(value: NameValueItem<any>[] | null) {\r\n    this._value = value;\r\n    this.propagateChange(this._value);\r\n    this.stateChanges.next();\r\n    if (!this.isEqual(this._value, value)) {\r\n      this.changed.emit(this._value);\r\n    }\r\n    if (this.multiple() || (this.collapsed() && this.collapsedDisplayMode() === \"button\")) {\r\n      this.selection = [];\r\n      if (this._value) {\r\n        (this.options() ?? []).forEach(n => {\r\n          if (this._value?.findIndex((x: any) => x.value === n.value) !== -1) {\r\n            this.selection.push(n);\r\n          }\r\n        })\r\n      }\r\n    } else {\r\n      (this.options() ?? []).forEach(n => {\r\n        if (this._value?.findIndex((x: any) => x.value === n.value) !== -1) {\r\n          this.selection = n;\r\n          return;\r\n        }\r\n      })\r\n    }\r\n  }\r\n  get value() {\r\n    return this._value;\r\n  }\r\n  get empty(): boolean {\r\n    return !this._value || this._value?.length === 0;\r\n  }\r\n  get errorState() {\r\n    return this.ngControl.errors != null && this.ngControl.touched;\r\n  }\r\n\r\n  private _required: boolean = false;\r\n  @Input()\r\n  get required() {\r\n    return this._required;\r\n  }\r\n  set required(value: boolean) {\r\n    this._required = coerceBooleanProperty(value);\r\n    this.stateChanges.next();\r\n  }\r\n\r\n  private _disabled: boolean = false;\r\n  @Input()\r\n  get disabled() {\r\n    if (this.ngControl && this.ngControl.disabled != null) {\r\n      return this.ngControl.disabled;\r\n    }\r\n    return this._disabled;\r\n  }\r\n  set disabled(value: boolean) {\r\n    this._disabled = coerceBooleanProperty(value);\r\n    if (this.focused) {\r\n      this.focused = false;\r\n      this.stateChanges.next();\r\n    }\r\n  }\r\n  private _placeholder: string = '';\r\n  @Input()\r\n  get placeholder() {\r\n    return this._placeholder;\r\n  }\r\n  set placeholder(value: string) {\r\n    this._placeholder = value;\r\n    this.stateChanges.next();\r\n  }\r\n\r\n\r\n  private propagateChange: (_: any) => void = (_: any) => { };\r\n  private propagateTouched: () => void = () => { };\r\n\r\n  @HostBinding() id = `chips-selector--${SystemUtils.generateUUID()}`;\r\n  @HostBinding('class.floating')\r\n  get shouldLabelFloat() {\r\n    return this.focused || !this.empty;\r\n  }\r\n  @HostBinding('attr.aria-describedBy') describedBy = '';\r\n\r\n  private renderer = inject(Renderer2);\r\n\r\n  protected selection: any;\r\n\r\n  constructor(\r\n    @Optional() @Self() public ngControl: NgControl,\r\n  ) {\r\n    if (this.ngControl != null) {\r\n      this.ngControl.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // React to window size change\r\n    fromEvent(window, 'resize')\r\n      .pipe(takeUntil(this.unsubscribe), debounceTime(250))\r\n      .subscribe(() => {\r\n        if (this.collapseAt() > 0) {\r\n          // Close the options menu if open\r\n          this.updateContainerWidth();\r\n        }\r\n      });\r\n\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.unsubscribe.next();\r\n    this.unsubscribe.complete();\r\n    this.stateChanges.complete();\r\n  }\r\n\r\n  ngAfterContentInit(): void {\r\n    setTimeout(() => {\r\n      this.updateContainerWidth();\r\n      this.changeDetector.markForCheck();\r\n    }, 250);\r\n  }\r\n\r\n  /**\r\n   * Checks if two values are equal\r\n   * @param a : value a\r\n   * @param b : value b \r\n   * @returns true if the two values are equal\r\n   */\r\n  private isEqual(a: NameValueItem<any>[], b: NameValueItem<any>[]): boolean {\r\n    if (a?.length !== b?.length) return false;\r\n    if (a && b) {\r\n      let v1 = \"\";\r\n      let v2 = \"\";\r\n      for (let i = 0; i < a.length; i++) {\r\n        v1 += a[i].value?.toString() ?? \"\";        \r\n      }\r\n      for (let i = 0; i < b.length; i++) {\r\n        v2 += b[i].value?.toString() ?? \"\";        \r\n      }\r\n      return v1 !== v2;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  /**\r\n   * Update container width\r\n   */\r\n  private updateContainerWidth() {\r\n    const elem = document.getElementById(this.containerId);\r\n    if (elem && elem.clientWidth > 0) {\r\n      this.containerWidth.set(\r\n        this.collapseAtContainer()\r\n          ? (elem?.clientWidth ?? -1)\r\n          : (window.innerWidth ?? -1));\r\n    } else {\r\n      setTimeout(() => {\r\n        this.updateContainerWidth();\r\n      }, 100)\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Update current value with a little delay\r\n   */\r\n  updateValue() {\r\n    setTimeout(() => {\r\n      if (!this.multiple() || (this.collapsed() && this.collapsedDisplayMode() === \"button\")) {\r\n        this.writeValue([this.selection]);\r\n      } else {\r\n        this.writeValue(this.selection);\r\n      }\r\n    }, 250);\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    if (this.value !== value) {\r\n      this.value = value;\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.propagateTouched = fn;\r\n  }\r\n\r\n  setDescribedByIds(ids: string[]) {\r\n    this.describedBy = ids.join(' ');\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean) {\r\n    if (!SystemUtils.isBrowser()) return;\r\n    let elem = document.getElementById(this.id);\r\n    if (elem) {\r\n      this.renderer.setProperty(elem, 'disabled', isDisabled);\r\n    }\r\n  }\r\n\r\n  onContainerClick() {\r\n    if (!this.focused) {\r\n      if (!SystemUtils.isBrowser()) return;\r\n      let elem = document.getElementById(this.id);\r\n      if (elem) {\r\n        elem.focus();\r\n        this.propagateTouched();\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Clear selection\r\n   * @param e : the click event\r\n   */\r\n  clear(e: Event) {\r\n    this.value = [];\r\n    e.stopPropagation();\r\n  }\r\n\r\n  /**\r\n   * Select single element\r\n   * @param item : the item to select\r\n   */\r\n  select(item: NameValueItem<any> | null) {\r\n    if (item) {\r\n      this.value = [item];\r\n    }\r\n  }\r\n\r\n}\r\n","<div [id]=\"containerId\" class=\"chips-container\">\r\n    @if(containerWidth() > 0) {\r\n    @if(collapsed()) {\r\n    @if(collapsedDisplayMode() === 'dropdown') {\r\n    <mat-form-field [ngStyle]=\"{'min-width': collapsedWidth() > 0 ? collapsedWidth()+'.px' : '100%'}\"\r\n        subscriptSizing=\"dynamic\">\r\n        @if(label()) {\r\n        <mat-label>{{label()}}</mat-label>\r\n        }\r\n        <mat-select [(ngModel)]=\"selection\" [multiple]=\"multiple()\" (selectionChange)=\"updateValue()\">\r\n            <mat-select-trigger>\r\n                @if (value && (value.length || 0) > 0) {\r\n                {{value[0].shortName ?? value[0].name}}\r\n                }\r\n                @if (value && (value.length || 0) > 1) {\r\n                <span class=\"collapsed-additional-selection\">\r\n                    (+{{(value.length || 0) - 1}} {{value.length === 2 ? 'altro' : 'altri'}})\r\n                </span>\r\n                }\r\n            </mat-select-trigger>\r\n            @for (o of options(); track o.value) {\r\n            <mat-option [value]=\"o\" [disabled]=\"o.disabled\">\r\n                {{o.name}}\r\n                @if(o.bag) {\r\n                &nbsp; ({{o.bag}});\r\n                }\r\n            </mat-option>\r\n            }\r\n        </mat-select>\r\n        @if (value && (value.length || 0) > 0) {\r\n        <button matSuffix tabindex=\"-1\" mat-icon-button aria-label=\"Pulisci\" (click)=\"clear($event)\">\r\n            <mat-icon>close</mat-icon>\r\n        </button>\r\n        }\r\n    </mat-form-field>\r\n    } @else  {\r\n    <button-selector [label]=\"label()\" [options]=\"options()\" [width]=\"collapsedWidth()\" [(ngModel)]=\"selection\"\r\n        name=\"value\" (selected)=\"updateValue()\"></button-selector>\r\n\r\n    }\r\n    } @else {\r\n    <mat-chip-listbox [multiple]=\"multiple()\" [(ngModel)]=\"selection\" (change)=\"updateValue()\">\r\n        @for (o of options(); track o.value) {\r\n        <mat-chip-option [matBadge]=\"o.bag\" [value]=\"o\" [disabled]=\"o.disabled\">{{o.shortName ??\r\n            o.name}}</mat-chip-option>\r\n        }\r\n    </mat-chip-listbox>\r\n    }\r\n    }\r\n</div>"]}
|
|
@@ -2103,7 +2103,9 @@ class ChipsSelectorComponent {
|
|
|
2103
2103
|
this._value = value;
|
|
2104
2104
|
this.propagateChange(this._value);
|
|
2105
2105
|
this.stateChanges.next();
|
|
2106
|
-
this.
|
|
2106
|
+
if (!this.isEqual(this._value, value)) {
|
|
2107
|
+
this.changed.emit(this._value);
|
|
2108
|
+
}
|
|
2107
2109
|
if (this.multiple() || (this.collapsed() && this.collapsedDisplayMode() === "button")) {
|
|
2108
2110
|
this.selection = [];
|
|
2109
2111
|
if (this._value) {
|
|
@@ -2219,6 +2221,28 @@ class ChipsSelectorComponent {
|
|
|
2219
2221
|
this.changeDetector.markForCheck();
|
|
2220
2222
|
}, 250);
|
|
2221
2223
|
}
|
|
2224
|
+
/**
|
|
2225
|
+
* Checks if two values are equal
|
|
2226
|
+
* @param a : value a
|
|
2227
|
+
* @param b : value b
|
|
2228
|
+
* @returns true if the two values are equal
|
|
2229
|
+
*/
|
|
2230
|
+
isEqual(a, b) {
|
|
2231
|
+
if (a?.length !== b?.length)
|
|
2232
|
+
return false;
|
|
2233
|
+
if (a && b) {
|
|
2234
|
+
let v1 = "";
|
|
2235
|
+
let v2 = "";
|
|
2236
|
+
for (let i = 0; i < a.length; i++) {
|
|
2237
|
+
v1 += a[i].value?.toString() ?? "";
|
|
2238
|
+
}
|
|
2239
|
+
for (let i = 0; i < b.length; i++) {
|
|
2240
|
+
v2 += b[i].value?.toString() ?? "";
|
|
2241
|
+
}
|
|
2242
|
+
return v1 !== v2;
|
|
2243
|
+
}
|
|
2244
|
+
return true;
|
|
2245
|
+
}
|
|
2222
2246
|
/**
|
|
2223
2247
|
* Update container width
|
|
2224
2248
|
*/
|