ng-inail-common 2.0.21 → 2.0.25

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.
@@ -53,6 +53,7 @@ export class FormElementComponent extends ResponsiveElementComponent {
53
53
  this.error = undefined;
54
54
  this.errorChange.emit(undefined);
55
55
  }
56
+ this.formElementCdr.detectChanges();
56
57
  });
57
58
  }
58
59
  registerOnChange(fn) {
@@ -111,4 +112,4 @@ FormElementComponent.propDecorators = {
111
112
  popoverHeader: [{ type: Input }],
112
113
  popoverContent: [{ type: Input }]
113
114
  };
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-element.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-inail-common/src/lib/components/core/form/form-element.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewEncapsulation} from '@angular/core';\nimport {Observable} from \"rxjs\";\nimport {ResponsiveElementComponent, ResponsiveElementComponentChanges} from \"../responsive-element.component\";\nimport {isNotBlankOrNull} from \"../../../utils/common.operators\";\nimport {BooleanChange, CHANGE_DETECTION_STRATEGY, ObservableChange, StringChange} from \"../base.component\";\n\n@Component({\n  selector: 'inail-form-element',\n  template: '',\n  styles: [],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class FormElementComponent extends ResponsiveElementComponent implements OnChanges, OnInit {\n\n  onChange: (val: any) => void\n  onTouched: () => void;\n\n  @Input()\n  label: NonNullable<string>;\n  @Input()\n  title: string;\n  @Input()\n  name: string;\n  @Input()\n  labelTitle: string;\n  @Input()\n  labelClass: string;\n  @Input()\n  inputClass: string;\n  @Input()\n  required: boolean = false;\n  @Input()\n  requiredSimbol: string = '*';\n  @Input()\n  requiredSimbolPosition: 'left' | 'right' = 'left';\n  @Input()\n  disabled: boolean = false;\n  @Input()\n  readonly: boolean = false;\n  @Input()\n  hasError: boolean = false;\n  @Output()\n  hasErrorChange = new EventEmitter<boolean>();\n  @Input()\n  hiddenLabel: boolean = false;\n  @Input()\n  error: string;\n  @Input()\n  description: string;\n  @Output()\n  errorChange = new EventEmitter<string>();\n  @Output()\n  enterUp = new EventEmitter();\n  @Input()\n  focus: Observable<boolean | void>;\n  @Input()\n  popover: boolean = false;\n  @Input()\n  popoverButtonIcon: string;\n  @Input()\n  popoverButtonTitle: string;\n  @Input()\n  popoverHeader: string;\n  @Input()\n  popoverContent: string;\n\n  getLabel = () => `${(this.required && this.requiredSimbolPosition === 'left') ? `${this.requiredSimbol} ` : ''}${this.label}${(this.required && this.requiredSimbolPosition === 'right') ? ` ${this.requiredSimbol}` : ''}`\n\n  isThereError = (): boolean => this.hasError || isNotBlankOrNull(this.error);\n\n  showError = (): boolean => this.isThereError() && isNotBlankOrNull(this.error);\n\n  getAriaDescribedBy = (): string => this.showError() || isNotBlankOrNull(this.description) ? `${this.id}-description` : undefined;\n\n  // showPopover = (): boolean => isNotBlankOrNull(this.popoverHeader) || isNotBlankOrNull(this.popoverContent);\n  showPopover = (): boolean => this.popover === true;\n\n  constructor(private formElementCdr: ChangeDetectorRef) {\n    super(formElementCdr);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n\n    super.ngOnChanges(changes);\n    this.title = this.getNotBlankValue(this.title);\n    this.name = this.getNotBlankValue(this.name);\n    this.labelTitle = this.getNotBlankValue(this.labelTitle);\n    this.popoverButtonTitle = this.getNotBlankValue(this.popoverButtonTitle);\n  }\n\n  ngOnInit() {\n    super.ngOnInit();\n    this.logPrefix = `${this.logPrefix}[${this.label}]`;\n  }\n\n  setDescError(s: string) {\n\n    this.error = s;\n    this.formElementCdr.detectChanges();\n  }\n\n  setHasError(b: boolean) {\n\n    this.hasError = b;\n    this.formElementCdr.detectChanges();\n  }\n\n  cleanError() {\n\n    setTimeout(() => {\n\n      if (this.hasError) {\n\n        this.hasError = false;\n        this.hasErrorChange.emit(false);\n      }\n\n      if (this.error) {\n\n        this.error = undefined;\n        this.errorChange.emit(undefined);\n      }\n    })\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n\n    this.emitDebug(`registerOnChange`);\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n\n    this.emitDebug(`registerOnTouched`);\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n\n    this.emitDebug(`setDisabledState: ${isDisabled}`);\n    this.disabled = isDisabled;\n    this.formElementCdr.detectChanges();\n  }\n\n  onBlur() {\n    if (this.onTouched) {\n      this.onTouched();\n    }\n  }\n}\n\nexport interface FormElementComponentChanges extends ResponsiveElementComponentChanges {\n\n  label: StringChange,\n  title: StringChange,\n  name: StringChange,\n  labelTitle: StringChange,\n  labelClass: StringChange,\n  inputClass: StringChange,\n  required: BooleanChange,\n  requiredSimbol: StringChange,\n  requiredSimbolPosition: StringChange,\n  disabled: BooleanChange,\n  readonly: BooleanChange,\n  hasError: BooleanChange,\n  hiddenLabel: BooleanChange,\n  error: StringChange,\n  focus: ObservableChange\n}\n"]}
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-element.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-inail-common/src/lib/components/core/form/form-element.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewEncapsulation} from '@angular/core';\nimport {Observable} from \"rxjs\";\nimport {ResponsiveElementComponent, ResponsiveElementComponentChanges} from \"../responsive-element.component\";\nimport {isNotBlankOrNull} from \"../../../utils/common.operators\";\nimport {BooleanChange, CHANGE_DETECTION_STRATEGY, ObservableChange, StringChange} from \"../base.component\";\n\n@Component({\n  selector: 'inail-form-element',\n  template: '',\n  styles: [],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class FormElementComponent extends ResponsiveElementComponent implements OnChanges, OnInit {\n\n  onChange: (val: any) => void\n  onTouched: () => void;\n\n  @Input()\n  label: NonNullable<string>;\n  @Input()\n  title: string;\n  @Input()\n  name: string;\n  @Input()\n  labelTitle: string;\n  @Input()\n  labelClass: string;\n  @Input()\n  inputClass: string;\n  @Input()\n  required: boolean = false;\n  @Input()\n  requiredSimbol: string = '*';\n  @Input()\n  requiredSimbolPosition: 'left' | 'right' = 'left';\n  @Input()\n  disabled: boolean = false;\n  @Input()\n  readonly: boolean = false;\n  @Input()\n  hasError: boolean = false;\n  @Output()\n  hasErrorChange = new EventEmitter<boolean>();\n  @Input()\n  hiddenLabel: boolean = false;\n  @Input()\n  error: string;\n  @Input()\n  description: string;\n  @Output()\n  errorChange = new EventEmitter<string>();\n  @Output()\n  enterUp = new EventEmitter();\n  @Input()\n  focus: Observable<boolean | void>;\n  @Input()\n  popover: boolean = false;\n  @Input()\n  popoverButtonIcon: string;\n  @Input()\n  popoverButtonTitle: string;\n  @Input()\n  popoverHeader: string;\n  @Input()\n  popoverContent: string;\n\n  getLabel = () => `${(this.required && this.requiredSimbolPosition === 'left') ? `${this.requiredSimbol} ` : ''}${this.label}${(this.required && this.requiredSimbolPosition === 'right') ? ` ${this.requiredSimbol}` : ''}`\n\n  isThereError = (): boolean => this.hasError || isNotBlankOrNull(this.error);\n\n  showError = (): boolean => this.isThereError() && isNotBlankOrNull(this.error);\n\n  getAriaDescribedBy = (): string => this.showError() || isNotBlankOrNull(this.description) ? `${this.id}-description` : undefined;\n\n  // showPopover = (): boolean => isNotBlankOrNull(this.popoverHeader) || isNotBlankOrNull(this.popoverContent);\n  showPopover = (): boolean => this.popover === true;\n\n  constructor(private formElementCdr: ChangeDetectorRef) {\n    super(formElementCdr);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n\n    super.ngOnChanges(changes);\n    this.title = this.getNotBlankValue(this.title);\n    this.name = this.getNotBlankValue(this.name);\n    this.labelTitle = this.getNotBlankValue(this.labelTitle);\n    this.popoverButtonTitle = this.getNotBlankValue(this.popoverButtonTitle);\n  }\n\n  ngOnInit() {\n    super.ngOnInit();\n    this.logPrefix = `${this.logPrefix}[${this.label}]`;\n  }\n\n  setDescError(s: string) {\n\n    this.error = s;\n    this.formElementCdr.detectChanges();\n  }\n\n  setHasError(b: boolean) {\n\n    this.hasError = b;\n    this.formElementCdr.detectChanges();\n  }\n\n  cleanError() {\n\n    setTimeout(() => {\n\n      if (this.hasError) {\n\n        this.hasError = false;\n        this.hasErrorChange.emit(false);\n      }\n\n      if (this.error) {\n\n        this.error = undefined;\n        this.errorChange.emit(undefined);\n      }\n\n      this.formElementCdr.detectChanges();\n    })\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n\n    this.emitDebug(`registerOnChange`);\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n\n    this.emitDebug(`registerOnTouched`);\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n\n    this.emitDebug(`setDisabledState: ${isDisabled}`);\n    this.disabled = isDisabled;\n    this.formElementCdr.detectChanges();\n  }\n\n  onBlur() {\n    if (this.onTouched) {\n      this.onTouched();\n    }\n  }\n}\n\nexport interface FormElementComponentChanges extends ResponsiveElementComponentChanges {\n\n  label: StringChange,\n  title: StringChange,\n  name: StringChange,\n  labelTitle: StringChange,\n  labelClass: StringChange,\n  inputClass: StringChange,\n  required: BooleanChange,\n  requiredSimbol: StringChange,\n  requiredSimbolPosition: StringChange,\n  disabled: BooleanChange,\n  readonly: BooleanChange,\n  hasError: BooleanChange,\n  hiddenLabel: BooleanChange,\n  error: StringChange,\n  focus: ObservableChange\n}\n"]}
@@ -43,11 +43,13 @@ export class InputFileComponent extends FormElementComponent {
43
43
  if (!this.addButton) {
44
44
  this.fileChange.emit(this.fileModel);
45
45
  }
46
+ this.cleanError();
46
47
  this.cdr.detectChanges();
47
48
  }
48
49
  reset() {
49
50
  this.fileModel = undefined;
50
51
  this.fileChange.emit(undefined);
52
+ this.cleanError();
51
53
  this.cdr.detectChanges();
52
54
  }
53
55
  }
@@ -71,4 +73,4 @@ InputFileComponent.propDecorators = {
71
73
  fileChange: [{ type: Output }],
72
74
  inputText: [{ type: ViewChild, args: ['inputText', { static: true },] }]
73
75
  };
