@arsedizioni/ars-utils 18.2.378 → 18.2.381

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.
Files changed (85) hide show
  1. package/clipper.common/common/definitions.d.ts +4 -0
  2. package/clipper.common/common/services/clipper.service.d.ts +6 -3
  3. package/clipper.ui/ui/document/document.component.d.ts +3 -3
  4. package/clipper.ui/ui/document-index/document-index.component.d.ts +2 -2
  5. package/clipper.ui/ui/document-menu/document-menu.component.d.ts +1 -1
  6. package/clipper.ui/ui/search-calendar/search-calendar.component.d.ts +2 -1
  7. package/clipper.ui/ui/search-dialog/search-dialog.component.d.ts +2 -2
  8. package/clipper.ui/ui/search-facets/search-facets.component.d.ts +2 -1
  9. package/clipper.ui/ui/search-free-text-query-builder/search-free-text-query-builder.component.d.ts +2 -1
  10. package/esm2022/clipper.common/common/definitions.mjs +6 -1
  11. package/esm2022/clipper.common/common/interceptors/auth.interceptor.mjs +15 -11
  12. package/esm2022/clipper.common/common/services/clipper.service.mjs +10 -4
  13. package/esm2022/clipper.ui/ui/document/document.component.mjs +11 -7
  14. package/esm2022/clipper.ui/ui/document-index/document-index.component.mjs +5 -3
  15. package/esm2022/clipper.ui/ui/search-calendar/search-calendar.component.mjs +5 -3
  16. package/esm2022/clipper.ui/ui/search-dialog/search-dialog.component.mjs +5 -3
  17. package/esm2022/clipper.ui/ui/search-facets/search-facets.component.mjs +6 -4
  18. package/esm2022/clipper.ui/ui/search-free-text-query-builder/search-free-text-query-builder.component.mjs +6 -4
  19. package/esm2022/evolution.common/common/definitions.mjs +6 -1
  20. package/esm2022/evolution.common/common/interceptors/auth.interceptor.mjs +14 -10
  21. package/esm2022/evolution.common/common/services/evolution.service.mjs +6 -1
  22. package/esm2022/support.common/common/definitions.mjs +6 -1
  23. package/esm2022/support.common/common/interceptors/auth.interceptor.mjs +14 -10
  24. package/esm2022/support.common/common/services/support.service.mjs +6 -2
  25. package/esm2022/tinymce/full-screen-editor/full-screen-editor.component.mjs +6 -4
  26. package/esm2022/ui/ui/dialogs/confirm/confirm-dialog.component.mjs +6 -4
  27. package/esm2022/ui/ui/dialogs/credentials/credentials-dialog.component.mjs +9 -5
  28. package/esm2022/ui/ui/dialogs/recover-password/recover-password-dialog.component.mjs +6 -4
  29. package/esm2022/ui/ui/dialogs/reset-password/reset-password-dialog.component.mjs +6 -4
  30. package/esm2022/ui/ui/dialogs/toast/toast.component.mjs +6 -4
  31. package/esm2022/ui.application/ui/components/button-selector/button-selector.component.mjs +9 -5
  32. package/esm2022/ui.application/ui/components/button-toggle/button-toggle.component.mjs +6 -4
  33. package/esm2022/ui.application/ui/components/chips-selector/chips-selector.component.mjs +6 -4
  34. package/esm2022/ui.application/ui/components/file-input/file-input.component.mjs +7 -7
  35. package/esm2022/ui.application/ui/components/filter-bar/filter-bar.component.mjs +6 -4
  36. package/esm2022/ui.application/ui/dialogs/prompt/prompt-dialog.component.mjs +5 -3
  37. package/esm2022/ui.application/ui/dialogs/prompt-date/prompt-date-dialog.component.mjs +5 -3
  38. package/esm2022/ui.application/ui/dialogs/prompt-time/prompt-time-dialog.component.mjs +5 -3
  39. package/esm2022/ui.application/ui/dialogs/select/select-dialog.component.mjs +26 -10
  40. package/esm2022/ui.application/ui/dialogs/select-file/select-file-dialog.component.mjs +6 -4
  41. package/esm2022/ui.application/ui/dialogs/select-picture/select-picture-dialog.component.mjs +6 -4
  42. package/esm2022/ui.application/ui/dialogs/select-tree/select-tree-dialog.component.mjs +6 -4
  43. package/esm2022/ui.application/ui/dialogs/send-to/send-to-dialog.component.mjs +9 -5
  44. package/esm2022/ui.oauth/ui/components/login/login-oauth.component.mjs +6 -4
  45. package/evolution.common/common/definitions.d.ts +4 -0
  46. package/evolution.common/common/services/evolution.service.d.ts +3 -1
  47. package/fesm2022/arsedizioni-ars-utils-clipper.common.mjs +26 -12
  48. package/fesm2022/arsedizioni-ars-utils-clipper.common.mjs.map +1 -1
  49. package/fesm2022/arsedizioni-ars-utils-clipper.ui.mjs +1377 -1363
  50. package/fesm2022/arsedizioni-ars-utils-clipper.ui.mjs.map +1 -1
  51. package/fesm2022/arsedizioni-ars-utils-evolution.common.mjs +22 -10
  52. package/fesm2022/arsedizioni-ars-utils-evolution.common.mjs.map +1 -1
  53. package/fesm2022/arsedizioni-ars-utils-support.common.mjs +22 -10
  54. package/fesm2022/arsedizioni-ars-utils-support.common.mjs.map +1 -1
  55. package/fesm2022/arsedizioni-ars-utils-tinymce.mjs +5 -3
  56. package/fesm2022/arsedizioni-ars-utils-tinymce.mjs.map +1 -1
  57. package/fesm2022/arsedizioni-ars-utils-ui.application.mjs +77 -35
  58. package/fesm2022/arsedizioni-ars-utils-ui.application.mjs.map +1 -1
  59. package/fesm2022/arsedizioni-ars-utils-ui.mjs +24 -12
  60. package/fesm2022/arsedizioni-ars-utils-ui.mjs.map +1 -1
  61. package/fesm2022/arsedizioni-ars-utils-ui.oauth.mjs +5 -3
  62. package/fesm2022/arsedizioni-ars-utils-ui.oauth.mjs.map +1 -1
  63. package/package.json +7 -7
  64. package/support.common/common/definitions.d.ts +4 -0
  65. package/support.common/common/services/support.service.d.ts +3 -1
  66. package/tinymce/full-screen-editor/full-screen-editor.component.d.ts +2 -2
  67. package/ui/ui/dialogs/confirm/confirm-dialog.component.d.ts +2 -2
  68. package/ui/ui/dialogs/credentials/credentials-dialog.component.d.ts +3 -3
  69. package/ui/ui/dialogs/recover-password/recover-password-dialog.component.d.ts +2 -1
  70. package/ui/ui/dialogs/reset-password/reset-password-dialog.component.d.ts +2 -2
  71. package/ui/ui/dialogs/toast/toast.component.d.ts +2 -1
  72. package/ui.application/ui/components/button-selector/button-selector.component.d.ts +3 -3
  73. package/ui.application/ui/components/button-toggle/button-toggle.component.d.ts +2 -2
  74. package/ui.application/ui/components/chips-selector/chips-selector.component.d.ts +2 -2
  75. package/ui.application/ui/components/file-input/file-input.component.d.ts +5 -5
  76. package/ui.application/ui/components/filter-bar/filter-bar.component.d.ts +2 -2
  77. package/ui.application/ui/dialogs/prompt/prompt-dialog.component.d.ts +2 -2
  78. package/ui.application/ui/dialogs/prompt-date/prompt-date-dialog.component.d.ts +2 -2
  79. package/ui.application/ui/dialogs/prompt-time/prompt-time-dialog.component.d.ts +2 -2
  80. package/ui.application/ui/dialogs/select/select-dialog.component.d.ts +9 -9
  81. package/ui.application/ui/dialogs/select-file/select-file-dialog.component.d.ts +2 -1
  82. package/ui.application/ui/dialogs/select-picture/select-picture-dialog.component.d.ts +2 -1
  83. package/ui.application/ui/dialogs/select-tree/select-tree-dialog.component.d.ts +2 -2
  84. package/ui.application/ui/dialogs/send-to/send-to-dialog.component.d.ts +3 -3
  85. package/ui.oauth/ui/components/login/login-oauth.component.d.ts +2 -2
