@arsedizioni/ars-utils 18.2.375 → 18.2.378
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/clipper.common/common/definitions.d.ts +4 -3
- package/clipper.ui/ui/document/document.component.d.ts +3 -3
- package/clipper.ui/ui/document-index/document-index.component.d.ts +2 -2
- package/clipper.ui/ui/document-menu/document-menu.component.d.ts +1 -1
- package/clipper.ui/ui/search-calendar/search-calendar.component.d.ts +1 -2
- package/clipper.ui/ui/search-dialog/search-dialog.component.d.ts +2 -2
- package/clipper.ui/ui/search-facets/search-facets.component.d.ts +1 -2
- package/clipper.ui/ui/search-free-text-query-builder/search-free-text-query-builder.component.d.ts +1 -2
- package/esm2022/clipper.common/common/definitions.mjs +2 -1
- package/esm2022/clipper.ui/ui/document/document.component.mjs +7 -11
- package/esm2022/clipper.ui/ui/document-index/document-index.component.mjs +3 -5
- package/esm2022/clipper.ui/ui/search-calendar/search-calendar.component.mjs +3 -5
- package/esm2022/clipper.ui/ui/search-dialog/search-dialog.component.mjs +3 -5
- package/esm2022/clipper.ui/ui/search-facets/search-facets.component.mjs +4 -6
- package/esm2022/clipper.ui/ui/search-free-text-query-builder/search-free-text-query-builder.component.mjs +4 -6
- package/esm2022/evolution.common/common/definitions.mjs +1 -1
- package/esm2022/tinymce/full-screen-editor/full-screen-editor.component.mjs +4 -6
- package/esm2022/ui/ui/dialogs/confirm/confirm-dialog.component.mjs +4 -6
- package/esm2022/ui/ui/dialogs/credentials/credentials-dialog.component.mjs +5 -9
- package/esm2022/ui/ui/dialogs/recover-password/recover-password-dialog.component.mjs +4 -6
- package/esm2022/ui/ui/dialogs/reset-password/reset-password-dialog.component.mjs +4 -6
- package/esm2022/ui/ui/dialogs/toast/toast.component.mjs +4 -6
- package/esm2022/ui.application/ui/components/button-selector/button-selector.component.mjs +5 -9
- package/esm2022/ui.application/ui/components/button-toggle/button-toggle.component.mjs +4 -6
- package/esm2022/ui.application/ui/components/chips-selector/chips-selector.component.mjs +4 -6
- package/esm2022/ui.application/ui/components/file-input/file-input.component.mjs +6 -12
- package/esm2022/ui.application/ui/components/filter-bar/filter-bar.component.mjs +4 -6
- package/esm2022/ui.application/ui/dialogs/prompt/prompt-dialog.component.mjs +3 -5
- package/esm2022/ui.application/ui/dialogs/prompt-date/prompt-date-dialog.component.mjs +3 -5
- package/esm2022/ui.application/ui/dialogs/prompt-time/prompt-time-dialog.component.mjs +3 -5
- package/esm2022/ui.application/ui/dialogs/select/select-dialog.component.mjs +10 -26
- package/esm2022/ui.application/ui/dialogs/select-file/select-file-dialog.component.mjs +4 -6
- package/esm2022/ui.application/ui/dialogs/select-picture/select-picture-dialog.component.mjs +4 -6
- package/esm2022/ui.application/ui/dialogs/select-tree/select-tree-dialog.component.mjs +4 -6
- package/esm2022/ui.application/ui/dialogs/send-to/send-to-dialog.component.mjs +5 -9
- package/esm2022/ui.oauth/ui/components/login/login-oauth.component.mjs +4 -6
- package/evolution.common/common/definitions.d.ts +2 -2
- package/fesm2022/arsedizioni-ars-utils-clipper.common.mjs +1 -0
- package/fesm2022/arsedizioni-ars-utils-clipper.common.mjs.map +1 -1
- package/fesm2022/arsedizioni-ars-utils-clipper.ui.mjs +973 -987
- package/fesm2022/arsedizioni-ars-utils-clipper.ui.mjs.map +1 -1
- package/fesm2022/arsedizioni-ars-utils-evolution.common.mjs.map +1 -1
- package/fesm2022/arsedizioni-ars-utils-tinymce.mjs +3 -5
- package/fesm2022/arsedizioni-ars-utils-tinymce.mjs.map +1 -1
- package/fesm2022/arsedizioni-ars-utils-ui.application.mjs +34 -82
- package/fesm2022/arsedizioni-ars-utils-ui.application.mjs.map +1 -1
- package/fesm2022/arsedizioni-ars-utils-ui.mjs +12 -24
- package/fesm2022/arsedizioni-ars-utils-ui.mjs.map +1 -1
- package/fesm2022/arsedizioni-ars-utils-ui.oauth.mjs +3 -5
- package/fesm2022/arsedizioni-ars-utils-ui.oauth.mjs.map +1 -1
- package/package.json +1 -1
- package/tinymce/full-screen-editor/full-screen-editor.component.d.ts +2 -2
- package/ui/ui/dialogs/confirm/confirm-dialog.component.d.ts +2 -2
- package/ui/ui/dialogs/credentials/credentials-dialog.component.d.ts +3 -3
- package/ui/ui/dialogs/recover-password/recover-password-dialog.component.d.ts +1 -2
- package/ui/ui/dialogs/reset-password/reset-password-dialog.component.d.ts +2 -2
- package/ui/ui/dialogs/toast/toast.component.d.ts +1 -2
- package/ui.application/ui/components/button-selector/button-selector.component.d.ts +3 -3
- package/ui.application/ui/components/button-toggle/button-toggle.component.d.ts +2 -2
- package/ui.application/ui/components/chips-selector/chips-selector.component.d.ts +2 -2
- package/ui.application/ui/components/file-input/file-input.component.d.ts +4 -4
- package/ui.application/ui/components/filter-bar/filter-bar.component.d.ts +2 -2
- package/ui.application/ui/dialogs/prompt/prompt-dialog.component.d.ts +2 -2
- package/ui.application/ui/dialogs/prompt-date/prompt-date-dialog.component.d.ts +2 -2
- package/ui.application/ui/dialogs/prompt-time/prompt-time-dialog.component.d.ts +2 -2
- package/ui.application/ui/dialogs/select/select-dialog.component.d.ts +9 -9
- package/ui.application/ui/dialogs/select-file/select-file-dialog.component.d.ts +1 -2
- package/ui.application/ui/dialogs/select-picture/select-picture-dialog.component.d.ts +1 -2
- package/ui.application/ui/dialogs/select-tree/select-tree-dialog.component.d.ts +2 -2
- package/ui.application/ui/dialogs/send-to/send-to-dialog.component.d.ts +3 -3
- package/ui.oauth/ui/components/login/login-oauth.component.d.ts +2 -2
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component,
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ViewChild, inject, output, signal } from "@angular/core";
|
|
2
2
|
import { FormsModule } from "@angular/forms";
|
|
3
3
|
import { MatButtonModule } from "@angular/material/button";
|
|
4
4
|
import { MatCheckboxModule } from "@angular/material/checkbox";
|
|
@@ -35,14 +35,14 @@ export class SelectDialogComponent {
|
|
|
35
35
|
this.changeDetector = inject(ChangeDetectorRef);
|
|
36
36
|
this.dialogRef = inject((MatDialogRef));
|
|
37
37
|
this.dialogData = inject(MAT_DIALOG_DATA) ?? { appearance: 'outline', title: 'Seleziona' };
|
|
38
|
-
this.done =
|
|
39
|
-
this.edit =
|
|
40
|
-
this.view =
|
|
41
|
-
this.append =
|
|
42
|
-
this.delete =
|
|
43
|
-
this.lookup =
|
|
44
|
-
this.lookupOptions =
|
|
45
|
-
this.filter =
|
|
38
|
+
this.done = output();
|
|
39
|
+
this.edit = output();
|
|
40
|
+
this.view = output();
|
|
41
|
+
this.append = output();
|
|
42
|
+
this.delete = output();
|
|
43
|
+
this.lookup = output();
|
|
44
|
+
this.lookupOptions = output();
|
|
45
|
+
this.filter = output();
|
|
46
46
|
this.canEdit = signal(false);
|
|
47
47
|
this.canView = signal(false);
|
|
48
48
|
this.canAppend = signal(false);
|
|
@@ -351,21 +351,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
|
|
|
351
351
|
}], selection: [{
|
|
352
352
|
type: ViewChild,
|
|
353
353
|
args: ["selection"]
|
|
354
|
-
}], done: [{
|
|
355
|
-
type: Output
|
|
356
|
-
}], edit: [{
|
|
357
|
-
type: Output
|
|
358
|
-
}], view: [{
|
|
359
|
-
type: Output
|
|
360
|
-
}], append: [{
|
|
361
|
-
type: Output
|
|
362
|
-
}], delete: [{
|
|
363
|
-
type: Output
|
|
364
|
-
}], lookup: [{
|
|
365
|
-
type: Output
|
|
366
|
-
}], lookupOptions: [{
|
|
367
|
-
type: Output
|
|
368
|
-
}], filter: [{
|
|
369
|
-
type: Output
|
|
370
354
|
}] } });
|
|
371
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-dialog.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select/select-dialog.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select/select-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter, OnInit,\r\n  Output,\r\n  ViewChild,\r\n  inject,\r\n  signal\r\n} from \"@angular/core\";\r\nimport { FormsModule } from \"@angular/forms\";\r\nimport { MatButtonModule } from \"@angular/material/button\";\r\nimport { MatCheckboxChange, MatCheckboxModule } from \"@angular/material/checkbox\";\r\nimport { MatOptionModule } from \"@angular/material/core\";\r\nimport { MAT_DIALOG_DATA, MatDialogActions, MatDialogClose, MatDialogContent, MatDialogRef, MatDialogTitle } from \"@angular/material/dialog\";\r\nimport { MatDividerModule } from \"@angular/material/divider\";\r\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\r\nimport { MatIconModule } from \"@angular/material/icon\";\r\nimport { MatInputModule } from \"@angular/material/input\";\r\nimport { MatListModule, MatSelectionList, MatSelectionListChange } from \"@angular/material/list\";\r\nimport { MatMenuModule } from \"@angular/material/menu\";\r\nimport { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';\r\nimport { MatSelectModule } from \"@angular/material/select\";\r\nimport { MatTooltipModule } from \"@angular/material/tooltip\";\r\nimport { SafeHtmlPipe, SearchFilterPipe, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport {\r\n  SelectDialogAppend,\r\n  SelectDialogData,\r\n  SelectDialogDelete,\r\n  SelectDialogFilter,\r\n  SelectDialogLookup,\r\n  SelectDialogResult,\r\n  SelectableItem,\r\n} from \"../../definitions\";\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\n\r\n  \r\n\r\n@Component({\r\n  host: { 'Bind': SystemUtils.generateUUID() },\r\n  templateUrl: \"./select-dialog.component.html\",\r\n  styleUrls: [\"./select-dialog.component.scss\"],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    FlexLayoutModule,\r\n    MatDialogTitle,    \r\n    MatFormFieldModule,\r\n    MatInputModule,\r\n    FormsModule,\r\n    MatButtonModule,\r\n    MatIconModule,\r\n    MatSelectModule,\r\n    MatOptionModule,\r\n    MatTooltipModule,\r\n    MatMenuModule,\r\n    MatDividerModule,\r\n    MatCheckboxModule,\r\n    MatDialogContent,\r\n    MatListModule,\r\n    MatDialogActions,\r\n    MatDialogClose,\r\n    MatPaginatorModule,\r\n    SearchFilterPipe,\r\n    SafeHtmlPipe\r\n  ],\r\n})\r\nexport class SelectDialogComponent implements OnInit {\r\n  @ViewChild('paginator') paginator!: MatPaginator;\r\n  @ViewChild(\"selection\") selection!: MatSelectionList;\r\n\r\n  private changeDetector = inject(ChangeDetectorRef);\r\n  private dialogRef = inject(MatDialogRef<SelectDialogComponent>);\r\n  protected dialogData: SelectDialogData = inject(MAT_DIALOG_DATA) ?? { appearance: 'outline', title: 'Seleziona' };\r\n\r\n  @Output() done = new EventEmitter<SelectDialogResult>();\r\n  @Output() edit = new EventEmitter<SelectableItem>();\r\n  @Output() view = new EventEmitter<SelectableItem>();\r\n  @Output() append = new EventEmitter<SelectDialogAppend>();\r\n  @Output() delete = new EventEmitter<SelectDialogDelete>();\r\n  @Output() lookup = new EventEmitter<SelectDialogLookup>();\r\n  @Output() lookupOptions = new EventEmitter();\r\n  @Output() filter = new EventEmitter<SelectDialogFilter>();\r\n\r\n  protected canEdit = signal<boolean>(false);\r\n  protected canView = signal<boolean>(false);\r\n  protected canAppend = signal<boolean>(false);\r\n  protected canDelete = signal<boolean>(false);\r\n  protected canPaginate = signal<boolean>(false);\r\n\r\n  // Handle submit button activity\r\n  protected okDisabled = signal<boolean>(true);\r\n\r\n  // Used for array filtering\r\n  protected filterText: string = \"\";\r\n  protected filterOptions: any = [];\r\n  protected filterOptionsInfo: string = \"Tutto\";\r\n\r\n  // Used to sincronize lookup fields and params\r\n  protected lookupField: string = \"\";\r\n  private lookupParams: any | null;\r\n\r\n\r\n  // Used to display selected elements\r\n  protected selectionInfo = signal<string>(null);\r\n  protected selectionMasterIndeterminate = signal<boolean>(false);\r\n  protected selectionMasterChecked = signal<boolean>(false);\r\n\r\n  ngOnInit() {\r\n    if (!this.dialogData.appearance) {\r\n      this.dialogData.appearance = 'outline';\r\n    }\r\n    if (!this.dialogData.title) {\r\n      this.dialogData.title = 'Seleziona';\r\n    }\r\n    if (this.dialogData.multi && !this.dialogData.items) {\r\n      this.dialogData.multi = true;\r\n    }\r\n    if (!this.dialogData.okCaption) {\r\n      this.dialogData.okCaption = \"Ok\";\r\n    }\r\n    this.canAppend.set(this.dialogData.canAppend);\r\n    if (this.dialogData.canLookup) {\r\n      this.dialogData.items = [];\r\n      if (this.dialogData.lookupFields && this.dialogData.lookupFields.length > 0) {\r\n        this.lookupField = this.dialogData.lookupFields[0].value;\r\n      }\r\n      if (this.dialogData.canFilter) {\r\n        this.filterOptions = this.dialogData.filters;\r\n      }\r\n      if (this.dialogData.canPaginate) {\r\n        this.canPaginate.set(this.dialogData.canPaginate);\r\n        if (!this.dialogData.pageSize) {\r\n          this.dialogData.pageSize = 100\r\n        }\r\n      }\r\n    }\r\n    this.okDisabled.set(this.dialogData.mustSelect);\r\n\r\n    // Apply filter if exists\r\n    if (this.dialogData.filter || this.dialogData.lookupOnInit) {\r\n      this.doFilter(this.dialogData.filter);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Mark for check\r\n   */\r\n  notifyChanges() {\r\n    this.changeDetector.markForCheck();\r\n  }\r\n\r\n  /**\r\n   * Check if every element are selected\r\n   */\r\n  private isAllSelected() {\r\n    return (\r\n      this.selection &&\r\n      this.selection.selectedOptions &&\r\n      this.selection.selectedOptions.selected &&\r\n      this.selection.selectedOptions.selected.length === this.dialogData.items.length\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Checks if exists a selection\r\n   */\r\n  private hasSelection() {\r\n    return (\r\n      this.selection &&\r\n      this.selection.selectedOptions &&\r\n      this.selection.selectedOptions.selected &&\r\n      this.selection.selectedOptions.selected.length > 0\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Master selection toggle\r\n   * @param e: the event\r\n   */\r\n  protected masterSelectionToggle(e: MatCheckboxChange) {\r\n    if (e.checked)\r\n      // Deselect if not allselected so that toggle makes the right choice\r\n      this.selection.selectAll();\r\n    else this.selection.deselectAll();\r\n    this.selectionMasterIndeterminate.set(false);\r\n    this.selectionMasterChecked.set(e.checked);\r\n    this.okDisabled.set(\r\n      this.dialogData.mustSelect &&\r\n      (!this.selection || this.selection.selectedOptions.selected.length === 0));\r\n    this.updateSelectionInfo();\r\n  }\r\n\r\n  /**\r\n   * Handle selection/deselection of an item\r\n   * @param e: the event\r\n   */\r\n  protected select(e: MatSelectionListChange) {\r\n    if (!this.dialogData.multi) {\r\n      this.selection.deselectAll();\r\n      if (e.options?.length > 0)\r\n        e.options[0].selected = true;\r\n      this.okDisabled.set(false);\r\n    } else {\r\n      this.okDisabled.set(\r\n        this.dialogData.mustSelect &&\r\n        (!this.selection ||\r\n          this.selection.selectedOptions.selected.length === 0));\r\n    }\r\n\r\n    // Update editors\r\n    this.canAppend.set(this.dialogData.canAppend);\r\n    this.canEdit.set(\r\n      this.dialogData.canEdit &&\r\n      this.selection &&\r\n      this.selection.selectedOptions.selected.length === 1);\r\n    this.canView.set(\r\n      this.dialogData.canView &&\r\n      this.selection &&\r\n      this.selection.selectedOptions.selected.length === 1);\r\n    this.canDelete.set(\r\n      this.dialogData.canDelete &&\r\n      this.selection &&\r\n      this.selection.selectedOptions.selected.length > 0);\r\n    this.selectionMasterIndeterminate.set(\r\n      !this.isAllSelected() && this.hasSelection());\r\n    this.selectionMasterChecked.set(this.hasSelection());\r\n    this.updateSelectionInfo();\r\n  }\r\n\r\n  /**\r\n   * Update selection info\r\n   */\r\n  private updateSelectionInfo() {\r\n    // Update selection info\r\n    if (this.selection && this.selection.selectedOptions.selected.length > 0 && this.dialogData.multi) {\r\n      this.selectionInfo.set(\r\n        this.selection.selectedOptions.selected.length +\r\n        \" / \" +\r\n        this.selection.options.length);\r\n    } else {\r\n      this.selectionInfo.set(null);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Clear current selection\r\n   */\r\n  clearSelection() {\r\n    this.selectionMasterIndeterminate.set(false);\r\n    this.selectionMasterChecked.set(false);\r\n    this.selection.deselectAll();\r\n    this.selectionInfo.set(null);\r\n  }\r\n\r\n  /**\r\n   * Submit selection\r\n   */\r\n  protected ok() {\r\n    if (!this.okDisabled()) {\r\n      // Multi selection\r\n      const selectedItems: any = [];\r\n      this.selection.selectedOptions.selected.forEach((element) => {\r\n        selectedItems.push(element.value);\r\n      });\r\n      this.dialogRef.close();\r\n      setTimeout(() => {\r\n        this.done.emit({ selectedItems: selectedItems });\r\n      }, 500);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Clear filter\r\n   */\r\n  protected clearFilter() {\r\n    this.filterText = \"\";\r\n  }\r\n\r\n\r\n  /**\r\n   * Show filter options\r\n   */\r\n  protected showFilterOptions() {\r\n    if (this.lookupOptions) {\r\n      this.lookupOptions.emit();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Apply filter\r\n   * @param text : the string to filter to\r\n   */\r\n  protected doFilter(text: string = null, e: any = null) {\r\n    if (text) {\r\n      this.filterText = text;\r\n    }\r\n    if (this.dialogData.canLookup) {\r\n      if (!e || e.keyCode === 13) {\r\n        this.lookup.emit({ items: this.dialogData.items, filter: this.filterText, owner: this });\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Apply filter using filter options\r\n   * @param filterOption : the current filter option\r\n   */\r\n  protected doFilterByOptions(filterOption: any) {\r\n    if (this.dialogData.canLookup && this.dialogData.canFilter) {\r\n      this.filter.emit({\r\n        items: this.dialogData.items,\r\n        filter: this.filterText,\r\n        filterOption: filterOption,\r\n        owner: this,\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Apply filter. This is accessible from public\r\n   * @param params : the object with current parameters\r\n   */\r\n  doLookup(params: any) {\r\n    if (this.dialogData.canLookup) {\r\n      this.lookupParams = params;\r\n      this.lookupParams.first = 0;\r\n      this.lookup.emit({ items: this.dialogData.items, params: this.lookupParams, owner: this });    \r\n    }\r\n  }\r\n\r\n  /**\r\n   * Update lookup paginatro\r\n   * @param total : the new total items\r\n   */\r\n  protected updateLookupPaginator(total: number) {\r\n    if (this.canPaginate()) {\r\n      if (this.paginator) {\r\n        this.paginator.pageIndex = 0;\r\n        this.paginator.length = total ?? 0;\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n  * Apply filter\r\n  * @param e : the MatPaginator PageEvent data\r\n  */\r\n  protected doLookupPage(e: any) {\r\n    if (this.dialogData.canLookup && this.dialogData.canPaginate) {\r\n      this.clearSelection();\r\n      this.lookupParams.first = e.pageIndex * (this.dialogData.pageSize ?? 0);\r\n      this.lookup.emit({ items: this.dialogData.items, params: this.lookupParams, owner: this });      \r\n    }\r\n  }\r\n\r\n  /**\r\n   * Append\r\n   */\r\n  protected doAppend() {\r\n    this.append.emit({ items: this.dialogData.items, owner: this } as SelectDialogAppend);   \r\n  }\r\n\r\n  /**\r\n   * Edit\r\n   */\r\n  protected doEdit() {\r\n    if (this.selection.selectedOptions.selected?.length > 0){\r\n      this.edit.emit(this.selection.selectedOptions.selected[0].value);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * View\r\n   */\r\n  protected doView() {\r\n    if (this.selection.selectedOptions.selected?.length > 0) {\r\n      this.view.emit(this.selection.selectedOptions.selected[0].value);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Delete\r\n   */\r\n  protected doDelete() {\r\n    let selectedItems: any = [];\r\n    this.selection.selectedOptions.selected.forEach((element) => {\r\n      selectedItems.push(element.value);\r\n    });\r\n    this.delete.emit({\r\n      items: this.dialogData.items,\r\n      selectedItems: selectedItems,\r\n    } as SelectDialogDelete);\r\n    this.canDelete.set(false);\r\n    \r\n  }\r\n}\r\n","<h2 mat-dialog-title>{{dialogData.title}}</h2>\r\n<div style=\"padding: 0 24px\">\r\n  @if (dialogData.description) {\r\n  <div class=\"selectfile-description\" [innerHtml]=\"dialogData.description | safeHtml\"></div>\r\n  }\r\n  <div>\r\n    <div fxLayout=\"row\" fxLayoutGap=\"20px\" fxFill>\r\n      @if (!dialogData.canLookupWithOptions) {\r\n      <div fxFlex=\"100\">\r\n        <mat-form-field style='width:100%' [appearance]=\"dialogData.appearance\" subscriptSizing=\"dynamic\">\r\n          <mat-label>Cerca...</mat-label>\r\n          <input type=\"text\" cdkFocusInitial (keyup.Enter)=\"doFilter()\" matInput\r\n            title=\"{{dialogData.canLookup ? 'Digita il testo e premi invio' : 'Digita il testo'}}\"\r\n            [(ngModel)]=\"filterText\">\r\n          @if (filterText) {\r\n          <button type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"clearFilter()\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n      </div>\r\n      }\r\n      @if (!dialogData.canLookupWithOptions && dialogData.canLookup && dialogData.lookupFields) {\r\n      <div fxFlex=\"100\">\r\n        <mat-form-field style='width:100%' [appearance]=\"dialogData.appearance\" subscriptSizing=\"dynamic\">\r\n          <mat-label>Come...</mat-label>\r\n          <mat-select [(value)]=\"lookupField\">\r\n            @for (field of dialogData.lookupFields; track field) {\r\n            <mat-option [value]=\"field.value\">\r\n              {{field.name}}\r\n            </mat-option>\r\n            }\r\n          </mat-select>\r\n        </mat-form-field>\r\n      </div>\r\n      }\r\n      @if (dialogData.canLookupWithOptions) {\r\n      <div fxFlex=\"*\" fxFlexAlign=\"center\">\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button aria-label=\"Ricerca\" (click)=\"showFilterOptions()\">\r\n          <mat-icon>search</mat-icon>Ricerca\r\n        </button>\r\n      </div>\r\n      }\r\n      @if (dialogData.canLookup && dialogData.canFilter) {\r\n      <div fxFlex=\"*\" fxFlexAlign=\"center\" style=\"white-space:nowrap\">\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button matTooltip=\"Filtra\" [attr.aria-label]=\"'Filtra'\"\r\n          [matMenuTriggerFor]=\"menuFilter\" color=\"primary\">\r\n          <mat-icon>filter_alt</mat-icon> {{filterOptionsInfo}} <mat-icon class=\"icon-menu-drop-down\">\r\n            arrow_drop_down</mat-icon>\r\n        </button>\r\n        <mat-menu #menuFilter=\"matMenu\" class=\"mat-menu-300\">\r\n          @for (f of filterOptions; track f) {\r\n\r\n          @if (f.divider) {\r\n          <mat-divider></mat-divider>\r\n          }\r\n          @if (f.groupName) {\r\n          <span style='font-size:small; padding: 2px 4px;'><i><b>{{f.groupName}}</b></i></span>\r\n          }\r\n          @if (!f.groupName && !f.divider) {\r\n          <button mat-menu-item (click)=\"doFilterByOptions(f)\" [attr.aria-label]=\"f.description\">\r\n            @if (f.radio && f.value) {\r\n            <span style=\"padding-left:40px\"></span>\r\n            }\r\n            <mat-icon>{{f.icon}}</mat-icon> {{f.title}}\r\n          </button>\r\n          }\r\n\r\n          }\r\n        </mat-menu>\r\n      </div>\r\n      }\r\n      @if (canEdit() || canAppend() || canView() || canDelete()) {\r\n      <div fxFlex=\"*\" fxLayoutAlign=\"end\" style=\"white-space:nowrap\">\r\n        @if (canAppend()) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"doAppend()\">\r\n          <mat-icon aria-label=\"Aggiungi\" matTooltip=\"Aggiungi\">add</mat-icon>\r\n        </button>\r\n        }\r\n        @if (canEdit()) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"doEdit()\">\r\n          <mat-icon aria-label=\"Modifica\" matTooltip=\"Modifica\">edit</mat-icon>\r\n        </button>\r\n        }\r\n        @if (canView()) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"doView()\">\r\n          <mat-icon aria-label=\"Mostra\" matTooltip=\"Mostra\">visibility</mat-icon>\r\n        </button>\r\n        }\r\n        @if (canDelete()) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"doDelete()\">\r\n          <mat-icon aria-label=\"Elimina\" matTooltip=\"Elimina\">delete</mat-icon>\r\n        </button>\r\n        }\r\n      </div>\r\n      }\r\n    </div>\r\n  </div>\r\n  @if ((dialogData.multi || dialogData.header) && dialogData.items?.length > 0) {\r\n  <div>\r\n    <div fxLayout=\"row\" fxFalyoutGap=\"10px\" fxFill style=\"padding-top: 10px;\">\r\n      <div fxFlex=\"72px\" fxFlexAlign=\"center\" style=\"padding-left: 8px;\">\r\n        @if (dialogData.multi) {\r\n        <mat-checkbox color=\"primary\" (change)=\"$event ? masterSelectionToggle($event) : null\"\r\n          [indeterminate]=\"selectionMasterIndeterminate()\" [checked]=\"selectionMasterChecked()\"\r\n          [attr.aria-label]=\"'Seleziona/deseleziona tutto'\" matTooltip=\"Seleziona/deseleziona tutto\">\r\n        </mat-checkbox>\r\n        }\r\n      </div>\r\n      <div fxFlex=\"100\" fxFlexAlign=\"center\">\r\n        @if (dialogData.header) {\r\n        <div [innerHtml]=\"dialogData.header | safeHtml\"></div>\r\n        }\r\n      </div>\r\n    </div>\r\n  </div>\r\n  }\r\n</div>\r\n<div mat-dialog-content>\r\n  <div fxLayout=\"column\" fxFill>\r\n    @if (dialogData.canLookup && (!dialogData.items || dialogData.items.length == 0)) {\r\n    <div class=\"message\"><i>\r\n        @if (!dialogData.emptyMessage) {\r\n        <span>Nessun elemento da visualizzare.<br>Esegui una nuova ricerca o modifica quella\r\n          esistente.\r\n          @if (dialogData.maxItems > 0) {\r\n          <span>Saranno mostrati al massimo {{dialogData.maxItems}} elementi.</span>\r\n          }\r\n        </span>\r\n        } @else {\r\n        <span [innerHtml]=\"dialogData.emptyMessage | safeHtml\"></span>\r\n        }\r\n      </i>\r\n    </div>\r\n    }\r\n    <mat-selection-list #selection (selectionChange)=\"select($event)\" dense hideSingleSelectionIndicator=\"true\">\r\n      @for (item of (dialogData.items | search: (!dialogData.canLookup ? filterText : '')); track item) {\r\n      <mat-list-option [value]=\"item\" [selected]=\"item.selected\" checkboxPosition=\"before\" >\r\n        <div [innerHtml]=\"item.template | safeHtml\"></div>\r\n      </mat-list-option>\r\n      }\r\n    </mat-selection-list>\r\n  </div>\r\n</div>\r\n<div mat-dialog-actions>\r\n  <div fxLayout=\"column\" fxFill>\r\n    <div fxLayout=\"row\" fxLayoutAlign=\"space-between center\" fxLayoutGap=\"10px\" fxFill>\r\n      <div style=\"padding-left:20px\">\r\n        @if (selectionInfo()) {\r\n        <span class=\"small\">selezione: &nbsp;</span><span class=\"bold\">{{selectionInfo()}}</span>\r\n        }\r\n      </div>\r\n      <div fxFlexAlign=\"center\">\r\n        @if (canPaginate()) {\r\n        <mat-paginator #paginator [hidePageSize]=\"true\" [pageSize]=\"dialogData.pageSize\" [showFirstLastButtons]=\"true\"\r\n          (page)=\"doLookupPage($event)\" [length]=\"dialogData.items?.length ?? 0\"></mat-paginator>\r\n\r\n        }\r\n      </div>\r\n    </div>\r\n    <div fxLayout=\"row\" fxLayoutAlign=\"end\" fxFill>\r\n      <button mat-flat-button color=\"primary\" (click)=\"ok()\" [disabled]=\"okDisabled()\">\r\n        <span>{{dialogData.mustSelect ? dialogData.okCaption : 'Chiudi'}}</span>\r\n      </button>\r\n      @if (dialogData.mustSelect) {\r\n      <button mat-button mat-dialog-close cdkFocusInitial color=\"primary\">\r\n        <span>Annulla</span>\r\n      </button>\r\n      }\r\n    </div>\r\n  </div>\r\n</div>"]}
|
|
355
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-dialog.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select/select-dialog.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select/select-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component, OnInit, ViewChild,\r\n  inject,\r\n  output,\r\n  signal\r\n} from \"@angular/core\";\r\nimport { FormsModule } from \"@angular/forms\";\r\nimport { MatButtonModule } from \"@angular/material/button\";\r\nimport { MatCheckboxChange, MatCheckboxModule } from \"@angular/material/checkbox\";\r\nimport { MatOptionModule } from \"@angular/material/core\";\r\nimport { MAT_DIALOG_DATA, MatDialogActions, MatDialogClose, MatDialogContent, MatDialogRef, MatDialogTitle } from \"@angular/material/dialog\";\r\nimport { MatDividerModule } from \"@angular/material/divider\";\r\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\r\nimport { MatIconModule } from \"@angular/material/icon\";\r\nimport { MatInputModule } from \"@angular/material/input\";\r\nimport { MatListModule, MatSelectionList, MatSelectionListChange } from \"@angular/material/list\";\r\nimport { MatMenuModule } from \"@angular/material/menu\";\r\nimport { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';\r\nimport { MatSelectModule } from \"@angular/material/select\";\r\nimport { MatTooltipModule } from \"@angular/material/tooltip\";\r\nimport { SafeHtmlPipe, SearchFilterPipe, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport {\r\n  SelectDialogAppend,\r\n  SelectDialogData,\r\n  SelectDialogDelete,\r\n  SelectDialogFilter,\r\n  SelectDialogLookup,\r\n  SelectDialogResult,\r\n  SelectableItem,\r\n} from \"../../definitions\";\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\n\r\n  \r\n\r\n@Component({\r\n  host: { 'Bind': SystemUtils.generateUUID() },\r\n  templateUrl: \"./select-dialog.component.html\",\r\n  styleUrls: [\"./select-dialog.component.scss\"],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    FlexLayoutModule,\r\n    MatDialogTitle,    \r\n    MatFormFieldModule,\r\n    MatInputModule,\r\n    FormsModule,\r\n    MatButtonModule,\r\n    MatIconModule,\r\n    MatSelectModule,\r\n    MatOptionModule,\r\n    MatTooltipModule,\r\n    MatMenuModule,\r\n    MatDividerModule,\r\n    MatCheckboxModule,\r\n    MatDialogContent,\r\n    MatListModule,\r\n    MatDialogActions,\r\n    MatDialogClose,\r\n    MatPaginatorModule,\r\n    SearchFilterPipe,\r\n    SafeHtmlPipe\r\n  ],\r\n})\r\nexport class SelectDialogComponent implements OnInit {\r\n  @ViewChild('paginator') paginator!: MatPaginator;\r\n  @ViewChild(\"selection\") selection!: MatSelectionList;\r\n\r\n  private changeDetector = inject(ChangeDetectorRef);\r\n  private dialogRef = inject(MatDialogRef<SelectDialogComponent>);\r\n  protected dialogData: SelectDialogData = inject(MAT_DIALOG_DATA) ?? { appearance: 'outline', title: 'Seleziona' };\r\n\r\n  done = output<SelectDialogResult>();\r\n  edit = output<SelectableItem>();\r\n  view = output<SelectableItem>();\r\n  append = output<SelectDialogAppend>();\r\n  delete = output<SelectDialogDelete>();\r\n  lookup = output<SelectDialogLookup>();\r\n  lookupOptions = output();\r\n  filter = output<SelectDialogFilter>();\r\n\r\n  protected canEdit = signal<boolean>(false);\r\n  protected canView = signal<boolean>(false);\r\n  protected canAppend = signal<boolean>(false);\r\n  protected canDelete = signal<boolean>(false);\r\n  protected canPaginate = signal<boolean>(false);\r\n\r\n  // Handle submit button activity\r\n  protected okDisabled = signal<boolean>(true);\r\n\r\n  // Used for array filtering\r\n  protected filterText: string = \"\";\r\n  protected filterOptions: any = [];\r\n  protected filterOptionsInfo: string = \"Tutto\";\r\n\r\n  // Used to sincronize lookup fields and params\r\n  protected lookupField: string = \"\";\r\n  private lookupParams: any | null;\r\n\r\n\r\n  // Used to display selected elements\r\n  protected selectionInfo = signal<string>(null);\r\n  protected selectionMasterIndeterminate = signal<boolean>(false);\r\n  protected selectionMasterChecked = signal<boolean>(false);\r\n\r\n  ngOnInit() {\r\n    if (!this.dialogData.appearance) {\r\n      this.dialogData.appearance = 'outline';\r\n    }\r\n    if (!this.dialogData.title) {\r\n      this.dialogData.title = 'Seleziona';\r\n    }\r\n    if (this.dialogData.multi && !this.dialogData.items) {\r\n      this.dialogData.multi = true;\r\n    }\r\n    if (!this.dialogData.okCaption) {\r\n      this.dialogData.okCaption = \"Ok\";\r\n    }\r\n    this.canAppend.set(this.dialogData.canAppend);\r\n    if (this.dialogData.canLookup) {\r\n      this.dialogData.items = [];\r\n      if (this.dialogData.lookupFields && this.dialogData.lookupFields.length > 0) {\r\n        this.lookupField = this.dialogData.lookupFields[0].value;\r\n      }\r\n      if (this.dialogData.canFilter) {\r\n        this.filterOptions = this.dialogData.filters;\r\n      }\r\n      if (this.dialogData.canPaginate) {\r\n        this.canPaginate.set(this.dialogData.canPaginate);\r\n        if (!this.dialogData.pageSize) {\r\n          this.dialogData.pageSize = 100\r\n        }\r\n      }\r\n    }\r\n    this.okDisabled.set(this.dialogData.mustSelect);\r\n\r\n    // Apply filter if exists\r\n    if (this.dialogData.filter || this.dialogData.lookupOnInit) {\r\n      this.doFilter(this.dialogData.filter);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Mark for check\r\n   */\r\n  notifyChanges() {\r\n    this.changeDetector.markForCheck();\r\n  }\r\n\r\n  /**\r\n   * Check if every element are selected\r\n   */\r\n  private isAllSelected() {\r\n    return (\r\n      this.selection &&\r\n      this.selection.selectedOptions &&\r\n      this.selection.selectedOptions.selected &&\r\n      this.selection.selectedOptions.selected.length === this.dialogData.items.length\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Checks if exists a selection\r\n   */\r\n  private hasSelection() {\r\n    return (\r\n      this.selection &&\r\n      this.selection.selectedOptions &&\r\n      this.selection.selectedOptions.selected &&\r\n      this.selection.selectedOptions.selected.length > 0\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Master selection toggle\r\n   * @param e: the event\r\n   */\r\n  protected masterSelectionToggle(e: MatCheckboxChange) {\r\n    if (e.checked)\r\n      // Deselect if not allselected so that toggle makes the right choice\r\n      this.selection.selectAll();\r\n    else this.selection.deselectAll();\r\n    this.selectionMasterIndeterminate.set(false);\r\n    this.selectionMasterChecked.set(e.checked);\r\n    this.okDisabled.set(\r\n      this.dialogData.mustSelect &&\r\n      (!this.selection || this.selection.selectedOptions.selected.length === 0));\r\n    this.updateSelectionInfo();\r\n  }\r\n\r\n  /**\r\n   * Handle selection/deselection of an item\r\n   * @param e: the event\r\n   */\r\n  protected select(e: MatSelectionListChange) {\r\n    if (!this.dialogData.multi) {\r\n      this.selection.deselectAll();\r\n      if (e.options?.length > 0)\r\n        e.options[0].selected = true;\r\n      this.okDisabled.set(false);\r\n    } else {\r\n      this.okDisabled.set(\r\n        this.dialogData.mustSelect &&\r\n        (!this.selection ||\r\n          this.selection.selectedOptions.selected.length === 0));\r\n    }\r\n\r\n    // Update editors\r\n    this.canAppend.set(this.dialogData.canAppend);\r\n    this.canEdit.set(\r\n      this.dialogData.canEdit &&\r\n      this.selection &&\r\n      this.selection.selectedOptions.selected.length === 1);\r\n    this.canView.set(\r\n      this.dialogData.canView &&\r\n      this.selection &&\r\n      this.selection.selectedOptions.selected.length === 1);\r\n    this.canDelete.set(\r\n      this.dialogData.canDelete &&\r\n      this.selection &&\r\n      this.selection.selectedOptions.selected.length > 0);\r\n    this.selectionMasterIndeterminate.set(\r\n      !this.isAllSelected() && this.hasSelection());\r\n    this.selectionMasterChecked.set(this.hasSelection());\r\n    this.updateSelectionInfo();\r\n  }\r\n\r\n  /**\r\n   * Update selection info\r\n   */\r\n  private updateSelectionInfo() {\r\n    // Update selection info\r\n    if (this.selection && this.selection.selectedOptions.selected.length > 0 && this.dialogData.multi) {\r\n      this.selectionInfo.set(\r\n        this.selection.selectedOptions.selected.length +\r\n        \" / \" +\r\n        this.selection.options.length);\r\n    } else {\r\n      this.selectionInfo.set(null);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Clear current selection\r\n   */\r\n  clearSelection() {\r\n    this.selectionMasterIndeterminate.set(false);\r\n    this.selectionMasterChecked.set(false);\r\n    this.selection.deselectAll();\r\n    this.selectionInfo.set(null);\r\n  }\r\n\r\n  /**\r\n   * Submit selection\r\n   */\r\n  protected ok() {\r\n    if (!this.okDisabled()) {\r\n      // Multi selection\r\n      const selectedItems: any = [];\r\n      this.selection.selectedOptions.selected.forEach((element) => {\r\n        selectedItems.push(element.value);\r\n      });\r\n      this.dialogRef.close();\r\n      setTimeout(() => {\r\n        this.done.emit({ selectedItems: selectedItems });\r\n      }, 500);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Clear filter\r\n   */\r\n  protected clearFilter() {\r\n    this.filterText = \"\";\r\n  }\r\n\r\n\r\n  /**\r\n   * Show filter options\r\n   */\r\n  protected showFilterOptions() {\r\n    if (this.lookupOptions) {\r\n      this.lookupOptions.emit();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Apply filter\r\n   * @param text : the string to filter to\r\n   */\r\n  protected doFilter(text: string = null, e: any = null) {\r\n    if (text) {\r\n      this.filterText = text;\r\n    }\r\n    if (this.dialogData.canLookup) {\r\n      if (!e || e.keyCode === 13) {\r\n        this.lookup.emit({ items: this.dialogData.items, filter: this.filterText, owner: this });\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Apply filter using filter options\r\n   * @param filterOption : the current filter option\r\n   */\r\n  protected doFilterByOptions(filterOption: any) {\r\n    if (this.dialogData.canLookup && this.dialogData.canFilter) {\r\n      this.filter.emit({\r\n        items: this.dialogData.items,\r\n        filter: this.filterText,\r\n        filterOption: filterOption,\r\n        owner: this,\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Apply filter. This is accessible from public\r\n   * @param params : the object with current parameters\r\n   */\r\n  doLookup(params: any) {\r\n    if (this.dialogData.canLookup) {\r\n      this.lookupParams = params;\r\n      this.lookupParams.first = 0;\r\n      this.lookup.emit({ items: this.dialogData.items, params: this.lookupParams, owner: this });    \r\n    }\r\n  }\r\n\r\n  /**\r\n   * Update lookup paginatro\r\n   * @param total : the new total items\r\n   */\r\n  protected updateLookupPaginator(total: number) {\r\n    if (this.canPaginate()) {\r\n      if (this.paginator) {\r\n        this.paginator.pageIndex = 0;\r\n        this.paginator.length = total ?? 0;\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n  * Apply filter\r\n  * @param e : the MatPaginator PageEvent data\r\n  */\r\n  protected doLookupPage(e: any) {\r\n    if (this.dialogData.canLookup && this.dialogData.canPaginate) {\r\n      this.clearSelection();\r\n      this.lookupParams.first = e.pageIndex * (this.dialogData.pageSize ?? 0);\r\n      this.lookup.emit({ items: this.dialogData.items, params: this.lookupParams, owner: this });      \r\n    }\r\n  }\r\n\r\n  /**\r\n   * Append\r\n   */\r\n  protected doAppend() {\r\n    this.append.emit({ items: this.dialogData.items, owner: this } as SelectDialogAppend);   \r\n  }\r\n\r\n  /**\r\n   * Edit\r\n   */\r\n  protected doEdit() {\r\n    if (this.selection.selectedOptions.selected?.length > 0){\r\n      this.edit.emit(this.selection.selectedOptions.selected[0].value);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * View\r\n   */\r\n  protected doView() {\r\n    if (this.selection.selectedOptions.selected?.length > 0) {\r\n      this.view.emit(this.selection.selectedOptions.selected[0].value);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Delete\r\n   */\r\n  protected doDelete() {\r\n    let selectedItems: any = [];\r\n    this.selection.selectedOptions.selected.forEach((element) => {\r\n      selectedItems.push(element.value);\r\n    });\r\n    this.delete.emit({\r\n      items: this.dialogData.items,\r\n      selectedItems: selectedItems,\r\n    } as SelectDialogDelete);\r\n    this.canDelete.set(false);\r\n    \r\n  }\r\n}\r\n","<h2 mat-dialog-title>{{dialogData.title}}</h2>\r\n<div style=\"padding: 0 24px\">\r\n  @if (dialogData.description) {\r\n  <div class=\"selectfile-description\" [innerHtml]=\"dialogData.description | safeHtml\"></div>\r\n  }\r\n  <div>\r\n    <div fxLayout=\"row\" fxLayoutGap=\"20px\" fxFill>\r\n      @if (!dialogData.canLookupWithOptions) {\r\n      <div fxFlex=\"100\">\r\n        <mat-form-field style='width:100%' [appearance]=\"dialogData.appearance\" subscriptSizing=\"dynamic\">\r\n          <mat-label>Cerca...</mat-label>\r\n          <input type=\"text\" cdkFocusInitial (keyup.Enter)=\"doFilter()\" matInput\r\n            title=\"{{dialogData.canLookup ? 'Digita il testo e premi invio' : 'Digita il testo'}}\"\r\n            [(ngModel)]=\"filterText\">\r\n          @if (filterText) {\r\n          <button type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"clearFilter()\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n      </div>\r\n      }\r\n      @if (!dialogData.canLookupWithOptions && dialogData.canLookup && dialogData.lookupFields) {\r\n      <div fxFlex=\"100\">\r\n        <mat-form-field style='width:100%' [appearance]=\"dialogData.appearance\" subscriptSizing=\"dynamic\">\r\n          <mat-label>Come...</mat-label>\r\n          <mat-select [(value)]=\"lookupField\">\r\n            @for (field of dialogData.lookupFields; track field) {\r\n            <mat-option [value]=\"field.value\">\r\n              {{field.name}}\r\n            </mat-option>\r\n            }\r\n          </mat-select>\r\n        </mat-form-field>\r\n      </div>\r\n      }\r\n      @if (dialogData.canLookupWithOptions) {\r\n      <div fxFlex=\"*\" fxFlexAlign=\"center\">\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button aria-label=\"Ricerca\" (click)=\"showFilterOptions()\">\r\n          <mat-icon>search</mat-icon>Ricerca\r\n        </button>\r\n      </div>\r\n      }\r\n      @if (dialogData.canLookup && dialogData.canFilter) {\r\n      <div fxFlex=\"*\" fxFlexAlign=\"center\" style=\"white-space:nowrap\">\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button matTooltip=\"Filtra\" [attr.aria-label]=\"'Filtra'\"\r\n          [matMenuTriggerFor]=\"menuFilter\" color=\"primary\">\r\n          <mat-icon>filter_alt</mat-icon> {{filterOptionsInfo}} <mat-icon class=\"icon-menu-drop-down\">\r\n            arrow_drop_down</mat-icon>\r\n        </button>\r\n        <mat-menu #menuFilter=\"matMenu\" class=\"mat-menu-300\">\r\n          @for (f of filterOptions; track f) {\r\n\r\n          @if (f.divider) {\r\n          <mat-divider></mat-divider>\r\n          }\r\n          @if (f.groupName) {\r\n          <span style='font-size:small; padding: 2px 4px;'><i><b>{{f.groupName}}</b></i></span>\r\n          }\r\n          @if (!f.groupName && !f.divider) {\r\n          <button mat-menu-item (click)=\"doFilterByOptions(f)\" [attr.aria-label]=\"f.description\">\r\n            @if (f.radio && f.value) {\r\n            <span style=\"padding-left:40px\"></span>\r\n            }\r\n            <mat-icon>{{f.icon}}</mat-icon> {{f.title}}\r\n          </button>\r\n          }\r\n\r\n          }\r\n        </mat-menu>\r\n      </div>\r\n      }\r\n      @if (canEdit() || canAppend() || canView() || canDelete()) {\r\n      <div fxFlex=\"*\" fxLayoutAlign=\"end\" style=\"white-space:nowrap\">\r\n        @if (canAppend()) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"doAppend()\">\r\n          <mat-icon aria-label=\"Aggiungi\" matTooltip=\"Aggiungi\">add</mat-icon>\r\n        </button>\r\n        }\r\n        @if (canEdit()) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"doEdit()\">\r\n          <mat-icon aria-label=\"Modifica\" matTooltip=\"Modifica\">edit</mat-icon>\r\n        </button>\r\n        }\r\n        @if (canView()) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"doView()\">\r\n          <mat-icon aria-label=\"Mostra\" matTooltip=\"Mostra\">visibility</mat-icon>\r\n        </button>\r\n        }\r\n        @if (canDelete()) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"doDelete()\">\r\n          <mat-icon aria-label=\"Elimina\" matTooltip=\"Elimina\">delete</mat-icon>\r\n        </button>\r\n        }\r\n      </div>\r\n      }\r\n    </div>\r\n  </div>\r\n  @if ((dialogData.multi || dialogData.header) && dialogData.items?.length > 0) {\r\n  <div>\r\n    <div fxLayout=\"row\" fxFalyoutGap=\"10px\" fxFill style=\"padding-top: 10px;\">\r\n      <div fxFlex=\"72px\" fxFlexAlign=\"center\" style=\"padding-left: 8px;\">\r\n        @if (dialogData.multi) {\r\n        <mat-checkbox color=\"primary\" (change)=\"$event ? masterSelectionToggle($event) : null\"\r\n          [indeterminate]=\"selectionMasterIndeterminate()\" [checked]=\"selectionMasterChecked()\"\r\n          [attr.aria-label]=\"'Seleziona/deseleziona tutto'\" matTooltip=\"Seleziona/deseleziona tutto\">\r\n        </mat-checkbox>\r\n        }\r\n      </div>\r\n      <div fxFlex=\"100\" fxFlexAlign=\"center\">\r\n        @if (dialogData.header) {\r\n        <div [innerHtml]=\"dialogData.header | safeHtml\"></div>\r\n        }\r\n      </div>\r\n    </div>\r\n  </div>\r\n  }\r\n</div>\r\n<div mat-dialog-content>\r\n  <div fxLayout=\"column\" fxFill>\r\n    @if (dialogData.canLookup && (!dialogData.items || dialogData.items.length == 0)) {\r\n    <div class=\"message\"><i>\r\n        @if (!dialogData.emptyMessage) {\r\n        <span>Nessun elemento da visualizzare.<br>Esegui una nuova ricerca o modifica quella\r\n          esistente.\r\n          @if (dialogData.maxItems > 0) {\r\n          <span>Saranno mostrati al massimo {{dialogData.maxItems}} elementi.</span>\r\n          }\r\n        </span>\r\n        } @else {\r\n        <span [innerHtml]=\"dialogData.emptyMessage | safeHtml\"></span>\r\n        }\r\n      </i>\r\n    </div>\r\n    }\r\n    <mat-selection-list #selection (selectionChange)=\"select($event)\" dense hideSingleSelectionIndicator=\"true\">\r\n      @for (item of (dialogData.items | search: (!dialogData.canLookup ? filterText : '')); track item) {\r\n      <mat-list-option [value]=\"item\" [selected]=\"item.selected\" checkboxPosition=\"before\" >\r\n        <div [innerHtml]=\"item.template | safeHtml\"></div>\r\n      </mat-list-option>\r\n      }\r\n    </mat-selection-list>\r\n  </div>\r\n</div>\r\n<div mat-dialog-actions>\r\n  <div fxLayout=\"column\" fxFill>\r\n    <div fxLayout=\"row\" fxLayoutAlign=\"space-between center\" fxLayoutGap=\"10px\" fxFill>\r\n      <div style=\"padding-left:20px\">\r\n        @if (selectionInfo()) {\r\n        <span class=\"small\">selezione: &nbsp;</span><span class=\"bold\">{{selectionInfo()}}</span>\r\n        }\r\n      </div>\r\n      <div fxFlexAlign=\"center\">\r\n        @if (canPaginate()) {\r\n        <mat-paginator #paginator [hidePageSize]=\"true\" [pageSize]=\"dialogData.pageSize\" [showFirstLastButtons]=\"true\"\r\n          (page)=\"doLookupPage($event)\" [length]=\"dialogData.items?.length ?? 0\"></mat-paginator>\r\n\r\n        }\r\n      </div>\r\n    </div>\r\n    <div fxLayout=\"row\" fxLayoutAlign=\"end\" fxFill>\r\n      <button mat-flat-button color=\"primary\" (click)=\"ok()\" [disabled]=\"okDisabled()\">\r\n        <span>{{dialogData.mustSelect ? dialogData.okCaption : 'Chiudi'}}</span>\r\n      </button>\r\n      @if (dialogData.mustSelect) {\r\n      <button mat-button mat-dialog-close cdkFocusInitial color=\"primary\">\r\n        <span>Annulla</span>\r\n      </button>\r\n      }\r\n    </div>\r\n  </div>\r\n</div>"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, inject, output } from '@angular/core';
|
|
2
2
|
import { FormsModule } from '@angular/forms';
|
|
3
3
|
import { MatButtonModule } from '@angular/material/button';
|
|
4
4
|
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
@@ -13,7 +13,7 @@ import * as i4 from "@angular/forms";
|
|
|
13
13
|
import * as i5 from "@arsedizioni/ars-utils/core";
|
|
14
14
|
export class SelectFileDialogComponent {
|
|
15
15
|
constructor() {
|
|
16
|
-
this.done =
|
|
16
|
+
this.done = output();
|
|
17
17
|
this.dialogRef = inject((MatDialogRef));
|
|
18
18
|
this.dialogData = inject(MAT_DIALOG_DATA);
|
|
19
19
|
this.file = null;
|
|
@@ -50,7 +50,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
|
|
|
50
50
|
type: Component,
|
|
51
51
|
args: [{ host: { 'Bind': SystemUtils.generateUUID() }, standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [MatDialogTitle, MatDialogContent, FlexModule, MatButtonModule, MatCheckboxModule, FormsModule,
|
|
52
52
|
MatDialogActions, MatDialogClose, ArsCoreModule, SafeHtmlPipe], template: "<h2 mat-dialog-title>{{dialogData.title}}</h2>\r\n@if (dialogData.description) {\r\n<div style=\"padding: 0 24px 24px 24px\" [innerHtml]=\"dialogData.description | safeHtml\"></div>\r\n}\r\n<div mat-dialog-content>\r\n <div fxLayout=\"column\" fxLayoutGap=\"32px\" fxFill>\r\n <div fxFlex=\"*\" fxLayout=\"column\" fxLayoutAlign=\"center center\" fxFill>\r\n <div class=\"selectfile-file\">\r\n <div style=\"text-align: center\">\r\n <input #_file type=\"file\" [hidden]=\"true\" (change)=\"update($event)\" />\r\n <button type=\"button\" mat-button color=\"primary\" (click)=\"_file.click()\">Seleziona file...</button>\r\n </div>\r\n @if (file) {\r\n <div class=\"truncated selectfile-info\">\r\n <div class=\"small\"><i>{{file.name}}</i></div>\r\n <div class=\"small\">Dimensioni: <i>{{size(file.size)}}</i></div>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n @if (dialogData.options) {\r\n <div>\r\n @for (o of dialogData.options; track $index; let i = $index) {\r\n <div>\r\n <mat-checkbox color=\"primary\" [(ngModel)]=\"o.value\" name=\"opt_{{i}}\">\r\n {{o.description}}\r\n </mat-checkbox>\r\n </div>\r\n }\r\n </div>\r\n }\r\n </div>\r\n</div>\r\n<div mat-dialog-actions>\r\n <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n <div fxFlex=\"50\">\r\n @if (dialogData.helpLink) {\r\n <a mat-button href=\"{{dialogData.helpLink}}\" target=\"_blank\" color=\"primary\">{{dialogData.helpCaption}}</a>\r\n }\r\n </div>\r\n <div fxFlex=\"50\" fxLayoutAlign=\"end\">\r\n <button mat-flat-button color=\"primary\" (click)=\"ok()\" [disabled]=\"!file\">{{dialogData.okCaption}}</button>\r\n <button mat-button [mat-dialog-close]=\"true\" color=\"primary\">Annulla</button>\r\n </div>\r\n </div>\r\n</div>", styles: [".dialog-info{font-size:x-small;font-weight:700;text-align:right;padding:10px}.dialog-info-green,.dialog-info-ok{color:var(--ars-color-ok, #388E3C)}.dialog-info-red,.dialog-info-error{color:var(--mat-form-field-error-text-color, #a80710)}.dialog-header{padding-bottom:20px}.dialog-close{margin-right:10px;margin-top:10px}.dialog-menu{margin-left:10px;margin-top:10px}.dialog-title{padding:0 24px}.section-title{font-size:large;font-weight:600;padding-top:10px;padding-bottom:8px}.center{text-align:center}.wide{min-width:100%!important;max-width:100%!important;width:100%!important}.fill{min-width:100%!important;max-width:100%!important;width:100%!important;min-height:100%!important;max-height:100%!important;height:100%!important}.scroll-auto{overflow:auto;height:100%}.scroll-hidden{overflow:hidden;height:100%}b{font-weight:700}.large{font-size:large!important}.smaller{font-size:smaller}.small{font-size:small!important;line-height:16px}.small-icon-button{width:1.5rem!important;height:1.5rem!important;padding:0!important;display:inline-flex!important;align-items:center;justify-content:center}.small-icon-button .mat-mdc-button-touch-target{width:1.5rem!important;height:1.5rem!important}.x-small{font-size:x-small!important;line-height:14px}.bold{font-weight:700}.uppercase{text-transform:uppercase!important}.lowercase{text-transform:lowercase!important}.truncated{min-width:0;max-width:100%}.truncated span,.truncated div{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clipped{min-width:0;max-width:100%}.clipped span,.clipped div{white-space:nowrap;overflow:hidden;text-overflow:clip}.accent{color:var(--ars-color-accent, #7894ae)!important}.primary{color:var(--ars-color-primary, #00a293)!important}.secondary{color:var(--ars-color-secondary, #4a635f)!important}.error{color:var(--ars-color-error, #ff5449)!important}.warning{color:var(--ars-color-warning, #FFC107)!important}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;background-color:var(--ars-color-overlay, rgba(255, 255, 255, .75))}.drawer-content{padding-top:10px}.drawer,.drawer-small{min-width:420px!important;max-width:420px!important;padding:20px 0 0}.drawer .title-container,.drawer-small .title-container{padding:20px 10px}.drawer .title-container-with-loader,.drawer-small .title-container-with-loader{padding:14px 10px 20px}.drawer .title,.drawer-small .title{font-size:1.2em;font-weight:600;padding-left:10px;min-width:200px;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer .accordion-panel,.drawer-small .accordion-panel{background-color:transparent!important}.drawer .accordion-header,.drawer-small .accordion-header{padding-left:15px;padding-right:20px;border-radius:var(--mat-expansion-container-shape)}.drawer .mat-expansion-panel-body,.drawer-small .mat-expansion-panel-body{padding-bottom:20px!important}.drawer-with-loader{padding-top:0!important}.drawer-transparent{background-color:transparent}.drawer-small{min-width:360px!important;max-width:360px!important}.drawer-small .title{min-width:150px;width:100%}@media screen and (min-width: 0px) and (max-width: 359px){.drawer{min-width:360px!important;max-width:360px!important}.drawer .title{min-width:150px}}.fade-in{animation:fadein .5s linear}@keyframes fadein{0%{opacity:0}to{opacity:1}}@media (prefers-color-scheme: dark){.dialog-info-green,.dialog-info-ok{color:var(--ars-color-ok, #4CAF50)}.dialog-info-red,.dialog-info-error{color:var(--mat-form-field-error-text-color, #ff5449)}b{font-weight:600}}.selectfile-file{padding:20px;width:320px;border:5px dotted #eee}.selectfile-info{width:100%;margin-top:30px;text-align:center}.selectfile-description{padding:0 24px 24px}\n"] }]
|
|
53
|
-
}]
|
|
54
|
-
|
|
55
|
-
}] } });
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWZpbGUtZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fycy11dGlscy91aS5hcHBsaWNhdGlvbi91aS9kaWFsb2dzL3NlbGVjdC1maWxlL3NlbGVjdC1maWxlLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnMtdXRpbHMvdWkuYXBwbGljYXRpb24vdWkvZGlhbG9ncy9zZWxlY3QtZmlsZS9zZWxlY3QtZmlsZS1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLEVBQUUsY0FBYyxFQUFFLGdCQUFnQixFQUFFLFlBQVksRUFBRSxjQUFjLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM3SSxPQUFPLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN2RixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7Ozs7Ozs7QUFZeEQsTUFBTSxPQUFPLHlCQUF5QjtJQVR0QztRQVVZLFNBQUksR0FBRyxJQUFJLFlBQVksRUFBYyxDQUFDO1FBQ3hDLGNBQVMsR0FBRyxNQUFNLENBQUMsQ0FBQSxZQUF1QyxDQUFBLENBQUMsQ0FBQztRQUMxRCxlQUFVLEdBQTBCLE1BQU0sQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUU1RCxTQUFJLEdBQWdCLElBQUksQ0FBQztLQThCcEM7SUEzQkM7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLENBQU07UUFDWCxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNoQyxDQUFDO0lBQ0gsQ0FBQztJQUVEOzs7T0FHRztJQUNILElBQUksQ0FBQyxJQUFZO1FBQ2YsT0FBTyxXQUFXLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFRDs7T0FFRztJQUNILEVBQUU7UUFDQSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3ZCLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDeEUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ1YsQ0FBQzs4R0FsQ1UseUJBQXlCO2tHQUF6Qix5QkFBeUIseUdBUnBCLFdBQVcsQ0FBQyxZQUFZLEVBQUUsOEJDVjVDLDAyREE2Q00sZ3FIRDlCTSxjQUFjLCtIQUFHLGdCQUFnQix3R0FBRSxVQUFVLHU2RUFBRSxlQUFlLHdZQUFHLGlCQUFpQixvWUFBRSxXQUFXLCtWQUN2RyxnQkFBZ0IsNEhBQUUsY0FBYyxvTEFBRSxhQUFhOzsyRkFFdEMseUJBQXlCO2tCQVRyQyxTQUFTOzJCQUNGLEVBQUUsTUFBTSxFQUFFLFdBQVcsQ0FBQyxZQUFZLEVBQUUsRUFBRSxjQUdoQyxJQUFJLG1CQUNDLHVCQUF1QixDQUFDLE1BQU0sV0FDdEMsQ0FBQyxjQUFjLEVBQUcsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRyxpQkFBaUIsRUFBRSxXQUFXO3dCQUN2RyxnQkFBZ0IsRUFBRSxjQUFjLEVBQUUsYUFBYSxFQUFFLFlBQVksQ0FBQzs4QkFHdEQsSUFBSTtzQkFBYixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBPdXRwdXQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcclxuaW1wb3J0IHsgTWF0Q2hlY2tib3hNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jaGVja2JveCc7XHJcbmltcG9ydCB7IE1BVF9ESUFMT0dfREFUQSwgTWF0RGlhbG9nQWN0aW9ucywgTWF0RGlhbG9nQ2xvc2UsIE1hdERpYWxvZ0NvbnRlbnQsIE1hdERpYWxvZ1JlZiwgTWF0RGlhbG9nVGl0bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5pbXBvcnQgeyBBcnNDb3JlTW9kdWxlLCBTYWZlSHRtbFBpcGUsIFN5c3RlbVV0aWxzIH0gZnJvbSAnQGFyc2VkaXppb25pL2Fycy11dGlscy9jb3JlJztcclxuaW1wb3J0IHsgRmxleE1vZHVsZSB9IGZyb20gJ0BuZ2JyYWNrZXQvbmd4LWxheW91dC9mbGV4JztcclxuaW1wb3J0IHsgU2VsZWN0RmlsZSwgU2VsZWN0RmlsZURpYWxvZ0RhdGEgfSBmcm9tICcuLi8uLi9kZWZpbml0aW9ucyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBob3N0OiB7ICdCaW5kJzogU3lzdGVtVXRpbHMuZ2VuZXJhdGVVVUlEKCkgfSxcclxuICB0ZW1wbGF0ZVVybDogJy4vc2VsZWN0LWZpbGUtZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9zZWxlY3QtZmlsZS1kaWFsb2cuY29tcG9uZW50LnNjc3MnXSxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gIGltcG9ydHM6IFtNYXREaWFsb2dUaXRsZSwgIE1hdERpYWxvZ0NvbnRlbnQsIEZsZXhNb2R1bGUsIE1hdEJ1dHRvbk1vZHVsZSwgIE1hdENoZWNrYm94TW9kdWxlLCBGb3Jtc01vZHVsZSwgXHJcbiAgICBNYXREaWFsb2dBY3Rpb25zLCBNYXREaWFsb2dDbG9zZSwgQXJzQ29yZU1vZHVsZSwgU2FmZUh0bWxQaXBlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2VsZWN0RmlsZURpYWxvZ0NvbXBvbmVudCB7XHJcbiAgQE91dHB1dCgpIGRvbmUgPSBuZXcgRXZlbnRFbWl0dGVyPFNlbGVjdEZpbGU+KCk7XHJcbiAgcHJpdmF0ZSBkaWFsb2dSZWYgPSBpbmplY3QoTWF0RGlhbG9nUmVmPFNlbGVjdEZpbGVEaWFsb2dDb21wb25lbnQ+KTtcclxuICBwcm90ZWN0ZWQgZGlhbG9nRGF0YSA6IFNlbGVjdEZpbGVEaWFsb2dEYXRhID0gaW5qZWN0KE1BVF9ESUFMT0dfREFUQSk7IFxyXG4gIFxyXG4gIHByb3RlY3RlZCBmaWxlOiBGaWxlIHwgbnVsbCA9IG51bGw7XHJcblxyXG5cclxuICAvKipcclxuICAgKiBVcGRhdGUgcHJldmlld1xyXG4gICAqIEBwYXJhbSBlIDogdGhlIGV2ZW50XHJcbiAgICovXHJcbiAgdXBkYXRlKGU6IGFueSkge1xyXG4gICAgaWYgKGUudGFyZ2V0LmZpbGVzKSB7XHJcbiAgICAgIHRoaXMuZmlsZSA9IGUudGFyZ2V0LmZpbGVzWzBdO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogRm9ybWF0IHNpemVcclxuICAgKiBAcGFyYW0gc2l6ZSB0aGUgZmlsZSBzaXplXHJcbiAgICovXHJcbiAgc2l6ZShzaXplOiBudW1iZXIpIHtcclxuICAgIHJldHVybiBTeXN0ZW1VdGlscy5mb3JtYXRGaWxlU2l6ZShzaXplKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFN1Ym1pdCBzZWxlY3Rpb25cclxuICAgKi9cclxuICBvaygpIHtcclxuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKCk7XHJcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgdGhpcy5kb25lLmVtaXQoeyBmaWxlOiB0aGlzLmZpbGUsIG9wdGlvbnM6IHRoaXMuZGlhbG9nRGF0YS5vcHRpb25zIH0pO1xyXG4gICAgfSwgNTAwKTtcclxuICB9XHJcbn1cclxuXHJcbiIsIjxoMiBtYXQtZGlhbG9nLXRpdGxlPnt7ZGlhbG9nRGF0YS50aXRsZX19PC9oMj5cclxuQGlmIChkaWFsb2dEYXRhLmRlc2NyaXB0aW9uKSB7XHJcbjxkaXYgc3R5bGU9XCJwYWRkaW5nOiAwIDI0cHggMjRweCAyNHB4XCIgW2lubmVySHRtbF09XCJkaWFsb2dEYXRhLmRlc2NyaXB0aW9uIHwgc2FmZUh0bWxcIj48L2Rpdj5cclxufVxyXG48ZGl2IG1hdC1kaWFsb2ctY29udGVudD5cclxuICA8ZGl2IGZ4TGF5b3V0PVwiY29sdW1uXCIgZnhMYXlvdXRHYXA9XCIzMnB4XCIgZnhGaWxsPlxyXG4gICAgPGRpdiBmeEZsZXg9XCIqXCIgZnhMYXlvdXQ9XCJjb2x1bW5cIiBmeExheW91dEFsaWduPVwiY2VudGVyIGNlbnRlclwiIGZ4RmlsbD5cclxuICAgICAgPGRpdiBjbGFzcz1cInNlbGVjdGZpbGUtZmlsZVwiPlxyXG4gICAgICAgIDxkaXYgc3R5bGU9XCJ0ZXh0LWFsaWduOiBjZW50ZXJcIj5cclxuICAgICAgICAgIDxpbnB1dCAjX2ZpbGUgdHlwZT1cImZpbGVcIiBbaGlkZGVuXT1cInRydWVcIiAoY2hhbmdlKT1cInVwZGF0ZSgkZXZlbnQpXCIgLz5cclxuICAgICAgICAgIDxidXR0b24gdHlwZT1cImJ1dHRvblwiIG1hdC1idXR0b24gY29sb3I9XCJwcmltYXJ5XCIgKGNsaWNrKT1cIl9maWxlLmNsaWNrKClcIj5TZWxlemlvbmEgZmlsZS4uLjwvYnV0dG9uPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIEBpZiAoZmlsZSkge1xyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJ0cnVuY2F0ZWQgc2VsZWN0ZmlsZS1pbmZvXCI+XHJcbiAgICAgICAgICA8ZGl2IGNsYXNzPVwic21hbGxcIj48aT57e2ZpbGUubmFtZX19PC9pPjwvZGl2PlxyXG4gICAgICAgICAgPGRpdiBjbGFzcz1cInNtYWxsXCI+RGltZW5zaW9uaTogPGk+e3tzaXplKGZpbGUuc2l6ZSl9fTwvaT48L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICB9XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgICBAaWYgKGRpYWxvZ0RhdGEub3B0aW9ucykge1xyXG4gICAgPGRpdj5cclxuICAgICAgQGZvciAobyBvZiBkaWFsb2dEYXRhLm9wdGlvbnM7IHRyYWNrICRpbmRleDsgbGV0IGkgPSAkaW5kZXgpIHtcclxuICAgICAgPGRpdj5cclxuICAgICAgICA8bWF0LWNoZWNrYm94IGNvbG9yPVwicHJpbWFyeVwiIFsobmdNb2RlbCldPVwiby52YWx1ZVwiIG5hbWU9XCJvcHRfe3tpfX1cIj5cclxuICAgICAgICAgIHt7by5kZXNjcmlwdGlvbn19XHJcbiAgICAgICAgPC9tYXQtY2hlY2tib3g+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICB9XHJcbiAgICA8L2Rpdj5cclxuICAgIH1cclxuICA8L2Rpdj5cclxuPC9kaXY+XHJcbjxkaXYgbWF0LWRpYWxvZy1hY3Rpb25zPlxyXG4gIDxkaXYgZnhMYXlvdXQ9XCJyb3dcIiBmeExheW91dEdhcD1cIjEwcHhcIiBmeEZpbGw+XHJcbiAgICA8ZGl2IGZ4RmxleD1cIjUwXCI+XHJcbiAgICAgIEBpZiAoZGlhbG9nRGF0YS5oZWxwTGluaykge1xyXG4gICAgICA8YSBtYXQtYnV0dG9uIGhyZWY9XCJ7e2RpYWxvZ0RhdGEuaGVscExpbmt9fVwiIHRhcmdldD1cIl9ibGFua1wiIGNvbG9yPVwicHJpbWFyeVwiPnt7ZGlhbG9nRGF0YS5oZWxwQ2FwdGlvbn19PC9hPlxyXG4gICAgICB9XHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgZnhGbGV4PVwiNTBcIiBmeExheW91dEFsaWduPVwiZW5kXCI+XHJcbiAgICAgIDxidXR0b24gbWF0LWZsYXQtYnV0dG9uIGNvbG9yPVwicHJpbWFyeVwiIChjbGljayk9XCJvaygpXCIgW2Rpc2FibGVkXT1cIiFmaWxlXCI+e3tkaWFsb2dEYXRhLm9rQ2FwdGlvbn19PC9idXR0b24+XHJcbiAgICAgIDxidXR0b24gbWF0LWJ1dHRvbiBbbWF0LWRpYWxvZy1jbG9zZV09XCJ0cnVlXCIgY29sb3I9XCJwcmltYXJ5XCI+QW5udWxsYTwvYnV0dG9uPlxyXG4gICAgPC9kaXY+XHJcbiAgPC9kaXY+XHJcbjwvZGl2PiJdfQ==
|
|
53
|
+
}] });
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWZpbGUtZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fycy11dGlscy91aS5hcHBsaWNhdGlvbi91aS9kaWFsb2dzL3NlbGVjdC1maWxlL3NlbGVjdC1maWxlLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnMtdXRpbHMvdWkuYXBwbGljYXRpb24vdWkvZGlhbG9ncy9zZWxlY3QtZmlsZS9zZWxlY3QtZmlsZS1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDL0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSxjQUFjLEVBQUUsZ0JBQWdCLEVBQUUsWUFBWSxFQUFFLGNBQWMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzdJLE9BQU8sRUFBRSxhQUFhLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3ZGLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7Ozs7OztBQVl4RCxNQUFNLE9BQU8seUJBQXlCO0lBVHRDO1FBVUUsU0FBSSxHQUFHLE1BQU0sRUFBYyxDQUFDO1FBQ3BCLGNBQVMsR0FBRyxNQUFNLENBQUMsQ0FBQSxZQUF1QyxDQUFBLENBQUMsQ0FBQztRQUMxRCxlQUFVLEdBQTBCLE1BQU0sQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUU1RCxTQUFJLEdBQWdCLElBQUksQ0FBQztLQThCcEM7SUEzQkM7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLENBQU07UUFDWCxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNoQyxDQUFDO0lBQ0gsQ0FBQztJQUVEOzs7T0FHRztJQUNILElBQUksQ0FBQyxJQUFZO1FBQ2YsT0FBTyxXQUFXLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFRDs7T0FFRztJQUNILEVBQUU7UUFDQSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3ZCLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDeEUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ1YsQ0FBQzs4R0FsQ1UseUJBQXlCO2tHQUF6Qix5QkFBeUIseUdBUnBCLFdBQVcsQ0FBQyxZQUFZLEVBQUUsOEJDVjVDLDAyREE2Q00sZ3FIRDlCTSxjQUFjLCtIQUFHLGdCQUFnQix3R0FBRSxVQUFVLHU2RUFBRSxlQUFlLHdZQUFHLGlCQUFpQixvWUFBRSxXQUFXLCtWQUN2RyxnQkFBZ0IsNEhBQUUsY0FBYyxvTEFBRSxhQUFhOzsyRkFFdEMseUJBQXlCO2tCQVRyQyxTQUFTOzJCQUNGLEVBQUUsTUFBTSxFQUFFLFdBQVcsQ0FBQyxZQUFZLEVBQUUsRUFBRSxjQUdoQyxJQUFJLG1CQUNDLHVCQUF1QixDQUFDLE1BQU0sV0FDdEMsQ0FBQyxjQUFjLEVBQUcsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRyxpQkFBaUIsRUFBRSxXQUFXO3dCQUN2RyxnQkFBZ0IsRUFBRSxjQUFjLEVBQUUsYUFBYSxFQUFFLFlBQVksQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdCwgb3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xyXG5pbXBvcnQgeyBNYXRDaGVja2JveE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NoZWNrYm94JztcclxuaW1wb3J0IHsgTUFUX0RJQUxPR19EQVRBLCBNYXREaWFsb2dBY3Rpb25zLCBNYXREaWFsb2dDbG9zZSwgTWF0RGlhbG9nQ29udGVudCwgTWF0RGlhbG9nUmVmLCBNYXREaWFsb2dUaXRsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7IEFyc0NvcmVNb2R1bGUsIFNhZmVIdG1sUGlwZSwgU3lzdGVtVXRpbHMgfSBmcm9tICdAYXJzZWRpemlvbmkvYXJzLXV0aWxzL2NvcmUnO1xyXG5pbXBvcnQgeyBGbGV4TW9kdWxlIH0gZnJvbSAnQG5nYnJhY2tldC9uZ3gtbGF5b3V0L2ZsZXgnO1xyXG5pbXBvcnQgeyBTZWxlY3RGaWxlLCBTZWxlY3RGaWxlRGlhbG9nRGF0YSB9IGZyb20gJy4uLy4uL2RlZmluaXRpb25zJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIGhvc3Q6IHsgJ0JpbmQnOiBTeXN0ZW1VdGlscy5nZW5lcmF0ZVVVSUQoKSB9LFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9zZWxlY3QtZmlsZS1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3NlbGVjdC1maWxlLWRpYWxvZy5jb21wb25lbnQuc2NzcyddLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbiAgaW1wb3J0czogW01hdERpYWxvZ1RpdGxlLCAgTWF0RGlhbG9nQ29udGVudCwgRmxleE1vZHVsZSwgTWF0QnV0dG9uTW9kdWxlLCAgTWF0Q2hlY2tib3hNb2R1bGUsIEZvcm1zTW9kdWxlLCBcclxuICAgIE1hdERpYWxvZ0FjdGlvbnMsIE1hdERpYWxvZ0Nsb3NlLCBBcnNDb3JlTW9kdWxlLCBTYWZlSHRtbFBpcGVdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZWxlY3RGaWxlRGlhbG9nQ29tcG9uZW50IHtcclxuICBkb25lID0gb3V0cHV0PFNlbGVjdEZpbGU+KCk7XHJcbiAgcHJpdmF0ZSBkaWFsb2dSZWYgPSBpbmplY3QoTWF0RGlhbG9nUmVmPFNlbGVjdEZpbGVEaWFsb2dDb21wb25lbnQ+KTtcclxuICBwcm90ZWN0ZWQgZGlhbG9nRGF0YSA6IFNlbGVjdEZpbGVEaWFsb2dEYXRhID0gaW5qZWN0KE1BVF9ESUFMT0dfREFUQSk7IFxyXG4gIFxyXG4gIHByb3RlY3RlZCBmaWxlOiBGaWxlIHwgbnVsbCA9IG51bGw7XHJcblxyXG5cclxuICAvKipcclxuICAgKiBVcGRhdGUgcHJldmlld1xyXG4gICAqIEBwYXJhbSBlIDogdGhlIGV2ZW50XHJcbiAgICovXHJcbiAgdXBkYXRlKGU6IGFueSkge1xyXG4gICAgaWYgKGUudGFyZ2V0LmZpbGVzKSB7XHJcbiAgICAgIHRoaXMuZmlsZSA9IGUudGFyZ2V0LmZpbGVzWzBdO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogRm9ybWF0IHNpemVcclxuICAgKiBAcGFyYW0gc2l6ZSB0aGUgZmlsZSBzaXplXHJcbiAgICovXHJcbiAgc2l6ZShzaXplOiBudW1iZXIpIHtcclxuICAgIHJldHVybiBTeXN0ZW1VdGlscy5mb3JtYXRGaWxlU2l6ZShzaXplKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFN1Ym1pdCBzZWxlY3Rpb25cclxuICAgKi9cclxuICBvaygpIHtcclxuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKCk7XHJcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgdGhpcy5kb25lLmVtaXQoeyBmaWxlOiB0aGlzLmZpbGUsIG9wdGlvbnM6IHRoaXMuZGlhbG9nRGF0YS5vcHRpb25zIH0pO1xyXG4gICAgfSwgNTAwKTtcclxuICB9XHJcbn1cclxuXHJcbiIsIjxoMiBtYXQtZGlhbG9nLXRpdGxlPnt7ZGlhbG9nRGF0YS50aXRsZX19PC9oMj5cclxuQGlmIChkaWFsb2dEYXRhLmRlc2NyaXB0aW9uKSB7XHJcbjxkaXYgc3R5bGU9XCJwYWRkaW5nOiAwIDI0cHggMjRweCAyNHB4XCIgW2lubmVySHRtbF09XCJkaWFsb2dEYXRhLmRlc2NyaXB0aW9uIHwgc2FmZUh0bWxcIj48L2Rpdj5cclxufVxyXG48ZGl2IG1hdC1kaWFsb2ctY29udGVudD5cclxuICA8ZGl2IGZ4TGF5b3V0PVwiY29sdW1uXCIgZnhMYXlvdXRHYXA9XCIzMnB4XCIgZnhGaWxsPlxyXG4gICAgPGRpdiBmeEZsZXg9XCIqXCIgZnhMYXlvdXQ9XCJjb2x1bW5cIiBmeExheW91dEFsaWduPVwiY2VudGVyIGNlbnRlclwiIGZ4RmlsbD5cclxuICAgICAgPGRpdiBjbGFzcz1cInNlbGVjdGZpbGUtZmlsZVwiPlxyXG4gICAgICAgIDxkaXYgc3R5bGU9XCJ0ZXh0LWFsaWduOiBjZW50ZXJcIj5cclxuICAgICAgICAgIDxpbnB1dCAjX2ZpbGUgdHlwZT1cImZpbGVcIiBbaGlkZGVuXT1cInRydWVcIiAoY2hhbmdlKT1cInVwZGF0ZSgkZXZlbnQpXCIgLz5cclxuICAgICAgICAgIDxidXR0b24gdHlwZT1cImJ1dHRvblwiIG1hdC1idXR0b24gY29sb3I9XCJwcmltYXJ5XCIgKGNsaWNrKT1cIl9maWxlLmNsaWNrKClcIj5TZWxlemlvbmEgZmlsZS4uLjwvYnV0dG9uPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIEBpZiAoZmlsZSkge1xyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJ0cnVuY2F0ZWQgc2VsZWN0ZmlsZS1pbmZvXCI+XHJcbiAgICAgICAgICA8ZGl2IGNsYXNzPVwic21hbGxcIj48aT57e2ZpbGUubmFtZX19PC9pPjwvZGl2PlxyXG4gICAgICAgICAgPGRpdiBjbGFzcz1cInNtYWxsXCI+RGltZW5zaW9uaTogPGk+e3tzaXplKGZpbGUuc2l6ZSl9fTwvaT48L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICB9XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgICBAaWYgKGRpYWxvZ0RhdGEub3B0aW9ucykge1xyXG4gICAgPGRpdj5cclxuICAgICAgQGZvciAobyBvZiBkaWFsb2dEYXRhLm9wdGlvbnM7IHRyYWNrICRpbmRleDsgbGV0IGkgPSAkaW5kZXgpIHtcclxuICAgICAgPGRpdj5cclxuICAgICAgICA8bWF0LWNoZWNrYm94IGNvbG9yPVwicHJpbWFyeVwiIFsobmdNb2RlbCldPVwiby52YWx1ZVwiIG5hbWU9XCJvcHRfe3tpfX1cIj5cclxuICAgICAgICAgIHt7by5kZXNjcmlwdGlvbn19XHJcbiAgICAgICAgPC9tYXQtY2hlY2tib3g+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICB9XHJcbiAgICA8L2Rpdj5cclxuICAgIH1cclxuICA8L2Rpdj5cclxuPC9kaXY+XHJcbjxkaXYgbWF0LWRpYWxvZy1hY3Rpb25zPlxyXG4gIDxkaXYgZnhMYXlvdXQ9XCJyb3dcIiBmeExheW91dEdhcD1cIjEwcHhcIiBmeEZpbGw+XHJcbiAgICA8ZGl2IGZ4RmxleD1cIjUwXCI+XHJcbiAgICAgIEBpZiAoZGlhbG9nRGF0YS5oZWxwTGluaykge1xyXG4gICAgICA8YSBtYXQtYnV0dG9uIGhyZWY9XCJ7e2RpYWxvZ0RhdGEuaGVscExpbmt9fVwiIHRhcmdldD1cIl9ibGFua1wiIGNvbG9yPVwicHJpbWFyeVwiPnt7ZGlhbG9nRGF0YS5oZWxwQ2FwdGlvbn19PC9hPlxyXG4gICAgICB9XHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgZnhGbGV4PVwiNTBcIiBmeExheW91dEFsaWduPVwiZW5kXCI+XHJcbiAgICAgIDxidXR0b24gbWF0LWZsYXQtYnV0dG9uIGNvbG9yPVwicHJpbWFyeVwiIChjbGljayk9XCJvaygpXCIgW2Rpc2FibGVkXT1cIiFmaWxlXCI+e3tkaWFsb2dEYXRhLm9rQ2FwdGlvbn19PC9idXR0b24+XHJcbiAgICAgIDxidXR0b24gbWF0LWJ1dHRvbiBbbWF0LWRpYWxvZy1jbG9zZV09XCJ0cnVlXCIgY29sb3I9XCJwcmltYXJ5XCI+QW5udWxsYTwvYnV0dG9uPlxyXG4gICAgPC9kaXY+XHJcbiAgPC9kaXY+XHJcbjwvZGl2PiJdfQ==
|
package/esm2022/ui.application/ui/dialogs/select-picture/select-picture-dialog.component.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, inject, output, signal } from '@angular/core';
|
|
2
2
|
import { MatDialogRef, MAT_DIALOG_DATA, MatDialogTitle, MatDialogContent, MatDialogActions, MatDialogClose } from '@angular/material/dialog';
|
|
3
3
|
import { SystemUtils } from '@arsedizioni/ars-utils/core';
|
|
4
4
|
import { SafeHtmlPipe } from '@arsedizioni/ars-utils/core';
|
|
@@ -13,7 +13,7 @@ import * as i3 from "@angular/material/checkbox";
|
|
|
13
13
|
import * as i4 from "@angular/forms";
|
|
14
14
|
export class SelectPictureDialogComponent {
|
|
15
15
|
constructor() {
|
|
16
|
-
this.done =
|
|
16
|
+
this.done = output();
|
|
17
17
|
this.dialogRef = inject((MatDialogRef));
|
|
18
18
|
this.dialogData = inject(MAT_DIALOG_DATA);
|
|
19
19
|
this.file = null;
|
|
@@ -56,7 +56,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
|
|
|
56
56
|
type: Component,
|
|
57
57
|
args: [{ host: { 'Bind': SystemUtils.generateUUID() }, standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [MatDialogTitle, MatDialogContent, FlexModule, MatButtonModule, MatCheckboxModule, FormsModule,
|
|
58
58
|
MatDialogActions, MatDialogClose, SafeHtmlPipe], template: "<h2 mat-dialog-title>{{dialogData.title}}</h2>\r\n@if (dialogData.description) {\r\n<div class=\"selectpicture-description\" [innerHtml]=\"dialogData.description | safeHtml\"></div>\r\n}\r\n<div mat-dialog-content>\r\n <div fxLayout=\"column\" fxLayoutGap=\"32px\" fxFill>\r\n <div fxFlex=\"*\" fxLayout=\"column\" fxLayoutAlign=\"center center\" fxFill>\r\n <input #_file type=\"file\" [hidden]=\"true\" accept=\"image/*\" (change)=\"update($event)\" />\r\n <button type=\"button\" mat-button color=\"primary\" (click)=\"_file.click()\">Seleziona file...</button>\r\n @if (file) {\r\n <div class=\"selectpicture-info\">\r\n <img [src]=\"filePreview()\" class=\"preview\"><br />\r\n <span class=\"small truncated\"><i>{{file.name}}</i></span>\r\n <div><span class=\"small truncated\">Dimensioni: <i>{{size(file.size)}}</i></span></div>\r\n </div>\r\n }\r\n </div>\r\n @if (dialogData.options) {\r\n <div>\r\n @for (o of dialogData.options; track $index; let i = $index) {\r\n <div>\r\n <mat-checkbox color=\"primary\" [(ngModel)]=\"o.value\" name=\"opt_{{i}}\">\r\n {{o.description}}\r\n </mat-checkbox>\r\n </div>\r\n }\r\n </div>\r\n }\r\n </div>\r\n</div>\r\n<div mat-dialog-actions>\r\n <div fxLayout=\"row\" fxLayoutAlign=\"end\" fxFill>\r\n <button mat-flat-button (click)=\"ok()\" color=\"primary\" [disabled]=\"!file\">{{dialogData.okCaption}}</button>\r\n <button mat-button mat-dialog-close cdkFocusInitial color=\"primary\">Annulla</button>\r\n </div>\r\n</div>", styles: [".dialog-info{font-size:x-small;font-weight:700;text-align:right;padding:10px}.dialog-info-green,.dialog-info-ok{color:var(--ars-color-ok, #388E3C)}.dialog-info-red,.dialog-info-error{color:var(--mat-form-field-error-text-color, #a80710)}.dialog-header{padding-bottom:20px}.dialog-close{margin-right:10px;margin-top:10px}.dialog-menu{margin-left:10px;margin-top:10px}.dialog-title{padding:0 24px}.section-title{font-size:large;font-weight:600;padding-top:10px;padding-bottom:8px}.center{text-align:center}.wide{min-width:100%!important;max-width:100%!important;width:100%!important}.fill{min-width:100%!important;max-width:100%!important;width:100%!important;min-height:100%!important;max-height:100%!important;height:100%!important}.scroll-auto{overflow:auto;height:100%}.scroll-hidden{overflow:hidden;height:100%}b{font-weight:700}.large{font-size:large!important}.smaller{font-size:smaller}.small{font-size:small!important;line-height:16px}.small-icon-button{width:1.5rem!important;height:1.5rem!important;padding:0!important;display:inline-flex!important;align-items:center;justify-content:center}.small-icon-button .mat-mdc-button-touch-target{width:1.5rem!important;height:1.5rem!important}.x-small{font-size:x-small!important;line-height:14px}.bold{font-weight:700}.uppercase{text-transform:uppercase!important}.lowercase{text-transform:lowercase!important}.truncated{min-width:0;max-width:100%}.truncated span,.truncated div{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clipped{min-width:0;max-width:100%}.clipped span,.clipped div{white-space:nowrap;overflow:hidden;text-overflow:clip}.accent{color:var(--ars-color-accent, #7894ae)!important}.primary{color:var(--ars-color-primary, #00a293)!important}.secondary{color:var(--ars-color-secondary, #4a635f)!important}.error{color:var(--ars-color-error, #ff5449)!important}.warning{color:var(--ars-color-warning, #FFC107)!important}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;background-color:var(--ars-color-overlay, rgba(255, 255, 255, .75))}.drawer-content{padding-top:10px}.drawer,.drawer-small{min-width:420px!important;max-width:420px!important;padding:20px 0 0}.drawer .title-container,.drawer-small .title-container{padding:20px 10px}.drawer .title-container-with-loader,.drawer-small .title-container-with-loader{padding:14px 10px 20px}.drawer .title,.drawer-small .title{font-size:1.2em;font-weight:600;padding-left:10px;min-width:200px;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer .accordion-panel,.drawer-small .accordion-panel{background-color:transparent!important}.drawer .accordion-header,.drawer-small .accordion-header{padding-left:15px;padding-right:20px;border-radius:var(--mat-expansion-container-shape)}.drawer .mat-expansion-panel-body,.drawer-small .mat-expansion-panel-body{padding-bottom:20px!important}.drawer-with-loader{padding-top:0!important}.drawer-transparent{background-color:transparent}.drawer-small{min-width:360px!important;max-width:360px!important}.drawer-small .title{min-width:150px;width:100%}@media screen and (min-width: 0px) and (max-width: 359px){.drawer{min-width:360px!important;max-width:360px!important}.drawer .title{min-width:150px}}.fade-in{animation:fadein .5s linear}@keyframes fadein{0%{opacity:0}to{opacity:1}}@media (prefers-color-scheme: dark){.dialog-info-green,.dialog-info-ok{color:var(--ars-color-ok, #4CAF50)}.dialog-info-red,.dialog-info-error{color:var(--mat-form-field-error-text-color, #ff5449)}b{font-weight:600}}.selectpicture-file{padding:20px;width:320px;border:5px dotted #eee}.selectpicture-info{width:100%;margin-top:30px;text-align:center}.selectpicture-info .preview{max-height:300px;max-width:300px}.selectpicture-description{padding:0 24px 24px}\n"] }]
|
|
59
|
-
}]
|
|
60
|
-
|
|
61
|
-
}] } });
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-picture-dialog.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select-picture/select-picture-dialog.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select-picture/select-picture-dialog.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACzG,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,cAAc,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC7I,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;;;;;;AAYxD,MAAM,OAAO,4BAA4B;IATzC;QAUY,SAAI,GAAG,IAAI,YAAY,EAAc,CAAC;QAExC,cAAS,GAAG,MAAM,CAAC,CAAA,YAA0C,CAAA,CAAC,CAAC;QAC7D,eAAU,GAA0B,MAAM,CAAC,eAAe,CAAC,CAAC;QAE5D,SAAI,GAAgB,IAAI,CAAC;QACzB,gBAAW,GAAG,MAAM,CAAM,IAAI,CAAC,CAAC;KAmC3C;IAhCC;;;OAGG;IACH,MAAM,CAAC,CAAM;QACX,IAAI,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;YACnB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAC9B,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAChC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAO,EAAE,EAAE;gBAC1B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAE,EAAE,CAAC,MAAqB,CAAC,MAAM,CAAC,CAAC;YACzD,CAAC,CAAC;YACF,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,IAAI,CAAC,IAAY;QACf,OAAO,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED;;OAEG;IACH,EAAE;QACA,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACvB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC;QACxE,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;8GAzCU,4BAA4B;kGAA5B,4BAA4B,yGARvB,WAAW,CAAC,YAAY,EAAE,8BCZ5C,4jDAmCM,uuHDlBM,cAAc,+HAAG,gBAAgB,wGAAE,UAAU,u6EAAE,eAAe,2NAAG,iBAAiB,oYAAE,WAAW,+VACvG,gBAAgB,4HAAE,cAAc,gLAAE,YAAY;;2FAErC,4BAA4B;kBATxC,SAAS;2BACF,EAAE,MAAM,EAAE,WAAW,CAAC,YAAY,EAAE,EAAE,cAGhC,IAAI,mBACC,uBAAuB,CAAC,MAAM,WACtC,CAAC,cAAc,EAAG,gBAAgB,EAAE,UAAU,EAAE,eAAe,EAAG,iBAAiB,EAAE,WAAW;wBACvG,gBAAgB,EAAE,cAAc,EAAE,YAAY,CAAC;8BAGvC,IAAI;sBAAb,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Output, inject, signal } from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA, MatDialogTitle, MatDialogContent, MatDialogActions, MatDialogClose } from '@angular/material/dialog';\r\nimport { SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { SelectFile, SelectFileDialogData } from '../../definitions';\r\nimport { SafeHtmlPipe } from '@arsedizioni/ars-utils/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { FlexModule } from '@ngbracket/ngx-layout/flex';\r\n\r\n\r\n@Component({\r\n  host: { 'Bind': SystemUtils.generateUUID() },\r\n  templateUrl: './select-picture-dialog.component.html',\r\n  styleUrls: ['./select-picture-dialog.component.scss'],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [MatDialogTitle,  MatDialogContent, FlexModule, MatButtonModule,  MatCheckboxModule, FormsModule, \r\n    MatDialogActions, MatDialogClose, SafeHtmlPipe]\r\n})\r\nexport class SelectPictureDialogComponent {\r\n  @Output() done = new EventEmitter<SelectFile>();\r\n\r\n  private dialogRef = inject(MatDialogRef<SelectPictureDialogComponent>);\r\n  protected dialogData : SelectFileDialogData = inject(MAT_DIALOG_DATA); \r\n\r\n  protected file: File | null = null;\r\n  protected filePreview = signal<any>(null);\r\n\r\n\r\n  /**\r\n   * Update preview\r\n   * @param e : the event\r\n   */\r\n  update(e: any) {\r\n    if (e.target.files) {\r\n      this.file = e.target.files[0];\r\n      const reader = new FileReader();\r\n      reader.onload = (_e: any) => {\r\n        this.filePreview.set((_e.target as FileReader).result);\r\n      };\r\n      reader.readAsDataURL(e.target.files[0]);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Format size\r\n   * @param size the file size\r\n   */\r\n  size(size: number) {\r\n    return SystemUtils.formatFileSize(size);\r\n  }\r\n\r\n  /**\r\n   * Submit selection\r\n   */\r\n  ok() {\r\n    this.dialogRef.close();\r\n    setTimeout(() => {\r\n      this.done.emit({ file: this.file, options: this.dialogData.options });\r\n    }, 500);\r\n  }\r\n}\r\n\r\n","<h2 mat-dialog-title>{{dialogData.title}}</h2>\r\n@if (dialogData.description) {\r\n<div class=\"selectpicture-description\" [innerHtml]=\"dialogData.description | safeHtml\"></div>\r\n}\r\n<div mat-dialog-content>\r\n  <div fxLayout=\"column\" fxLayoutGap=\"32px\" fxFill>\r\n    <div fxFlex=\"*\" fxLayout=\"column\" fxLayoutAlign=\"center center\" fxFill>\r\n      <input #_file type=\"file\" [hidden]=\"true\" accept=\"image/*\" (change)=\"update($event)\" />\r\n      <button type=\"button\" mat-button color=\"primary\" (click)=\"_file.click()\">Seleziona file...</button>\r\n      @if (file) {\r\n      <div class=\"selectpicture-info\">\r\n        <img [src]=\"filePreview()\" class=\"preview\"><br />\r\n        <span class=\"small truncated\"><i>{{file.name}}</i></span>\r\n        <div><span class=\"small truncated\">Dimensioni: <i>{{size(file.size)}}</i></span></div>\r\n      </div>\r\n      }\r\n    </div>\r\n    @if (dialogData.options) {\r\n    <div>\r\n      @for (o of dialogData.options; track $index; let i = $index) {\r\n      <div>\r\n        <mat-checkbox color=\"primary\" [(ngModel)]=\"o.value\" name=\"opt_{{i}}\">\r\n          {{o.description}}\r\n        </mat-checkbox>\r\n      </div>\r\n      }\r\n    </div>\r\n    }\r\n  </div>\r\n</div>\r\n<div mat-dialog-actions>\r\n  <div fxLayout=\"row\" fxLayoutAlign=\"end\" fxFill>\r\n    <button mat-flat-button (click)=\"ok()\" color=\"primary\" [disabled]=\"!file\">{{dialogData.okCaption}}</button>\r\n    <button mat-button mat-dialog-close cdkFocusInitial color=\"primary\">Annulla</button>\r\n  </div>\r\n</div>"]}
|
|
59
|
+
}] });
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-picture-dialog.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select-picture/select-picture-dialog.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select-picture/select-picture-dialog.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,cAAc,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC7I,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;;;;;;AAYxD,MAAM,OAAO,4BAA4B;IATzC;QAUE,SAAI,GAAG,MAAM,EAAc,CAAC;QAEpB,cAAS,GAAG,MAAM,CAAC,CAAA,YAA0C,CAAA,CAAC,CAAC;QAC7D,eAAU,GAA0B,MAAM,CAAC,eAAe,CAAC,CAAC;QAE5D,SAAI,GAAgB,IAAI,CAAC;QACzB,gBAAW,GAAG,MAAM,CAAM,IAAI,CAAC,CAAC;KAmC3C;IAhCC;;;OAGG;IACH,MAAM,CAAC,CAAM;QACX,IAAI,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;YACnB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAC9B,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAChC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAO,EAAE,EAAE;gBAC1B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAE,EAAE,CAAC,MAAqB,CAAC,MAAM,CAAC,CAAC;YACzD,CAAC,CAAC;YACF,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,IAAI,CAAC,IAAY;QACf,OAAO,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED;;OAEG;IACH,EAAE;QACA,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACvB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC;QACxE,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;8GAzCU,4BAA4B;kGAA5B,4BAA4B,yGARvB,WAAW,CAAC,YAAY,EAAE,8BCZ5C,4jDAmCM,uuHDlBM,cAAc,+HAAG,gBAAgB,wGAAE,UAAU,u6EAAE,eAAe,2NAAG,iBAAiB,oYAAE,WAAW,+VACvG,gBAAgB,4HAAE,cAAc,gLAAE,YAAY;;2FAErC,4BAA4B;kBATxC,SAAS;2BACF,EAAE,MAAM,EAAE,WAAW,CAAC,YAAY,EAAE,EAAE,cAGhC,IAAI,mBACC,uBAAuB,CAAC,MAAM,WACtC,CAAC,cAAc,EAAG,gBAAgB,EAAE,UAAU,EAAE,eAAe,EAAG,iBAAiB,EAAE,WAAW;wBACvG,gBAAgB,EAAE,cAAc,EAAE,YAAY,CAAC","sourcesContent":["import { ChangeDetectionStrategy, Component, inject, output, signal } from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA, MatDialogTitle, MatDialogContent, MatDialogActions, MatDialogClose } from '@angular/material/dialog';\r\nimport { SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { SelectFile, SelectFileDialogData } from '../../definitions';\r\nimport { SafeHtmlPipe } from '@arsedizioni/ars-utils/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { FlexModule } from '@ngbracket/ngx-layout/flex';\r\n\r\n\r\n@Component({\r\n  host: { 'Bind': SystemUtils.generateUUID() },\r\n  templateUrl: './select-picture-dialog.component.html',\r\n  styleUrls: ['./select-picture-dialog.component.scss'],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [MatDialogTitle,  MatDialogContent, FlexModule, MatButtonModule,  MatCheckboxModule, FormsModule, \r\n    MatDialogActions, MatDialogClose, SafeHtmlPipe]\r\n})\r\nexport class SelectPictureDialogComponent {\r\n  done = output<SelectFile>();\r\n\r\n  private dialogRef = inject(MatDialogRef<SelectPictureDialogComponent>);\r\n  protected dialogData : SelectFileDialogData = inject(MAT_DIALOG_DATA); \r\n\r\n  protected file: File | null = null;\r\n  protected filePreview = signal<any>(null);\r\n\r\n\r\n  /**\r\n   * Update preview\r\n   * @param e : the event\r\n   */\r\n  update(e: any) {\r\n    if (e.target.files) {\r\n      this.file = e.target.files[0];\r\n      const reader = new FileReader();\r\n      reader.onload = (_e: any) => {\r\n        this.filePreview.set((_e.target as FileReader).result);\r\n      };\r\n      reader.readAsDataURL(e.target.files[0]);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Format size\r\n   * @param size the file size\r\n   */\r\n  size(size: number) {\r\n    return SystemUtils.formatFileSize(size);\r\n  }\r\n\r\n  /**\r\n   * Submit selection\r\n   */\r\n  ok() {\r\n    this.dialogRef.close();\r\n    setTimeout(() => {\r\n      this.done.emit({ file: this.file, options: this.dialogData.options });\r\n    }, 500);\r\n  }\r\n}\r\n\r\n","<h2 mat-dialog-title>{{dialogData.title}}</h2>\r\n@if (dialogData.description) {\r\n<div class=\"selectpicture-description\" [innerHtml]=\"dialogData.description | safeHtml\"></div>\r\n}\r\n<div mat-dialog-content>\r\n  <div fxLayout=\"column\" fxLayoutGap=\"32px\" fxFill>\r\n    <div fxFlex=\"*\" fxLayout=\"column\" fxLayoutAlign=\"center center\" fxFill>\r\n      <input #_file type=\"file\" [hidden]=\"true\" accept=\"image/*\" (change)=\"update($event)\" />\r\n      <button type=\"button\" mat-button color=\"primary\" (click)=\"_file.click()\">Seleziona file...</button>\r\n      @if (file) {\r\n      <div class=\"selectpicture-info\">\r\n        <img [src]=\"filePreview()\" class=\"preview\"><br />\r\n        <span class=\"small truncated\"><i>{{file.name}}</i></span>\r\n        <div><span class=\"small truncated\">Dimensioni: <i>{{size(file.size)}}</i></span></div>\r\n      </div>\r\n      }\r\n    </div>\r\n    @if (dialogData.options) {\r\n    <div>\r\n      @for (o of dialogData.options; track $index; let i = $index) {\r\n      <div>\r\n        <mat-checkbox color=\"primary\" [(ngModel)]=\"o.value\" name=\"opt_{{i}}\">\r\n          {{o.description}}\r\n        </mat-checkbox>\r\n      </div>\r\n      }\r\n    </div>\r\n    }\r\n  </div>\r\n</div>\r\n<div mat-dialog-actions>\r\n  <div fxLayout=\"row\" fxLayoutAlign=\"end\" fxFill>\r\n    <button mat-flat-button (click)=\"ok()\" color=\"primary\" [disabled]=\"!file\">{{dialogData.okCaption}}</button>\r\n    <button mat-button mat-dialog-close cdkFocusInitial color=\"primary\">Annulla</button>\r\n  </div>\r\n</div>"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { FlatTreeControl } from '@angular/cdk/tree';
|
|
2
2
|
import { NgClass } from '@angular/common';
|
|
3
|
-
import { ChangeDetectionStrategy, Component,
|
|
3
|
+
import { ChangeDetectionStrategy, Component, Injectable, inject, output } from '@angular/core';
|
|
4
4
|
import { FormsModule } from '@angular/forms';
|
|
5
5
|
import { MatButtonModule } from '@angular/material/button';
|
|
6
6
|
import { MAT_DIALOG_DATA, MatDialogActions, MatDialogClose, MatDialogContent, MatDialogRef, MatDialogTitle } from '@angular/material/dialog';
|
|
@@ -134,7 +134,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
|
|
|
134
134
|
}] });
|
|
135
135
|
export class SelectTreeDialogComponent {
|
|
136
136
|
constructor() {
|
|
137
|
-
this.done =
|
|
137
|
+
this.done = output();
|
|
138
138
|
this.unsubscribe = new Subject();
|
|
139
139
|
this.dialogRef = inject((MatDialogRef));
|
|
140
140
|
this.dialogData = inject(MAT_DIALOG_DATA);
|
|
@@ -271,7 +271,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
|
|
|
271
271
|
args: [{ host: { 'Bind': SystemUtils.generateUUID() }, providers: [TreeDataSource], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [MatDialogTitle, FlexLayoutModule, MatFormFieldModule, MatInputModule, FormsModule, MatButtonModule,
|
|
272
272
|
MatIconModule, MatTooltipModule, MatDialogContent, MatTreeModule, NgClass, MatDialogActions,
|
|
273
273
|
MatDialogClose, SafeHtmlPipe], template: "<h2 mat-dialog-title (keyup.ArrowDown)=\"nextFiltered()\">{{dialogData.title}}</h2>\r\n<div style=\"padding: 0 24px\">\r\n @if (dialogData.description) {\r\n <div [innerHtml]=\"dialogData.description | safeHtml\"></div>\r\n }\r\n <div style=\"padding-bottom: 10px;\">\r\n <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n <div fxFlex=\"50\">\r\n <mat-form-field style=\"width:100%\" [appearance]=\"dialogData.appearance\" subscriptSizing=\"dynamic\" >\r\n <mat-label>Cerca...</mat-label>\r\n <input type=\"text\" cdkFocusInitial (keyup)=\"doFilter()\" matInput title=\"Digita il testo'\"\r\n [(ngModel)]=\"filterText\">\r\n @if (filterText) {\r\n <button type=\"button\" type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Clear\"\r\n (click)=\"clearFilter()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n }\r\n </mat-form-field>\r\n </div>\r\n @if (filteredItems.length > 0) {\r\n <div fxFlex=\"50px\" fxLayoutAlign=\"end\">\r\n <div fxFlexAlign=\"center\" class=\"small\">{{filterIndex + 1}} / {{filteredItems.length}}</div>\r\n </div>\r\n }\r\n <div fxFlex=\"50\" fxLayoutAlign=\"end\" style=\"white-space:nowrap\">\r\n <div fxFlexAlign=\"center\">\r\n @if (filteredItems.length > 0) {\r\n <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"nextFiltered()\">\r\n <mat-icon aria-label=\"Vai al prossimo\" matTooltip=\"Vai al prossimo\">arrow_downward</mat-icon>\r\n </button>\r\n }\r\n <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"treeControl.collapseAll()\">\r\n <mat-icon aria-label=\"Comprimi tutto\" matTooltip=\"Comprimi tutto\">unfold_less</mat-icon>\r\n </button>\r\n <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"treeControl.expandAll()\">\r\n <mat-icon aria-label=\"Espandi tutto\" matTooltip=\"Espandi tutto\">unfold_more</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n<div mat-dialog-content>\r\n <div fxLayout=\"column\" fxFill>\r\n <mat-tree [dataSource]=\"treeData\" [treeControl]=\"treeControl\">\r\n <mat-tree-node [id]=\"node.id\" *matTreeNodeDef=\"let node\" matTreeNodeToggle matTreeNodePadding\r\n [matTreeNodePaddingIndent]=\"20\" class=\"tree-node tree-node-simple\" (click)=\"select($event, node);\"\r\n [ngClass]=\"{'tree-node-activated': currentNode && currentNode.id === node.id}\" >\r\n <div fxLayout=\"row\" fxLayoutGap=\"5px\" fxFill class=\"small\">\r\n <button type=\"button\" mat-icon-button disabled class=\"small-icon-button\"></button>\r\n <div fxFlex=\"*\" fxFlexAlign=\"center\" class=\"uppercase \">\r\n {{node.name}}\r\n </div>\r\n <div fxFlex=\"30px\" fxFlexAlign=\"center\">\r\n @if (node.count > 0) {\r\n <span fxLayoutAlign=\"end\">({{node.count}})</span>\r\n }\r\n </div>\r\n </div>\r\n </mat-tree-node>\r\n\r\n <mat-tree-node [id]=\"node.id\" *matTreeNodeDef=\"let node;when: hasChild\" matTreeNodePadding\r\n [matTreeNodePaddingIndent]=\"20\" class=\"tree-node tree-node-simple\"\r\n [ngClass]=\"{'tree-node-activated': currentNode && currentNode.id === node.id }\" (click)=\"select($event, node);\">\r\n <div fxLayout=\"row\" fxLayoutGap=\"5px\" fxFill class=\"small\">\r\n <div fxFlex=\"30px\" fxFlexAlign=\"center\">\r\n <button type=\"button\" mat-icon-button matTreeNodeToggle [attr.aria-label]=\"'Apri/chiudi ' + node.name\"\r\n class=\"small-icon-button\">\r\n <mat-icon class=\"mat-icon-rtl-mirror\">\r\n {{treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'}}\r\n </mat-icon>\r\n </button>\r\n </div>\r\n <div fxFlex=\"*\" fxFlexAlign=\"center\" class=\"uppercase truncated\">\r\n <div>\r\n {{node.name}}\r\n </div>\r\n </div>\r\n <div fxFlex=\"30px\" fxFlexAlign=\"center\">\r\n @if (node.count > 0) {\r\n <div fxLayoutAlign=\"end\">({{node.count}})</div>\r\n }\r\n </div>\r\n </div>\r\n </mat-tree-node>\r\n </mat-tree>\r\n </div>\r\n</div>\r\n<div mat-dialog-actions>\r\n <div fxLayout=\"row\" fxLayoutAlign=\"end\" fxFill>\r\n <button mat-flat-button color=\"primary\" (click)=\"ok()\" \r\n [disabled]=\"!currentNode\">{{dialogData.okCaption}}</button>\r\n <button mat-button mat-dialog-close cdkFocusInitial \r\n color=\"primary\">Annulla</button>\r\n </div>\r\n</div>", styles: [".dialog-info{font-size:x-small;font-weight:700;text-align:right;padding:10px}.dialog-info-green,.dialog-info-ok{color:var(--ars-color-ok, #388E3C)}.dialog-info-red,.dialog-info-error{color:var(--mat-form-field-error-text-color, #a80710)}.dialog-header{padding-bottom:20px}.dialog-close{margin-right:10px;margin-top:10px}.dialog-menu{margin-left:10px;margin-top:10px}.dialog-title{padding:0 24px}.section-title{font-size:large;font-weight:600;padding-top:10px;padding-bottom:8px}.center{text-align:center}.wide{min-width:100%!important;max-width:100%!important;width:100%!important}.fill{min-width:100%!important;max-width:100%!important;width:100%!important;min-height:100%!important;max-height:100%!important;height:100%!important}.scroll-auto{overflow:auto;height:100%}.scroll-hidden{overflow:hidden;height:100%}b{font-weight:700}.large{font-size:large!important}.smaller{font-size:smaller}.small{font-size:small!important;line-height:16px}.small-icon-button{width:1.5rem!important;height:1.5rem!important;padding:0!important;display:inline-flex!important;align-items:center;justify-content:center}.small-icon-button .mat-mdc-button-touch-target{width:1.5rem!important;height:1.5rem!important}.x-small{font-size:x-small!important;line-height:14px}.bold{font-weight:700}.uppercase{text-transform:uppercase!important}.lowercase{text-transform:lowercase!important}.truncated{min-width:0;max-width:100%}.truncated span,.truncated div{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clipped{min-width:0;max-width:100%}.clipped span,.clipped div{white-space:nowrap;overflow:hidden;text-overflow:clip}.accent{color:var(--ars-color-accent, #7894ae)!important}.primary{color:var(--ars-color-primary, #00a293)!important}.secondary{color:var(--ars-color-secondary, #4a635f)!important}.error{color:var(--ars-color-error, #ff5449)!important}.warning{color:var(--ars-color-warning, #FFC107)!important}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;background-color:var(--ars-color-overlay, rgba(255, 255, 255, .75))}.drawer-content{padding-top:10px}.drawer,.drawer-small{min-width:420px!important;max-width:420px!important;padding:20px 0 0}.drawer .title-container,.drawer-small .title-container{padding:20px 10px}.drawer .title-container-with-loader,.drawer-small .title-container-with-loader{padding:14px 10px 20px}.drawer .title,.drawer-small .title{font-size:1.2em;font-weight:600;padding-left:10px;min-width:200px;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer .accordion-panel,.drawer-small .accordion-panel{background-color:transparent!important}.drawer .accordion-header,.drawer-small .accordion-header{padding-left:15px;padding-right:20px;border-radius:var(--mat-expansion-container-shape)}.drawer .mat-expansion-panel-body,.drawer-small .mat-expansion-panel-body{padding-bottom:20px!important}.drawer-with-loader{padding-top:0!important}.drawer-transparent{background-color:transparent}.drawer-small{min-width:360px!important;max-width:360px!important}.drawer-small .title{min-width:150px;width:100%}@media screen and (min-width: 0px) and (max-width: 359px){.drawer{min-width:360px!important;max-width:360px!important}.drawer .title{min-width:150px}}.fade-in{animation:fadein .5s linear}@keyframes fadein{0%{opacity:0}to{opacity:1}}@media (prefers-color-scheme: dark){.dialog-info-green,.dialog-info-ok{color:var(--ars-color-ok, #4CAF50)}.dialog-info-red,.dialog-info-error{color:var(--mat-form-field-error-text-color, #ff5449)}b{font-weight:600}}.tree{overflow-x:hidden}.tree-node{min-height:36px!important;padding-right:12px;margin-right:0}.tree-node .small-icon-button{width:2rem!important;height:2rem!important;padding:0!important;display:inline-flex!important;align-items:center;justify-content:center}.tree-node .small-icon-button .mat-mdc-button-touch-target{width:2rem!important;height:2rem!important}.tree-node:hover{cursor:pointer;background-color:var(--mat-menu-item-hover-state-layer-color, transparent);border-radius:24px}.tree-node-simple,.tree-node-simple>div{min-height:36px!important}.tree-node-activated,.tree-node-activated>div{min-height:36px!important;font-weight:700!important}\n"] }]
|
|
274
|
-
}]
|
|
275
|
-
type: Output
|
|
276
|
-
}] } });
|
|
277
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-tree-dialog.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select-tree/select-tree-dialog.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select-tree/select-tree-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FlatTreeControl } from '@angular/cdk/tree';\r\nimport { NgClass } from '@angular/common';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  EventEmitter, Injectable,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  inject\r\n} from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MAT_DIALOG_DATA, MatDialogActions, MatDialogClose, MatDialogContent, MatDialogRef, MatDialogTitle } from '@angular/material/dialog';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatTreeFlatDataSource, MatTreeFlattener, MatTreeModule } from '@angular/material/tree';\r\nimport { SafeHtmlPipe, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { BehaviorSubject, Observable, Subject, of as observableOf } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { ItemNode, SelectDialogResult, SelectTreeDialogData, SelectableNode } from '../../definitions';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\n\r\n\r\n@Injectable()\r\nexport class TreeDataSource implements OnDestroy {\r\n  dataChange = new BehaviorSubject<ItemNode[]>([]);\r\n\r\n  get data(): ItemNode[] {\r\n    return this.dataChange.value;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.dataChange.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Initialzie the data source\r\n   * @param data : data\r\n   */\r\n  initialize(data: ItemNode[]) {\r\n    this.dataChange.next(data);\r\n  }\r\n\r\n  /**\r\n   * Find a node by id recursively\r\n   * @param node: the source node\r\n   * @param id : the id to search for\r\n   */\r\n  findNode(node: ItemNode, id: string): ItemNode {\r\n    let children;\r\n    if (node && node.id === id) return node;\r\n    if (node) children = node.children;\r\n    else if (this.data && this.data.length > 0)\r\n      children = this.data[0].children;\r\n    if (children) {\r\n      let _n = null;\r\n      children.some(n => {\r\n        if (n.id === id) {\r\n          _n = n;\r\n          return true;\r\n        }\r\n        _n = this.findNode(n, id);\r\n        if (_n) return true;\r\n        return false;\r\n      });\r\n      return _n;\r\n    }\r\n    return null;\r\n  }\r\n  /**\r\n   * Remove a node\r\n   * @param id : the node id to remove\r\n   */\r\n  removeNode(id: string) {\r\n    let n = this.findNode(null, id);\r\n    if (!n) return;\r\n    if (n.parent) {\r\n      const p = n.parent.children.findIndex(n => n.id === id);\r\n      if (p != -1) {\r\n        n.parent.children.splice(p, 1);\r\n        if (n.parent.count > 0) n.parent.count--;\r\n      }\r\n    } else {\r\n      const p = this.data.findIndex(n => n.id === id);\r\n      if (p != -1) {\r\n        this.data.splice(p, 1);\r\n      }\r\n    }\r\n\r\n    this.dataChange.next(this.data);\r\n  }\r\n\r\n  /**\r\n   * Insert a new node\r\n   * @param node : the new node\r\n   */\r\n  insertNode(node: ItemNode) {\r\n    if (node.parent) {\r\n      node.parent.children.unshift(node);\r\n      node.parent.count++;\r\n    } else this.data.unshift(node);\r\n\r\n    this.dataChange.next(this.data);\r\n  }\r\n\r\n  /**\r\n   * Rename a node\r\n   * @param id : the node id\r\n   * @param name : the new node name\r\n   */\r\n  renameNode(id: string, name: string): ItemNode {\r\n    let n = this.findNode(null, id);\r\n    if (n) {\r\n      n.name = name;\r\n      this.dataChange.next(this.data);\r\n    }\r\n    return n;\r\n  }\r\n\r\n  /**\r\n   * Update data\r\n   */\r\n  update() {\r\n    this.dataChange.next(this.data);\r\n  }\r\n}\r\n\r\n@Component({\r\n  host: { 'Bind': SystemUtils.generateUUID() },\r\n  templateUrl: './select-tree-dialog.component.html',\r\n  styleUrls: ['./select-tree-dialog.component.scss'],\r\n  providers: [TreeDataSource],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [MatDialogTitle, FlexLayoutModule, MatFormFieldModule, MatInputModule, FormsModule, MatButtonModule, \r\n    MatIconModule, MatTooltipModule, MatDialogContent, MatTreeModule, NgClass, MatDialogActions, \r\n    MatDialogClose, SafeHtmlPipe]\r\n})\r\nexport class SelectTreeDialogComponent implements OnInit, OnDestroy {\r\n  @Output() done = new EventEmitter<SelectDialogResult>();\r\n\r\n  private unsubscribe: Subject<void> = new Subject<void>();\r\n  private dialogRef = inject(MatDialogRef<SelectTreeDialogComponent>);\r\n  protected dialogData: SelectTreeDialogData = inject(MAT_DIALOG_DATA);\r\n  private tree = inject(TreeDataSource);\r\n  private treeFlattener: MatTreeFlattener<ItemNode, SelectableNode>;\r\n  protected treeControl: FlatTreeControl<SelectableNode>;\r\n  protected treeData: MatTreeFlatDataSource<ItemNode, SelectableNode>;\r\n  protected currentNode: ItemNode;\r\n\r\n  // Used for array filtering\r\n  protected filterText: string = '';\r\n  protected filteredItems: SelectableNode[] = [];\r\n  protected filterIndex: number = -1;\r\n\r\n  /**\r\n   * Manage flat tree view\r\n   */\r\n  private getChildren = (node: ItemNode): Observable<ItemNode[]> =>\r\n    observableOf(node.children);\r\n  private getLevel = (node: SelectableNode) => node.level;\r\n  private isExpandable = (node: SelectableNode) => node.expandable;\r\n  protected hasChild = (_: number, _node: SelectableNode) => _node.expandable;\r\n  protected transformer = (item: ItemNode, level: number) => {\r\n    return new SelectableNode(item, level);\r\n  };\r\n\r\n  ngOnInit() {\r\n    this.dialogData = this.dialogData || { appearance: 'outline', title: 'Seleziona', okCaption: 'Ok' };\r\n    this.treeFlattener = new MatTreeFlattener(\r\n      this.transformer,\r\n      this.getLevel,\r\n      this.isExpandable,\r\n      this.getChildren\r\n    );\r\n    this.treeControl = new FlatTreeControl<SelectableNode>(\r\n      this.getLevel,\r\n      this.isExpandable\r\n    );\r\n    this.treeData = new MatTreeFlatDataSource(\r\n      this.treeControl,\r\n      this.treeFlattener\r\n    );\r\n    this.tree.dataChange\r\n      .pipe(takeUntil(this.unsubscribe))\r\n      .subscribe(data => (this.treeData.data = data));\r\n    if (this.dialogData.nodes) {\r\n      this.tree.initialize(this.dialogData.nodes);\r\n    }\r\n    if (!this.dialogData.title) {\r\n      this.dialogData.title = 'Seleziona';\r\n    }\r\n    if (!this.dialogData.okCaption) {\r\n      this.dialogData.okCaption = 'OK';\r\n    }\r\n    if (this.dialogData.initialFilter) {\r\n      this.doFilter(this.dialogData.initialFilter);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.unsubscribe.next();\r\n    this.unsubscribe.complete();\r\n  }\r\n\r\n  /**\r\n   * Submit selection\r\n   */\r\n  ok() {\r\n    this.dialogRef.close();\r\n    setTimeout(() => {\r\n      this.done.emit({ selectedItems: [this.currentNode] });\r\n    }, 500);\r\n  }\r\n\r\n  /**\r\n   * Select  a node\r\n   * @param e : the event\r\n   * @param node : the\r\n   */\r\n  protected select(e: any, node: SelectableNode) {\r\n    if (e) e.stopPropagation();\r\n    if (node) {\r\n      this.currentNode = node;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Clear filter\r\n   */\r\n  protected clearFilter() {\r\n    this.filterText = '';\r\n  }\r\n\r\n  /**\r\n   * Apply filter\r\n   * @param text : the text to filter\r\n   */\r\n  protected doFilter(text: string = null) {\r\n    if (text) this.filterText = text;\r\n    this.filteredItems = [];\r\n    this.filterIndex = -1;\r\n    if (this.filterText) {\r\n      this.treeControl.dataNodes.forEach(n => {\r\n        if (n.name.indexOf(this.filterText) != -1) {\r\n          this.filteredItems.push(n);\r\n        }\r\n      });\r\n\r\n      if (this.filteredItems.length > 0) {\r\n        this.nextFiltered();\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Goto next filtered item\r\n   */\r\n  protected nextFiltered() {\r\n    if (!SystemUtils.isBrowser()) return;\r\n    if (this.filteredItems.length === 0) return;\r\n    this.filterIndex++;\r\n    if (this.filterIndex === this.filteredItems.length) this.filterIndex = 0;\r\n    let node = this.filteredItems[this.filterIndex];\r\n    this.currentNode = node;\r\n    this.expand(node);\r\n    let elem = document.getElementById(node.id);\r\n    if (elem) elem.scrollIntoView();\r\n  }\r\n\r\n  /**\r\n   * Expand a node and all its parents\r\n   * @param node : the selectable node to expand\r\n   */\r\n  protected expand(node: SelectableNode) {\r\n    this.treeControl.expand(node);\r\n    let _n = node.parent;\r\n    while (_n) {\r\n      this.treeControl.dataNodes.some(n => {\r\n        if (n.id === _n.id) {\r\n          this.treeControl.expand(n);\r\n          _n = _n.parent;\r\n          return true;\r\n        }\r\n        return false;\r\n      });\r\n    }\r\n    return false;\r\n  }\r\n}\r\n\r\n","<h2 mat-dialog-title (keyup.ArrowDown)=\"nextFiltered()\">{{dialogData.title}}</h2>\r\n<div style=\"padding: 0 24px\">\r\n  @if (dialogData.description) {\r\n  <div [innerHtml]=\"dialogData.description | safeHtml\"></div>\r\n  }\r\n  <div style=\"padding-bottom: 10px;\">\r\n    <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n      <div fxFlex=\"50\">\r\n        <mat-form-field style=\"width:100%\" [appearance]=\"dialogData.appearance\" subscriptSizing=\"dynamic\" >\r\n          <mat-label>Cerca...</mat-label>\r\n          <input type=\"text\" cdkFocusInitial (keyup)=\"doFilter()\" matInput title=\"Digita il testo'\"\r\n            [(ngModel)]=\"filterText\">\r\n          @if (filterText) {\r\n          <button type=\"button\" type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Clear\"\r\n            (click)=\"clearFilter()\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n      </div>\r\n      @if (filteredItems.length > 0) {\r\n      <div fxFlex=\"50px\" fxLayoutAlign=\"end\">\r\n        <div fxFlexAlign=\"center\" class=\"small\">{{filterIndex + 1}} / {{filteredItems.length}}</div>\r\n      </div>\r\n      }\r\n      <div fxFlex=\"50\" fxLayoutAlign=\"end\" style=\"white-space:nowrap\">\r\n        <div fxFlexAlign=\"center\">\r\n          @if (filteredItems.length > 0) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"nextFiltered()\">\r\n            <mat-icon aria-label=\"Vai al prossimo\" matTooltip=\"Vai al prossimo\">arrow_downward</mat-icon>\r\n          </button>\r\n          }\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"treeControl.collapseAll()\">\r\n            <mat-icon aria-label=\"Comprimi tutto\" matTooltip=\"Comprimi tutto\">unfold_less</mat-icon>\r\n          </button>\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"treeControl.expandAll()\">\r\n            <mat-icon aria-label=\"Espandi tutto\" matTooltip=\"Espandi tutto\">unfold_more</mat-icon>\r\n          </button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n<div mat-dialog-content>\r\n  <div fxLayout=\"column\" fxFill>\r\n    <mat-tree [dataSource]=\"treeData\" [treeControl]=\"treeControl\">\r\n      <mat-tree-node [id]=\"node.id\" *matTreeNodeDef=\"let node\" matTreeNodeToggle matTreeNodePadding\r\n        [matTreeNodePaddingIndent]=\"20\" class=\"tree-node tree-node-simple\" (click)=\"select($event, node);\"\r\n        [ngClass]=\"{'tree-node-activated': currentNode && currentNode.id === node.id}\" >\r\n        <div fxLayout=\"row\" fxLayoutGap=\"5px\" fxFill class=\"small\">\r\n          <button type=\"button\" mat-icon-button disabled class=\"small-icon-button\"></button>\r\n          <div fxFlex=\"*\" fxFlexAlign=\"center\" class=\"uppercase \">\r\n            {{node.name}}\r\n          </div>\r\n          <div fxFlex=\"30px\" fxFlexAlign=\"center\">\r\n            @if (node.count > 0) {\r\n            <span fxLayoutAlign=\"end\">({{node.count}})</span>\r\n            }\r\n          </div>\r\n        </div>\r\n      </mat-tree-node>\r\n\r\n      <mat-tree-node [id]=\"node.id\" *matTreeNodeDef=\"let node;when: hasChild\" matTreeNodePadding\r\n        [matTreeNodePaddingIndent]=\"20\" class=\"tree-node tree-node-simple\"\r\n        [ngClass]=\"{'tree-node-activated': currentNode && currentNode.id === node.id }\" (click)=\"select($event, node);\">\r\n        <div fxLayout=\"row\" fxLayoutGap=\"5px\" fxFill class=\"small\">\r\n          <div fxFlex=\"30px\" fxFlexAlign=\"center\">\r\n            <button type=\"button\" mat-icon-button matTreeNodeToggle [attr.aria-label]=\"'Apri/chiudi ' + node.name\"\r\n              class=\"small-icon-button\">\r\n              <mat-icon class=\"mat-icon-rtl-mirror\">\r\n                {{treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'}}\r\n              </mat-icon>\r\n            </button>\r\n          </div>\r\n          <div fxFlex=\"*\" fxFlexAlign=\"center\" class=\"uppercase truncated\">\r\n            <div>\r\n              {{node.name}}\r\n            </div>\r\n          </div>\r\n          <div fxFlex=\"30px\" fxFlexAlign=\"center\">\r\n            @if (node.count > 0) {\r\n            <div fxLayoutAlign=\"end\">({{node.count}})</div>\r\n            }\r\n          </div>\r\n        </div>\r\n      </mat-tree-node>\r\n    </mat-tree>\r\n  </div>\r\n</div>\r\n<div mat-dialog-actions>\r\n  <div fxLayout=\"row\" fxLayoutAlign=\"end\" fxFill>\r\n    <button mat-flat-button color=\"primary\" (click)=\"ok()\" \r\n      [disabled]=\"!currentNode\">{{dialogData.okCaption}}</button>\r\n    <button mat-button mat-dialog-close cdkFocusInitial \r\n      color=\"primary\">Annulla</button>\r\n  </div>\r\n</div>"]}
|
|
274
|
+
}] });
|
|
275
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-tree-dialog.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select-tree/select-tree-dialog.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/dialogs/select-tree/select-tree-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FlatTreeControl } from '@angular/cdk/tree';\r\nimport { NgClass } from '@angular/common';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  Component, Injectable,\r\n  OnDestroy,\r\n  OnInit, inject,\r\n  output\r\n} from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MAT_DIALOG_DATA, MatDialogActions, MatDialogClose, MatDialogContent, MatDialogRef, MatDialogTitle } from '@angular/material/dialog';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatTreeFlatDataSource, MatTreeFlattener, MatTreeModule } from '@angular/material/tree';\r\nimport { SafeHtmlPipe, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { BehaviorSubject, Observable, Subject, of as observableOf } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { ItemNode, SelectDialogResult, SelectTreeDialogData, SelectableNode } from '../../definitions';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\n\r\n\r\n@Injectable()\r\nexport class TreeDataSource implements OnDestroy {\r\n  dataChange = new BehaviorSubject<ItemNode[]>([]);\r\n\r\n  get data(): ItemNode[] {\r\n    return this.dataChange.value;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.dataChange.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Initialzie the data source\r\n   * @param data : data\r\n   */\r\n  initialize(data: ItemNode[]) {\r\n    this.dataChange.next(data);\r\n  }\r\n\r\n  /**\r\n   * Find a node by id recursively\r\n   * @param node: the source node\r\n   * @param id : the id to search for\r\n   */\r\n  findNode(node: ItemNode, id: string): ItemNode {\r\n    let children;\r\n    if (node && node.id === id) return node;\r\n    if (node) children = node.children;\r\n    else if (this.data && this.data.length > 0)\r\n      children = this.data[0].children;\r\n    if (children) {\r\n      let _n = null;\r\n      children.some(n => {\r\n        if (n.id === id) {\r\n          _n = n;\r\n          return true;\r\n        }\r\n        _n = this.findNode(n, id);\r\n        if (_n) return true;\r\n        return false;\r\n      });\r\n      return _n;\r\n    }\r\n    return null;\r\n  }\r\n  /**\r\n   * Remove a node\r\n   * @param id : the node id to remove\r\n   */\r\n  removeNode(id: string) {\r\n    let n = this.findNode(null, id);\r\n    if (!n) return;\r\n    if (n.parent) {\r\n      const p = n.parent.children.findIndex(n => n.id === id);\r\n      if (p != -1) {\r\n        n.parent.children.splice(p, 1);\r\n        if (n.parent.count > 0) n.parent.count--;\r\n      }\r\n    } else {\r\n      const p = this.data.findIndex(n => n.id === id);\r\n      if (p != -1) {\r\n        this.data.splice(p, 1);\r\n      }\r\n    }\r\n\r\n    this.dataChange.next(this.data);\r\n  }\r\n\r\n  /**\r\n   * Insert a new node\r\n   * @param node : the new node\r\n   */\r\n  insertNode(node: ItemNode) {\r\n    if (node.parent) {\r\n      node.parent.children.unshift(node);\r\n      node.parent.count++;\r\n    } else this.data.unshift(node);\r\n\r\n    this.dataChange.next(this.data);\r\n  }\r\n\r\n  /**\r\n   * Rename a node\r\n   * @param id : the node id\r\n   * @param name : the new node name\r\n   */\r\n  renameNode(id: string, name: string): ItemNode {\r\n    let n = this.findNode(null, id);\r\n    if (n) {\r\n      n.name = name;\r\n      this.dataChange.next(this.data);\r\n    }\r\n    return n;\r\n  }\r\n\r\n  /**\r\n   * Update data\r\n   */\r\n  update() {\r\n    this.dataChange.next(this.data);\r\n  }\r\n}\r\n\r\n@Component({\r\n  host: { 'Bind': SystemUtils.generateUUID() },\r\n  templateUrl: './select-tree-dialog.component.html',\r\n  styleUrls: ['./select-tree-dialog.component.scss'],\r\n  providers: [TreeDataSource],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [MatDialogTitle, FlexLayoutModule, MatFormFieldModule, MatInputModule, FormsModule, MatButtonModule, \r\n    MatIconModule, MatTooltipModule, MatDialogContent, MatTreeModule, NgClass, MatDialogActions, \r\n    MatDialogClose, SafeHtmlPipe]\r\n})\r\nexport class SelectTreeDialogComponent implements OnInit, OnDestroy {\r\n  done = output<SelectDialogResult>();\r\n\r\n  private unsubscribe: Subject<void> = new Subject<void>();\r\n  private dialogRef = inject(MatDialogRef<SelectTreeDialogComponent>);\r\n  protected dialogData: SelectTreeDialogData = inject(MAT_DIALOG_DATA);\r\n  private tree = inject(TreeDataSource);\r\n  private treeFlattener: MatTreeFlattener<ItemNode, SelectableNode>;\r\n  protected treeControl: FlatTreeControl<SelectableNode>;\r\n  protected treeData: MatTreeFlatDataSource<ItemNode, SelectableNode>;\r\n  protected currentNode: ItemNode;\r\n\r\n  // Used for array filtering\r\n  protected filterText: string = '';\r\n  protected filteredItems: SelectableNode[] = [];\r\n  protected filterIndex: number = -1;\r\n\r\n  /**\r\n   * Manage flat tree view\r\n   */\r\n  private getChildren = (node: ItemNode): Observable<ItemNode[]> =>\r\n    observableOf(node.children);\r\n  private getLevel = (node: SelectableNode) => node.level;\r\n  private isExpandable = (node: SelectableNode) => node.expandable;\r\n  protected hasChild = (_: number, _node: SelectableNode) => _node.expandable;\r\n  protected transformer = (item: ItemNode, level: number) => {\r\n    return new SelectableNode(item, level);\r\n  };\r\n\r\n  ngOnInit() {\r\n    this.dialogData = this.dialogData || { appearance: 'outline', title: 'Seleziona', okCaption: 'Ok' };\r\n    this.treeFlattener = new MatTreeFlattener(\r\n      this.transformer,\r\n      this.getLevel,\r\n      this.isExpandable,\r\n      this.getChildren\r\n    );\r\n    this.treeControl = new FlatTreeControl<SelectableNode>(\r\n      this.getLevel,\r\n      this.isExpandable\r\n    );\r\n    this.treeData = new MatTreeFlatDataSource(\r\n      this.treeControl,\r\n      this.treeFlattener\r\n    );\r\n    this.tree.dataChange\r\n      .pipe(takeUntil(this.unsubscribe))\r\n      .subscribe(data => (this.treeData.data = data));\r\n    if (this.dialogData.nodes) {\r\n      this.tree.initialize(this.dialogData.nodes);\r\n    }\r\n    if (!this.dialogData.title) {\r\n      this.dialogData.title = 'Seleziona';\r\n    }\r\n    if (!this.dialogData.okCaption) {\r\n      this.dialogData.okCaption = 'OK';\r\n    }\r\n    if (this.dialogData.initialFilter) {\r\n      this.doFilter(this.dialogData.initialFilter);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.unsubscribe.next();\r\n    this.unsubscribe.complete();\r\n  }\r\n\r\n  /**\r\n   * Submit selection\r\n   */\r\n  ok() {\r\n    this.dialogRef.close();\r\n    setTimeout(() => {\r\n      this.done.emit({ selectedItems: [this.currentNode] });\r\n    }, 500);\r\n  }\r\n\r\n  /**\r\n   * Select  a node\r\n   * @param e : the event\r\n   * @param node : the\r\n   */\r\n  protected select(e: any, node: SelectableNode) {\r\n    if (e) e.stopPropagation();\r\n    if (node) {\r\n      this.currentNode = node;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Clear filter\r\n   */\r\n  protected clearFilter() {\r\n    this.filterText = '';\r\n  }\r\n\r\n  /**\r\n   * Apply filter\r\n   * @param text : the text to filter\r\n   */\r\n  protected doFilter(text: string = null) {\r\n    if (text) this.filterText = text;\r\n    this.filteredItems = [];\r\n    this.filterIndex = -1;\r\n    if (this.filterText) {\r\n      this.treeControl.dataNodes.forEach(n => {\r\n        if (n.name.indexOf(this.filterText) != -1) {\r\n          this.filteredItems.push(n);\r\n        }\r\n      });\r\n\r\n      if (this.filteredItems.length > 0) {\r\n        this.nextFiltered();\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Goto next filtered item\r\n   */\r\n  protected nextFiltered() {\r\n    if (!SystemUtils.isBrowser()) return;\r\n    if (this.filteredItems.length === 0) return;\r\n    this.filterIndex++;\r\n    if (this.filterIndex === this.filteredItems.length) this.filterIndex = 0;\r\n    let node = this.filteredItems[this.filterIndex];\r\n    this.currentNode = node;\r\n    this.expand(node);\r\n    let elem = document.getElementById(node.id);\r\n    if (elem) elem.scrollIntoView();\r\n  }\r\n\r\n  /**\r\n   * Expand a node and all its parents\r\n   * @param node : the selectable node to expand\r\n   */\r\n  protected expand(node: SelectableNode) {\r\n    this.treeControl.expand(node);\r\n    let _n = node.parent;\r\n    while (_n) {\r\n      this.treeControl.dataNodes.some(n => {\r\n        if (n.id === _n.id) {\r\n          this.treeControl.expand(n);\r\n          _n = _n.parent;\r\n          return true;\r\n        }\r\n        return false;\r\n      });\r\n    }\r\n    return false;\r\n  }\r\n}\r\n\r\n","<h2 mat-dialog-title (keyup.ArrowDown)=\"nextFiltered()\">{{dialogData.title}}</h2>\r\n<div style=\"padding: 0 24px\">\r\n  @if (dialogData.description) {\r\n  <div [innerHtml]=\"dialogData.description | safeHtml\"></div>\r\n  }\r\n  <div style=\"padding-bottom: 10px;\">\r\n    <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n      <div fxFlex=\"50\">\r\n        <mat-form-field style=\"width:100%\" [appearance]=\"dialogData.appearance\" subscriptSizing=\"dynamic\" >\r\n          <mat-label>Cerca...</mat-label>\r\n          <input type=\"text\" cdkFocusInitial (keyup)=\"doFilter()\" matInput title=\"Digita il testo'\"\r\n            [(ngModel)]=\"filterText\">\r\n          @if (filterText) {\r\n          <button type=\"button\" type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Clear\"\r\n            (click)=\"clearFilter()\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n      </div>\r\n      @if (filteredItems.length > 0) {\r\n      <div fxFlex=\"50px\" fxLayoutAlign=\"end\">\r\n        <div fxFlexAlign=\"center\" class=\"small\">{{filterIndex + 1}} / {{filteredItems.length}}</div>\r\n      </div>\r\n      }\r\n      <div fxFlex=\"50\" fxLayoutAlign=\"end\" style=\"white-space:nowrap\">\r\n        <div fxFlexAlign=\"center\">\r\n          @if (filteredItems.length > 0) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"nextFiltered()\">\r\n            <mat-icon aria-label=\"Vai al prossimo\" matTooltip=\"Vai al prossimo\">arrow_downward</mat-icon>\r\n          </button>\r\n          }\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"treeControl.collapseAll()\">\r\n            <mat-icon aria-label=\"Comprimi tutto\" matTooltip=\"Comprimi tutto\">unfold_less</mat-icon>\r\n          </button>\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button color=\"primary\" (click)=\"treeControl.expandAll()\">\r\n            <mat-icon aria-label=\"Espandi tutto\" matTooltip=\"Espandi tutto\">unfold_more</mat-icon>\r\n          </button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n<div mat-dialog-content>\r\n  <div fxLayout=\"column\" fxFill>\r\n    <mat-tree [dataSource]=\"treeData\" [treeControl]=\"treeControl\">\r\n      <mat-tree-node [id]=\"node.id\" *matTreeNodeDef=\"let node\" matTreeNodeToggle matTreeNodePadding\r\n        [matTreeNodePaddingIndent]=\"20\" class=\"tree-node tree-node-simple\" (click)=\"select($event, node);\"\r\n        [ngClass]=\"{'tree-node-activated': currentNode && currentNode.id === node.id}\" >\r\n        <div fxLayout=\"row\" fxLayoutGap=\"5px\" fxFill class=\"small\">\r\n          <button type=\"button\" mat-icon-button disabled class=\"small-icon-button\"></button>\r\n          <div fxFlex=\"*\" fxFlexAlign=\"center\" class=\"uppercase \">\r\n            {{node.name}}\r\n          </div>\r\n          <div fxFlex=\"30px\" fxFlexAlign=\"center\">\r\n            @if (node.count > 0) {\r\n            <span fxLayoutAlign=\"end\">({{node.count}})</span>\r\n            }\r\n          </div>\r\n        </div>\r\n      </mat-tree-node>\r\n\r\n      <mat-tree-node [id]=\"node.id\" *matTreeNodeDef=\"let node;when: hasChild\" matTreeNodePadding\r\n        [matTreeNodePaddingIndent]=\"20\" class=\"tree-node tree-node-simple\"\r\n        [ngClass]=\"{'tree-node-activated': currentNode && currentNode.id === node.id }\" (click)=\"select($event, node);\">\r\n        <div fxLayout=\"row\" fxLayoutGap=\"5px\" fxFill class=\"small\">\r\n          <div fxFlex=\"30px\" fxFlexAlign=\"center\">\r\n            <button type=\"button\" mat-icon-button matTreeNodeToggle [attr.aria-label]=\"'Apri/chiudi ' + node.name\"\r\n              class=\"small-icon-button\">\r\n              <mat-icon class=\"mat-icon-rtl-mirror\">\r\n                {{treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'}}\r\n              </mat-icon>\r\n            </button>\r\n          </div>\r\n          <div fxFlex=\"*\" fxFlexAlign=\"center\" class=\"uppercase truncated\">\r\n            <div>\r\n              {{node.name}}\r\n            </div>\r\n          </div>\r\n          <div fxFlex=\"30px\" fxFlexAlign=\"center\">\r\n            @if (node.count > 0) {\r\n            <div fxLayoutAlign=\"end\">({{node.count}})</div>\r\n            }\r\n          </div>\r\n        </div>\r\n      </mat-tree-node>\r\n    </mat-tree>\r\n  </div>\r\n</div>\r\n<div mat-dialog-actions>\r\n  <div fxLayout=\"row\" fxLayoutAlign=\"end\" fxFill>\r\n    <button mat-flat-button color=\"primary\" (click)=\"ok()\" \r\n      [disabled]=\"!currentNode\">{{dialogData.okCaption}}</button>\r\n    <button mat-button mat-dialog-close cdkFocusInitial \r\n      color=\"primary\">Annulla</button>\r\n  </div>\r\n</div>"]}
|