@arsedizioni/ars-utils 18.3.34 → 18.3.36

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.
@@ -166,16 +166,14 @@ export class ChipsSelectorComponent {
166
166
  */
167
167
  updateValue() {
168
168
  setTimeout(() => {
169
- if (!this.multiple()) {
170
- this.writeValue([this.singleSelection]);
169
+ const value = !this.multiple() && this.collapsed() && this.collapsedDisplayMode() === "button"
170
+ ? this.singleSelection
171
+ : this.selection;
172
+ if (Array.isArray(value)) {
173
+ this.writeValue(value);
171
174
  }
172
175
  else {
173
- if (Array.isArray(this.selection)) {
174
- this.writeValue(this.selection);
175
- }
176
- else {
177
- this.writeValue([this.selection]);
178
- }
176
+ this.writeValue([value]);
179
177
  }
180
178
  }, 250);
181
179
  }
@@ -261,4 +259,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor
261
259
  type: HostBinding,
262
260
  args: ['attr.aria-describedBy']
263
261
  }] } });
264
- //# 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 { MatTooltipModule } from '@angular/material/tooltip';\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, MatTooltipModule,\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 focused: boolean = false;\r\n  private stateChanges: Subject<void> = new Subject<void>();\r\n  private unsubscribe: Subject<void> = new Subject<void>();\r\n  private changeDetector = inject(ChangeDetectorRef);\r\n  private changesEnabled = false;\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.changesEnabled) {\r\n      this.changed.emit(this._value);\r\n    }\r\n    this.selection = [];\r\n    this.singleSelection = null;\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      if (this.selection.length > 0) {\r\n        this.singleSelection = this.selection[0]\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: NameValueItem<any>[] = [];\r\n  protected singleSelection: NameValueItem<any> | null = null;\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.changesEnabled = true;\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()) {\r\n        this.writeValue([this.singleSelection]);\r\n      } else {\r\n        if (Array.isArray(this.selection)) {\r\n          this.writeValue(this.selection);\r\n        } else {\r\n          this.writeValue([this.selection]);\r\n        }\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.writeValue([]);\r\n    e.stopPropagation();\r\n    this.changeDetector.markForCheck();\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.writeValue([item]);\r\n      this.changeDetector.markForCheck();\r\n    }\r\n  }\r\n\r\n}\r\n","<div [id]=\"containerId\" class=\"chips-selector\">\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)]=\"singleSelection\"\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\" [matTooltip]=\"o.bagInfo ?? ''\" [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>"]}
262
+ //# 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 { MatTooltipModule } from '@angular/material/tooltip';\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, MatTooltipModule,\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 focused: boolean = false;\r\n  private stateChanges: Subject<void> = new Subject<void>();\r\n  private unsubscribe: Subject<void> = new Subject<void>();\r\n  private changeDetector = inject(ChangeDetectorRef);\r\n  private changesEnabled = false;\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.changesEnabled) {\r\n      this.changed.emit(this._value);\r\n    }\r\n    this.selection = [];\r\n    this.singleSelection = null;\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      if (this.selection.length > 0) {\r\n        this.singleSelection = this.selection[0]\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: NameValueItem<any>[] = [];\r\n  protected singleSelection: NameValueItem<any> | null = null;\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.changesEnabled = true;\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      const value =\r\n        !this.multiple() && this.collapsed() && this.collapsedDisplayMode() === \"button\"\r\n          ? this.singleSelection\r\n          : this.selection;\r\n      if (Array.isArray(value)) {\r\n        this.writeValue(value);\r\n      } else {\r\n        this.writeValue([value]);\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.writeValue([]);\r\n    e.stopPropagation();\r\n    this.changeDetector.markForCheck();\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.writeValue([item]);\r\n      this.changeDetector.markForCheck();\r\n    }\r\n  }\r\n\r\n}\r\n","<div [id]=\"containerId\" class=\"chips-selector\">\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)]=\"singleSelection\"\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\" [matTooltip]=\"o.bagInfo ?? ''\" [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>"]}
@@ -2305,16 +2305,14 @@ class ChipsSelectorComponent {
2305
2305
  */
2306
2306
  updateValue() {
2307
2307
  setTimeout(() => {
2308
- if (!this.multiple()) {
2309
- this.writeValue([this.singleSelection]);
2308
+ const value = !this.multiple() && this.collapsed() && this.collapsedDisplayMode() === "button"
2309
+ ? this.singleSelection
2310
+ : this.selection;
2311
+ if (Array.isArray(value)) {
2312
+ this.writeValue(value);
2310
2313
  }
2311
2314
  else {
2312
- if (Array.isArray(this.selection)) {
2313
- this.writeValue(this.selection);
2314
- }
2315
- else {
2316
- this.writeValue([this.selection]);
2317
- }
2315
+ this.writeValue([value]);
2318
2316
  }
2319
2317
  }, 250);
2320
2318
  }