@@ -1,6 +1,6 @@
1
1
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
2
  import { NgClass, NgStyle } from '@angular/common';
3
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, Input, Optional, Renderer2, Self, inject, input, output } 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';
@@ -40,8 +40,8 @@ export class ButtonSelectorComponent {
40
40
  }
41
41
  constructor(ngControl) {
42
42
  this.ngControl = ngControl;
43
- this.changed = output();
44
- this.selected = output();
43
+ this.changed = new EventEmitter();
44
+ this.selected = new EventEmitter();
45
45
  this.changeDetector = inject(ChangeDetectorRef);
46
46
  this.stateChanges = new Subject();
47
47
  this.focused = false;
@@ -132,7 +132,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
132
132
  type: Optional
133
133
  }, {
134
134
  type: Self
135
- }] }], propDecorators: { disabled: [{
135
+ }] }], propDecorators: { changed: [{
136
+ type: Output
137
+ }], selected: [{
138
+ type: Output
139
+ }], disabled: [{
136
140
  type: Input
137
141
  }], id: [{
138
142
  type: HostBinding
@@ -140,4 +144,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
140
144
  type: HostBinding,
141
145
  args: ['attr.aria-describedBy']
142
146
  }] } });
143
- //# 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, HostBinding, Input, OnDestroy, OnInit, Optional, Renderer2, Self, inject, input, output } 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  changed = output<NameValueItem<any> | null>();\r\n  selected = output<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> | null = 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    this.current = this._value;    \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 = `button-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>"]}
147
+ //# 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> | null = 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    this.current = this._value;    \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 = `button-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>"]}
@@ -1,5 +1,5 @@
1
1
  import { NgClass, NgStyle } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, EventEmitter, Output, computed, input } from '@angular/core';
3
3
  import { MatButtonModule } from '@angular/material/button';
4
4
  import { MatIconModule } from '@angular/material/icon';
5
5
  import { FlexLayoutModule } from '@ngbracket/ngx-layout';
@@ -10,7 +10,7 @@ import * as i3 from "@angular/material/icon";
10
10
  import * as i4 from "@angular/material/button";