74
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZmlsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1pbmFpbC1jb21tb24vc3JjL2xpYi9jb21wb25lbnRzL2NvcmUvZm9ybS9pbnB1dC1maWxlL2lucHV0LWZpbGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBZ0IsaUJBQWlCLEVBQUUsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQWdDLE1BQU0sRUFBaUIsU0FBUyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzNLLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQy9ELE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQU81RCxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsb0JBQW9CO0lBc0IxRCxZQUFvQixHQUFzQjtRQUN4QyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFETyxRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQWpCMUMscUJBQWdCLEdBQVcsZ0JBQWdCLENBQUM7UUFFNUMsa0JBQWEsR0FBVyxVQUFVLENBQUM7UUFFbkMsaUJBQVksR0FBWSxJQUFJLENBQUM7UUFFN0IsY0FBUyxHQUFZLElBQUksQ0FBQztRQUsxQixlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQVFwQyxJQUFJLENBQUMsU0FBUyxHQUFHLG9CQUFvQixDQUFDO1FBQ3RDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNoQixDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBRWhDLEtBQUssQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFM0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRTNELElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELFFBQVE7UUFFTixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFakIsSUFBSSxDQUFDLFNBQVMsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDO1FBQzVDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBRS9CLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUVkLElBQUksQ0FBQyxJQUFJLENBQ1AsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFlLEVBQUUsRUFBRTtnQkFFdkMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsQ0FBQztnQkFDL0IsUUFBUSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1lBQ2pELENBQUMsQ0FBQyxDQUNILENBQUM7U0FDSDtJQUNILENBQUM7SUFFRCxlQUFlO0lBRWYsQ0FBQztJQUVELFdBQVc7UUFFVCxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVELFlBQVk7UUFDVixRQUFRLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUMzQyxDQUFDO0lBRUQsV0FBVyxDQUFDLE1BQWE7UUFFdkIsYUFBYTtRQUNiLElBQUksQ0FBQyxTQUFTLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLElBQUksTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFFL0QsSUFBRyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1NBQ3RDO1FBRUQsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRUQsS0FBSztRQUVILElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO1FBQzNCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQzs7O1lBM0ZGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsa0JBQWtCO2dCQUM1QiwyL0dBQTBDOzthQUUzQzs7O1lBUnNCLGlCQUFpQjs7OzBCQVdyQyxLQUFLOytCQUVMLEtBQUs7NEJBRUwsS0FBSzsyQkFFTCxLQUFLO3dCQUVMLEtBQUs7cUJBR0wsS0FBSzt5QkFFTCxNQUFNO3dCQUlOLFNBQVMsU0FBQyxXQUFXLEVBQUUsRUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBZnRlclZpZXdJbml0LCBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkNoYW5nZXMsIE9uRGVzdHJveSwgT25Jbml0LCBPdXRwdXQsIFNpbXBsZUNoYW5nZXMsIFZpZXdDaGlsZH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Zvcm1FbGVtZW50Q29tcG9uZW50fSBmcm9tIFwiLi4vZm9ybS1lbGVtZW50LmNvbXBvbmVudFwiO1xuaW1wb3J0IHtzZXRGb2N1c30gZnJvbSBcIi4uLy4uLy4uLy4uL3V0aWxzL2NvbW1vbi5vcGVyYXRvcnNcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaW5haWwtaW5wdXQtZmlsZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9pbnB1dC1maWxlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vaW5wdXQtZmlsZS5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgSW5wdXRGaWxlQ29tcG9uZW50IGV4dGVuZHMgRm9ybUVsZW1lbnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcywgQWZ0ZXJWaWV3SW5pdCwgT25EZXN0cm95IHtcblxuICBASW5wdXQoKVxuICBwbGFjZWhvbGRlcjogc3RyaW5nO1xuICBASW5wdXQoKVxuICBjaG9vc2VCdXR0b25UZXh0OiBzdHJpbmcgPSAnU2NlZ2xpIGlsIGZpbGUnO1xuICBASW5wdXQoKVxuICBhZGRCdXR0b25UZXh0OiBzdHJpbmcgPSAnQWdnaXVuZ2knO1xuICBASW5wdXQoKVxuICBjaG9vc2VCdXR0b246IGJvb2xlYW4gPSB0cnVlO1xuICBASW5wdXQoKVxuICBhZGRCdXR0b246IGJvb2xlYW4gPSB0cnVlO1xuICAvKiogRXN0ZW5zaW9uaSBhY2NldHRhdGUgc2VwYXJhdGUgZGEgdmlyZ29sYSAoZXNlbXBpbzogXCIucGRmLCAudHh0LCAuZG9jXCIpICovXG4gIEBJbnB1dCgpXG4gIGFjY2VwdDogc3RyaW5nO1xuICBAT3V0cHV0KClcbiAgZmlsZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8RmlsZT4oKTtcbiAgZmlsZU1vZGVsOiBGaWxlO1xuXG4gIEBWaWV3Q2hpbGQoJ2lucHV0VGV4dCcsIHtzdGF0aWM6IHRydWV9KVxuICBpbnB1dFRleHQ6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+O1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xuICAgIHN1cGVyKGNkcik7XG4gICAgdGhpcy5sb2dQcmVmaXggPSBgW2luYWlsLWlucHV0LWZpbGVdYDtcbiAgICB0aGlzLmRldGFjaCgpO1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuXG4gICAgc3VwZXIubmdPbkNoYW5nZXMoY2hhbmdlcyk7XG5cbiAgICB0aGlzLnBsYWNlaG9sZGVyID0gdGhpcy5nZXROb3RCbGFua1ZhbHVlKHRoaXMucGxhY2Vob2xkZXIpO1xuXG4gICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICB9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG5cbiAgICBzdXBlci5uZ09uSW5pdCgpO1xuXG4gICAgdGhpcy5lbWl0RGVidWcoYEBWaWV3Q2hpbGQoJ2Zvcm1Db250cm9sJylgKTtcbiAgICB0aGlzLmVtaXREZWJ1Zyh0aGlzLmlucHV0VGV4dCk7XG5cbiAgICBpZiAodGhpcy5mb2N1cykge1xuXG4gICAgICB0aGlzLnB1c2goXG4gICAgICAgIHRoaXMuZm9jdXMuc3Vic2NyaWJlKChzY3JvbGw6IGJvb2xlYW4pID0+IHtcblxuICAgICAgICAgIHRoaXMuZW1pdERlYnVnKGBDYXRjaCBmb2N1cyFgKTtcbiAgICAgICAgICBzZXRGb2N1cyh0aGlzLmlucHV0VGV4dC5uYXRpdmVFbGVtZW50LCBzY3JvbGwpO1xuICAgICAgICB9KVxuICAgICAgKTtcbiAgICB9XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG5cbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuXG4gICAgc3VwZXIubmdPbkRlc3Ryb3koKTtcbiAgfVxuXG4gIHByb21wdFVwbG9hZCgpIHtcbiAgICBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCh0aGlzLmlkKS5jbGljaygpO1xuICB9XG5cbiAgY2hhbmdlTW9kZWwoJGV2ZW50OiBFdmVudCkge1xuXG4gICAgLy8gQHRzLWlnbm9yZVxuICAgIHRoaXMuZmlsZU1vZGVsID0gJGV2ZW50LnRhcmdldC5maWxlcyAmJiAkZXZlbnQudGFyZ2V0LmZpbGVzWzBdO1xuXG4gICAgaWYoIXRoaXMuYWRkQnV0dG9uKSB7XG4gICAgICB0aGlzLmZpbGVDaGFuZ2UuZW1pdCh0aGlzLmZpbGVNb2RlbCk7XG4gICAgfVxuXG4gICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICB9XG5cbiAgcmVzZXQoKSB7XG5cbiAgICB0aGlzLmZpbGVNb2RlbCA9IHVuZGVmaW5lZDtcbiAgICB0aGlzLmZpbGVDaGFuZ2UuZW1pdCh1bmRlZmluZWQpO1xuICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgfVxufVxuIl19
76
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZmlsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1pbmFpbC1jb21tb24vc3JjL2xpYi9jb21wb25lbnRzL2NvcmUvZm9ybS9pbnB1dC1maWxlL2lucHV0LWZpbGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBZ0IsaUJBQWlCLEVBQUUsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQWdDLE1BQU0sRUFBaUIsU0FBUyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzNLLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQy9ELE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQU81RCxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsb0JBQW9CO0lBc0IxRCxZQUFvQixHQUFzQjtRQUN4QyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFETyxRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQWpCMUMscUJBQWdCLEdBQVcsZ0JBQWdCLENBQUM7UUFFNUMsa0JBQWEsR0FBVyxVQUFVLENBQUM7UUFFbkMsaUJBQVksR0FBWSxJQUFJLENBQUM7UUFFN0IsY0FBUyxHQUFZLElBQUksQ0FBQztRQUsxQixlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQVFwQyxJQUFJLENBQUMsU0FBUyxHQUFHLG9CQUFvQixDQUFDO1FBQ3RDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNoQixDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBRWhDLEtBQUssQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFM0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRTNELElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELFFBQVE7UUFFTixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFakIsSUFBSSxDQUFDLFNBQVMsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDO1FBQzVDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBRS9CLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUVkLElBQUksQ0FBQyxJQUFJLENBQ1AsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFlLEVBQUUsRUFBRTtnQkFFdkMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsQ0FBQztnQkFDL0IsUUFBUSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1lBQ2pELENBQUMsQ0FBQyxDQUNILENBQUM7U0FDSDtJQUNILENBQUM7SUFFRCxlQUFlO0lBRWYsQ0FBQztJQUVELFdBQVc7UUFFVCxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVELFlBQVk7UUFDVixRQUFRLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUMzQyxDQUFDO0lBRUQsV0FBVyxDQUFDLE1BQWE7UUFFdkIsYUFBYTtRQUNiLElBQUksQ0FBQyxTQUFTLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLElBQUksTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFFL0QsSUFBRyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1NBQ3RDO1FBRUQsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELEtBQUs7UUFFSCxJQUFJLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQztRQUMzQixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNoQyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDbEIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUMzQixDQUFDOzs7WUE3RkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxrQkFBa0I7Z0JBQzVCLDIvR0FBMEM7O2FBRTNDOzs7WUFSc0IsaUJBQWlCOzs7MEJBV3JDLEtBQUs7K0JBRUwsS0FBSzs0QkFFTCxLQUFLOzJCQUVMLEtBQUs7d0JBRUwsS0FBSztxQkFHTCxLQUFLO3lCQUVMLE1BQU07d0JBSU4sU0FBUyxTQUFDLFdBQVcsRUFBRSxFQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0FmdGVyVmlld0luaXQsIENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uQ2hhbmdlcywgT25EZXN0cm95LCBPbkluaXQsIE91dHB1dCwgU2ltcGxlQ2hhbmdlcywgVmlld0NoaWxkfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Rm9ybUVsZW1lbnRDb21wb25lbnR9IGZyb20gXCIuLi9mb3JtLWVsZW1lbnQuY29tcG9uZW50XCI7XG5pbXBvcnQge3NldEZvY3VzfSBmcm9tIFwiLi4vLi4vLi4vLi4vdXRpbHMvY29tbW9uLm9wZXJhdG9yc1wiO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdpbmFpbC1pbnB1dC1maWxlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2lucHV0LWZpbGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9pbnB1dC1maWxlLmNvbXBvbmVudC5jc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBJbnB1dEZpbGVDb21wb25lbnQgZXh0ZW5kcyBGb3JtRWxlbWVudENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzLCBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xuXG4gIEBJbnB1dCgpXG4gIHBsYWNlaG9sZGVyOiBzdHJpbmc7XG4gIEBJbnB1dCgpXG4gIGNob29zZUJ1dHRvblRleHQ6IHN0cmluZyA9ICdTY2VnbGkgaWwgZmlsZSc7XG4gIEBJbnB1dCgpXG4gIGFkZEJ1dHRvblRleHQ6IHN0cmluZyA9ICdBZ2dpdW5naSc7XG4gIEBJbnB1dCgpXG4gIGNob29zZUJ1dHRvbjogYm9vbGVhbiA9IHRydWU7XG4gIEBJbnB1dCgpXG4gIGFkZEJ1dHRvbjogYm9vbGVhbiA9IHRydWU7XG4gIC8qKiBFc3RlbnNpb25pIGFjY2V0dGF0ZSBzZXBhcmF0ZSBkYSB2aXJnb2xhIChlc2VtcGlvOiBcIi5wZGYsIC50eHQsIC5kb2NcIikgKi9cbiAgQElucHV0KClcbiAgYWNjZXB0OiBzdHJpbmc7XG4gIEBPdXRwdXQoKVxuICBmaWxlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxGaWxlPigpO1xuICBmaWxlTW9kZWw6IEZpbGU7XG5cbiAgQFZpZXdDaGlsZCgnaW5wdXRUZXh0Jywge3N0YXRpYzogdHJ1ZX0pXG4gIGlucHV0VGV4dDogRWxlbWVudFJlZjxIVE1MRWxlbWVudD47XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7XG4gICAgc3VwZXIoY2RyKTtcbiAgICB0aGlzLmxvZ1ByZWZpeCA9IGBbaW5haWwtaW5wdXQtZmlsZV1gO1xuICAgIHRoaXMuZGV0YWNoKCk7XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG5cbiAgICBzdXBlci5uZ09uQ2hhbmdlcyhjaGFuZ2VzKTtcblxuICAgIHRoaXMucGxhY2Vob2xkZXIgPSB0aGlzLmdldE5vdEJsYW5rVmFsdWUodGhpcy5wbGFjZWhvbGRlcik7XG5cbiAgICB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XG4gIH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcblxuICAgIHN1cGVyLm5nT25Jbml0KCk7XG5cbiAgICB0aGlzLmVtaXREZWJ1ZyhgQFZpZXdDaGlsZCgnZm9ybUNvbnRyb2wnKWApO1xuICAgIHRoaXMuZW1pdERlYnVnKHRoaXMuaW5wdXRUZXh0KTtcblxuICAgIGlmICh0aGlzLmZvY3VzKSB7XG5cbiAgICAgIHRoaXMucHVzaChcbiAgICAgICAgdGhpcy5mb2N1cy5zdWJzY3JpYmUoKHNjcm9sbDogYm9vbGVhbikgPT4ge1xuXG4gICAgICAgICAgdGhpcy5lbWl0RGVidWcoYENhdGNoIGZvY3VzIWApO1xuICAgICAgICAgIHNldEZvY3VzKHRoaXMuaW5wdXRUZXh0Lm5hdGl2ZUVsZW1lbnQsIHNjcm9sbCk7XG4gICAgICAgIH0pXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcblxuICB9XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG5cbiAgICBzdXBlci5uZ09uRGVzdHJveSgpO1xuICB9XG5cbiAgcHJvbXB0VXBsb2FkKCkge1xuICAgIGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKHRoaXMuaWQpLmNsaWNrKCk7XG4gIH1cblxuICBjaGFuZ2VNb2RlbCgkZXZlbnQ6IEV2ZW50KSB7XG5cbiAgICAvLyBAdHMtaWdub3JlXG4gICAgdGhpcy5maWxlTW9kZWwgPSAkZXZlbnQudGFyZ2V0LmZpbGVzICYmICRldmVudC50YXJnZXQuZmlsZXNbMF07XG5cbiAgICBpZighdGhpcy5hZGRCdXR0b24pIHtcbiAgICAgIHRoaXMuZmlsZUNoYW5nZS5lbWl0KHRoaXMuZmlsZU1vZGVsKTtcbiAgICB9XG5cbiAgICB0aGlzLmNsZWFuRXJyb3IoKTtcbiAgICB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XG4gIH1cblxuICByZXNldCgpIHtcblxuICAgIHRoaXMuZmlsZU1vZGVsID0gdW5kZWZpbmVkO1xuICAgIHRoaXMuZmlsZUNoYW5nZS5lbWl0KHVuZGVmaW5lZCk7XG4gICAgdGhpcy5jbGVhbkVycm9yKCk7XG4gICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,121 @@
1
+ import { ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { FormElementComponent } from "../form-element.component";
3
+ import { CHANGE_DETECTION_STRATEGY } from "../../base.component";
4
+ import { setFocus } from "../../../../utils/common.operators";
5
+ export class MultiSelectComponent extends FormElementComponent {
6
+ constructor(cdr) {
7
+ super(cdr);
8
+ this.cdr = cdr;
9
+ this.options = [];
10
+ this.values = [];
11
+ this.valuesChange = new EventEmitter();
12
+ this.placeholder = '- seleziona opzioni -';
13
+ this.toggle = () => window['$'](this.formControlElement.nativeElement).dropdown('toggle');
14
+ this.isExpanded = () => this.formControlElement.nativeElement.getAttribute('aria-expanded') === 'true';
15
+ this.hasFormControlFocus = () => this.formControlElement.nativeElement.matches(':focus');
16
+ this.hasDropdownMenuFocus = () => this.dropdownMenu.nativeElement.matches(':focus-within');
17
+ this.isChecked = (value) => this.values.some(v => v === value);
18
+ this.getInputTextValue = () => this.options.filter(opt => this.isChecked(opt.value)).map(opt => opt.label).join(', ');
19
+ this.pushValue = (value) => this.values = this.options.filter(opt => opt.value === value || this.isChecked(opt.value)).map(opt => opt.value);
20
+ this.isFocusOut = () => window['$'](this.multiSelect.nativeElement).find(document.activeElement).length == 0;
21
+ this.logPrefix = `[inail-multi-select]`;
22
+ this.detach();
23
+ }
24
+ ngOnChanges(changes) {
25
+ var _a, _b, _c;
26
+ super.ngOnChanges(changes);
27
+ if ((((_a = changes === null || changes === void 0 ? void 0 : changes.options) === null || _a === void 0 ? void 0 : _a.currentValue) || ((_b = changes === null || changes === void 0 ? void 0 : changes.sort) === null || _b === void 0 ? void 0 : _b.currentValue)) && this.sort) {
28
+ let direction = "ASC" == this.sort.toUpperCase() ? 1 : "DESC" == this.sort.toUpperCase() ? -1 : 0;
29
+ if (direction != 0 && this.options != undefined) {
30
+ this.options.sort((a, b) => a.label < b.label ? -direction : a.label > b.label ? direction : 0);
31
+ }
32
+ }
33
+ if ((_c = changes === null || changes === void 0 ? void 0 : changes.options) === null || _c === void 0 ? void 0 : _c.currentValue) {
34
+ this.inputTextValue = this.getInputTextValue();
35
+ }
36
+ this.cdr.detectChanges();
37
+ }
38
+ ngOnInit() {
39
+ super.ngOnInit();
40
+ this.emitDebug(`@ViewChild('formControl')`);
41
+ this.emitDebug(this.formControlElement);
42
+ if (this.focus) {
43
+ this.push(this.focus.subscribe((scroll) => {
44
+ this.emitDebug(`Catch focus!`);
45
+ setFocus(this.formControlElement.nativeElement, scroll);
46
+ }));
47
+ }
48
+ }
49
+ ngAfterViewInit() {
50
+ }
51
+ ngOnDestroy() {
52
+ super.ngOnDestroy();
53
+ }
54
+ onKeypress($event) {
55
+ $event.preventDefault();
56
+ }
57
+ onFocusIn() {
58
+ setTimeout(() => {
59
+ this.showDropdownMenu();
60
+ }, 250);
61
+ }
62
+ onFocusOut() {
63
+ setTimeout(() => {
64
+ if (this.isFocusOut()) {
65
+ this.closeDropdownMenu();
66
+ }
67
+ }, 150);
68
+ }
69
+ showDropdownMenu() {
70
+ setTimeout(() => {
71
+ if (!this.isExpanded()) {
72
+ this.toggle();
73
+ }
74
+ });
75
+ }
76
+ closeDropdownMenu() {
77
+ setTimeout(() => {
78
+ if (this.isExpanded()) {
79
+ this.toggle();
80
+ }
81
+ });
82
+ }
83
+ onCheck(cb) {
84
+ if (!cb.firstChange) {
85
+ if (cb.checked && !this.isChecked(cb.value)) {
86
+ this.pushValue(cb.value);
87
+ this.cleanError();
88
+ }
89
+ else if (!cb.checked && this.isChecked(cb.value)) {
90
+ this.values = this.values.filter(value => value != cb.value);
91
+ this.cleanError();
92
+ }
93
+ this.valuesChange.emit(this.values);
94
+ this.inputTextValue = this.getInputTextValue();
95
+ this.cdr.detectChanges();
96
+ }
97
+ }
98
+ }
99
+ MultiSelectComponent.decorators = [
100
+ { type: Component, args: [{
101
+ selector: 'inail-multi-select',
102
+ template: "<div #multiSelect\n class=\"form-group {{getResponsiveClass()}} noPaddingLeft {{class}} inail-multi-select\"\n [ngClass]=\"{'has-error': isThereError()}\">\n <label *ngIf=\"label\"\n class=\"control-label {{labelClass}}\"\n [ngClass]=\"{'sr-only': hiddenLabel}\"\n [attr.title]=\"labelTitle\"\n [for]=\"id\"\n [innerHTML]=\"getLabel()\"></label>\n <span *ngIf=\"showPopover()\"\n [style.padding-left.px]=\"5\">\n <inail-popover [iconClass]=\"popoverButtonIcon\"\n [buttonTitle]=\"popoverButtonTitle\"\n [header]=\"popoverHeader\"\n [content]=\"popoverContent\">\n </inail-popover>\n </span>\n <div class=\"form-control-wrapper\"\n [ngClass]=\"{'no-label' : hiddenLabel || !label}\">\n <input #formControl\n type=\"text\"\n [id]=\"id\"\n class=\"form-control dropdown-toggle {{inputClass}}\"\n data-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\"\n [ngClass]=\"{'disabled': disabled}\"\n [attr.name]=\"name\"\n [attr.title]=\"title\"\n [disabled]=\"disabled\"\n [readonly]=\"true\"\n [attr.placeholder]=\"placeholder\"\n [attr.aria-required]=\"required === true ? true : undefined\"\n [attr.aria-invalid]=\"isThereError() === true ? true : undefined\"\n [attr.aria-describedBy]=\"getAriaDescribedBy()\"\n (blur)=\"onBlur()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut()\"\n (keypress)=\"onKeypress($event)\"\n (keyup.enter)=\"enterUp.emit()\"\n [ngModel]=\"inputTextValue\">\n <div #dropdownMenu\n class=\"dropdown-menu\"\n (focusout)=\"onFocusOut()\"\n [attr.aria-labelledby]=\"id\">\n <ng-container *ngFor=\"let opt of options\">\n <div *ngIf=\"opt.beforeDivider\" class=\"divider\"></div>\n <div class=\"row\" [attr.tabIndex]=\"opt.disabled ? 0 : undefined\">\n <inail-checkbox [label]=\"opt.label\"\n [value]=\"opt.value\"\n [title]=\"opt.title\"\n [checked]=\"isChecked(opt.value)\"\n [disabled]=\"opt.disabled\"\n (stateChange)=\"onCheck($event)\">\n </inail-checkbox>\n </div>\n <div *ngIf=\"opt.afterDivider\" class=\"divider\"></div>\n </ng-container>\n </div>\n </div>\n <div *ngIf=\"showError()\" [id]=\"id+'-description'\">\n <div class=\"msg msg-errore\">\n <strong [innerHTML]=\"'ERRORE: '+this.error\"></strong>\n </div>\n <div *ngIf=\"description\" [innerHTML]=\"this.description\"></div>\n </div>\n <div *ngIf=\"description && !showError()\"\n [id]=\"id+'-description'\"\n [innerHTML]=\"this.description\">\n </div>\n</div>\n",
103
+ changeDetection: CHANGE_DETECTION_STRATEGY,
104
+ encapsulation: ViewEncapsulation.None,
105
+ styles: [".inail-multi-select .form-control-wrapper:after{font-family:FontAwesome;content:\"\\f078\";right:31px;position:absolute;top:35px;font-size:10px;color:#0083f5}.inail-multi-select .form-control-wrapper.no-label:after{top:11px}.inail-multi-select .form-control[readonly]:not([disabled]){background-color:#fff}.inail-multi-select .form-control:not([disabled]){cursor:pointer}.inail-multi-select .dropdown-menu .form-group{margin:0!important;padding-left:20px!important}.inail-multi-select .dropdown-menu .form-group:hover{background-color:#eaedf2}.inail-multi-select .dropdown-menu .form-group .checkbox{margin:0!important}.inail-multi-select .dropdown-menu .form-group .checkbox label{margin-top:5px!important;margin-bottom:5px!important;display:block!important}"]
106
+ },] }
107
+ ];
108
+ MultiSelectComponent.ctorParameters = () => [
109
+ { type: ChangeDetectorRef }
110
+ ];
111
+ MultiSelectComponent.propDecorators = {
112
+ multiSelect: [{ type: ViewChild, args: ['multiSelect', { static: true },] }],
113
+ formControlElement: [{ type: ViewChild, args: ['formControl', { static: true },] }],
114
+ dropdownMenu: [{ type: ViewChild, args: ['dropdownMenu', { static: true },] }],
115
+ options: [{ type: Input }],
116
+ values: [{ type: Input }],
117
+ valuesChange: [{ type: Output }],
118
+ placeholder: [{ type: Input }],
119
+ sort: [{ type: Input }]
120
+ };
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ng-inail-common/src/lib/components/core/form/multi-select/multi-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport {FormElementComponent} from \"../form-element.component\";\nimport {CHANGE_DETECTION_STRATEGY} from \"../../base.component\";\nimport {isNotBlankOrNull, setFocus} from \"../../../../utils/common.operators\";\nimport {SelectOption} from \"../select/select.component\";\nimport {CheckboxState} from \"../checkbox/checkbox.component\";\n\nexport interface MultiSelectOption extends SelectOption {\n\n  title?: string;\n  beforeDivider?: boolean;\n  afterDivider?: boolean;\n}\n\n@Component({\n  selector: 'inail-multi-select',\n  templateUrl: './multi-select.component.html',\n  styleUrls: ['./multi-select.component.css'],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class MultiSelectComponent extends FormElementComponent implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n\n  @ViewChild('multiSelect', {static: true})\n  multiSelect: ElementRef<HTMLElement>;\n\n  @ViewChild('formControl', {static: true})\n  formControlElement: ElementRef<HTMLElement>;\n\n  @ViewChild('dropdownMenu', {static: true})\n  dropdownMenu: ElementRef<HTMLElement>;\n\n  @Input()\n  options: MultiSelectOption[] = [];\n\n  @Input()\n  values: string[] = [];\n\n  @Output()\n  valuesChange: EventEmitter<string[]> = new EventEmitter<string[]>();\n\n  @Input()\n  placeholder: string = '- seleziona opzioni -';\n\n  @Input()\n  sort: 'asc' | 'desc';\n\n  inputTextValue: string;\n\n  toggle = () => window['$'](this.formControlElement.nativeElement).dropdown('toggle');\n  isExpanded = (): boolean => this.formControlElement.nativeElement.getAttribute('aria-expanded') === 'true';\n  hasFormControlFocus = (): boolean => this.formControlElement.nativeElement.matches(':focus');\n  hasDropdownMenuFocus = (): boolean => this.dropdownMenu.nativeElement.matches(':focus-within');\n  isChecked = (value: string): boolean => this.values.some(v => v === value);\n  getInputTextValue = (): string => this.options.filter(opt => this.isChecked(opt.value)).map(opt => opt.label).join(', ');\n  pushValue = (value: string) => this.values = this.options.filter(opt => opt.value === value || this.isChecked(opt.value)).map(opt => opt.value);\n  isFocusOut = () => window['$'](this.multiSelect.nativeElement).find(document.activeElement).length == 0;\n\n  constructor(private cdr: ChangeDetectorRef) {\n    super(cdr);\n    this.logPrefix = `[inail-multi-select]`;\n    this.detach();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n\n    super.ngOnChanges(changes);\n\n    if ((changes?.options?.currentValue || changes?.sort?.currentValue) && this.sort) {\n\n      let direction: number = \"ASC\" == this.sort.toUpperCase() ? 1 : \"DESC\" == this.sort.toUpperCase() ? -1 : 0;\n\n      if (direction != 0 && this.options != undefined) {\n\n        this.options.sort((a: MultiSelectOption, b: MultiSelectOption) => a.label < b.label ? -direction : a.label > b.label ? direction : 0);\n      }\n    }\n\n    if(changes?.options?.currentValue) {\n\n      this.inputTextValue = this.getInputTextValue();\n    }\n\n    this.cdr.detectChanges();\n  }\n\n  ngOnInit(): void {\n\n    super.ngOnInit();\n\n    this.emitDebug(`@ViewChild('formControl')`);\n    this.emitDebug(this.formControlElement);\n\n    if (this.focus) {\n\n      this.push(\n        this.focus.subscribe((scroll: boolean) => {\n\n          this.emitDebug(`Catch focus!`);\n          setFocus(this.formControlElement.nativeElement, scroll);\n        })\n      );\n    }\n  }\n\n  ngAfterViewInit(): void {\n  }\n\n  ngOnDestroy(): void {\n\n    super.ngOnDestroy();\n  }\n\n  onKeypress($event: KeyboardEvent) {\n\n    $event.preventDefault();\n  }\n\n  onFocusIn() {\n\n    setTimeout(() => {\n\n      this.showDropdownMenu();\n\n    }, 250)\n  }\n\n  onFocusOut() {\n\n    setTimeout(() => {\n\n      if (this.isFocusOut()) {\n\n        this.closeDropdownMenu();\n      }\n    }, 150);\n  }\n\n  showDropdownMenu() {\n\n    setTimeout(() => {\n\n      if(!this.isExpanded()) {\n\n        this.toggle();\n      }\n    });\n  }\n\n  closeDropdownMenu() {\n\n    setTimeout(() => {\n\n      if(this.isExpanded()) {\n\n        this.toggle();\n      }\n    });\n  }\n\n  onCheck(cb: CheckboxState) {\n\n    if (!cb.firstChange) {\n\n      if (cb.checked && !this.isChecked(cb.value)) {\n\n        this.pushValue(cb.value);\n        this.cleanError();\n\n      } else if (!cb.checked && this.isChecked(cb.value)) {\n\n        this.values = this.values.filter(value => value != cb.value);\n        this.cleanError();\n      }\n\n      this.valuesChange.emit(this.values);\n      this.inputTextValue = this.getInputTextValue();\n      this.cdr.detectChanges();\n    }\n  }\n}\n"]}
@@ -7,8 +7,6 @@ import { TrCheckboxComponent } from "../tr-checkbox/tr-checkbox.component";
7
7
  const DEFAULT_TABLE_LENGTH = 10;
