@arsedizioni/ars-utils 18.4.67 → 18.4.69

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.
@@ -82,9 +82,7 @@ export class SupportNotificationsBrowserComponent {
82
82
  let elem = document.getElementById('notifications-browser-scrollable');
83
83
  if (elem) {
84
84
  const height = this.dialogService.getCurrentDialogScrollableHeight(['notifications-browser-fixed'], window.innerHeight);
85
- if (height != elem.clientHeight) {
86
- elem.setAttribute('style', 'height:' + height + 'px !important;max-height:' + height + 'px !important');
87
- }
85
+ elem.setAttribute('style', 'height:' + height + 'px !important;max-height:' + height + 'px !important');
88
86
  }
89
87
  else {
90
88
  this.resize();
@@ -254,4 +252,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
254
252
  type: ViewChild,
255
253
  args: ['contextMenuTrigger']
256
254
  }] } });
257
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-browser.component.js","sourceRoot":"","sources":["../../../../../../projects/ars-utils/support.ui/ui/notifications-browser/notifications-browser.component.ts","../../../../../../projects/ars-utils/support.ui/ui/notifications-browser/notifications-browser.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  Component, OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n  inject,\r\n  signal\r\n} from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatBadgeModule } from '@angular/material/badge';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatDialogActions, MatDialogClose, MatDialogContent, 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 { MatMenuModule, MatMenuTrigger } from '@angular/material/menu';\r\nimport { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { BroadcastService, FormatPipe, ScreenService, SelectableModel, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { SupportMessages, SupportNotificationInfo, SupportNotificationsSearchParams, SupportService } from '@arsedizioni/ars-utils/support.common';\r\nimport {\r\n  DialogService\r\n} from '@arsedizioni/ars-utils/ui';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\nimport { Subject, debounceTime, finalize, fromEvent, takeUntil } from 'rxjs';\r\nimport { SupportNotificationComponent } from './notification/notification.component';\r\n\r\n@Component({\r\n  host: { 'Bind': SystemUtils.generateUUID() },\r\n  templateUrl: './notifications-browser.component.html',\r\n  styleUrls: ['./notifications-browser.component.scss'],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [FlexLayoutModule, MatDialogTitle, MatButtonModule, MatTooltipModule, MatDialogClose,\r\n    MatIconModule, MatFormFieldModule, MatInputModule, FormsModule, MatMenuModule, MatBadgeModule, MatDividerModule, MatDialogContent,\r\n    MatCheckboxModule, MatDialogActions, MatPaginatorModule, FormatPipe, SupportNotificationComponent]\r\n})\r\nexport class SupportNotificationsBrowserComponent\r\n  implements OnInit, OnDestroy, AfterViewInit {\r\n\r\n  @ViewChild('paginator') paginator!: MatPaginator;\r\n  @ViewChild('contextMenuTrigger') contextMenu!: MatMenuTrigger;\r\n\r\n\r\n  protected screenService = inject(ScreenService);\r\n  private supportService = inject(SupportService);\r\n  private broadcastService = inject(BroadcastService);\r\n  private dialogService = inject(DialogService);\r\n  private unsubscribe: Subject<void> = new Subject<void>();\r\n  protected selection = new SelectableModel<SupportNotificationInfo, number>(true, 'id');\r\n  protected searchParams: SupportNotificationsSearchParams = {\r\n    first: 0,\r\n    count: 25\r\n  };\r\n  protected total = signal<number>(-1);\r\n  protected items = signal<any>(null);\r\n  protected contextMenuPosition = { x: '0px', y: '0px' };\r\n\r\n\r\n  ngOnInit(): void {\r\n    // React to window size change\r\n    fromEvent(window, 'resize')\r\n      .pipe(takeUntil(this.unsubscribe), debounceTime(250))\r\n      .subscribe(() => {\r\n        this.resize();\r\n      });\r\n\r\n    // React to message broadcasting\r\n    this.broadcastService.getMessage()\r\n      .pipe(takeUntil(this.unsubscribe))\r\n      .subscribe(message => {\r\n        if (message.id === SupportMessages.NOTIFICATION_READ) {\r\n          const item = this.items().find((n: any) => n.id === message.data);\r\n          if (item) {\r\n            item.isRead = true;\r\n          }\r\n        }\r\n      });\r\n  }\r\n\r\n\r\n  ngOnDestroy(): void {\r\n    this.unsubscribe.next();\r\n    this.unsubscribe.complete();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.resize();\r\n    this.find();\r\n  }\r\n\r\n\r\n  /**\r\n   * Resize dialog\r\n   */\r\n  private resize() {\r\n    setTimeout(() => {\r\n      let elem = document.getElementById('notifications-browser-scrollable');\r\n      if (elem) {\r\n        const height = this.dialogService.getCurrentDialogScrollableHeight(\r\n          ['notifications-browser-fixed'],\r\n          window.innerHeight\r\n        );\r\n        if (height != elem.clientHeight) {\r\n          elem.setAttribute('style', 'height:' + height + 'px !important;max-height:' + height + 'px !important');\r\n        }\r\n      } else {\r\n        this.resize();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  protected onContextMenu(event: MouseEvent, item: any) {\r\n    event.preventDefault();\r\n    this.contextMenuPosition.x = event.clientX + 'px';\r\n    this.contextMenuPosition.y = event.clientY + 'px';\r\n    this.contextMenu.menuData = { item: item };\r\n    this.contextMenu.openMenu();\r\n  }\r\n\r\n  /**\r\n   * Update scroll\r\n   */\r\n  private updateScroll() {\r\n    // Scroll to top\r\n    let elem = document.getElementById('notifications-browser-scroller');\r\n    if (elem) elem.parentElement.scrollTop = 0;\r\n  }\r\n\r\n  /**\r\n   * Update menu buttons visibility when the menu is closed\r\n   */\r\n  protected updateMenuButtonsVisibility() {\r\n    this.items()?.forEach((n: any) => {\r\n      n.isMenuOpen = false;\r\n    });\r\n  }\r\n\r\n  /**\r\n     * Get all selected ids\r\n     * @returns: the selected ids as an array\r\n     */\r\n  private getSeletectIds(): number[] {\r\n    if (this.selection.all?.length > 50) {\r\n      this.dialogService.error('La selezione non può contenere più di 50 elementi.');\r\n      return null;\r\n    }\r\n    let ids: number[] = [];\r\n    if (this.selection.all?.length > 0) {\r\n      this.selection.all?.forEach((n: any) => {\r\n        ids.push(n.id);\r\n      });\r\n    }\r\n    return ids;\r\n  }\r\n\r\n  /**\r\n* Return item state css class\r\n* @param item : the item to evaluate\r\n*/\r\n  protected getItemStateCssClass(item: any) {\r\n    if (!item.isRead) return 'unread-bg';\r\n    return null;\r\n  }\r\n\r\n  /**\r\n   * Return the item state tooltip text\r\n   * @param item : the item to evaluate\r\n   */\r\n  protected getItemStateTooltip(item: any): string {\r\n    if (!item.isRead) return 'Non letto';\r\n    return '';\r\n  }\r\n\r\n  /**\r\n   * Perform a new search\r\n   */\r\n  protected find() {\r\n    this.searchParams.first = 0;\r\n    if (this.paginator) {\r\n      this.paginator.pageIndex = 0;\r\n    }\r\n    this.fetch();\r\n  }\r\n\r\n  /**\r\n   * Retrieve data\r\n   */\r\n  private fetch() {\r\n    if (!this.supportService.loggedIn()) return;\r\n    this.dialogService.busy('Caricamento in corso...');\r\n    this.supportService.queryNotifications(this.searchParams)\r\n      .pipe(finalize(() => this.dialogService.clearBusy()))\r\n      .subscribe(r => {\r\n        if (!r.success) {\r\n          this.dialogService.error(r.message);\r\n        } else {\r\n          this.items.set(r.value?.items ?? []);\r\n          this.total.set(r.value?.total ?? 0);\r\n          this.updateScroll();\r\n        }\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Show a new page result\r\n   * @param e : the MatPaginator PageEvent data\r\n   */\r\n  protected fetchMore(e: any) {\r\n    let first = e.pageIndex * this.searchParams.count;\r\n    this.searchParams.first = first;\r\n    this.fetch();\r\n  }\r\n\r\n\r\n  /**\r\n   * Mark a notification as read or unread\r\n   * @param item : the item to set or null to use selection\r\n   * @param unmark : true to set as unread or false to set as read\r\n   */\r\n  protected mark(item: any = null, unmark: boolean = false) {\r\n    if (!this.supportService.loggedIn()) return;\r\n    if (!item && !this.selection.all?.length) return;\r\n    const ids: number[] = item ? [item.id] : this.getSeletectIds();\r\n    this.dialogService.busy('Aggiornamento in corso...');\r\n    this.supportService.markNotifications({\r\n      ids: ids,\r\n      unmark: unmark\r\n    })\r\n      .pipe(finalize(() => this.dialogService.clearBusy()))\r\n      .subscribe(r => {\r\n        if (!r.success) {\r\n          this.dialogService.error(r.message);\r\n        } else {\r\n          ids.forEach((id: number) => {\r\n            const p = this.items().findIndex((n: any) => n.id === id);\r\n            if (p !== -1) {\r\n              this.items()[p].isRead = !unmark;\r\n            }\r\n          });\r\n          this.selection.clear();\r\n          this.supportService.countUnreadNotifications();\r\n        }\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Display a notification\r\n   * @param item : the item to display\r\n   */\r\n  protected show(item: any) {\r\n    this.dialogService.open(SupportNotificationComponent, {\r\n      ariaLabel: 'visualizza notifica',\r\n      autoFocus: false,\r\n      restoreFocus: false,\r\n      disableClose: true,\r\n      data: { id: item.id },\r\n      minWidth: '375px',\r\n      maxWidth: '900px',\r\n      width: '100%',\r\n      height: '100%'\r\n    });\r\n  }\r\n\r\n}\r\n","<div class=\"notifications-browser-fixed\">\r\n  <div class=\"notifications-browser-header\">\r\n    <div fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutGap=\"10px\" fxFill >\r\n      <div fxFlex=\"*\">\r\n        <h2 mat-dialog-title>Novità e informazioni</h2>\r\n      </div>\r\n      <div fxLayoutAlign=\"end\">\r\n        <button fxFlexAlign=\"start\" type=\"button\" mat-icon-button matTooltip=\"Chiudi\" aria-label=\"Chiudi\"\r\n          [mat-dialog-close]=\"true\" class=\"dialog-close\">\r\n          <mat-icon>close</mat-icon>\r\n        </button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div style=\"padding-left: 24px; padding-right: 24px; padding-bottom: 10px;\">\r\n    <div fxLayout=\"row wrap\" fxFill fxLayoutAlign=\"space-between\">\r\n      <div fxFlex=\"200px\" fxFlexAlign=\"end\">\r\n        <mat-form-field style=\"width:200px\" subscriptSizing=\"dynamic\" appearance=\"outline\">\r\n          <mat-label>Cerca</mat-label>\r\n          <input matInput #searchInput=\"matInput\" type=\"text\" [(ngModel)]=\"searchParams.any\" maxlength=\"200\"\r\n            (keyup.Enter)=\"find()\" autofocus placeholder=\"Inserisci testo + INVIO...\" />\r\n          @if (searchParams.any) {\r\n          <button type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Pulisci\"\r\n            (click)=\"searchParams.any = ''\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n      </div>\r\n      <div fxFlex=\"*\" fxLayoutAlign=\"end\">\r\n        <div fxFlexAlign=\"center\">\r\n          @if (selection.hasValue()) {\r\n          <button type=\"button\" mat-icon-button matTooltip=\"Azioni da eseguire sugli elementi selezionati\"\r\n            [attr.aria-label]=\"'Menu opzioni per elementi selezionati'\" [matMenuTriggerFor]=\"menuSelections\">\r\n            <mat-icon aria-hidden=\"false\" [matBadge]=\"selection.all.length\">checklist</mat-icon>\r\n          </button>\r\n          }\r\n          <mat-menu #menuSelections=\"matMenu\">\r\n            <button mat-menu-item (click)=\"selection.clear()\" [attr.aria-label]=\"'Deseleziona tutti'\">\r\n              <mat-icon>clear</mat-icon>Deseleziona tutti\r\n            </button>\r\n            <mat-divider></mat-divider>\r\n            <button mat-menu-item [attr.aria-label]=\"'Segna come da leggere'\" (click)=\"mark(null, true)\">\r\n              <mat-icon>outlined_flag</mat-icon>Segna come da leggere\r\n            </button>\r\n            <button mat-menu-item [attr.aria-label]=\"'Segna come già letto'\" (click)=\"mark(null)\">\r\n              <mat-icon>flag</mat-icon>Segna come già letto\r\n            </button>\r\n          </mat-menu>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n<mat-dialog-content id=\"notifications-browser-scrollable\">\r\n  <div id=\"notifications-browser-scroller\">\r\n    @if (total() === 0) {\r\n    <div>\r\n      <p class=\"message\"><i>Nessun elemento da visualizzare.</i></p>\r\n    </div>\r\n    } @else {\r\n    <div>\r\n      @for (item of items(); track item.id; let i = $index) {\r\n      <div (mouseenter)=\"item.isOver = true;\" (mouseleave)=\"item.isOver = false\"\r\n        (contextmenu)=\"onContextMenu($event, item)\">\r\n        <div class=\"news\" fxLayout=\"row\" fxLayoutGap=\"6px\" fxFill [ngClass]=\"{'news-selected': selection.isSelected(item.id), \r\n          'news-read': item.isRead}\">\r\n          <div fxFlex=\"6px\" [ngClass]=\"getItemStateCssClass(item)\" [matTooltip]=\"getItemStateTooltip(item)\">\r\n          </div>\r\n          <div fxFlex=\"48px\" fxFlexAlign=\"center\" fxLayoutAlign=\"center\">\r\n            @if (screenService.isTouchable || item.isOver || selection.isSelected(item.id)) {\r\n            <mat-checkbox (change)=\"$event ? selection.toggle(item, item.id) : null\"\r\n              [checked]=\"selection.isSelected(item.id)\">\r\n            </mat-checkbox>\r\n            }\r\n          </div>\r\n          <div fxFlex=\"*\" fxFlexAlign=\"center\" (click)=\"show(item); $event.stopPropagation()\">\r\n            <div class=\"info-1 uppercase\">\r\n              {{ (item.publishingDate ?? item.created) | format:'D':'dd/MM/yyyy'}}</div>\r\n            <div>{{item.title}}</div>\r\n            <div class=\"info-2 uppercase\">\r\n              {{item.productNames}}\r\n              @if (item.productModulesNames) {\r\n              <span> | {{item.productModulesNames}}</span>\r\n              }\r\n            </div>\r\n          </div>\r\n          <div fxFlex=\"50px\" fxFlexAlign=\"center\">\r\n            @if (item.isOver || item.isMenuOpen || selection.isSelected(item.id)) {\r\n            <button type=\"button\" mat-icon-button matTooltip=\"Menu\" [attr.aria-label]=\"'Menu opzioni'\"\r\n              [matMenuTriggerFor]=\"contextMenu\" [matMenuTriggerData]=\"{item: item}\" (click)=\"item.isMenuOpen = true\">\r\n              <mat-icon>more_vert</mat-icon>\r\n            </button>\r\n            }\r\n          </div>\r\n        </div>\r\n      </div>\r\n      }\r\n      <div #contextMenuTrigger=\"matMenuTrigger\" style=\"position: fixed\" [style.left]=\"contextMenuPosition.x\"\r\n        [style.top]=\"contextMenuPosition.y\" [matMenuTriggerFor]=\"contextMenu\">\r\n      </div>\r\n      <mat-menu #contextMenu=\"matMenu\" (closed)=\"updateMenuButtonsVisibility()\">\r\n        <ng-template matMenuContent let-item=\"item\">\r\n          @if (item.isRead) {\r\n          <button mat-menu-item [attr.aria-label]=\"'Segna come da leggere'\" (click)=\"mark(item, true)\">\r\n            <mat-icon>flag</mat-icon>Segna come da leggere\r\n          </button>\r\n          }\r\n          @if (!item.isRead) {\r\n          <button mat-menu-item [attr.aria-label]=\"'Segna come da già letto'\" (click)=\"mark(item)\">\r\n            <mat-icon>outlined_flag</mat-icon>Segna come già letto\r\n          </button>\r\n          }\r\n        </ng-template>\r\n      </mat-menu>\r\n    </div>\r\n    }\r\n  </div>\r\n</mat-dialog-content>\r\n<mat-dialog-actions class=\"notifications-browser-fixed\">\r\n  <div fxLayout=\"row wrap\" fxLayoutGap=\"10px\" fxLayoutAlign=\"space-between\" fxFill>\r\n    <!-- legend -->\r\n    <div fxFlex.lt-md=\"100\" class=\"legend-container\">\r\n      <div class=\"legend unread-bg\"></div>\r\n      da leggere\r\n    </div>\r\n    <div fxFlex.lt-md=\"100\" fxLayoutAlign=\"end\">\r\n      <mat-paginator #paginator [hidePageSize]=\"true\" [length]=\"total()\" [pageSize]=\"searchParams.count\"\r\n        [showFirstLastButtons]=\"true\" (page)=\"fetchMore($event)\"></mat-paginator>\r\n    </div>\r\n  </div>\r\n</mat-dialog-actions>"]}
255
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-browser.component.js","sourceRoot":"","sources":["../../../../../../projects/ars-utils/support.ui/ui/notifications-browser/notifications-browser.component.ts","../../../../../../projects/ars-utils/support.ui/ui/notifications-browser/notifications-browser.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  Component, OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n  inject,\r\n  signal\r\n} from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatBadgeModule } from '@angular/material/badge';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatDialogActions, MatDialogClose, MatDialogContent, 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 { MatMenuModule, MatMenuTrigger } from '@angular/material/menu';\r\nimport { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { BroadcastService, FormatPipe, ScreenService, SelectableModel, SystemUtils } from '@arsedizioni/ars-utils/core';\r\nimport { SupportMessages, SupportNotificationInfo, SupportNotificationsSearchParams, SupportService } from '@arsedizioni/ars-utils/support.common';\r\nimport {\r\n  DialogService\r\n} from '@arsedizioni/ars-utils/ui';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\nimport { Subject, debounceTime, finalize, fromEvent, takeUntil } from 'rxjs';\r\nimport { SupportNotificationComponent } from './notification/notification.component';\r\n\r\n@Component({\r\n  host: { 'Bind': SystemUtils.generateUUID() },\r\n  templateUrl: './notifications-browser.component.html',\r\n  styleUrls: ['./notifications-browser.component.scss'],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [FlexLayoutModule, MatDialogTitle, MatButtonModule, MatTooltipModule, MatDialogClose,\r\n    MatIconModule, MatFormFieldModule, MatInputModule, FormsModule, MatMenuModule, MatBadgeModule, MatDividerModule, MatDialogContent,\r\n    MatCheckboxModule, MatDialogActions, MatPaginatorModule, FormatPipe, SupportNotificationComponent]\r\n})\r\nexport class SupportNotificationsBrowserComponent\r\n  implements OnInit, OnDestroy, AfterViewInit {\r\n\r\n  @ViewChild('paginator') paginator!: MatPaginator;\r\n  @ViewChild('contextMenuTrigger') contextMenu!: MatMenuTrigger;\r\n\r\n\r\n  protected screenService = inject(ScreenService);\r\n  private supportService = inject(SupportService);\r\n  private broadcastService = inject(BroadcastService);\r\n  private dialogService = inject(DialogService);\r\n  private unsubscribe: Subject<void> = new Subject<void>();\r\n  protected selection = new SelectableModel<SupportNotificationInfo, number>(true, 'id');\r\n  protected searchParams: SupportNotificationsSearchParams = {\r\n    first: 0,\r\n    count: 25\r\n  };\r\n  protected total = signal<number>(-1);\r\n  protected items = signal<any>(null);\r\n  protected contextMenuPosition = { x: '0px', y: '0px' };\r\n\r\n\r\n  ngOnInit(): void {\r\n    // React to window size change\r\n    fromEvent(window, 'resize')\r\n      .pipe(takeUntil(this.unsubscribe), debounceTime(250))\r\n      .subscribe(() => {\r\n        this.resize();\r\n      });\r\n\r\n    // React to message broadcasting\r\n    this.broadcastService.getMessage()\r\n      .pipe(takeUntil(this.unsubscribe))\r\n      .subscribe(message => {\r\n        if (message.id === SupportMessages.NOTIFICATION_READ) {\r\n          const item = this.items().find((n: any) => n.id === message.data);\r\n          if (item) {\r\n            item.isRead = true;\r\n          }\r\n        }\r\n      });\r\n  }\r\n\r\n\r\n  ngOnDestroy(): void {\r\n    this.unsubscribe.next();\r\n    this.unsubscribe.complete();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.resize();\r\n    this.find();\r\n  }\r\n\r\n\r\n  /**\r\n   * Resize dialog\r\n   */\r\n  private resize() {\r\n    setTimeout(() => {\r\n      let elem = document.getElementById('notifications-browser-scrollable');\r\n      if (elem) {\r\n        const height = this.dialogService.getCurrentDialogScrollableHeight(\r\n          ['notifications-browser-fixed'],\r\n          window.innerHeight\r\n        );\r\n        elem.setAttribute('style', 'height:' + height + 'px !important;max-height:' + height + 'px !important');\r\n      } else {\r\n        this.resize();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  protected onContextMenu(event: MouseEvent, item: any) {\r\n    event.preventDefault();\r\n    this.contextMenuPosition.x = event.clientX + 'px';\r\n    this.contextMenuPosition.y = event.clientY + 'px';\r\n    this.contextMenu.menuData = { item: item };\r\n    this.contextMenu.openMenu();\r\n  }\r\n\r\n  /**\r\n   * Update scroll\r\n   */\r\n  private updateScroll() {\r\n    // Scroll to top\r\n    let elem = document.getElementById('notifications-browser-scroller');\r\n    if (elem) elem.parentElement.scrollTop = 0;\r\n  }\r\n\r\n  /**\r\n   * Update menu buttons visibility when the menu is closed\r\n   */\r\n  protected updateMenuButtonsVisibility() {\r\n    this.items()?.forEach((n: any) => {\r\n      n.isMenuOpen = false;\r\n    });\r\n  }\r\n\r\n  /**\r\n     * Get all selected ids\r\n     * @returns: the selected ids as an array\r\n     */\r\n  private getSeletectIds(): number[] {\r\n    if (this.selection.all?.length > 50) {\r\n      this.dialogService.error('La selezione non può contenere più di 50 elementi.');\r\n      return null;\r\n    }\r\n    let ids: number[] = [];\r\n    if (this.selection.all?.length > 0) {\r\n      this.selection.all?.forEach((n: any) => {\r\n        ids.push(n.id);\r\n      });\r\n    }\r\n    return ids;\r\n  }\r\n\r\n  /**\r\n* Return item state css class\r\n* @param item : the item to evaluate\r\n*/\r\n  protected getItemStateCssClass(item: any) {\r\n    if (!item.isRead) return 'unread-bg';\r\n    return null;\r\n  }\r\n\r\n  /**\r\n   * Return the item state tooltip text\r\n   * @param item : the item to evaluate\r\n   */\r\n  protected getItemStateTooltip(item: any): string {\r\n    if (!item.isRead) return 'Non letto';\r\n    return '';\r\n  }\r\n\r\n  /**\r\n   * Perform a new search\r\n   */\r\n  protected find() {\r\n    this.searchParams.first = 0;\r\n    if (this.paginator) {\r\n      this.paginator.pageIndex = 0;\r\n    }\r\n    this.fetch();\r\n  }\r\n\r\n  /**\r\n   * Retrieve data\r\n   */\r\n  private fetch() {\r\n    if (!this.supportService.loggedIn()) return;\r\n    this.dialogService.busy('Caricamento in corso...');\r\n    this.supportService.queryNotifications(this.searchParams)\r\n      .pipe(finalize(() => this.dialogService.clearBusy()))\r\n      .subscribe(r => {\r\n        if (!r.success) {\r\n          this.dialogService.error(r.message);\r\n        } else {\r\n          this.items.set(r.value?.items ?? []);\r\n          this.total.set(r.value?.total ?? 0);\r\n          this.updateScroll();\r\n        }\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Show a new page result\r\n   * @param e : the MatPaginator PageEvent data\r\n   */\r\n  protected fetchMore(e: any) {\r\n    let first = e.pageIndex * this.searchParams.count;\r\n    this.searchParams.first = first;\r\n    this.fetch();\r\n  }\r\n\r\n\r\n  /**\r\n   * Mark a notification as read or unread\r\n   * @param item : the item to set or null to use selection\r\n   * @param unmark : true to set as unread or false to set as read\r\n   */\r\n  protected mark(item: any = null, unmark: boolean = false) {\r\n    if (!this.supportService.loggedIn()) return;\r\n    if (!item && !this.selection.all?.length) return;\r\n    const ids: number[] = item ? [item.id] : this.getSeletectIds();\r\n    this.dialogService.busy('Aggiornamento in corso...');\r\n    this.supportService.markNotifications({\r\n      ids: ids,\r\n      unmark: unmark\r\n    })\r\n      .pipe(finalize(() => this.dialogService.clearBusy()))\r\n      .subscribe(r => {\r\n        if (!r.success) {\r\n          this.dialogService.error(r.message);\r\n        } else {\r\n          ids.forEach((id: number) => {\r\n            const p = this.items().findIndex((n: any) => n.id === id);\r\n            if (p !== -1) {\r\n              this.items()[p].isRead = !unmark;\r\n            }\r\n          });\r\n          this.selection.clear();\r\n          this.supportService.countUnreadNotifications();\r\n        }\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Display a notification\r\n   * @param item : the item to display\r\n   */\r\n  protected show(item: any) {\r\n    this.dialogService.open(SupportNotificationComponent, {\r\n      ariaLabel: 'visualizza notifica',\r\n      autoFocus: false,\r\n      restoreFocus: false,\r\n      disableClose: true,\r\n      data: { id: item.id },\r\n      minWidth: '375px',\r\n      maxWidth: '900px',\r\n      width: '100%',\r\n      height: '100%'\r\n    });\r\n  }\r\n\r\n}\r\n","<div class=\"notifications-browser-fixed\">\r\n  <div class=\"notifications-browser-header\">\r\n    <div fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutGap=\"10px\" fxFill >\r\n      <div fxFlex=\"*\">\r\n        <h2 mat-dialog-title>Novità e informazioni</h2>\r\n      </div>\r\n      <div fxLayoutAlign=\"end\">\r\n        <button fxFlexAlign=\"start\" type=\"button\" mat-icon-button matTooltip=\"Chiudi\" aria-label=\"Chiudi\"\r\n          [mat-dialog-close]=\"true\" class=\"dialog-close\">\r\n          <mat-icon>close</mat-icon>\r\n        </button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div style=\"padding-left: 24px; padding-right: 24px; padding-bottom: 10px;\">\r\n    <div fxLayout=\"row wrap\" fxFill fxLayoutAlign=\"space-between\">\r\n      <div fxFlex=\"200px\" fxFlexAlign=\"end\">\r\n        <mat-form-field style=\"width:200px\" subscriptSizing=\"dynamic\" appearance=\"outline\">\r\n          <mat-label>Cerca</mat-label>\r\n          <input matInput #searchInput=\"matInput\" type=\"text\" [(ngModel)]=\"searchParams.any\" maxlength=\"200\"\r\n            (keyup.Enter)=\"find()\" autofocus placeholder=\"Inserisci testo + INVIO...\" />\r\n          @if (searchParams.any) {\r\n          <button type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Pulisci\"\r\n            (click)=\"searchParams.any = ''\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n      </div>\r\n      <div fxFlex=\"*\" fxLayoutAlign=\"end\">\r\n        <div fxFlexAlign=\"center\">\r\n          @if (selection.hasValue()) {\r\n          <button type=\"button\" mat-icon-button matTooltip=\"Azioni da eseguire sugli elementi selezionati\"\r\n            [attr.aria-label]=\"'Menu opzioni per elementi selezionati'\" [matMenuTriggerFor]=\"menuSelections\">\r\n            <mat-icon aria-hidden=\"false\" [matBadge]=\"selection.all.length\">checklist</mat-icon>\r\n          </button>\r\n          }\r\n          <mat-menu #menuSelections=\"matMenu\">\r\n            <button mat-menu-item (click)=\"selection.clear()\" [attr.aria-label]=\"'Deseleziona tutti'\">\r\n              <mat-icon>clear</mat-icon>Deseleziona tutti\r\n            </button>\r\n            <mat-divider></mat-divider>\r\n            <button mat-menu-item [attr.aria-label]=\"'Segna come da leggere'\" (click)=\"mark(null, true)\">\r\n              <mat-icon>outlined_flag</mat-icon>Segna come da leggere\r\n            </button>\r\n            <button mat-menu-item [attr.aria-label]=\"'Segna come già letto'\" (click)=\"mark(null)\">\r\n              <mat-icon>flag</mat-icon>Segna come già letto\r\n            </button>\r\n          </mat-menu>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n<mat-dialog-content id=\"notifications-browser-scrollable\">\r\n  <div id=\"notifications-browser-scroller\">\r\n    @if (total() === 0) {\r\n    <div>\r\n      <p class=\"message\"><i>Nessun elemento da visualizzare.</i></p>\r\n    </div>\r\n    } @else {\r\n    <div>\r\n      @for (item of items(); track item.id; let i = $index) {\r\n      <div (mouseenter)=\"item.isOver = true;\" (mouseleave)=\"item.isOver = false\"\r\n        (contextmenu)=\"onContextMenu($event, item)\">\r\n        <div class=\"news\" fxLayout=\"row\" fxLayoutGap=\"6px\" fxFill [ngClass]=\"{'news-selected': selection.isSelected(item.id), \r\n          'news-read': item.isRead}\">\r\n          <div fxFlex=\"6px\" [ngClass]=\"getItemStateCssClass(item)\" [matTooltip]=\"getItemStateTooltip(item)\">\r\n          </div>\r\n          <div fxFlex=\"48px\" fxFlexAlign=\"center\" fxLayoutAlign=\"center\">\r\n            @if (screenService.isTouchable || item.isOver || selection.isSelected(item.id)) {\r\n            <mat-checkbox (change)=\"$event ? selection.toggle(item, item.id) : null\"\r\n              [checked]=\"selection.isSelected(item.id)\">\r\n            </mat-checkbox>\r\n            }\r\n          </div>\r\n          <div fxFlex=\"*\" fxFlexAlign=\"center\" (click)=\"show(item); $event.stopPropagation()\">\r\n            <div class=\"info-1 uppercase\">\r\n              {{ (item.publishingDate ?? item.created) | format:'D':'dd/MM/yyyy'}}</div>\r\n            <div>{{item.title}}</div>\r\n            <div class=\"info-2 uppercase\">\r\n              {{item.productNames}}\r\n              @if (item.productModulesNames) {\r\n              <span> | {{item.productModulesNames}}</span>\r\n              }\r\n            </div>\r\n          </div>\r\n          <div fxFlex=\"50px\" fxFlexAlign=\"center\">\r\n            @if (item.isOver || item.isMenuOpen || selection.isSelected(item.id)) {\r\n            <button type=\"button\" mat-icon-button matTooltip=\"Menu\" [attr.aria-label]=\"'Menu opzioni'\"\r\n              [matMenuTriggerFor]=\"contextMenu\" [matMenuTriggerData]=\"{item: item}\" (click)=\"item.isMenuOpen = true\">\r\n              <mat-icon>more_vert</mat-icon>\r\n            </button>\r\n            }\r\n          </div>\r\n        </div>\r\n      </div>\r\n      }\r\n      <div #contextMenuTrigger=\"matMenuTrigger\" style=\"position: fixed\" [style.left]=\"contextMenuPosition.x\"\r\n        [style.top]=\"contextMenuPosition.y\" [matMenuTriggerFor]=\"contextMenu\">\r\n      </div>\r\n      <mat-menu #contextMenu=\"matMenu\" (closed)=\"updateMenuButtonsVisibility()\">\r\n        <ng-template matMenuContent let-item=\"item\">\r\n          @if (item.isRead) {\r\n          <button mat-menu-item [attr.aria-label]=\"'Segna come da leggere'\" (click)=\"mark(item, true)\">\r\n            <mat-icon>flag</mat-icon>Segna come da leggere\r\n          </button>\r\n          }\r\n          @if (!item.isRead) {\r\n          <button mat-menu-item [attr.aria-label]=\"'Segna come da già letto'\" (click)=\"mark(item)\">\r\n            <mat-icon>outlined_flag</mat-icon>Segna come già letto\r\n          </button>\r\n          }\r\n        </ng-template>\r\n      </mat-menu>\r\n    </div>\r\n    }\r\n  </div>\r\n</mat-dialog-content>\r\n<mat-dialog-actions class=\"notifications-browser-fixed\">\r\n  <div fxLayout=\"row wrap\" fxLayoutGap=\"10px\" fxLayoutAlign=\"space-between\" fxFill>\r\n    <!-- legend -->\r\n    <div fxFlex.lt-md=\"100\" class=\"legend-container\">\r\n      <div class=\"legend unread-bg\"></div>\r\n      da leggere\r\n    </div>\r\n    <div fxFlex.lt-md=\"100\" fxLayoutAlign=\"end\">\r\n      <mat-paginator #paginator [hidePageSize]=\"true\" [length]=\"total()\" [pageSize]=\"searchParams.count\"\r\n        [showFirstLastButtons]=\"true\" (page)=\"fetchMore($event)\"></mat-paginator>\r\n    </div>\r\n  </div>\r\n</mat-dialog-actions>"]}
@@ -59,9 +59,7 @@ export class FilePreviewComponent {
59
59
  let elem = document.getElementById('file-preview-scrollable');
60
60
  if (elem) {
61
61
  const height = this.dialogService.getCurrentDialogScrollableHeight(['file-preview-fixed'], window.innerHeight);
62
- if (height != elem.clientHeight) {
63
- elem.setAttribute('style', 'height:' + height + 'px !important;max-height:' + height + 'px !important');
64
- }
62
+ elem.setAttribute('style', 'height:' + height + 'px !important;max-height:' + height + 'px !important');
65
63
  }
66
64
  else {
67
65
  this.resize();
@@ -96,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
96
94
  args: [{ standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [MatDialogContent, NgStyle, FlexLayoutModule, MatDialogActions, MatButtonModule, MatTooltipModule,
97
95
  MatDialogClose, SafeUrlPipe], template: "<mat-dialog-content class=\"file-preview\" id=\"file-preview-scrollable\">\r\n <div class=\"content\">\r\n @if (!url) {\r\n <div class=\"loading\">Caricamento in corso...</div>\r\n } @else {\r\n <iframe class=\"iframe\" onload=\"scrollTo(0,0)\" [src]=\"url() | safeUrl\"></iframe>\r\n }\r\n </div>\r\n</mat-dialog-content>\r\n<mat-dialog-actions id=\"file-preview-fixed\">\r\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutGap=\"10px\" fxFill>\r\n <div fxFlex=\"50\">\r\n <button mat-stroked-button color=\"primary\" (click)=\"troubles()\"\r\n matTooltip=\"Fai click se non riesci a visualizzare l'anteprima dei file PDF\">Problemi con i PDF?</button>\r\n </div>\r\n <div fxFlex=\"50\" fxLayoutAlign=\"end\">\r\n <button mat-stroked-button color=\"primary\" (click)=\"download()\">Scarica</button>\r\n <button mat-stroked-button [mat-dialog-close]=\"true\" color=\"primary\">Chiudi</button>\r\n </div>\r\n </div>\r\n</mat-dialog-actions>", styles: [".file-preview{padding:0}.file-preview .content{height:100%;width:100%;overflow:hidden;background-color:var(--ars-filepreview-content-background-color, aliceblue)}.file-preview .content .loading{width:100%;height:100%;padding:20px}.file-preview .content .iframe{width:100%;height:100%;border:0}@media (prefers-color-scheme: dark){.file-preview .content{background-color:var(--ars-filepreview-content-background-color, aliceblue)}}\n"] }]
98
96
  }] });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-preview.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/components/file-preview/file-preview.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/components/file-preview/file-preview.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpHeaders } from '@angular/common/http';\r\nimport { Component, OnInit, OnDestroy, ChangeDetectionStrategy, inject, signal, AfterViewInit } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogContent, MatDialogActions, MatDialogClose } from '@angular/material/dialog';\r\nimport { fromEvent, takeUntil, Subject, debounceTime } from 'rxjs';\r\nimport { SafeUrlPipe } from '@arsedizioni/ars-utils/core';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { NgStyle } from '@angular/common';\r\nimport { DialogService } from '@arsedizioni/ars-utils/ui';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\n\r\nexport interface FilePreviewDialogData {\r\n  url?: string | null;\r\n  embed?: boolean | null;\r\n  authToken?: string | null;\r\n}\r\n\r\n\r\n@Component({\r\n  templateUrl: './file-preview.component.html',\r\n  styleUrls: ['./file-preview.component.scss'],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [MatDialogContent, NgStyle, FlexLayoutModule, MatDialogActions, MatButtonModule, MatTooltipModule,\r\n    MatDialogClose, SafeUrlPipe]\r\n})\r\nexport class FilePreviewComponent implements OnInit, OnDestroy, AfterViewInit {\r\n\r\n  private unsubscribe: Subject<void> = new Subject<void>();\r\n  private httpClient = inject(HttpClient);\r\n  private dialogService = inject(DialogService);\r\n  protected dialogData: FilePreviewDialogData = inject(MAT_DIALOG_DATA);\r\n  protected url = signal(null);\r\n\r\n\r\n  ngOnInit() {\r\n    if (this.dialogData) {\r\n      if (!this.dialogData.embed) {\r\n        this.httpClient.get(\r\n          this.dialogData.url,\r\n          {\r\n            headers:\r\n              this.dialogData.authToken\r\n                ? new HttpHeaders().set(\"Authorization\", this.dialogData.authToken)\r\n                : new HttpHeaders(),\r\n            responseType: 'blob'\r\n          }\r\n        ).subscribe(\r\n          (res: any) => {\r\n            this.url.set(URL.createObjectURL(res));\r\n          });\r\n      } else {\r\n        this.url.set('https://view.officeapps.live.com/op/embed.aspx?src=' + encodeURIComponent(this.dialogData.url));\r\n      }\r\n    }\r\n\r\n    // React to window size change\r\n    fromEvent(window, 'resize')\r\n      .pipe(takeUntil(this.unsubscribe), debounceTime(250))\r\n      .subscribe(() => {\r\n        this.resize();\r\n      });\r\n\r\n  }\r\n\r\n\r\n  ngOnDestroy() {\r\n    this.unsubscribe.next();\r\n    this.unsubscribe.complete();\r\n    this.url.set(null);\r\n  }\r\n\r\n\r\n  ngAfterViewInit(): void {\r\n    this.resize();\r\n  }\r\n\r\n  /**\r\n * Resize \r\n */\r\n  private resize() {\r\n    setTimeout(() => {\r\n      let elem = document.getElementById('file-preview-scrollable');\r\n      if (elem) {\r\n        const height = this.dialogService.getCurrentDialogScrollableHeight(\r\n          ['file-preview-fixed'],\r\n          window.innerHeight\r\n        );\r\n        if (height != elem.clientHeight) {\r\n          elem.setAttribute('style', 'height:' + height + 'px !important;max-height:' + height + 'px !important');\r\n        }\r\n      } else {\r\n        this.resize();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  /**\r\n   * Download manually\r\n   */\r\n  download() {\r\n    window.open(this.url(), '_blank');\r\n  }\r\n\r\n  /**\r\n   * Troubles with pdf?\r\n   */\r\n  troubles() {\r\n    this.dialogService.info(\r\n      \"<p>Se non riesci a visualizzare l'anteprima dei file PDF probabilmente devi abilitare un'impostazione del tuo browser.</p>\" +\r\n      \"<b>Per Google Chrome</b><br>\" +\r\n      \"<p class='small' style='padding-left:10px'><i>impostazioni > privacy e sicurezza > impostazioni sito > documenti PDF</i></p>\" +\r\n      \"<b>Per Microsoft Chrome</b><br>\" +\r\n      \"<p class='small' style='padding-left:10px'><i>impostazioni > cookie e autorizzazioni sito > documenti PDF</i></p>\" +\r\n      \"<b>Per Mozilla Firefox</b><br>\" +\r\n      \"<p class='small' style='padding-left:10px'><i>impostazioni > generale > applicazioni</i></p>\" +\r\n      \"<b>Altri browser</b><br>\" +\r\n      \"<p class='small' style='padding-left:10px'>Fate riferimento alla documentazione specifica del vostro browser.</p>\",\r\n      \"Problemi con lee anteprime dei file PDF?\"\r\n    )\r\n  }\r\n}\r\n\r\n\r\n\r\n","<mat-dialog-content class=\"file-preview\"  id=\"file-preview-scrollable\">\r\n  <div class=\"content\">\r\n    @if (!url) {\r\n    <div class=\"loading\">Caricamento in corso...</div>\r\n    } @else {\r\n    <iframe class=\"iframe\" onload=\"scrollTo(0,0)\"  [src]=\"url() | safeUrl\"></iframe>\r\n    }\r\n  </div>\r\n</mat-dialog-content>\r\n<mat-dialog-actions id=\"file-preview-fixed\">\r\n  <div fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutGap=\"10px\" fxFill>\r\n    <div fxFlex=\"50\">\r\n      <button mat-stroked-button color=\"primary\" (click)=\"troubles()\"\r\n        matTooltip=\"Fai click se non riesci a visualizzare l'anteprima dei file PDF\">Problemi con i PDF?</button>\r\n    </div>\r\n    <div fxFlex=\"50\" fxLayoutAlign=\"end\">\r\n      <button mat-stroked-button color=\"primary\" (click)=\"download()\">Scarica</button>\r\n      <button mat-stroked-button [mat-dialog-close]=\"true\" color=\"primary\">Chiudi</button>\r\n    </div>\r\n  </div>\r\n</mat-dialog-actions>"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-preview.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/components/file-preview/file-preview.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/components/file-preview/file-preview.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAqB,uBAAuB,EAAE,MAAM,EAAE,MAAM,EAAiB,MAAM,eAAe,CAAC;AACrH,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC/G,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;;;;;AAiBzD,MAAM,OAAO,oBAAoB;IARjC;QAUU,gBAAW,GAAkB,IAAI,OAAO,EAAQ,CAAC;QACjD,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAChC,kBAAa,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QACpC,eAAU,GAA0B,MAAM,CAAC,eAAe,CAAC,CAAC;QAC5D,QAAG,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;KAuF9B;IApFC,QAAQ;QACN,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;gBAC3B,IAAI,CAAC,UAAU,CAAC,GAAG,CACjB,IAAI,CAAC,UAAU,CAAC,GAAG,EACnB;oBACE,OAAO,EACL,IAAI,CAAC,UAAU,CAAC,SAAS;wBACvB,CAAC,CAAC,IAAI,WAAW,EAAE,CAAC,GAAG,CAAC,eAAe,EAAE,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC;wBACnE,CAAC,CAAC,IAAI,WAAW,EAAE;oBACvB,YAAY,EAAE,MAAM;iBACrB,CACF,CAAC,SAAS,CACT,CAAC,GAAQ,EAAE,EAAE;oBACX,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC;gBACzC,CAAC,CAAC,CAAC;YACP,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,qDAAqD,GAAG,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;YAChH,CAAC;QACH,CAAC;QAED,8BAA8B;QAC9B,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC;aACxB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC;aACpD,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC,CAAC,CAAC;IAEP,CAAC;IAGD,WAAW;QACT,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QAC5B,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC;IAGD,eAAe;QACb,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED;;KAEC;IACO,MAAM;QACZ,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,IAAI,GAAG,QAAQ,CAAC,cAAc,CAAC,yBAAyB,CAAC,CAAC;YAC9D,IAAI,IAAI,EAAE,CAAC;gBACT,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,gCAAgC,CAChE,CAAC,oBAAoB,CAAC,EACtB,MAAM,CAAC,WAAW,CACnB,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,SAAS,GAAG,MAAM,GAAG,2BAA2B,GAAG,MAAM,GAAG,eAAe,CAAC,CAAC;YAC1G,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;IACpC,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,4HAA4H;YAC5H,8BAA8B;YAC9B,8HAA8H;YAC9H,iCAAiC;YACjC,mHAAmH;YACnH,gCAAgC;YAChC,8FAA8F;YAC9F,0BAA0B;YAC1B,mHAAmH,EACnH,0CAA0C,CAC3C,CAAA;IACH,CAAC;8GA5FU,oBAAoB;kGAApB,oBAAoB,wEC1BjC,i/BAoBqB,yeDGT,gBAAgB,wGAAW,gBAAgB,w6EAAE,gBAAgB,2HAAE,eAAe,2NAAE,gBAAgB,6TACxG,cAAc,gLAAE,WAAW;;2FAElB,oBAAoB;kBARhC,SAAS;iCAGI,IAAI,mBACC,uBAAuB,CAAC,MAAM,WACtC,CAAC,gBAAgB,EAAE,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,eAAe,EAAE,gBAAgB;wBACxG,cAAc,EAAE,WAAW,CAAC","sourcesContent":["import { HttpClient, HttpHeaders } from '@angular/common/http';\r\nimport { Component, OnInit, OnDestroy, ChangeDetectionStrategy, inject, signal, AfterViewInit } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogContent, MatDialogActions, MatDialogClose } from '@angular/material/dialog';\r\nimport { fromEvent, takeUntil, Subject, debounceTime } from 'rxjs';\r\nimport { SafeUrlPipe } from '@arsedizioni/ars-utils/core';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { NgStyle } from '@angular/common';\r\nimport { DialogService } from '@arsedizioni/ars-utils/ui';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\n\r\nexport interface FilePreviewDialogData {\r\n  url?: string | null;\r\n  embed?: boolean | null;\r\n  authToken?: string | null;\r\n}\r\n\r\n\r\n@Component({\r\n  templateUrl: './file-preview.component.html',\r\n  styleUrls: ['./file-preview.component.scss'],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [MatDialogContent, NgStyle, FlexLayoutModule, MatDialogActions, MatButtonModule, MatTooltipModule,\r\n    MatDialogClose, SafeUrlPipe]\r\n})\r\nexport class FilePreviewComponent implements OnInit, OnDestroy, AfterViewInit {\r\n\r\n  private unsubscribe: Subject<void> = new Subject<void>();\r\n  private httpClient = inject(HttpClient);\r\n  private dialogService = inject(DialogService);\r\n  protected dialogData: FilePreviewDialogData = inject(MAT_DIALOG_DATA);\r\n  protected url = signal(null);\r\n\r\n\r\n  ngOnInit() {\r\n    if (this.dialogData) {\r\n      if (!this.dialogData.embed) {\r\n        this.httpClient.get(\r\n          this.dialogData.url,\r\n          {\r\n            headers:\r\n              this.dialogData.authToken\r\n                ? new HttpHeaders().set(\"Authorization\", this.dialogData.authToken)\r\n                : new HttpHeaders(),\r\n            responseType: 'blob'\r\n          }\r\n        ).subscribe(\r\n          (res: any) => {\r\n            this.url.set(URL.createObjectURL(res));\r\n          });\r\n      } else {\r\n        this.url.set('https://view.officeapps.live.com/op/embed.aspx?src=' + encodeURIComponent(this.dialogData.url));\r\n      }\r\n    }\r\n\r\n    // React to window size change\r\n    fromEvent(window, 'resize')\r\n      .pipe(takeUntil(this.unsubscribe), debounceTime(250))\r\n      .subscribe(() => {\r\n        this.resize();\r\n      });\r\n\r\n  }\r\n\r\n\r\n  ngOnDestroy() {\r\n    this.unsubscribe.next();\r\n    this.unsubscribe.complete();\r\n    this.url.set(null);\r\n  }\r\n\r\n\r\n  ngAfterViewInit(): void {\r\n    this.resize();\r\n  }\r\n\r\n  /**\r\n * Resize \r\n */\r\n  private resize() {\r\n    setTimeout(() => {\r\n      let elem = document.getElementById('file-preview-scrollable');\r\n      if (elem) {\r\n        const height = this.dialogService.getCurrentDialogScrollableHeight(\r\n          ['file-preview-fixed'],\r\n          window.innerHeight\r\n        );\r\n        elem.setAttribute('style', 'height:' + height + 'px !important;max-height:' + height + 'px !important');\r\n      } else {\r\n        this.resize();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  /**\r\n   * Download manually\r\n   */\r\n  download() {\r\n    window.open(this.url(), '_blank');\r\n  }\r\n\r\n  /**\r\n   * Troubles with pdf?\r\n   */\r\n  troubles() {\r\n    this.dialogService.info(\r\n      \"<p>Se non riesci a visualizzare l'anteprima dei file PDF probabilmente devi abilitare un'impostazione del tuo browser.</p>\" +\r\n      \"<b>Per Google Chrome</b><br>\" +\r\n      \"<p class='small' style='padding-left:10px'><i>impostazioni > privacy e sicurezza > impostazioni sito > documenti PDF</i></p>\" +\r\n      \"<b>Per Microsoft Chrome</b><br>\" +\r\n      \"<p class='small' style='padding-left:10px'><i>impostazioni > cookie e autorizzazioni sito > documenti PDF</i></p>\" +\r\n      \"<b>Per Mozilla Firefox</b><br>\" +\r\n      \"<p class='small' style='padding-left:10px'><i>impostazioni > generale > applicazioni</i></p>\" +\r\n      \"<b>Altri browser</b><br>\" +\r\n      \"<p class='small' style='padding-left:10px'>Fate riferimento alla documentazione specifica del vostro browser.</p>\",\r\n      \"Problemi con lee anteprime dei file PDF?\"\r\n    )\r\n  }\r\n}\r\n\r\n\r\n\r\n","<mat-dialog-content class=\"file-preview\"  id=\"file-preview-scrollable\">\r\n  <div class=\"content\">\r\n    @if (!url) {\r\n    <div class=\"loading\">Caricamento in corso...</div>\r\n    } @else {\r\n    <iframe class=\"iframe\" onload=\"scrollTo(0,0)\"  [src]=\"url() | safeUrl\"></iframe>\r\n    }\r\n  </div>\r\n</mat-dialog-content>\r\n<mat-dialog-actions id=\"file-preview-fixed\">\r\n  <div fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutGap=\"10px\" fxFill>\r\n    <div fxFlex=\"50\">\r\n      <button mat-stroked-button color=\"primary\" (click)=\"troubles()\"\r\n        matTooltip=\"Fai click se non riesci a visualizzare l'anteprima dei file PDF\">Problemi con i PDF?</button>\r\n    </div>\r\n    <div fxFlex=\"50\" fxLayoutAlign=\"end\">\r\n      <button mat-stroked-button color=\"primary\" (click)=\"download()\">Scarica</button>\r\n      <button mat-stroked-button [mat-dialog-close]=\"true\" color=\"primary\">Chiudi</button>\r\n    </div>\r\n  </div>\r\n</mat-dialog-actions>"]}
@@ -1723,9 +1723,7 @@ class ClipperReferencesComponent extends ClipperSearchResultManager {
1723
1723
  let elem = document.getElementById('clipper-references-scrollable');
1724
1724
  if (elem) {
1725
1725
  const height = this.dialogService.getCurrentDialogScrollableHeight(['clipper-references-fixed'], window.innerHeight);
1726
- if (height != elem.clientHeight) {
1727
- elem.setAttribute('style', 'padding:0 0 0 0;' + height + 'px !important;max-height:' + height + 'px !important');
1728
- }
1726
+ elem.setAttribute('style', 'padding:0 0 0 0;' + height + 'px !important;max-height:' + height + 'px !important');
1729
1727
  }
1730
1728
  else {
1731
1729
  this.resize();
@@ -2207,12 +2205,9 @@ class ClipperDocumentComponent extends ClipperDocumentManager {
2207
2205
  let elem = document.getElementById('clipper-document-scrollable');
2208
2206
  if (elem) {
2209
2207
  const height = this.dialogService.getCurrentDialogScrollableHeight(['clipper-document-fixed'], window.innerHeight);
2210
- console.log(height);
2211
- if (height != elem.clientHeight) {
2212
- elem.setAttribute('style', 'padding:0;height:' + height + 'px !important;max-height:' + height + 'px !important');
2213
- elem = document.getElementById('clipper-document-iframe');
2214
- elem?.setAttribute('style', 'height:' + (height - 20) + 'px !important;max-height:' + (height - 20) + 'px !important');
2215
- }
2208
+ elem.setAttribute('style', 'padding:0;height:' + height + 'px !important;max-height:' + height + 'px !important');
2209
+ elem = document.getElementById('clipper-document-iframe');
2210
+ elem?.setAttribute('style', 'height:' + (height - 20) + 'px !important;max-height:' + (height - 20) + 'px !important');
2216
2211
  }
2217
2212
  else {
2218
2213
  this.resize();
@@ -3287,9 +3282,7 @@ class ClipperBrowserDialogComponent extends ClipperSearchResultManager {
3287
3282
  let elem = document.getElementById('clipper-browser-scrollable');
3288
3283
  if (elem) {
3289
3284
  const height = this.dialogService.getCurrentDialogScrollableHeight(['clipper-browser-fixed'], window.innerHeight);
3290
- if (height != elem.clientHeight) {
3291
- elem.setAttribute('style', 'padding:0 0 0 0;height:' + height + 'px !important;max-height:' + height + 'px !important');
3292
- }
3285
+ elem.setAttribute('style', 'padding:0 0 0 0;height:' + height + 'px !important;max-height:' + height + 'px !important');
3293
3286
  }
3294
3287
  else {
3295
3288
  this.resize();