11
11
  export class ButtonToggleComponent {
12
12
  constructor() {
13
- this.changed = output();
13
+ this.changed = new EventEmitter();
14
14
  this.current = computed(() => {
15
15
  return this.value();
16
16
  });
@@ -43,5 +43,7 @@ export class ButtonToggleComponent {
43
43
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: ButtonToggleComponent, decorators: [{
44
44
  type: Component,
45
45
  args: [{ selector: 'button-toggle', standalone: true, imports: [NgStyle, NgClass, FlexLayoutModule, MatIconModule, MatButtonModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<button mat-stroked-button [ngStyle]=\"{\r\n 'border': border() >= 0 ? border() : 'auto',\r\n 'height': border() <= 0 ? '40px' : 'auto',\r\n 'min-width.px': width() > 0 ? width() : 'auto' \r\n}\" [class]=\"cssClass()\" [attr.aria-label]=\"label()\" (click)=\"toggle()\" [ngClass]=\"{'button-on': value() === true}\">\r\n <div fxLayout=\"row\" fxLayoutGap=\"8px\" fxLayoutAlign=\"center center\" fxFill>\r\n @if(icon()) {\r\n <div fxFlex=\"24px\"><mat-icon>{{icon()}}</mat-icon></div>\r\n }\r\n <div fxFlex=\"*\">{{label()}}</div>\r\n </div>\r\n</button>", styles: [".button-on{background-color:var(--mdc-switch-selected-focus-handle-color)!important;border-color:var(--mdc-switch-selected-focus-handle-color)!important;font-weight:700}\n"] }]
46
- }] });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLXRvZ2dsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnMtdXRpbHMvdWkuYXBwbGljYXRpb24vdWkvY29tcG9uZW50cy9idXR0b24tdG9nZ2xlL2J1dHRvbi10b2dnbGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXJzLXV0aWxzL3VpLmFwcGxpY2F0aW9uL3VpL2NvbXBvbmVudHMvYnV0dG9uLXRvZ2dsZS9idXR0b24tdG9nZ2xlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDbkQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBVSxRQUFRLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwRyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDOzs7Ozs7QUFnQnpELE1BQU0sT0FBTyxxQkFBcUI7SUFSbEM7UUFVRSxZQUFPLEdBQUcsTUFBTSxFQUFvQixDQUFDO1FBRTNCLFlBQU8sR0FBb0IsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUNqRCxPQUFPLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN0QixDQUFDLENBQUMsQ0FBQTtRQUVGLFlBQU8sR0FBWSxLQUFLLENBQUM7UUFFekIsVUFBSyxHQUFFLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUM3QixVQUFLLEdBQUcsS0FBSyxDQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDMUIsV0FBTSxHQUFHLEtBQUssQ0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzNCLFlBQU8sR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUMxQixhQUFRLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDM0IsV0FBTSxHQUFHLEtBQUssRUFBVSxDQUFDO1FBQ3pCLFlBQU8sR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUMxQixhQUFRLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFFakIsVUFBSyxHQUFtQixRQUFRLENBQUMsR0FBRyxFQUFFO1lBQzlDLE9BQU8sSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDO1FBQ3JFLENBQUMsQ0FBQyxDQUFBO1FBRVEsU0FBSSxHQUFtQixRQUFRLENBQUMsR0FBRyxFQUFFO1lBQzdDLE9BQU8sSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDO1FBQ25FLENBQUMsQ0FBQyxDQUFBO0tBVUg7SUFSQzs7T0FFRztJQUNILE1BQU07UUFDSixJQUFJLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUMvQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUMsQ0FBQyxDQUFDO0lBQ2xFLENBQUM7OEdBakNVLHFCQUFxQjtrR0FBckIscUJBQXFCLDBsQ0NwQmxDLHNsQkFXUyxxT0RJRyxPQUFPLDJFQUFFLE9BQU8sbUZBQUUsZ0JBQWdCLDg2R0FBRSxhQUFhLG1MQUFFLGVBQWU7OzJGQUtqRSxxQkFBcUI7a0JBUmpDLFNBQVM7K0JBQ0UsZUFBZSxjQUNiLElBQUksV0FDUCxDQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsYUFBYSxFQUFFLGVBQWUsQ0FBQyxtQkFHNUQsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nQ2xhc3MsIE5nU3R5bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBTaWduYWwsIGNvbXB1dGVkLCBpbnB1dCwgb3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuaW1wb3J0IHsgRmxleExheW91dE1vZHVsZSB9IGZyb20gJ0BuZ2JyYWNrZXQvbmd4LWxheW91dCc7XHJcblxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBCdXR0b25Ub2dnbGVJbmZvIHtcclxuICB2YWx1ZTogYm9vbGVhbixcclxuICB0b2dnbGVkOiBib29sZWFuXHJcbn1cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYnV0dG9uLXRvZ2dsZScsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbTmdTdHlsZSwgTmdDbGFzcywgRmxleExheW91dE1vZHVsZSwgTWF0SWNvbk1vZHVsZSwgTWF0QnV0dG9uTW9kdWxlXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vYnV0dG9uLXRvZ2dsZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL2J1dHRvbi10b2dnbGUuY29tcG9uZW50LnNjc3MnLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQnV0dG9uVG9nZ2xlQ29tcG9uZW50ICB7XHJcblxyXG4gIGNoYW5nZWQgPSBvdXRwdXQ8QnV0dG9uVG9nZ2xlSW5mbz4oKTtcclxuXHJcbiAgcHJvdGVjdGVkIGN1cnJlbnQ6IFNpZ25hbDxib29sZWFuPiA9IGNvbXB1dGVkKCgpID0+IHtcclxuICAgIHJldHVybiB0aGlzLnZhbHVlKCk7XHJcbiAgfSlcclxuXHJcbiAgdG9nZ2xlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICB2YWx1ZT0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xyXG4gIHdpZHRoID0gaW5wdXQ8bnVtYmVyPigtMSk7XHJcbiAgYm9yZGVyID0gaW5wdXQ8bnVtYmVyPigtMSk7XHJcbiAgbGFiZWxPbiA9IGlucHV0PHN0cmluZz4oKTtcclxuICBsYWJlbE9mZiA9IGlucHV0PHN0cmluZz4oKTtcclxuICBpY29uT24gPSBpbnB1dDxzdHJpbmc+KCk7XHJcbiAgaWNvbk9mZiA9IGlucHV0PHN0cmluZz4oKTtcclxuICBjc3NDbGFzcyA9IGlucHV0PHN0cmluZz4oKTtcclxuXHJcbiAgcHJvdGVjdGVkIGxhYmVsOiBTaWduYWw8c3RyaW5nPiA9IGNvbXB1dGVkKCgpID0+IHtcclxuICAgIHJldHVybiB0aGlzLnZhbHVlKCkgPyB0aGlzLmxhYmVsT24oKSA/PyAnJyA6IHRoaXMubGFiZWxPZmYoKSA/PyAnJztcclxuICB9KVxyXG5cclxuICBwcm90ZWN0ZWQgaWNvbjogU2lnbmFsPHN0cmluZz4gPSBjb21wdXRlZCgoKSA9PiB7XHJcbiAgICByZXR1cm4gdGhpcy52YWx1ZSgpID8gdGhpcy5pY29uT24oKSA/PyAnJyA6IHRoaXMuaWNvbk9mZigpID8/ICcnO1xyXG4gIH0pXHJcblxyXG4gIC8qKlxyXG4gICAqIFRvZ2dsZSB0aGUgYnV0dG9uXHJcbiAgICovXHJcbiAgdG9nZ2xlKCkge1xyXG4gICAgdGhpcy50b2dnbGVkID0gISh0aGlzLnZhbHVlKCkpO1xyXG4gICAgdGhpcy5jaGFuZ2VkLmVtaXQoe3ZhbHVlOiB0aGlzLnZhbHVlKCksIHRvZ2dsZWQ6IHRoaXMudG9nZ2xlZH0pO1xyXG4gIH1cclxuXHJcbn1cclxuIiwiPGJ1dHRvbiBtYXQtc3Ryb2tlZC1idXR0b24gW25nU3R5bGVdPVwie1xyXG4gICAgJ2JvcmRlcic6IGJvcmRlcigpID49IDAgPyBib3JkZXIoKSA6ICdhdXRvJyxcclxuICAgICdoZWlnaHQnOiBib3JkZXIoKSA8PSAwID8gJzQwcHgnIDogJ2F1dG8nLFxyXG4gICAgJ21pbi13aWR0aC5weCc6IHdpZHRoKCkgPiAwID8gd2lkdGgoKSA6ICdhdXRvJyBcclxufVwiIFtjbGFzc109XCJjc3NDbGFzcygpXCIgW2F0dHIuYXJpYS1sYWJlbF09XCJsYWJlbCgpXCIgKGNsaWNrKT1cInRvZ2dsZSgpXCIgW25nQ2xhc3NdPVwieydidXR0b24tb24nOiB2YWx1ZSgpID09PSB0cnVlfVwiPlxyXG4gICAgPGRpdiBmeExheW91dD1cInJvd1wiIGZ4TGF5b3V0R2FwPVwiOHB4XCIgZnhMYXlvdXRBbGlnbj1cImNlbnRlciBjZW50ZXJcIiBmeEZpbGw+XHJcbiAgICAgICAgQGlmKGljb24oKSkge1xyXG4gICAgICAgIDxkaXYgZnhGbGV4PVwiMjRweFwiPjxtYXQtaWNvbj57e2ljb24oKX19PC9tYXQtaWNvbj48L2Rpdj5cclxuICAgICAgICB9XHJcbiAgICAgICAgPGRpdiBmeEZsZXg9XCIqXCI+e3tsYWJlbCgpfX08L2Rpdj5cclxuICAgIDwvZGl2PlxyXG48L2J1dHRvbj4iXX0=
46
+ }], propDecorators: { changed: [{
47
+ type: Output
48
+ }] } });
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLXRvZ2dsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnMtdXRpbHMvdWkuYXBwbGljYXRpb24vdWkvY29tcG9uZW50cy9idXR0b24tdG9nZ2xlL2J1dHRvbi10b2dnbGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXJzLXV0aWxzL3VpLmFwcGxpY2F0aW9uL3VpL2NvbXBvbmVudHMvYnV0dG9uLXRvZ2dsZS9idXR0b24tdG9nZ2xlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDbkQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFVLFFBQVEsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEgsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7Ozs7O0FBZ0J6RCxNQUFNLE9BQU8scUJBQXFCO0lBUmxDO1FBVVksWUFBTyxHQUFHLElBQUksWUFBWSxFQUFvQixDQUFDO1FBRS9DLFlBQU8sR0FBb0IsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUNqRCxPQUFPLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN0QixDQUFDLENBQUMsQ0FBQTtRQUVGLFlBQU8sR0FBWSxLQUFLLENBQUM7UUFFekIsVUFBSyxHQUFFLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUM3QixVQUFLLEdBQUcsS0FBSyxDQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDMUIsV0FBTSxHQUFHLEtBQUssQ0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzNCLFlBQU8sR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUMxQixhQUFRLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDM0IsV0FBTSxHQUFHLEtBQUssRUFBVSxDQUFDO1FBQ3pCLFlBQU8sR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUMxQixhQUFRLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFFakIsVUFBSyxHQUFtQixRQUFRLENBQUMsR0FBRyxFQUFFO1lBQzlDLE9BQU8sSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDO1FBQ3JFLENBQUMsQ0FBQyxDQUFBO1FBRVEsU0FBSSxHQUFtQixRQUFRLENBQUMsR0FBRyxFQUFFO1lBQzdDLE9BQU8sSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDO1FBQ25FLENBQUMsQ0FBQyxDQUFBO0tBVUg7SUFSQzs7T0FFRztJQUNILE1BQU07UUFDSixJQUFJLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUMvQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUMsQ0FBQyxDQUFDO0lBQ2xFLENBQUM7OEdBakNVLHFCQUFxQjtrR0FBckIscUJBQXFCLDBsQ0NwQmxDLHNsQkFXUyxxT0RJRyxPQUFPLDJFQUFFLE9BQU8sbUZBQUUsZ0JBQWdCLDg2R0FBRSxhQUFhLG1MQUFFLGVBQWU7OzJGQUtqRSxxQkFBcUI7a0JBUmpDLFNBQVM7K0JBQ0UsZUFBZSxjQUNiLElBQUksV0FDUCxDQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsYUFBYSxFQUFFLGVBQWUsQ0FBQyxtQkFHNUQsdUJBQXVCLENBQUMsTUFBTTs4QkFJckMsT0FBTztzQkFBaEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nQ2xhc3MsIE5nU3R5bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIE91dHB1dCwgU2lnbmFsLCBjb21wdXRlZCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBGbGV4TGF5b3V0TW9kdWxlIH0gZnJvbSAnQG5nYnJhY2tldC9uZ3gtbGF5b3V0JztcclxuXHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEJ1dHRvblRvZ2dsZUluZm8ge1xyXG4gIHZhbHVlOiBib29sZWFuLFxyXG4gIHRvZ2dsZWQ6IGJvb2xlYW5cclxufVxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdidXR0b24tdG9nZ2xlJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtOZ1N0eWxlLCBOZ0NsYXNzLCBGbGV4TGF5b3V0TW9kdWxlLCBNYXRJY29uTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGVdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9idXR0b24tdG9nZ2xlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vYnV0dG9uLXRvZ2dsZS5jb21wb25lbnQuc2NzcycsXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBCdXR0b25Ub2dnbGVDb21wb25lbnQgIHtcclxuXHJcbiAgQE91dHB1dCgpIGNoYW5nZWQgPSBuZXcgRXZlbnRFbWl0dGVyPEJ1dHRvblRvZ2dsZUluZm8+KCk7XHJcblxyXG4gIHByb3RlY3RlZCBjdXJyZW50OiBTaWduYWw8Ym9vbGVhbj4gPSBjb21wdXRlZCgoKSA9PiB7XHJcbiAgICByZXR1cm4gdGhpcy52YWx1ZSgpO1xyXG4gIH0pXHJcblxyXG4gIHRvZ2dsZWQ6IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgdmFsdWU9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcclxuICB3aWR0aCA9IGlucHV0PG51bWJlcj4oLTEpO1xyXG4gIGJvcmRlciA9IGlucHV0PG51bWJlcj4oLTEpO1xyXG4gIGxhYmVsT24gPSBpbnB1dDxzdHJpbmc+KCk7XHJcbiAgbGFiZWxPZmYgPSBpbnB1dDxzdHJpbmc+KCk7XHJcbiAgaWNvbk9uID0gaW5wdXQ8c3RyaW5nPigpO1xyXG4gIGljb25PZmYgPSBpbnB1dDxzdHJpbmc+KCk7XHJcbiAgY3NzQ2xhc3MgPSBpbnB1dDxzdHJpbmc+KCk7XHJcblxyXG4gIHByb3RlY3RlZCBsYWJlbDogU2lnbmFsPHN0cmluZz4gPSBjb21wdXRlZCgoKSA9PiB7XHJcbiAgICByZXR1cm4gdGhpcy52YWx1ZSgpID8gdGhpcy5sYWJlbE9uKCkgPz8gJycgOiB0aGlzLmxhYmVsT2ZmKCkgPz8gJyc7XHJcbiAgfSlcclxuXHJcbiAgcHJvdGVjdGVkIGljb246IFNpZ25hbDxzdHJpbmc+ID0gY29tcHV0ZWQoKCkgPT4ge1xyXG4gICAgcmV0dXJuIHRoaXMudmFsdWUoKSA/IHRoaXMuaWNvbk9uKCkgPz8gJycgOiB0aGlzLmljb25PZmYoKSA/PyAnJztcclxuICB9KVxyXG5cclxuICAvKipcclxuICAgKiBUb2dnbGUgdGhlIGJ1dHRvblxyXG4gICAqL1xyXG4gIHRvZ2dsZSgpIHtcclxuICAgIHRoaXMudG9nZ2xlZCA9ICEodGhpcy52YWx1ZSgpKTtcclxuICAgIHRoaXMuY2hhbmdlZC5lbWl0KHt2YWx1ZTogdGhpcy52YWx1ZSgpLCB0b2dnbGVkOiB0aGlzLnRvZ2dsZWR9KTtcclxuICB9XHJcblxyXG59XHJcbiIsIjxidXR0b24gbWF0LXN0cm9rZWQtYnV0dG9uIFtuZ1N0eWxlXT1cIntcclxuICAgICdib3JkZXInOiBib3JkZXIoKSA+PSAwID8gYm9yZGVyKCkgOiAnYXV0bycsXHJcbiAgICAnaGVpZ2h0JzogYm9yZGVyKCkgPD0gMCA/ICc0MHB4JyA6ICdhdXRvJyxcclxuICAgICdtaW4td2lkdGgucHgnOiB3aWR0aCgpID4gMCA/IHdpZHRoKCkgOiAnYXV0bycgXHJcbn1cIiBbY2xhc3NdPVwiY3NzQ2xhc3MoKVwiIFthdHRyLmFyaWEtbGFiZWxdPVwibGFiZWwoKVwiIChjbGljayk9XCJ0b2dnbGUoKVwiIFtuZ0NsYXNzXT1cInsnYnV0dG9uLW9uJzogdmFsdWUoKSA9PT0gdHJ1ZX1cIj5cclxuICAgIDxkaXYgZnhMYXlvdXQ9XCJyb3dcIiBmeExheW91dEdhcD1cIjhweFwiIGZ4TGF5b3V0QWxpZ249XCJjZW50ZXIgY2VudGVyXCIgZnhGaWxsPlxyXG4gICAgICAgIEBpZihpY29uKCkpIHtcclxuICAgICAgICA8ZGl2IGZ4RmxleD1cIjI0cHhcIj48bWF0LWljb24+e3tpY29uKCl9fTwvbWF0LWljb24+PC9kaXY+XHJcbiAgICAgICAgfVxyXG4gICAgICAgIDxkaXYgZnhGbGV4PVwiKlwiPnt7bGFiZWwoKX19PC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuPC9idXR0b24+Il19
@@ -1,6 +1,6 @@
1
1
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
2
  import { NgClass, NgStyle } from '@angular/common';