8
8
  const ASC = 'asc';
9
9
  const DESC = 'desc';
10
- export class PaginationState {
11
- }
12
10
  export class TableComponent extends ResponsiveElementComponent {
13
11
  constructor(cdr, renderer) {
14
12
  super(cdr);
@@ -51,7 +49,7 @@ export class TableComponent extends ResponsiveElementComponent {
51
49
  this.detach();
52
50
  }
53
51
  ngOnChanges(changes) {
54
- var _a, _b, _c, _d, _e, _f;
52
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
55
53
  super.ngOnChanges(changes);
56
54
  // Controllo se la paginazione richiesta e' interna o esterna
57
55
  if (!this.externalPaginationSorting
@@ -59,6 +57,16 @@ export class TableComponent extends ResponsiveElementComponent {
59
57
  && ((_b = changes.paginationState) === null || _b === void 0 ? void 0 : _b.currentValue) != undefined) {
60
58
  this.externalPaginationSorting = true;
61
59
  }
60
+ // Se per la paginazione esterna viene specificata una proprieta di sorting
61
+ // attivo il componente thLabel associato
62
+ if ((_d = (_c = changes.paginationState) === null || _c === void 0 ? void 0 : _c.currentValue) === null || _d === void 0 ? void 0 : _d.sortProperty) {
63
+ this.attivaThLabelOrdinamentoSpecificato();
64
+ }
65
+ // Se per la paginazione interna viene specificato un ordinamento iniziale
66
+ // attivo il componente thLabel associato
67
+ if ((_f = (_e = changes.initialSort) === null || _e === void 0 ? void 0 : _e.currentValue) === null || _f === void 0 ? void 0 : _f.sortProperty) {
68
+ this.attivaThLabelOrdinamentoSpecificato();
69
+ }
62
70
  // Verifico se e' cambiata la lista degli elementi in input.
63
71
  // Nel caso in cui si stia effettuando una paginazione interna
64
72
  // emetto il sottoinsieme inerente la prima pagina
@@ -72,7 +80,7 @@ export class TableComponent extends ResponsiveElementComponent {
72
80
  }
73
81
  // Richiesta di paginazione
74
82
  if (!this.externalPaginationSorting
75
- && ((_c = changes.doPagination) === null || _c === void 0 ? void 0 : _c.currentValue)) {
83
+ && ((_g = changes.doPagination) === null || _g === void 0 ? void 0 : _g.currentValue)) {
76
84
  this.push(changes.doPagination.currentValue.subscribe((info) => {
77
85
  this.lengthOnChange(info.pageSize);
78
86
  setTimeout(() => this.doSorting(info.sortProperty, info.sortDirection), 100);
@@ -86,12 +94,12 @@ export class TableComponent extends ResponsiveElementComponent {
86
94
  this.lengthOnChange(this.elementsPerPage);
87
95
  }
88
96
  // Calcolo il numero di colonne visibili
89
- if (((_d = changes.noDataFound) === null || _d === void 0 ? void 0 : _d.currentValue) === true) {
97
+ if (((_h = changes.noDataFound) === null || _h === void 0 ? void 0 : _h.currentValue) === true) {
90
98
  // setTimeout(() => this.numeroColonne = document.querySelectorAll(`#${this.id} th`).length);
91
99
  this.numeroColonne = document.querySelectorAll(`#${this.id} th`).length;
92
100
  }
93
- if ((_e = changes.selectableRowValues) === null || _e === void 0 ? void 0 : _e.currentValue) {
94
- this.righeSelezionabili = [...(_f = changes.selectableRowValues) === null || _f === void 0 ? void 0 : _f.currentValue];
101
+ if ((_j = changes.selectableRowValues) === null || _j === void 0 ? void 0 : _j.currentValue) {
102
+ this.righeSelezionabili = [...(_k = changes.selectableRowValues) === null || _k === void 0 ? void 0 : _k.currentValue];
95
103
  }
96
104
  this.cdr.detectChanges();
97
105
  }
@@ -108,6 +116,7 @@ export class TableComponent extends ResponsiveElementComponent {
108
116
  ngAfterViewInit() {
109
117
  this.inizializzaTabella(this.thLabelComponents);
110
118
  this.lookAtThLabel(this.thLabelComponents);
119
+ this.attivaThLabelOrdinamentoSpecificato();
111
120
  setTimeout(() => { var _a; return this.visualizzaBaseFooter = ((_a = this.baseFooter) === null || _a === void 0 ? void 0 : _a.nativeElement.childElementCount) > 0; });
112
121
  this.cdr.detectChanges();
113
122
  }
@@ -418,6 +427,42 @@ export class TableComponent extends ResponsiveElementComponent {
418
427
  return !this.disablePagination
419
428
  && (this.dataSource != undefined || (this.externalPaginationSorting != undefined && this.paginationState != undefined));
420
429
  }
430
+ /**
431
+ * Attiva il th label inerente l'ordinamento specificato
432
+ */
433
+ attivaThLabelOrdinamentoSpecificato() {
434
+ if (this.thLabelComponents) {
435
+ // Paginazione esterna
436
+ if (this.externalPaginationSorting && this.paginationState) {
437
+ let thLabel = this.thLabelComponents.find(item => item.property == this.paginationState.sortProperty);
438
+ this.setSortDirection(thLabel, this.paginationState.sortDirection);
439
+ }
440
+ // Ordinamento iniziale paginazione interna
441
+ else if (this.initialSort) {
442
+ this.thLabelComponents.forEach(thLabel => {
443
+ thLabel.property == this.initialSort.sortProperty
444
+ ? this.setSortDirection(thLabel, this.initialSort.sortDirection)
445
+ : this.setSortDirection(thLabel, undefined);
446
+ });
447
+ }
448
+ }
449
+ }
450
+ setSortDirection(thLabel, direction) {
451
+ if (thLabel) {
452
+ switch (direction) {
453
+ case "asc":
454
+ thLabel.direction = ThLabelComponent.ASC;
455
+ break;
456
+ case "desc":
457
+ thLabel.direction = ThLabelComponent.DESC;
458
+ break;
459
+ default:
460
+ thLabel.direction = ThLabelComponent.UNSORTED;
461
+ break;
462
+ }
463
+ this.modificaTh(thLabel);
464
+ }
465
+ }
421
466
  }
422
467
  TableComponent.decorators = [
423
468
  { type: Component, args: [{
@@ -438,6 +483,7 @@ TableComponent.propDecorators = {
438
483
  displayedDataChange: [{ type: Output }],
439
484
  doPagination: [{ type: Input }],
440
485
  elementsPerPage: [{ type: Input }],
486
+ initialSort: [{ type: Input }],
441
487
  paginationState: [{ type: Input }],
442
488
  elementsPerPageOptions: [{ type: Input }],
443
489
  noDataFound: [{ type: Input }],
@@ -461,4 +507,4 @@ TableComponent.propDecorators = {
461
507
  tablePageSelectorComponent: [{ type: ViewChild, args: [InailTablePageSelectorComponent,] }],
462
508
  baseFooter: [{ type: ViewChild, args: ['baseFooter',] }]
463
509
  };
464
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ng-inail-common/src/lib/components/core/table/table/table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewChecked,\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChange,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport {CHANGE_DETECTION_STRATEGY} from \"../../base.component\";\nimport {ResponsiveElementComponent} from \"../../responsive-element.component\";\nimport {Observable, Subscription} from \"rxjs\";\nimport {InailTablePageSelectorComponent} from \"../inail-table-page-selector/inail-table-page-selector.component\";\nimport {SortingInfo, ThLabelComponent} from \"../th-label/th-label.component\";\nimport {TrCheckboxComponent} from \"../tr-checkbox/tr-checkbox.component\";\n\nconst DEFAULT_TABLE_LENGTH: number = 10;\n\ntype SortDirection = 'asc' | 'desc';\n\nconst ASC: SortDirection = 'asc';\nconst DESC: SortDirection = 'desc';\n\nexport class PaginationState {\n\n  fullListSize?: number;\n  pageNumber?: number;\n  pageSize?: number;\n  sortProperty?: string;\n  sortDirection?: 'asc' | 'desc';\n}\n\ninterface TableChanges extends SimpleChanges {\n\n  dataSource?: SimpleChange,\n  paginationState?: SimpleChange,\n  doPagination?: SimpleChange,\n  noDataFound?: SimpleChange\n  elementsPerPage?: SimpleChange\n}\n\n@Component({\n  selector: 'inail-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.css'],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class TableComponent extends ResponsiveElementComponent implements OnChanges, OnInit, AfterViewInit, AfterViewChecked, OnDestroy {\n\n  tableLength: number;\n  currentPage: number;\n  externalPaginationSorting: boolean = false;\n\n  // --- Paginazione INTERNA -----------------------------------------------\n\n  // Obbligatorio\n  @Input()\n  dataSource: any[];\n\n  // Obbligatorio\n  @Input()\n  displayedData: any[];\n\n  @Output()\n  displayedDataChange = new EventEmitter<any[]>();\n\n  @Input()\n  doPagination: Observable<PaginationState>;\n\n  @Input()\n  elementsPerPage: number = DEFAULT_TABLE_LENGTH;\n\n  // --- Paginazione INTERNA -----------------------------------------------\n\n  // Obbligatorio\n  @Input()\n  paginationState: PaginationState;\n\n  // -----------------------------------------------------------------------\n\n  @Input()\n  elementsPerPageOptions: number[] = [10, 25, 50, 100];\n\n  // @Input()\n  // waiting: boolean = false;\n\n  // @Input()\n  // waitingText: string = 'Recupero in corso...';\n\n  @Input()\n  noDataFound: boolean = false;\n\n  @Input()\n  noDataFoundText: string = 'Nessun elemento trovato';\n\n  @Input()\n  disablePagination: boolean = false;\n\n  @Output()\n  pagination = new EventEmitter<PaginationState>();\n\n  @Input()\n  tallRows: boolean = false;\n\n  // @Input()\n  // alternativeTable: boolean = false;\n\n  @Input()\n  caption: string;\n\n  @Input()\n  captionHidden: boolean = false;\n\n  @Input()\n  bgWhite: boolean = true;\n\n  @Input()\n  description: string;\n\n  @Input()\n  tableClass: string;\n\n  @Input()\n  title: string;\n\n  @Input()\n  titleClass: string;\n\n  @Input()\n  detailsLink: string;\n\n  @Input()\n  selectableRowValues: string[];\n\n  @Output()\n  detailsClick: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  checkedRowsChange: EventEmitter<string[]> = new EventEmitter<string[]>();\n\n  @ContentChildren(ThLabelComponent, {descendants: true})\n  thLabelComponents: QueryList<ThLabelComponent>;\n\n  @ContentChildren(TrCheckboxComponent, {descendants: true})\n  trCheckboxComponents: QueryList<TrCheckboxComponent>;\n\n  @ViewChild(InailTablePageSelectorComponent)\n  tablePageSelectorComponent: InailTablePageSelectorComponent;\n\n  @ViewChild('baseFooter')\n  baseFooter: ElementRef;\n\n  visualizzaBaseFooter: boolean = true;\n\n  numeroColonne: number;\n\n  // Insiemi delle Subscription agli eventi dei TrCheckboxComponent\n  trcbInitSubscriptions: { [id: string]: Subscription } = {};\n  trcbClickSubscriptions: { [id: string]: Subscription } = {};\n  trcbDestroySubscriptions: { [id: string]: Subscription } = {};\n\n  righeSelezionate: string[] = [];\n  righeSelezionabili: string[] = [];\n\n  getPageSize = (): number => this.externalPaginationSorting ? this.paginationState.pageSize : this.tableLength;\n  getListSize = (): number => this.externalPaginationSorting ? this.paginationState.fullListSize : this.dataSource.length;\n  getCurrentPage = (): number => this.externalPaginationSorting && this.paginationState ? this.paginationState.pageNumber : this.currentPage;\n\n  // Operatori per gestione selezione righe\n  isChecked = (trcbValue: string): boolean => this.righeSelezionate.some(value => value == trcbValue);\n  isAllChecked = (): boolean => this.righeSelezionabili.length > 0 && this.righeSelezionabili.every(this.isChecked);\n  isThCheckbox = (trcb: TrCheckboxComponent): boolean => document.querySelectorAll(`th #${trcb.id}`).length > 0;\n  isSelezionabile = (value: string) => this.righeSelezionabili.some(valoreSelezionabile => valoreSelezionabile == value);\n\n  constructor(private cdr: ChangeDetectorRef, private renderer: Renderer2) {\n    super(cdr);\n    this.logPrefix = '[inail-table]';\n    this.detach();\n  }\n\n  ngOnChanges(changes: TableChanges): void {\n\n    super.ngOnChanges(changes);\n\n    // Controllo se la paginazione richiesta e' interna o esterna\n    if (!this.externalPaginationSorting\n      && changes.paginationState?.firstChange === true\n      && changes.paginationState?.currentValue != undefined) {\n\n      this.externalPaginationSorting = true;\n    }\n\n    // Verifico se e' cambiata la lista degli elementi in input.\n    // Nel caso in cui si stia effettuando una paginazione interna\n    // emetto il sottoinsieme inerente la prima pagina\n    if (changes.dataSource != undefined\n      && !changes.dataSource.firstChange\n      && !this.externalPaginationSorting) {\n\n      if (this.tablePageSelectorComponent) {\n\n        this.tablePageSelectorComponent.currentPage = 1;\n      }\n\n      this.emitSubset(1);\n    }\n\n    // Richiesta di paginazione\n    if (!this.externalPaginationSorting\n      && changes.doPagination?.currentValue) {\n\n      this.push(\n        changes.doPagination.currentValue.subscribe((info: PaginationState) => {\n\n          this.lengthOnChange(info.pageSize);\n          setTimeout(() => this.doSorting(info.sortProperty, info.sortDirection), 100);\n          setTimeout(() => this.pageOnChange(info.pageNumber), 200);\n        })\n      );\n    }\n\n    // Elementi per pagina\n    if (changes.elementsPerPage != undefined\n      && !changes.elementsPerPage.firstChange\n      && !this.externalPaginationSorting) {\n\n      this.lengthOnChange(this.elementsPerPage);\n    }\n\n    // Calcolo il numero di colonne visibili\n    if (changes.noDataFound?.currentValue === true) {\n\n      // setTimeout(() => this.numeroColonne = document.querySelectorAll(`#${this.id} th`).length);\n      this.numeroColonne = document.querySelectorAll(`#${this.id} th`).length;\n    }\n\n    if(changes.selectableRowValues?.currentValue) {\n\n      this.righeSelezionabili = [...changes.selectableRowValues?.currentValue];\n    }\n\n    this.cdr.detectChanges();\n  }\n\n  ngOnInit(): void {\n\n    super.ngOnInit();\n\n    this.tableLength = this.externalPaginationSorting ? this.paginationState.pageSize : this.elementsPerPage;\n\n    if (!this.externalPaginationSorting) {\n\n      setTimeout(() => {\n        // console.info('ngOnInit---', this.currentPage)\n        this.emitSubset(this.currentPage || 1);\n      });\n    }\n  }\n\n  ngAfterViewInit(): void {\n\n    this.inizializzaTabella(this.thLabelComponents);\n    this.lookAtThLabel(this.thLabelComponents);\n\n    setTimeout(() => this.visualizzaBaseFooter = this.baseFooter?.nativeElement.childElementCount > 0);\n\n    this.cdr.detectChanges();\n  }\n\n  ngAfterViewChecked(): void {\n\n    this.gestisciTrCheckbox();\n  }\n\n  ngOnDestroy(): void {\n\n    super.ngOnDestroy();\n  }\n\n  /**\n   * Gestione dei checkbox per la selezione delle righe\n   */\n  public gestisciTrCheckbox() {\n\n    if (this.trCheckboxComponents?.length > 0) {\n\n      this.trCheckboxComponents.forEach((trcb: TrCheckboxComponent) => {\n\n        // Gestione evento initComplete\n        // Effettuo la subscribe se non ne e' gia presente\n        // una Subscription per quel trcb\n        if (this.trcbInitSubscriptions[trcb.id] == undefined) {\n\n          this.trcbInitSubscriptions[trcb.id] = trcb.initComplete.subscribe(() => {\n\n            // Se l'insieme di tutti i valori selezionabili\n            // non e' stato passato dall'esterno\n            if (this.selectableRowValues == undefined) {\n\n              // Ricalcolo i valori selezionabili\n              this.righeSelezionabili = this.trCheckboxComponents.filter(trcb => !this.isThCheckbox(trcb)).map(trcb => trcb.value);\n            }\n          });\n        }\n\n        // Gestione evento click\n        if (this.trcbClickSubscriptions[trcb.id] == undefined) {\n\n          this.trcbClickSubscriptions[trcb.id] = trcb.onclick.subscribe(() => {\n\n            if(this.isThCheckbox(trcb)) {\n\n              this.checkAllOnClick();\n            }\n            else {\n              this.checkOnClick(trcb.value);\n            }\n\n            this.checkedRowsChange.emit(this.righeSelezionate);\n          });\n        }\n\n        // Gestione evento onDestroy\n        // Quando un tcrb emette l'evento onDestroy\n        // effettuo l'unsubscribe a tutti gli eventi ad esso collegato\n        if (this.trcbDestroySubscriptions[trcb.id] == undefined) {\n\n          this.trcbDestroySubscriptions[trcb.id] = trcb.onDestroy.subscribe(() => {\n\n            this.trcbInitSubscriptions[trcb.id]?.unsubscribe();\n            this.trcbClickSubscriptions[trcb.id]?.unsubscribe();\n            this.trcbDestroySubscriptions[trcb.id]?.unsubscribe();\n\n            // In questo modo evito che gli oggetti crescano in maniera incontrollata\n            delete this.trcbInitSubscriptions[trcb.id];\n            delete this.trcbClickSubscriptions[trcb.id];\n            delete this.trcbDestroySubscriptions[trcb.id];\n          });\n        }\n      });\n\n      // Indico ad un trcb se e' selezionato.\n      this.trCheckboxComponents.forEach((trcb: TrCheckboxComponent) => {\n\n        if (trcb) {\n\n          if(this.isThCheckbox(trcb)) {\n\n            trcb.setChecked(this.isAllChecked());\n          }\n          else {\n            trcb.setChecked(this.isChecked(trcb.value));\n          }\n        }\n      });\n    }\n  }\n\n  /**\n   * Click di un trcb\n   *\n   * @param valueCb\n   * @private\n   */\n  private checkOnClick(valueCb: string) {\n\n    if (this.isChecked(valueCb)) {\n\n      this.righeSelezionate = this.righeSelezionate.filter(value => value != valueCb);\n    } else {\n\n      this.righeSelezionate.push(valueCb);\n    }\n  }\n\n  checkAllOnClick() {\n\n    if (this.isAllChecked()) {\n\n      this.righeSelezionate = this.righeSelezionate.filter(value => !this.isSelezionabile(value));\n\n    } else {\n\n      this.righeSelezionate = this.righeSelezionate.concat(this.righeSelezionabili.filter(value => !this.isChecked(value)));\n    }\n  }\n\n  /**\n   * Effettua varie operazioni di inizializzazione della tabella\n   */\n  public inizializzaTabella(thLabelComponents: QueryList<ThLabelComponent>) {\n\n    if (thLabelComponents) {\n\n      // Inizializzo tutti i th della tabella\n      thLabelComponents.forEach(\n        (thLabel: ThLabelComponent) => {\n\n          this.modificaTh(thLabel);\n        })\n    }\n  }\n\n  /**\n   * Si mette in ascolto sugli eventi emessi dai thLabelComponents dati in input\n   * per poter eseguire le opportune azioni\n   *\n   * @param thLabelComponents\n   */\n  public lookAtThLabel(thLabelComponents: QueryList<ThLabelComponent>) {\n\n    if (thLabelComponents) {\n\n      this.thLabelComponents = thLabelComponents;\n\n      thLabelComponents.forEach(\n        (thLabel: ThLabelComponent) => {\n\n          if (thLabel) {\n\n            // Subscribe al click del th label\n            this.push(\n              thLabel.click.subscribe(\n                (info: SortingInfo) => {\n\n                  this.performSorting(info, thLabel);\n                }\n              )\n            );\n          }\n        }\n      )\n    }\n  }\n\n  /**\n   *\n   * @param sortProperty\n   * @param sortDirection\n   */\n  public doSorting(sortProperty: string, sortDirection: string) {\n\n    let info: SortingInfo = {\n      property: sortProperty,\n      direction: sortDirection == ASC ? ThLabelComponent.ASC : sortDirection == DESC ? ThLabelComponent.DESC : undefined\n    }\n\n    let thLabel: ThLabelComponent = this.thLabelComponents.find(item => item.property == sortProperty);\n\n    this.performSorting(info, thLabel)\n  }\n\n  /**\n   *\n   * @param info\n   * @param thLabel\n   */\n  performSorting(info: SortingInfo, thLabel: ThLabelComponent) {\n\n    if (thLabel != undefined && info != undefined && info.property != undefined) {\n\n      let eventoPaginazione: PaginationState = {};\n\n      eventoPaginazione.sortProperty = info.property;\n      eventoPaginazione.sortDirection = info.direction == ThLabelComponent.ASC ? ASC : info.direction == ThLabelComponent.DESC ? DESC : undefined;\n      eventoPaginazione.pageNumber = 1;\n\n      this.resetDirectionSorting(thLabel, this.thLabelComponents);\n      this.modificaTh(thLabel);\n\n      if (this.externalPaginationSorting) {\n\n        eventoPaginazione.fullListSize = this.paginationState.fullListSize;\n        eventoPaginazione.pageSize = this.paginationState.pageSize;\n      } else {\n\n        this.ordina(info);\n        this.emitSubset(1);\n      }\n\n      this.pagination.emit(eventoPaginazione);\n    }\n  }\n\n  /**\n   * Reimposta ad unsorted tutti i th label ad eccezione\n   * di quelli dato in input\n   *\n   * @param thLabel\n   * @param thLabelComponents\n   */\n  private resetDirectionSorting(thLabel: ThLabelComponent, thLabelComponents: QueryList<ThLabelComponent>) {\n\n    if (thLabelComponents) {\n\n      thLabelComponents.forEach((item: ThLabelComponent) => {\n\n        if (item && item.property != thLabel.property) {\n\n          item.setAsUnsorted();\n          this.modificaTh(item);\n        }\n      })\n    }\n  }\n\n  /**\n   * Modifica l'elemento th che contiene il ThLabelComponent\n   */\n  private modificaTh(thLabelComponent: ThLabelComponent) {\n\n    if (thLabelComponent && thLabelComponent.sortable === true) {\n\n      let th: HTMLElement = thLabelComponent.elementRef.nativeElement.parentNode;\n\n      if (th) {\n\n        this.removeSortClass(th);\n        this.renderer.addClass(th, this.getThSortClass(thLabelComponent.direction));\n\n        th.setAttribute('aria-sort', this.getAriaSortValue(thLabelComponent.direction));\n\n        if (thLabelComponent.direction == ThLabelComponent.UNSORTED) {\n\n          th.removeAttribute('aria-sort');\n        }\n      }\n    }\n  }\n\n  /**\n   *\n   * @param element\n   */\n  private removeSortClass(element: HTMLElement) {\n\n    this.renderer.removeClass(element, 'sorting_asc');\n    this.renderer.removeClass(element, 'sorting_desc');\n    this.renderer.removeClass(element, 'sorting');\n  }\n\n  /**\n   *\n   * @param direction\n   */\n  private getThSortClass(direction: number) {\n\n    let value: string\n\n    switch (direction) {\n\n      case ThLabelComponent.ASC:\n        value = 'sorting_asc';\n        break\n      case ThLabelComponent.DESC:\n        value = 'sorting_desc';\n        break\n      case ThLabelComponent.UNSORTED:\n        value = 'sorting';\n        break\n    }\n\n    return value;\n  }\n\n  /**\n   *\n   * @param direction\n   */\n  private getAriaSortValue(direction: number): string {\n\n    let value: string\n\n    switch (direction) {\n\n      case ThLabelComponent.ASC:\n        value = 'ascending';\n        break\n      case ThLabelComponent.DESC:\n        value = 'descending';\n        break\n      case ThLabelComponent.UNSORTED:\n        value = 'none';\n        break\n    }\n\n    return value;\n  }\n\n  private ordina(info: SortingInfo) {\n\n    if (info && this.dataSource && info.property) {\n\n      info.direction = info.direction * -1;\n\n      if (info.direction == ThLabelComponent.UNSORTED) {\n\n        info.direction = ThLabelComponent.ASC;\n      }\n\n      this.dataSource.sort(this.propertyComparator(info.property, info.direction));\n      this.dataSource = [].concat(this.dataSource);\n\n      this.cdr.detectChanges();\n    }\n  }\n\n  private propertyComparator(property: string, direction: number) {\n\n    let pList = property ? property.split('.') : undefined;\n\n    function estraiValore(e: any, pList: string[]): any {\n\n      if (e && pList) {\n\n        if (pList.length > 1) {\n\n          return estraiValore(e[pList[0]], pList.slice(1, pList.length));\n        } else {\n\n          return e[pList[0]];\n        }\n      }\n    }\n\n    return function (e1, e2) {\n\n      return (estraiValore(e1, pList) > estraiValore(e2, pList) ? ThLabelComponent.DESC : ThLabelComponent.ASC) * direction;\n    }\n  }\n\n  lengthOnChange(value: number) {\n\n    if (value != undefined && (!this.paginationState || value != this.paginationState.pageSize)) {\n\n      let eventoPaginazione: PaginationState = {};\n\n      if (this.externalPaginationSorting) {\n\n        eventoPaginazione = {...this.paginationState};\n\n      } else if (this.tableLength != value) {\n\n        this.tableLength = value;\n        eventoPaginazione = {};\n\n        this.emitSubset(1);\n      }\n\n      eventoPaginazione.pageSize = value;\n      eventoPaginazione.pageNumber = 1;\n\n      this.pagination.emit(eventoPaginazione);\n    }\n  }\n\n  pageOnChange(page: number) {\n\n    if (page != undefined) {\n\n      let eventoPaginazione: PaginationState;\n\n      if (this.externalPaginationSorting) {\n\n        eventoPaginazione = {...this.paginationState};\n\n      } else {\n\n        eventoPaginazione = {};\n        this.emitSubset(page);\n      }\n\n      eventoPaginazione.pageNumber = page;\n      this.pagination.emit(eventoPaginazione);\n    }\n\n    this.cdr.detectChanges();\n  }\n\n  emitSubset(page: number) {\n\n    if (page && !this.externalPaginationSorting && this.dataSource != undefined) {\n\n      let firstElementIndex = this.tableLength * (page - 1);\n\n      let lastIndex: number = Number(firstElementIndex) + Number(this.tableLength);\n\n      let a: any[] = this.dataSource.slice(firstElementIndex, lastIndex);\n\n      this.currentPage = page;\n      this.displayedDataChange.emit(a);\n    }\n  }\n\n  visualizzaPaginazione(): boolean {\n\n    return !this.disablePagination\n      && (this.dataSource != undefined || (this.externalPaginationSorting != undefined && this.paginationState != undefined));\n  }\n}\n"]}
510
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ng-inail-common/src/lib/components/core/table/table/table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewChecked,\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChange,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport {CHANGE_DETECTION_STRATEGY} from \"../../base.component\";\nimport {ResponsiveElementComponent} from \"../../responsive-element.component\";\nimport {Observable, Subscription} from \"rxjs\";\nimport {InailTablePageSelectorComponent} from \"../inail-table-page-selector/inail-table-page-selector.component\";\nimport {SortingInfo, ThLabelComponent} from \"../th-label/th-label.component\";\nimport {TrCheckboxComponent} from \"../tr-checkbox/tr-checkbox.component\";\n\nconst DEFAULT_TABLE_LENGTH: number = 10;\n\ntype SortDirection = 'asc' | 'desc';\n\nconst ASC: SortDirection = 'asc';\nconst DESC: SortDirection = 'desc';\n\nexport interface SortState {\n\n  sortProperty?: string;\n  sortDirection?: 'asc' | 'desc';\n}\n\nexport interface PaginationState extends SortState {\n\n  fullListSize?: number;\n  pageNumber?: number;\n  pageSize?: number;\n}\n\ninterface TableChanges extends SimpleChanges {\n\n  dataSource?: SimpleChange,\n  paginationState?: SimpleChange,\n  initialSort?: SimpleChange,\n  doPagination?: SimpleChange,\n  noDataFound?: SimpleChange\n  elementsPerPage?: SimpleChange\n}\n\n@Component({\n  selector: 'inail-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.css'],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class TableComponent extends ResponsiveElementComponent implements OnChanges, OnInit, AfterViewInit, AfterViewChecked, OnDestroy {\n\n  tableLength: number;\n  currentPage: number;\n  externalPaginationSorting: boolean = false;\n\n  // --- Paginazione INTERNA -----------------------------------------------\n\n  // Obbligatorio\n  @Input()\n  dataSource: any[];\n\n  // Obbligatorio\n  @Input()\n  displayedData: any[];\n\n  @Output()\n  displayedDataChange = new EventEmitter<any[]>();\n\n  @Input()\n  doPagination: Observable<PaginationState>;\n\n  @Input()\n  elementsPerPage: number = DEFAULT_TABLE_LENGTH;\n\n  @Input()\n  initialSort: SortState;\n\n  // --- Paginazione ESTERNA -----------------------------------------------\n\n  // Obbligatorio\n  @Input()\n  paginationState: PaginationState;\n\n  // -----------------------------------------------------------------------\n\n  @Input()\n  elementsPerPageOptions: number[] = [10, 25, 50, 100];\n\n  // @Input()\n  // waiting: boolean = false;\n\n  // @Input()\n  // waitingText: string = 'Recupero in corso...';\n\n  @Input()\n  noDataFound: boolean = false;\n\n  @Input()\n  noDataFoundText: string = 'Nessun elemento trovato';\n\n  @Input()\n  disablePagination: boolean = false;\n\n  @Output()\n  pagination = new EventEmitter<PaginationState>();\n\n  @Input()\n  tallRows: boolean = false;\n\n  // @Input()\n  // alternativeTable: boolean = false;\n\n  @Input()\n  caption: string;\n\n  @Input()\n  captionHidden: boolean = false;\n\n  @Input()\n  bgWhite: boolean = true;\n\n  @Input()\n  description: string;\n\n  @Input()\n  tableClass: string;\n\n  @Input()\n  title: string;\n\n  @Input()\n  titleClass: string;\n\n  @Input()\n  detailsLink: string;\n\n  @Input()\n  selectableRowValues: string[];\n\n  @Output()\n  detailsClick: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  checkedRowsChange: EventEmitter<string[]> = new EventEmitter<string[]>();\n\n  @ContentChildren(ThLabelComponent, {descendants: true})\n  thLabelComponents: QueryList<ThLabelComponent>;\n\n  @ContentChildren(TrCheckboxComponent, {descendants: true})\n  trCheckboxComponents: QueryList<TrCheckboxComponent>;\n\n  @ViewChild(InailTablePageSelectorComponent)\n  tablePageSelectorComponent: InailTablePageSelectorComponent;\n\n  @ViewChild('baseFooter')\n  baseFooter: ElementRef;\n\n  visualizzaBaseFooter: boolean = true;\n\n  numeroColonne: number;\n\n  // Insiemi delle Subscription agli eventi dei TrCheckboxComponent\n  trcbInitSubscriptions: { [id: string]: Subscription } = {};\n  trcbClickSubscriptions: { [id: string]: Subscription } = {};\n  trcbDestroySubscriptions: { [id: string]: Subscription } = {};\n\n  righeSelezionate: string[] = [];\n  righeSelezionabili: string[] = [];\n\n  getPageSize = (): number => this.externalPaginationSorting ? this.paginationState.pageSize : this.tableLength;\n  getListSize = (): number => this.externalPaginationSorting ? this.paginationState.fullListSize : this.dataSource.length;\n  getCurrentPage = (): number => this.externalPaginationSorting && this.paginationState ? this.paginationState.pageNumber : this.currentPage;\n\n  // Operatori per gestione selezione righe\n  isChecked = (trcbValue: string): boolean => this.righeSelezionate.some(value => value == trcbValue);\n  isAllChecked = (): boolean => this.righeSelezionabili.length > 0 && this.righeSelezionabili.every(this.isChecked);\n  isThCheckbox = (trcb: TrCheckboxComponent): boolean => document.querySelectorAll(`th #${trcb.id}`).length > 0;\n  isSelezionabile = (value: string) => this.righeSelezionabili.some(valoreSelezionabile => valoreSelezionabile == value);\n\n  constructor(private cdr: ChangeDetectorRef, private renderer: Renderer2) {\n    super(cdr);\n    this.logPrefix = '[inail-table]';\n    this.detach();\n  }\n\n  ngOnChanges(changes: TableChanges): void {\n\n    super.ngOnChanges(changes);\n\n    // Controllo se la paginazione richiesta e' interna o esterna\n    if (!this.externalPaginationSorting\n      && changes.paginationState?.firstChange === true\n      && changes.paginationState?.currentValue != undefined) {\n\n      this.externalPaginationSorting = true;\n    }\n\n    // Se per la paginazione esterna viene specificata una proprieta di sorting\n    // attivo il componente thLabel associato\n    if (changes.paginationState?.currentValue?.sortProperty) {\n\n      this.attivaThLabelOrdinamentoSpecificato();\n    }\n\n    // Se per la paginazione interna viene specificato un ordinamento iniziale\n    // attivo il componente thLabel associato\n    if (changes.initialSort?.currentValue?.sortProperty) {\n\n      this.attivaThLabelOrdinamentoSpecificato();\n    }\n\n    // Verifico se e' cambiata la lista degli elementi in input.\n    // Nel caso in cui si stia effettuando una paginazione interna\n    // emetto il sottoinsieme inerente la prima pagina\n    if (changes.dataSource != undefined\n      && !changes.dataSource.firstChange\n      && !this.externalPaginationSorting) {\n\n      if (this.tablePageSelectorComponent) {\n\n        this.tablePageSelectorComponent.currentPage = 1;\n      }\n\n      this.emitSubset(1);\n    }\n\n    // Richiesta di paginazione\n    if (!this.externalPaginationSorting\n      && changes.doPagination?.currentValue) {\n\n      this.push(\n        changes.doPagination.currentValue.subscribe((info: PaginationState) => {\n\n          this.lengthOnChange(info.pageSize);\n          setTimeout(() => this.doSorting(info.sortProperty, info.sortDirection), 100);\n          setTimeout(() => this.pageOnChange(info.pageNumber), 200);\n        })\n      );\n    }\n\n    // Elementi per pagina\n    if (changes.elementsPerPage != undefined\n      && !changes.elementsPerPage.firstChange\n      && !this.externalPaginationSorting) {\n\n      this.lengthOnChange(this.elementsPerPage);\n    }\n\n    // Calcolo il numero di colonne visibili\n    if (changes.noDataFound?.currentValue === true) {\n\n      // setTimeout(() => this.numeroColonne = document.querySelectorAll(`#${this.id} th`).length);\n      this.numeroColonne = document.querySelectorAll(`#${this.id} th`).length;\n    }\n\n    if (changes.selectableRowValues?.currentValue) {\n\n      this.righeSelezionabili = [...changes.selectableRowValues?.currentValue];\n    }\n\n    this.cdr.detectChanges();\n  }\n\n  ngOnInit(): void {\n\n    super.ngOnInit();\n\n    this.tableLength = this.externalPaginationSorting ? this.paginationState.pageSize : this.elementsPerPage;\n\n    if (!this.externalPaginationSorting) {\n\n      setTimeout(() => {\n        // console.info('ngOnInit---', this.currentPage)\n        this.emitSubset(this.currentPage || 1);\n      });\n    }\n  }\n\n  ngAfterViewInit(): void {\n\n    this.inizializzaTabella(this.thLabelComponents);\n    this.lookAtThLabel(this.thLabelComponents);\n    this.attivaThLabelOrdinamentoSpecificato();\n\n    setTimeout(() => this.visualizzaBaseFooter = this.baseFooter?.nativeElement.childElementCount > 0);\n\n    this.cdr.detectChanges();\n  }\n\n  ngAfterViewChecked(): void {\n\n    this.gestisciTrCheckbox();\n  }\n\n  ngOnDestroy(): void {\n\n    super.ngOnDestroy();\n  }\n\n  /**\n   * Gestione dei checkbox per la selezione delle righe\n   */\n  public gestisciTrCheckbox() {\n\n    if (this.trCheckboxComponents?.length > 0) {\n\n      this.trCheckboxComponents.forEach((trcb: TrCheckboxComponent) => {\n\n        // Gestione evento initComplete\n        // Effettuo la subscribe se non ne e' gia presente\n        // una Subscription per quel trcb\n        if (this.trcbInitSubscriptions[trcb.id] == undefined) {\n\n          this.trcbInitSubscriptions[trcb.id] = trcb.initComplete.subscribe(() => {\n\n            // Se l'insieme di tutti i valori selezionabili\n            // non e' stato passato dall'esterno\n            if (this.selectableRowValues == undefined) {\n\n              // Ricalcolo i valori selezionabili\n              this.righeSelezionabili = this.trCheckboxComponents.filter(trcb => !this.isThCheckbox(trcb)).map(trcb => trcb.value);\n            }\n          });\n        }\n\n        // Gestione evento click\n        if (this.trcbClickSubscriptions[trcb.id] == undefined) {\n\n          this.trcbClickSubscriptions[trcb.id] = trcb.onclick.subscribe(() => {\n\n            if (this.isThCheckbox(trcb)) {\n\n              this.checkAllOnClick();\n            } else {\n              this.checkOnClick(trcb.value);\n            }\n\n            this.checkedRowsChange.emit(this.righeSelezionate);\n          });\n        }\n\n        // Gestione evento onDestroy\n        // Quando un tcrb emette l'evento onDestroy\n        // effettuo l'unsubscribe a tutti gli eventi ad esso collegato\n        if (this.trcbDestroySubscriptions[trcb.id] == undefined) {\n\n          this.trcbDestroySubscriptions[trcb.id] = trcb.onDestroy.subscribe(() => {\n\n            this.trcbInitSubscriptions[trcb.id]?.unsubscribe();\n            this.trcbClickSubscriptions[trcb.id]?.unsubscribe();\n            this.trcbDestroySubscriptions[trcb.id]?.unsubscribe();\n\n            // In questo modo evito che gli oggetti crescano in maniera incontrollata\n            delete this.trcbInitSubscriptions[trcb.id];\n            delete this.trcbClickSubscriptions[trcb.id];\n            delete this.trcbDestroySubscriptions[trcb.id];\n          });\n        }\n      });\n\n      // Indico ad un trcb se e' selezionato.\n      this.trCheckboxComponents.forEach((trcb: TrCheckboxComponent) => {\n\n        if (trcb) {\n\n          if (this.isThCheckbox(trcb)) {\n\n            trcb.setChecked(this.isAllChecked());\n          } else {\n            trcb.setChecked(this.isChecked(trcb.value));\n          }\n        }\n      });\n    }\n  }\n\n  /**\n   * Click di un trcb\n   *\n   * @param valueCb\n   * @private\n   */\n  private checkOnClick(valueCb: string) {\n\n    if (this.isChecked(valueCb)) {\n\n      this.righeSelezionate = this.righeSelezionate.filter(value => value != valueCb);\n    } else {\n\n      this.righeSelezionate.push(valueCb);\n    }\n  }\n\n  checkAllOnClick() {\n\n    if (this.isAllChecked()) {\n\n      this.righeSelezionate = this.righeSelezionate.filter(value => !this.isSelezionabile(value));\n\n    } else {\n\n      this.righeSelezionate = this.righeSelezionate.concat(this.righeSelezionabili.filter(value => !this.isChecked(value)));\n    }\n  }\n\n  /**\n   * Effettua varie operazioni di inizializzazione della tabella\n   */\n  public inizializzaTabella(thLabelComponents: QueryList<ThLabelComponent>) {\n\n    if (thLabelComponents) {\n\n      // Inizializzo tutti i th della tabella\n      thLabelComponents.forEach(\n        (thLabel: ThLabelComponent) => {\n\n          this.modificaTh(thLabel);\n        })\n    }\n  }\n\n  /**\n   * Si mette in ascolto sugli eventi emessi dai thLabelComponents dati in input\n   * per poter eseguire le opportune azioni\n   *\n   * @param thLabelComponents\n   */\n  public lookAtThLabel(thLabelComponents: QueryList<ThLabelComponent>) {\n\n    if (thLabelComponents) {\n\n      this.thLabelComponents = thLabelComponents;\n\n      thLabelComponents.forEach(\n        (thLabel: ThLabelComponent) => {\n\n          if (thLabel) {\n\n            // Subscribe al click del th label\n            this.push(\n              thLabel.click.subscribe(\n                (info: SortingInfo) => {\n\n                  this.performSorting(info, thLabel);\n                }\n              )\n            );\n          }\n        }\n      )\n    }\n  }\n\n  /**\n   *\n   * @param sortProperty\n   * @param sortDirection\n   */\n  public doSorting(sortProperty: string, sortDirection: string) {\n\n    let info: SortingInfo = {\n      property: sortProperty,\n      direction: sortDirection == ASC ? ThLabelComponent.ASC : sortDirection == DESC ? ThLabelComponent.DESC : undefined\n    }\n\n    let thLabel: ThLabelComponent = this.thLabelComponents.find(item => item.property == sortProperty);\n\n    this.performSorting(info, thLabel)\n  }\n\n  /**\n   *\n   * @param info\n   * @param thLabel\n   */\n  performSorting(info: SortingInfo, thLabel: ThLabelComponent) {\n\n    if (thLabel != undefined && info != undefined && info.property != undefined) {\n\n      let eventoPaginazione: PaginationState = {};\n\n      eventoPaginazione.sortProperty = info.property;\n      eventoPaginazione.sortDirection = info.direction == ThLabelComponent.ASC ? ASC : info.direction == ThLabelComponent.DESC ? DESC : undefined;\n      eventoPaginazione.pageNumber = 1;\n\n      this.resetDirectionSorting(thLabel, this.thLabelComponents);\n      this.modificaTh(thLabel);\n\n      if (this.externalPaginationSorting) {\n\n        eventoPaginazione.fullListSize = this.paginationState.fullListSize;\n        eventoPaginazione.pageSize = this.paginationState.pageSize;\n      } else {\n\n        this.ordina(info);\n        this.emitSubset(1);\n      }\n\n      this.pagination.emit(eventoPaginazione);\n    }\n  }\n\n  /**\n   * Reimposta ad unsorted tutti i th label ad eccezione\n   * di quelli dato in input\n   *\n   * @param thLabel\n   * @param thLabelComponents\n   */\n  private resetDirectionSorting(thLabel: ThLabelComponent, thLabelComponents: QueryList<ThLabelComponent>) {\n\n    if (thLabelComponents) {\n\n      thLabelComponents.forEach((item: ThLabelComponent) => {\n\n        if (item && item.property != thLabel.property) {\n\n          item.setAsUnsorted();\n          this.modificaTh(item);\n        }\n      })\n    }\n  }\n\n  /**\n   * Modifica l'elemento th che contiene il ThLabelComponent\n   */\n  private modificaTh(thLabelComponent: ThLabelComponent) {\n\n    if (thLabelComponent && thLabelComponent.sortable === true) {\n\n      let th: HTMLElement = thLabelComponent.elementRef.nativeElement.parentNode;\n\n      if (th) {\n\n        this.removeSortClass(th);\n        this.renderer.addClass(th, this.getThSortClass(thLabelComponent.direction));\n\n        th.setAttribute('aria-sort', this.getAriaSortValue(thLabelComponent.direction));\n\n        if (thLabelComponent.direction == ThLabelComponent.UNSORTED) {\n\n          th.removeAttribute('aria-sort');\n        }\n      }\n    }\n  }\n\n  /**\n   *\n   * @param element\n   */\n  private removeSortClass(element: HTMLElement) {\n\n    this.renderer.removeClass(element, 'sorting_asc');\n    this.renderer.removeClass(element, 'sorting_desc');\n    this.renderer.removeClass(element, 'sorting');\n  }\n\n  /**\n   *\n   * @param direction\n   */\n  private getThSortClass(direction: number) {\n\n    let value: string\n\n    switch (direction) {\n\n      case ThLabelComponent.ASC:\n        value = 'sorting_asc';\n        break\n      case ThLabelComponent.DESC:\n        value = 'sorting_desc';\n        break\n      case ThLabelComponent.UNSORTED:\n        value = 'sorting';\n        break\n    }\n\n    return value;\n  }\n\n  /**\n   *\n   * @param direction\n   */\n  private getAriaSortValue(direction: number): string {\n\n    let value: string\n\n    switch (direction) {\n\n      case ThLabelComponent.ASC:\n        value = 'ascending';\n        break\n      case ThLabelComponent.DESC:\n        value = 'descending';\n        break\n      case ThLabelComponent.UNSORTED:\n        value = 'none';\n        break\n    }\n\n    return value;\n  }\n\n  private ordina(info: SortingInfo) {\n\n    if (info && this.dataSource && info.property) {\n\n      info.direction = info.direction * -1;\n\n      if (info.direction == ThLabelComponent.UNSORTED) {\n\n        info.direction = ThLabelComponent.ASC;\n      }\n\n      this.dataSource.sort(this.propertyComparator(info.property, info.direction));\n      this.dataSource = [].concat(this.dataSource);\n\n      this.cdr.detectChanges();\n    }\n  }\n\n  private propertyComparator(property: string, direction: number) {\n\n    let pList = property ? property.split('.') : undefined;\n\n    function estraiValore(e: any, pList: string[]): any {\n\n      if (e && pList) {\n\n        if (pList.length > 1) {\n\n          return estraiValore(e[pList[0]], pList.slice(1, pList.length));\n        } else {\n\n          return e[pList[0]];\n        }\n      }\n    }\n\n    return function (e1, e2) {\n\n      return (estraiValore(e1, pList) > estraiValore(e2, pList) ? ThLabelComponent.DESC : ThLabelComponent.ASC) * direction;\n    }\n  }\n\n  lengthOnChange(value: number) {\n\n    if (value != undefined && (!this.paginationState || value != this.paginationState.pageSize)) {\n\n      let eventoPaginazione: PaginationState = {};\n\n      if (this.externalPaginationSorting) {\n\n        eventoPaginazione = {...this.paginationState};\n\n      } else if (this.tableLength != value) {\n\n        this.tableLength = value;\n        eventoPaginazione = {};\n\n        this.emitSubset(1);\n      }\n\n      eventoPaginazione.pageSize = value;\n      eventoPaginazione.pageNumber = 1;\n\n      this.pagination.emit(eventoPaginazione);\n    }\n  }\n\n  pageOnChange(page: number) {\n\n    if (page != undefined) {\n\n      let eventoPaginazione: PaginationState;\n\n      if (this.externalPaginationSorting) {\n\n        eventoPaginazione = {...this.paginationState};\n\n      } else {\n\n        eventoPaginazione = {};\n        this.emitSubset(page);\n      }\n\n      eventoPaginazione.pageNumber = page;\n      this.pagination.emit(eventoPaginazione);\n    }\n\n    this.cdr.detectChanges();\n  }\n\n  emitSubset(page: number) {\n\n    if (page && !this.externalPaginationSorting && this.dataSource != undefined) {\n\n      let firstElementIndex = this.tableLength * (page - 1);\n\n      let lastIndex: number = Number(firstElementIndex) + Number(this.tableLength);\n\n      let a: any[] = this.dataSource.slice(firstElementIndex, lastIndex);\n\n      this.currentPage = page;\n      this.displayedDataChange.emit(a);\n    }\n  }\n\n  visualizzaPaginazione(): boolean {\n\n    return !this.disablePagination\n      && (this.dataSource != undefined || (this.externalPaginationSorting != undefined && this.paginationState != undefined));\n  }\n\n  /**\n   * Attiva il th label inerente l'ordinamento specificato\n   */\n  attivaThLabelOrdinamentoSpecificato() {\n\n    if (this.thLabelComponents) {\n\n      // Paginazione esterna\n      if (this.externalPaginationSorting && this.paginationState) {\n\n        let thLabel: ThLabelComponent = this.thLabelComponents.find(item => item.property == this.paginationState.sortProperty);\n        this.setSortDirection(thLabel, this.paginationState.sortDirection);\n      }\n      // Ordinamento iniziale paginazione interna\n      else if (this.initialSort) {\n\n        this.thLabelComponents.forEach(thLabel => {\n\n          thLabel.property == this.initialSort.sortProperty\n            ? this.setSortDirection(thLabel, this.initialSort.sortDirection)\n            : this.setSortDirection(thLabel, undefined);\n        });\n      }\n    }\n  }\n\n  setSortDirection(thLabel: ThLabelComponent, direction: SortDirection) {\n\n    if (thLabel) {\n\n      switch (direction) {\n\n        case \"asc\":\n          thLabel.direction = ThLabelComponent.ASC;\n          break;\n\n        case \"desc\":\n          thLabel.direction = ThLabelComponent.DESC;\n          break;\n\n        default:\n          thLabel.direction = ThLabelComponent.UNSORTED;\n          break\n      }\n\n      this.modificaTh(thLabel);\n    }\n  }\n}\n"]}