@arsedizioni/ars-utils 18.2.164 → 18.2.165

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.
@@ -1,6 +1,6 @@
1
1
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
2
  import { NgClass, NgStyle } from '@angular/common';
3
- import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Optional, Output, Renderer2, Self, inject, input } from '@angular/core';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, Optional, Output, Renderer2, Self, inject, input } from '@angular/core';
4
4
  import { MatButtonModule } from '@angular/material/button';
5
5
  import { MatIconModule } from '@angular/material/icon';
6
6
  import { MatMenuModule } from '@angular/material/menu';
@@ -64,6 +64,7 @@ export class ButtonSelectorComponent {
64
64
  this.ngControl = ngControl;
65
65
  this.changed = new EventEmitter();
66
66
  this.selected = new EventEmitter();
67
+ this.changeDetector = inject(ChangeDetectorRef);
67
68
  this.stateChanges = new Subject();
68
69
  this.focused = false;
69
70
  this._value = [];
@@ -134,6 +135,7 @@ export class ButtonSelectorComponent {
134
135
  select(item) {
135
136
  this.writeValue([item]);
136
137
  this.selected.emit(item);
138
+ this.changeDetector.markForCheck();
137
139
  }
138
140
  /**
139
141
  * Reset value
@@ -164,4 +166,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
164
166
  type: HostBinding,
165
167
  args: ['attr.aria-describedBy']
166
168
  }] } });
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-selector.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/components/button-selector/button-selector.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/components/button-selector/button-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 { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Optional, Output, Renderer2, Self, inject, input } from '@angular/core';\r\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatMenuModule } from '@angular/material/menu';\r\nimport { NameValueItem, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\nimport { Subject } from 'rxjs';\r\n\r\n\r\n@Component({\r\n  selector: 'button-selector',\r\n  standalone: true,\r\n  imports: [NgStyle, NgClass, FlexLayoutModule, MatIconModule, MatButtonModule,\r\n    MatMenuModule],\r\n  templateUrl: './button-selector.component.html',\r\n  styleUrl: './button-selector.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ButtonSelectorComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n\r\n  @Output() changed = new EventEmitter<NameValueItem<any> | null>();\r\n  @Output() selected = new EventEmitter<NameValueItem<any> | null>();\r\n\r\n  private stateChanges = new Subject<void>();\r\n  private focused = false;\r\n\r\n  private _value: NameValueItem<any>[] | any | null = []\r\n  set value(value: NameValueItem<any>[] | any | null) {\r\n    let v1 = 0;\r\n    let v2 = 0;\r\n    if (this._value?.length > 0){\r\n      this._value.forEach((n: NameValueItem<any>) => v1 += n.value);\r\n    }    \r\n    if (value && !Array.isArray(value)) {\r\n      v2 = value.value;\r\n      this._value = [value]\r\n    } else {\r\n      if (value?.length > 0){\r\n        value.forEach((n: NameValueItem<any>) => v2 += n.value);\r\n      }\r\n      this._value = value;\r\n    }\r\n    this.propagateChange(this._value);\r\n    this.stateChanges.next();\r\n    if (this._value && this._value.length > 0) {\r\n      this.current = this._value[0];\r\n      if (v2 !== v1) {\r\n        this.changed.emit(this._value[0]);\r\n      }\r\n    } else {\r\n      this.current = null;\r\n      this.changed.emit(null);\r\n    }\r\n\r\n  }\r\n  get value() {\r\n    return this._value;\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\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('attr.aria-describedBy') describedBy = '';\r\n\r\n  private renderer = inject(Renderer2);\r\n\r\n  protected current: NameValueItem<any> | null = null;\r\n\r\n  width = input<number>(-1);\r\n  border = input<number>(-1);\r\n  borderRadius = input<string>(\"9999px\");\r\n  label = input<string>();\r\n  labelSelected = input<string>();\r\n  options = input<NameValueItem<any>[]>();\r\n  autoSelect = input<boolean>(false);\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    if (this.autoSelect()) {\r\n      const options = this.options();\r\n      if (options && options.length > 0 && options[0].value) {\r\n        this.current = options[0];\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.stateChanges.complete();\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    this.value = value;\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 * Select an element\r\n * @param item : the item to select\r\n */\r\n  select(item: NameValueItem<any>) {\r\n    this.writeValue([item]);\r\n    this.selected.emit(item);\r\n  }\r\n\r\n  /**\r\n   * Reset value\r\n   */\r\n  reset() {\r\n    this.writeValue(null);\r\n  }\r\n}\r\n","<button mat-stroked-button class=\"menu-selector-button\" [ngStyle]=\"{\r\n    'border': border() >= 0 ? border() : 'auto',\r\n    'border-radius': borderRadius(),\r\n    'height': border() <= 0 ? '40px' : 'auto',\r\n    'min-width': width() > 0 ? width()+'px' : (width() === -1 ? '100%' : 'auto')\r\n}\" [attr.aria-label]=\"label()\" [matMenuTriggerFor]=\"optionsMenu\">\r\n    <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n        <div fxFlex=\"100\" fxFlexAlign=\"center\">\r\n            @if(current) {\r\n            <div class=\"truncated\" style=\"text-align: left;\"\r\n                [ngStyle]=\"{'min-width': width() > 0 ? width()+'px' : (width() === -1 ? '100%' : 'auto')}\">\r\n                <div class=\"x-small \">{{labelSelected() ?? label()}}</div>\r\n                <div class=\"small\" style=\"margin-top:2px\">{{current.shortName ?? current.name}}</div>\r\n            </div>\r\n            } @else {\r\n            <div class=\"truncated\" style=\"text-align: left;\"\r\n                [ngStyle]=\"{'min-width': width() > 0 ? width()+'px' : (width() === -1 ? '100%' : 'auto')}\">\r\n                {{label()}}</div>\r\n            }\r\n        </div>\r\n        <div fxLayoutAlign=\"end\" fxFlexAlign=\"center\">\r\n            <mat-icon>arrow_drop_down</mat-icon>\r\n        </div>\r\n    </div>\r\n</button>\r\n<mat-menu #optionsMenu=\"matMenu\" xPosition=\"before\">\r\n    @for (o of options(); track o.value) {\r\n    <button mat-menu-item (click)=\"select(o)\" [disabled]=\"o.disabled\">\r\n        {{o.name}}\r\n        @if(o.bag) {\r\n            ({{o.bag}})\r\n        }\r\n    </button>\r\n    }\r\n</mat-menu>"]}
169
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-selector.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/components/button-selector/button-selector.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/components/button-selector/button-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 { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Optional, Output, Renderer2, Self, inject, input } from '@angular/core';\r\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatMenuModule } from '@angular/material/menu';\r\nimport { NameValueItem, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\nimport { Subject } from 'rxjs';\r\n\r\n\r\n@Component({\r\n  selector: 'button-selector',\r\n  standalone: true,\r\n  imports: [NgStyle, NgClass, FlexLayoutModule, MatIconModule, MatButtonModule,\r\n    MatMenuModule],\r\n  templateUrl: './button-selector.component.html',\r\n  styleUrl: './button-selector.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ButtonSelectorComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n\r\n  @Output() changed = new EventEmitter<NameValueItem<any> | null>();\r\n  @Output() selected = new EventEmitter<NameValueItem<any> | null>();\r\n  private changeDetector = inject(ChangeDetectorRef);\r\n  private stateChanges = new Subject<void>();\r\n  private focused = false;\r\n\r\n  private _value: NameValueItem<any>[] | any | null = []\r\n  set value(value: NameValueItem<any>[] | any | null) {\r\n    let v1 = 0;\r\n    let v2 = 0;\r\n    if (this._value?.length > 0){\r\n      this._value.forEach((n: NameValueItem<any>) => v1 += n.value);\r\n    }    \r\n    if (value && !Array.isArray(value)) {\r\n      v2 = value.value;\r\n      this._value = [value]\r\n    } else {\r\n      if (value?.length > 0){\r\n        value.forEach((n: NameValueItem<any>) => v2 += n.value);\r\n      }\r\n      this._value = value;\r\n    }\r\n    this.propagateChange(this._value);\r\n    this.stateChanges.next();\r\n    if (this._value && this._value.length > 0) {\r\n      this.current = this._value[0];\r\n      if (v2 !== v1) {\r\n        this.changed.emit(this._value[0]);\r\n      }\r\n    } else {\r\n      this.current = null;\r\n      this.changed.emit(null);\r\n    }\r\n\r\n  }\r\n  get value() {\r\n    return this._value;\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\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('attr.aria-describedBy') describedBy = '';\r\n\r\n  private renderer = inject(Renderer2);\r\n\r\n  protected current: NameValueItem<any> | null = null;\r\n\r\n  width = input<number>(-1);\r\n  border = input<number>(-1);\r\n  borderRadius = input<string>(\"9999px\");\r\n  label = input<string>();\r\n  labelSelected = input<string>();\r\n  options = input<NameValueItem<any>[]>();\r\n  autoSelect = input<boolean>(false);\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    if (this.autoSelect()) {\r\n      const options = this.options();\r\n      if (options && options.length > 0 && options[0].value) {\r\n        this.current = options[0];\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.stateChanges.complete();\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    this.value = value;\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 * Select an element\r\n * @param item : the item to select\r\n */\r\n  select(item: NameValueItem<any>) {\r\n    this.writeValue([item]);\r\n    this.selected.emit(item);\r\n    this.changeDetector.markForCheck();\r\n  }\r\n\r\n  /**\r\n   * Reset value\r\n   */\r\n  reset() {\r\n    this.writeValue(null);\r\n  }\r\n}\r\n","<button mat-stroked-button class=\"menu-selector-button\" [ngStyle]=\"{\r\n    'border': border() >= 0 ? border() : 'auto',\r\n    'border-radius': borderRadius(),\r\n    'height': border() <= 0 ? '40px' : 'auto',\r\n    'min-width': width() > 0 ? width()+'px' : (width() === -1 ? '100%' : 'auto')\r\n}\" [attr.aria-label]=\"label()\" [matMenuTriggerFor]=\"optionsMenu\">\r\n    <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n        <div fxFlex=\"100\" fxFlexAlign=\"center\">\r\n            @if(current) {\r\n            <div class=\"truncated\" style=\"text-align: left;\"\r\n                [ngStyle]=\"{'min-width': width() > 0 ? width()+'px' : (width() === -1 ? '100%' : 'auto')}\">\r\n                <div class=\"x-small \">{{labelSelected() ?? label()}}</div>\r\n                <div class=\"small\" style=\"margin-top:2px\">{{current.shortName ?? current.name}}</div>\r\n            </div>\r\n            } @else {\r\n            <div class=\"truncated\" style=\"text-align: left;\"\r\n                [ngStyle]=\"{'min-width': width() > 0 ? width()+'px' : (width() === -1 ? '100%' : 'auto')}\">\r\n                {{label()}}</div>\r\n            }\r\n        </div>\r\n        <div fxLayoutAlign=\"end\" fxFlexAlign=\"center\">\r\n            <mat-icon>arrow_drop_down</mat-icon>\r\n        </div>\r\n    </div>\r\n</button>\r\n<mat-menu #optionsMenu=\"matMenu\" xPosition=\"before\">\r\n    @for (o of options(); track o.value) {\r\n    <button mat-menu-item (click)=\"select(o)\" [disabled]=\"o.disabled\">\r\n        {{o.name}}\r\n        @if(o.bag) {\r\n            ({{o.bag}})\r\n        }\r\n    </button>\r\n    }\r\n</mat-menu>"]}
@@ -2021,6 +2021,7 @@ class ButtonSelectorComponent {
2021
2021
  this.ngControl = ngControl;
2022
2022
  this.changed = new EventEmitter();
2023
2023
  this.selected = new EventEmitter();
2024
+ this.changeDetector = inject(ChangeDetectorRef);
2024
2025
  this.stateChanges = new Subject();
2025
2026
  this.focused = false;
2026
2027
  this._value = [];
@@ -2091,6 +2092,7 @@ class ButtonSelectorComponent {
2091
2092
  select(item) {
2092
2093
  this.writeValue([item]);
2093
2094
  this.selected.emit(item);
2095
+ this.changeDetector.markForCheck();
2094
2096
  }
2095
2097
  /**
2096
2098
  * Reset value