3
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, computed, HostBinding, inject, Input, input, Optional, output, Renderer2, Self, signal } from '@angular/core';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, computed, EventEmitter, HostBinding, inject, Input, input, Optional, Output, Renderer2, Self, signal } from '@angular/core';
4
4
  import { FormsModule } from '@angular/forms';
5
5
  import { MatBadgeModule } from '@angular/material/badge';
6
6
  import { MatButtonModule } from '@angular/material/button';
@@ -92,7 +92,7 @@ export class ChipsSelectorComponent {
92
92
  }
93
93
  constructor(ngControl) {
94
94
  this.ngControl = ngControl;
95
- this.changed = output();
95
+ this.changed = new EventEmitter();
96
96
  this.containerId = `chips-selector-container--${SystemUtils.generateUUID()}`;
97
97
  this.containerWidth = signal(-6);
98
98
  this.focused = false;
@@ -244,7 +244,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
244
244
  type: Optional
245
245
  }, {
246
246
  type: Self
247
- }] }], propDecorators: { required: [{
247
+ }] }], propDecorators: { changed: [{
248
+ type: Output
249
+ }], required: [{
248
250
  type: Input
249
251
  }], disabled: [{
250
252
  type: Input
@@ -259,4 +261,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
259
261
  type: HostBinding,
260
262
  args: ['attr.aria-describedBy']
261
263
  }] } });
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, 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\nimport { MatTooltipModule } from '@angular/material/tooltip';\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  changed = output<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  badgeColor = input<'primary' | 'secondary' | 'tertiary' | 'error' | 'accent'>('accent');\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    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.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() || (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.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-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\" [matBadgeColor]=\"badgeColor()\" [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>"]}
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 { ButtonSelectorComponent } from '../button-selector/button-selector.component';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\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  badgeColor = input<'primary' | 'secondary' | 'tertiary' | 'error' | 'accent'>('accent');\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    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.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() || (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.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-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\" [matBadgeColor]=\"badgeColor()\" [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>"]}
@@ -1,5 +1,5 @@
1
1
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
- import { ChangeDetectionStrategy, Component, HostBinding, Input, Optional, Renderer2, Self, ViewChild, inject, input, output } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Optional, Renderer2, Self, ViewChild, inject, input } from '@angular/core';
3
3
  import { FormsModule } from '@angular/forms';
4
4
  import { MatFormFieldControl, MatFormFieldModule } from '@angular/material/form-field';
5
5
  import { FileInfo, FileSizeValidatorDirective, SystemUtils } from '@arsedizioni/ars-utils/core';
@@ -88,9 +88,9 @@ export class FileInputComponent {
88
88
  this.accept = input();
89
89
  this.id = `${this.controlType}-${FileInputComponent.nextId++}`;
90
90
  this.describedBy = '';
91
- this.changed = output();
92
- this.download = output();
93
- this.preview = output();
91
+ this.changed = new EventEmitter();
92
+ this.download = new EventEmitter();
93
+ this.preview = new EventEmitter();
94
94
  this.propagateChange = (_) => { };
95
95
  this.propagateTouched = () => { };
96
96
  if (this.ngControl != null) {
@@ -215,7 +215,7 @@ export class FileInputComponent {
215
215
  */
216
216
  downloadFile() {
217
217
  if (!this.isNew())
218
- this.download.emit(null);
218
+ this.download.emit();
219
219
  }
220
220
  /**
221
221
  * Preview
@@ -225,7 +225,7 @@ export class FileInputComponent {
225
225
  this.preview.emit();
226
226
  }
227
227
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: FileInputComponent, deps: [{ token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
228
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: FileInputComponent, isStandalone: true, selector: "file-input", inputs: { required: { classPropertyName: "required", publicName: "required", isSignal: false, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: false, isRequired: false, transformFunction: null }, fileName: { classPropertyName: "fileName", publicName: "fileName", isSignal: false, isRequired: false, transformFunction: null }, maxSizeMb: { classPropertyName: "maxSizeMb", publicName: "maxSizeMb", isSignal: true, isRequired: false, transformFunction: null }, minSizeMb: { classPropertyName: "minSizeMb", publicName: "minSizeMb", isSignal: true, isRequired: false, transformFunction: null }, isNew: { classPropertyName: "isNew", publicName: "isNew", isSignal: true, isRequired: false, transformFunction: null }, canPreview: { classPropertyName: "canPreview", publicName: "canPreview", isSignal: true, isRequired: false, transformFunction: null }, appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, accept: { classPropertyName: "accept", publicName: "accept", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { changed: "changed", download: "download", preview: "preview" }, host: { properties: { "id": "this.id", "class.floating": "this.shouldLabelFloat", "attr.aria-describedBy": "this.describedBy" } }, providers: [{ provide: MatFormFieldControl, useExisting: FileInputComponent }], viewQueries: [{ propertyName: "__file", first: true, predicate: ["__file"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<mat-form-field style=\"width:100%\" [appearance]=\"appearance()\">\r\n <mat-label>{{placeholder}}</mat-label>\r\n <input type=\"file\" [hidden]=\"true\" [accept]=\"accept()\" (change)=\"selectFile($event)\" #__file />\r\n <input name=\"_fileName\" #_fileName=\"ngModel\" [(ngModel)]=\"fileName\" [id]=\"id\" matInput readonly [required]=\"required\"\r\n fileSize [size]=\"fileSize\" [maxSizeMb]=\"maxSizeMb()\" [minSizeMb]=\"minSizeMb()\" [disabled]=\"disabled\" />\r\n @if (hasFile()) {\r\n <button type=\"button\" tabindex=\"-1\" mat-icon-button matSuffix aria-label=\"Azzera\" (click)=\"clearFile()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n }\r\n @if (!disabled) {\r\n <button type=\"button\" type=\"button\" mat-icon-button matSuffix (click)=\"__file.click()\" aria-label=\"Seleziona file\"\r\n matTooltip=\"Seleziona\">\r\n <mat-icon>add</mat-icon>\r\n </button>\r\n }\r\n @if (!isNew() && canPreview()) {\r\n <button type=\"button\" mat-icon-button matSuffix (click)=\"previewFile()\" aria-label=\"Anteprima\" matTooltip=\"Anteprima\">\r\n <mat-icon>preview</mat-icon>\r\n </button>\r\n }\r\n @if (!isNew()) {\r\n<button type=\"button\" mat-icon-button matSuffix (click)=\"downloadFile()\" aria-label=\"Scarica file\"\r\n matTooltip=\"Scarica\">\r\n <mat-icon>save_alt</mat-icon>\r\n</button>\r\n}\r\n @if (hasFile() && fileSize > 0) {\r\n<mat-hint align=\"left\">{{fileSize}} MB</mat-hint>\r\n}\r\n @if (hasFile() && fileSize == 0) {\r\n<mat-hint align=\"left\">\r\n < 1 MB</mat-hint>\r\n} @if (maxSizeMb()) {\r\n<mat-hint align=\"end\">Massimo {{maxSizeMb()}} MB\r\n </mat-hint>\r\n}\r\n @if (_fileName.invalid && !hasFile()) {\r\n<mat-error>Obbligatorio.</mat-error>\r\n}\r\n @if (_fileName.invalid && hasFile()) {\r\n<mat-error>Dimensione non consentita.</mat-error>\r\n}\r\n</mat-form-field>", styles: [""], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i2.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: FileSizeValidatorDirective, selector: "[fileSize]", inputs: ["maxSizeMb", "minSizeMb", "size"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
228
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: FileInputComponent, isStandalone: true, selector: "file-input", inputs: { required: { classPropertyName: "required", publicName: "required", isSignal: false, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: false, isRequired: false, transformFunction: null }, fileName: { classPropertyName: "fileName", publicName: "fileName", isSignal: false, isRequired: false, transformFunction: null }, maxSizeMb: { classPropertyName: "maxSizeMb", publicName: "maxSizeMb", isSignal: true, isRequired: false, transformFunction: null }, minSizeMb: { classPropertyName: "minSizeMb", publicName: "minSizeMb", isSignal: true, isRequired: false, transformFunction: null }, isNew: { classPropertyName: "isNew", publicName: "isNew", isSignal: true, isRequired: false, transformFunction: null }, canPreview: { classPropertyName: "canPreview", publicName: "canPreview", isSignal: true, isRequired: false, transformFunction: null }, appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, accept: { classPropertyName: "accept", publicName: "accept", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "id": "this.id", "class.floating": "this.shouldLabelFloat", "attr.aria-describedBy": "this.describedBy" } }, providers: [{ provide: MatFormFieldControl, useExisting: FileInputComponent }], viewQueries: [{ propertyName: "__file", first: true, predicate: ["__file"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<mat-form-field style=\"width:100%\" [appearance]=\"appearance()\">\r\n <mat-label>{{placeholder}}</mat-label>\r\n <input type=\"file\" [hidden]=\"true\" [accept]=\"accept()\" (change)=\"selectFile($event)\" #__file />\r\n <input name=\"_fileName\" #_fileName=\"ngModel\" [(ngModel)]=\"fileName\" [id]=\"id\" matInput readonly [required]=\"required\"\r\n fileSize [size]=\"fileSize\" [maxSizeMb]=\"maxSizeMb()\" [minSizeMb]=\"minSizeMb()\" [disabled]=\"disabled\" />\r\n @if (hasFile()) {\r\n <button type=\"button\" tabindex=\"-1\" mat-icon-button matSuffix aria-label=\"Azzera\" (click)=\"clearFile()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n }\r\n @if (!disabled) {\r\n <button type=\"button\" type=\"button\" mat-icon-button matSuffix (click)=\"__file.click()\" aria-label=\"Seleziona file\"\r\n matTooltip=\"Seleziona\">\r\n <mat-icon>add</mat-icon>\r\n </button>\r\n }\r\n @if (!isNew() && canPreview()) {\r\n <button type=\"button\" mat-icon-button matSuffix (click)=\"previewFile()\" aria-label=\"Anteprima\" matTooltip=\"Anteprima\">\r\n <mat-icon>preview</mat-icon>\r\n </button>\r\n }\r\n @if (!isNew()) {\r\n<button type=\"button\" mat-icon-button matSuffix (click)=\"downloadFile()\" aria-label=\"Scarica file\"\r\n matTooltip=\"Scarica\">\r\n <mat-icon>save_alt</mat-icon>\r\n</button>\r\n}\r\n @if (hasFile() && fileSize > 0) {\r\n<mat-hint align=\"left\">{{fileSize}} MB</mat-hint>\r\n}\r\n @if (hasFile() && fileSize == 0) {\r\n<mat-hint align=\"left\">\r\n < 1 MB</mat-hint>\r\n} @if (maxSizeMb()) {\r\n<mat-hint align=\"end\">Massimo {{maxSizeMb()}} MB\r\n </mat-hint>\r\n}\r\n @if (_fileName.invalid && !hasFile()) {\r\n<mat-error>Obbligatorio.</mat-error>\r\n}\r\n @if (_fileName.invalid && hasFile()) {\r\n<mat-error>Dimensione non consentita.</mat-error>\r\n}\r\n</mat-form-field>", styles: [""], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i2.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: FileSizeValidatorDirective, selector: "[fileSize]", inputs: ["maxSizeMb", "minSizeMb", "size"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
229
229
  }
230
230
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: FileInputComponent, decorators: [{
231
231
  type: Component,
@@ -255,4 +255,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
255
255
  type: HostBinding,
256
256
  args: ['attr.aria-describedBy']
257
257
  }] } });
258
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/components/file-input/file-input.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/components/file-input/file-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\r\nimport { AfterViewInit, ChangeDetectionStrategy, Component, DoCheck, ElementRef, HostBinding, Input, OnChanges, OnDestroy, Optional, Renderer2, Self, SimpleChanges, ViewChild, inject, input, output } from '@angular/core';\r\nimport { ControlValueAccessor, NgControl, FormsModule } from '@angular/forms';\r\nimport { MatFormFieldControl, MatFormFieldModule } from '@angular/material/form-field';\r\nimport { FileInfo, FileSizeValidatorDirective, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { Subject } from 'rxjs';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { UIService } from '@arsedizioni/ars-utils/ui';\r\n\r\n@Component({\r\n    selector: 'file-input',\r\n    templateUrl: './file-input.component.html',\r\n    styleUrls: ['./file-input.component.scss'],\r\n    providers: [{ provide: MatFormFieldControl, useExisting: FileInputComponent }],\r\n    standalone: true,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    imports: [MatFormFieldModule, MatInputModule, FormsModule, FileSizeValidatorDirective,  MatButtonModule, \r\n      MatIconModule, MatTooltipModule]\r\n})\r\nexport class FileInputComponent\r\n  implements\r\n  OnDestroy,\r\n  AfterViewInit,\r\n  DoCheck,\r\n  OnChanges,\r\n  MatFormFieldControl<FileInfo>,\r\n  ControlValueAccessor {\r\n\r\n  @ViewChild('__file') __file!: ElementRef;\r\n\r\n  private renderer = inject(Renderer2);\r\n  private uiService = inject(UIService);\r\n\r\n  // Initialize\r\n  static nextId = 0;\r\n  readonly stateChanges = new Subject<void>();\r\n  private previousNativeValue: any;\r\n  controlType: string = 'file-input';\r\n  focused = false;\r\n  protected fileSize: number;\r\n  \r\n  protected canCapture: boolean = false;\r\n\r\n  private _value: FileInfo = new FileInfo();\r\n  set value(value: FileInfo) {\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  }\r\n  get value() {\r\n    return this._value;\r\n  }\r\n  get size() {\r\n    return this._value && this._value.file.size;\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  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  @Input() fileName: string | null = null;\r\n  maxSizeMb = input<number>(5);\r\n  minSizeMb = input<number>(0);\r\n  isNew = input<boolean>(false);\r\n  canPreview = input<boolean>(false);\r\n  appearance = input<'fill' | 'outline' | null>(this.uiService.appearance);\r\n  accept = input<string>();\r\n  get empty(): boolean {\r\n    return !this._value || !this._value.file;\r\n  }\r\n  get errorState() {\r\n    return this.ngControl.errors != null && this.ngControl.touched;\r\n  }\r\n  @HostBinding() id = `${this.controlType}-${FileInputComponent.nextId++}`;\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  changed = output<FileInfo>();\r\n  download = output();\r\n  preview = output();\r\n\r\n  private propagateChange: (_: any) => void = (_: any) => { };\r\n  private propagateTouched: () => void = () => { };\r\n\r\n\r\n  constructor(\r\n    @Optional() @Self() public ngControl: NgControl) {\r\n    if (this.ngControl != null) {\r\n      this.ngControl.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  async ngAfterViewInit() {\r\n    await this.setupDevices();\r\n  }\r\n\r\n  /**\r\n   * Setup capture devices   \r\n   */\r\n  async setupDevices() {\r\n    this.canCapture = false;\r\n    if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {\r\n      try {\r\n        const stream = await navigator.mediaDevices.getUserMedia({\r\n          video: true\r\n        });\r\n        if (stream) {\r\n          this.canCapture = true;\r\n        }\r\n      } catch { }\r\n    }\r\n    if (!this.placeholder) {\r\n      this.placeholder =\r\n        this.canCapture\r\n          ? \"Seleziona file o acquisisci con fotocamera\"\r\n          : \"Seleziona file\"\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.stateChanges.complete();\r\n  }\r\n\r\n  ngDoCheck() {\r\n    this.updateInputDirtyCheck();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.currentValue != changes.previousValue) {\r\n      this.propagateChange(changes.currentValue);\r\n      this.stateChanges.next();\r\n    }\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  protected updateInputDirtyCheck() {\r\n    const newValue = this._value;\r\n    if (this.previousNativeValue !== newValue) {\r\n      this.previousNativeValue = newValue;\r\n      this.stateChanges.next();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Select a file\r\n   * @param e : event\r\n   */\r\n  protected  selectFile(e: any) {\r\n    if (e.target.files) {\r\n      let f = e.target.files[0];\r\n      this.fileName = f.name;\r\n      this.fileSize = Math.round(f.size / (1024 * 1024));\r\n      let fileInfo = new FileInfo();\r\n      fileInfo.file = f;\r\n      fileInfo.valid =\r\n        (!this.maxSizeMb || this.fileSize <= this.maxSizeMb()) &&\r\n        (!this.minSizeMb || this.fileSize >= this.minSizeMb());\r\n      this.writeValue(fileInfo);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Check if a file has been selected\r\n   */\r\n  protected hasFile(): boolean {\r\n    return this._value && this._value.file;\r\n  }\r\n\r\n  /**\r\n   * Clear file\r\n   */\r\n  protected  clearFile() {\r\n    if (this.hasFile()) {\r\n      this.fileName = null;\r\n      this.fileSize = 0;\r\n      let fi = new FileInfo();\r\n      fi.file = null;\r\n      fi.valid = !this.required\r\n      this.writeValue(fi);\r\n      this.__file.nativeElement.value = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Download\r\n   */\r\n  protected  downloadFile() {\r\n    if (!this.isNew()) this.download.emit(null);\r\n  }\r\n\r\n  /**\r\n * Preview\r\n */\r\n  protected previewFile() {\r\n    if (!this.isNew() && this.canPreview()) this.preview.emit();\r\n  }\r\n}\r\n","<mat-form-field style=\"width:100%\" [appearance]=\"appearance()\">\r\n  <mat-label>{{placeholder}}</mat-label>\r\n  <input type=\"file\" [hidden]=\"true\" [accept]=\"accept()\" (change)=\"selectFile($event)\" #__file />\r\n  <input name=\"_fileName\" #_fileName=\"ngModel\" [(ngModel)]=\"fileName\" [id]=\"id\" matInput readonly [required]=\"required\"\r\n    fileSize [size]=\"fileSize\" [maxSizeMb]=\"maxSizeMb()\" [minSizeMb]=\"minSizeMb()\" [disabled]=\"disabled\" />\r\n  @if (hasFile()) {\r\n  <button type=\"button\" tabindex=\"-1\" mat-icon-button matSuffix aria-label=\"Azzera\" (click)=\"clearFile()\">\r\n    <mat-icon>close</mat-icon>\r\n  </button>\r\n  }\r\n  @if (!disabled) {\r\n  <button type=\"button\" type=\"button\" mat-icon-button matSuffix (click)=\"__file.click()\" aria-label=\"Seleziona file\"\r\n    matTooltip=\"Seleziona\">\r\n    <mat-icon>add</mat-icon>\r\n  </button>\r\n  }\r\n  @if (!isNew() && canPreview()) {\r\n  <button type=\"button\" mat-icon-button matSuffix (click)=\"previewFile()\" aria-label=\"Anteprima\" matTooltip=\"Anteprima\">\r\n    <mat-icon>preview</mat-icon>\r\n  </button>\r\n  }\r\n  @if (!isNew()) {\r\n<button type=\"button\" mat-icon-button matSuffix (click)=\"downloadFile()\" aria-label=\"Scarica file\"\r\n   matTooltip=\"Scarica\">\r\n  <mat-icon>save_alt</mat-icon>\r\n</button>\r\n}\r\n  @if (hasFile() && fileSize > 0) {\r\n<mat-hint align=\"left\">{{fileSize}} MB</mat-hint>\r\n}\r\n  @if (hasFile() && fileSize == 0) {\r\n<mat-hint align=\"left\">\r\n    < 1 MB</mat-hint>\r\n} @if (maxSizeMb()) {\r\n<mat-hint align=\"end\">Massimo {{maxSizeMb()}} MB\r\n  </mat-hint>\r\n}\r\n  @if (_fileName.invalid && !hasFile()) {\r\n<mat-error>Obbligatorio.</mat-error>\r\n}\r\n  @if (_fileName.invalid && hasFile()) {\r\n<mat-error>Dimensione non consentita.</mat-error>\r\n}\r\n</mat-form-field>"]}
258
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/components/file-input/file-input.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/components/file-input/file-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\r\nimport { AfterViewInit, ChangeDetectionStrategy, Component, DoCheck, ElementRef, EventEmitter, HostBinding, Input, OnChanges, OnDestroy, Optional, Renderer2, Self, SimpleChanges, ViewChild, inject, input } from '@angular/core';\r\nimport { ControlValueAccessor, NgControl, FormsModule } from '@angular/forms';\r\nimport { MatFormFieldControl, MatFormFieldModule } from '@angular/material/form-field';\r\nimport { FileInfo, FileSizeValidatorDirective, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { Subject } from 'rxjs';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { UIService } from '@arsedizioni/ars-utils/ui';\r\n\r\n@Component({\r\n    selector: 'file-input',\r\n    templateUrl: './file-input.component.html',\r\n    styleUrls: ['./file-input.component.scss'],\r\n    providers: [{ provide: MatFormFieldControl, useExisting: FileInputComponent }],\r\n    standalone: true,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    imports: [MatFormFieldModule, MatInputModule, FormsModule, FileSizeValidatorDirective,  MatButtonModule, \r\n      MatIconModule, MatTooltipModule]\r\n})\r\nexport class FileInputComponent\r\n  implements\r\n  OnDestroy,\r\n  AfterViewInit,\r\n  DoCheck,\r\n  OnChanges,\r\n  MatFormFieldControl<FileInfo>,\r\n  ControlValueAccessor {\r\n\r\n  @ViewChild('__file') __file!: ElementRef;\r\n\r\n  private renderer = inject(Renderer2);\r\n  private uiService = inject(UIService);\r\n\r\n  // Initialize\r\n  static nextId = 0;\r\n  readonly stateChanges = new Subject<void>();\r\n  private previousNativeValue: any;\r\n  controlType: string = 'file-input';\r\n  focused = false;\r\n  protected fileSize: number;\r\n  \r\n  protected canCapture: boolean = false;\r\n\r\n  private _value: FileInfo = new FileInfo();\r\n  set value(value: FileInfo) {\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  }\r\n  get value() {\r\n    return this._value;\r\n  }\r\n  get size() {\r\n    return this._value && this._value.file.size;\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  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  @Input() fileName: string | null = null;\r\n  maxSizeMb = input<number>(5);\r\n  minSizeMb = input<number>(0);\r\n  isNew = input<boolean>(false);\r\n  canPreview = input<boolean>(false);\r\n  appearance = input<'fill' | 'outline' | null>(this.uiService.appearance);\r\n  accept = input<string>();\r\n  get empty(): boolean {\r\n    return !this._value || !this._value.file;\r\n  }\r\n  get errorState() {\r\n    return this.ngControl.errors != null && this.ngControl.touched;\r\n  }\r\n  @HostBinding() id = `${this.controlType}-${FileInputComponent.nextId++}`;\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  changed = new EventEmitter<FileInfo>();\r\n  download = new EventEmitter();\r\n  preview = new EventEmitter();\r\n\r\n  private propagateChange: (_: any) => void = (_: any) => { };\r\n  private propagateTouched: () => void = () => { };\r\n\r\n\r\n  constructor(\r\n    @Optional() @Self() public ngControl: NgControl) {\r\n    if (this.ngControl != null) {\r\n      this.ngControl.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  async ngAfterViewInit() {\r\n    await this.setupDevices();\r\n  }\r\n\r\n  /**\r\n   * Setup capture devices   \r\n   */\r\n  async setupDevices() {\r\n    this.canCapture = false;\r\n    if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {\r\n      try {\r\n        const stream = await navigator.mediaDevices.getUserMedia({\r\n          video: true\r\n        });\r\n        if (stream) {\r\n          this.canCapture = true;\r\n        }\r\n      } catch { }\r\n    }\r\n    if (!this.placeholder) {\r\n      this.placeholder =\r\n        this.canCapture\r\n          ? \"Seleziona file o acquisisci con fotocamera\"\r\n          : \"Seleziona file\"\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.stateChanges.complete();\r\n  }\r\n\r\n  ngDoCheck() {\r\n    this.updateInputDirtyCheck();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.currentValue != changes.previousValue) {\r\n      this.propagateChange(changes.currentValue);\r\n      this.stateChanges.next();\r\n    }\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  protected updateInputDirtyCheck() {\r\n    const newValue = this._value;\r\n    if (this.previousNativeValue !== newValue) {\r\n      this.previousNativeValue = newValue;\r\n      this.stateChanges.next();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Select a file\r\n   * @param e : event\r\n   */\r\n  protected  selectFile(e: any) {\r\n    if (e.target.files) {\r\n      let f = e.target.files[0];\r\n      this.fileName = f.name;\r\n      this.fileSize = Math.round(f.size / (1024 * 1024));\r\n      let fileInfo = new FileInfo();\r\n      fileInfo.file = f;\r\n      fileInfo.valid =\r\n        (!this.maxSizeMb || this.fileSize <= this.maxSizeMb()) &&\r\n        (!this.minSizeMb || this.fileSize >= this.minSizeMb());\r\n      this.writeValue(fileInfo);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Check if a file has been selected\r\n   */\r\n  protected hasFile(): boolean {\r\n    return this._value && this._value.file;\r\n  }\r\n\r\n  /**\r\n   * Clear file\r\n   */\r\n  protected  clearFile() {\r\n    if (this.hasFile()) {\r\n      this.fileName = null;\r\n      this.fileSize = 0;\r\n      let fi = new FileInfo();\r\n      fi.file = null;\r\n      fi.valid = !this.required\r\n      this.writeValue(fi);\r\n      this.__file.nativeElement.value = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Download\r\n   */\r\n  protected  downloadFile() {\r\n    if (!this.isNew()) this.download.emit();\r\n  }\r\n\r\n  /**\r\n * Preview\r\n */\r\n  protected previewFile() {\r\n    if (!this.isNew() && this.canPreview()) this.preview.emit();\r\n  }\r\n}\r\n","<mat-form-field style=\"width:100%\" [appearance]=\"appearance()\">\r\n  <mat-label>{{placeholder}}</mat-label>\r\n  <input type=\"file\" [hidden]=\"true\" [accept]=\"accept()\" (change)=\"selectFile($event)\" #__file />\r\n  <input name=\"_fileName\" #_fileName=\"ngModel\" [(ngModel)]=\"fileName\" [id]=\"id\" matInput readonly [required]=\"required\"\r\n    fileSize [size]=\"fileSize\" [maxSizeMb]=\"maxSizeMb()\" [minSizeMb]=\"minSizeMb()\" [disabled]=\"disabled\" />\r\n  @if (hasFile()) {\r\n  <button type=\"button\" tabindex=\"-1\" mat-icon-button matSuffix aria-label=\"Azzera\" (click)=\"clearFile()\">\r\n    <mat-icon>close</mat-icon>\r\n  </button>\r\n  }\r\n  @if (!disabled) {\r\n  <button type=\"button\" type=\"button\" mat-icon-button matSuffix (click)=\"__file.click()\" aria-label=\"Seleziona file\"\r\n    matTooltip=\"Seleziona\">\r\n    <mat-icon>add</mat-icon>\r\n  </button>\r\n  }\r\n  @if (!isNew() && canPreview()) {\r\n  <button type=\"button\" mat-icon-button matSuffix (click)=\"previewFile()\" aria-label=\"Anteprima\" matTooltip=\"Anteprima\">\r\n    <mat-icon>preview</mat-icon>\r\n  </button>\r\n  }\r\n  @if (!isNew()) {\r\n<button type=\"button\" mat-icon-button matSuffix (click)=\"downloadFile()\" aria-label=\"Scarica file\"\r\n   matTooltip=\"Scarica\">\r\n  <mat-icon>save_alt</mat-icon>\r\n</button>\r\n}\r\n  @if (hasFile() && fileSize > 0) {\r\n<mat-hint align=\"left\">{{fileSize}} MB</mat-hint>\r\n}\r\n  @if (hasFile() && fileSize == 0) {\r\n<mat-hint align=\"left\">\r\n    < 1 MB</mat-hint>\r\n} @if (maxSizeMb()) {\r\n<mat-hint align=\"end\">Massimo {{maxSizeMb()}} MB\r\n  </mat-hint>\r\n}\r\n  @if (_fileName.invalid && !hasFile()) {\r\n<mat-error>Obbligatorio.</mat-error>\r\n}\r\n  @if (_fileName.invalid && hasFile()) {\r\n<mat-error>Dimensione non consentita.</mat-error>\r\n}\r\n</mat-form-field>"]}