@arsedizioni/ars-utils 18.2.209 → 18.2.210

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,7 +1,7 @@
1
1
  import { ChangeDetectorRef, OnInit } from '@angular/core';
2
2
  import { MatMenu, MatMenuTrigger } from '@angular/material/menu';
3
3
  import { ClipperDocumentInfo, ClipperModel } from '@arsedizioni/ars-utils/clipper.common';
4
- import { ScreenService } from '@arsedizioni/ars-utils/core';
4
+ import { BroadcastService, ScreenService } from '@arsedizioni/ars-utils/core';
5
5
  import { Subject } from 'rxjs';
6
6
  import { ClipperSearchResultManager } from '../search-result-manager/search-result-manager';
7
7
  import * as i0 from "@angular/core";
@@ -13,6 +13,7 @@ export declare class ClipperSearchResultItemComponent implements OnInit {
13
13
  contextMenuTrigger: MatMenuTrigger;
14
14
  protected unsubscribe: Subject<void>;
15
15
  protected screenService: ScreenService;
16
+ protected broadcastService: BroadcastService;
16
17
  protected changeDetector: ChangeDetectorRef;
17
18
  parent: import("@angular/core").InputSignal<ClipperSearchResultManager>;
18
19
  item: import("@angular/core").InputSignal<ClipperDocumentInfo>;
@@ -5,8 +5,8 @@ import { MatCheckboxModule } from '@angular/material/checkbox';
5
5
  import { MatIconModule } from '@angular/material/icon';
6
6
  import { MatMenuModule } from '@angular/material/menu';
7
7
  import { MatTooltipModule } from '@angular/material/tooltip';
8
- import { ClipperModel } from '@arsedizioni/ars-utils/clipper.common';
9
- import { FormatPipe, ScreenService } from '@arsedizioni/ars-utils/core';
8
+ import { ClipperMessages, ClipperModel } from '@arsedizioni/ars-utils/clipper.common';
9
+ import { BroadcastService, FormatPipe, ScreenService } from '@arsedizioni/ars-utils/core';
10
10
  import { FlexLayoutModule } from '@ngbracket/ngx-layout';
11
11
  import { Subject, takeUntil } from 'rxjs';
12
12
  import * as i0 from "@angular/core";
@@ -26,6 +26,7 @@ export class ClipperSearchResultItemComponent {
26
26
  constructor() {
27
27
  this.unsubscribe = new Subject();
28
28
  this.screenService = inject(ScreenService);
29
+ this.broadcastService = inject(BroadcastService);
29
30
  this.changeDetector = inject(ChangeDetectorRef);
30
31
  this.parent = input();
31
32
  this.item = input();
@@ -46,6 +47,16 @@ export class ClipperSearchResultItemComponent {
46
47
  .subscribe(() => {
47
48
  this.changeDetector.markForCheck();
48
49
  });
50
+ // React to message broadcasting
51
+ this.broadcastService.getMessage()
52
+ .pipe(takeUntil(this.unsubscribe))
53
+ .subscribe(message => {
54
+ if (message.id === ClipperMessages.DOCUMENT_NAVIGATED) {
55
+ if (this.isReadable && !this.item().isRead) {
56
+ this.parent()?.setRead(true, this.item());
57
+ }
58
+ }
59
+ });
49
60
  }
50
61
  onContextMenu(event, item) {
51
62
  event.preventDefault();
@@ -89,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImpor
89
100
  type: ViewChild,
90
101
  args: ['contextMenuTrigger']
91
102
  }] } });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-result-item.component.js","sourceRoot":"","sources":["../../../../../../projects/ars-utils/clipper.ui/ui/search-result-item/search-result-item.component.ts","../../../../../../projects/ars-utils/clipper.ui/ui/search-result-item/search-result-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, inject, input, OnInit, ViewChild } from '@angular/core';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatMenu, MatMenuModule, MatMenuTrigger } from '@angular/material/menu';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { ClipperDocumentInfo, ClipperModel } from '@arsedizioni/ars-utils/clipper.common';\r\nimport { FormatPipe, ScreenService } from '@arsedizioni/ars-utils/core';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { ClipperSearchResultManager } from '../search-result-manager/search-result-manager';\r\n\r\n\r\nexport enum ClipperSearchResultItemDisplayMode {\r\n  List = 1,\r\n  Tile = 2\r\n}\r\n\r\n\r\n@Component({\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  selector: 'clipper-search-result-item',\r\n  templateUrl: './search-result-item.component.html',\r\n  styleUrls: ['./search-result-item.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    NgClass,\r\n    MatCheckboxModule,\r\n    MatButtonModule,\r\n    MatTooltipModule,\r\n    MatIconModule,\r\n    MatMenuModule,\r\n    FlexLayoutModule,\r\n    FormatPipe\r\n  ],\r\n})\r\nexport class ClipperSearchResultItemComponent implements OnInit {\r\n\r\n  @ViewChild('contextMenuTrigger') contextMenuTrigger!: MatMenuTrigger;\r\n  protected unsubscribe: Subject<void> = new Subject<void>();\r\n  protected screenService = inject(ScreenService);\r\n  protected changeDetector = inject(ChangeDetectorRef);\r\n  parent = input<ClipperSearchResultManager>();\r\n  item = input<ClipperDocumentInfo>();\r\n  actions = input<MatMenu>();\r\n  tileNoPictureUrl = input<string>();\r\n  tilePictureUrl = input<string>();\r\n  isSelectable = input<boolean>(true);\r\n  isReadable = input<boolean>(true);\r\n  displayModelName = input<boolean>(false);\r\n  displayMode = input<ClipperSearchResultItemDisplayMode>(ClipperSearchResultItemDisplayMode.List);\r\n  protected readonly displayModesEnum: typeof ClipperSearchResultItemDisplayMode = ClipperSearchResultItemDisplayMode;\r\n  protected readonly modelsEnum: typeof ClipperModel = ClipperModel;\r\n  protected contextMenuPosition = { x: '0px', y: '0px' };\r\n\r\n  ngOnInit(): void {\r\n    this.parent()?.selection?.changed\r\n      .pipe(takeUntil(this.unsubscribe))\r\n      .subscribe(() => {\r\n        this.changeDetector.markForCheck();\r\n      });\r\n  }\r\n\r\n  onContextMenu(event: MouseEvent, item: ClipperDocumentInfo) {\r\n    event.preventDefault();\r\n    this.contextMenuPosition.x = event.clientX + 'px';\r\n    this.contextMenuPosition.y = event.clientY + 'px';\r\n    this.contextMenuTrigger.menuData = { item: item };\r\n    this.contextMenuTrigger.openMenu();\r\n  }\r\n\r\n  /**\r\n   * Checks if current item is selected\r\n   * @returns true if current item is selected\r\n   */\r\n  protected isSelected(): boolean {\r\n    return  this.isSelectable() && this.parent()?.selection?.isSelected(this.item().documentId);\r\n  };\r\n\r\n  /**\r\n   * Checks if current item is isReadable\r\n   * @returns true if current item is isReadable\r\n   */\r\n  protected isRead(): boolean {\r\n    return  this.isReadable() && this.item().isRead === true;\r\n  };\r\n\r\n}\r\n","<div>\r\n  @if (displayMode() === displayModesEnum.List ) {\r\n  <div class=\"item\" fxLayout=\"row\" fxLayoutGap=\"6px\" fxLayoutAlign=\"start center\" fxFill\r\n    [ngClass]=\"{'item-selected': isSelected() }\" (contextmenu)=\"onContextMenu($event, item())\"\r\n    (mouseenter)=\"item().isOver = true\" (mouseleave)=\"item().isOver = false\">\r\n    <div fxFlex=\"6px\" fxFlexAlign=\"stretch\" [ngClass]=\"parent()?.getItemStateCssClass(item())\"\r\n      [matTooltip]=\"parent()?.getItemStateTooltip(item())\"><span></span>\r\n    </div>\r\n    <div [fxFlex]=\"isSelectable() ? '48px' : '18px'\" fxLayoutAlign=\"center\">\r\n      @if (isSelectable() && (screenService.isTouchable || item().isOver || isSelected())) {\r\n      <mat-checkbox (click)=\"$event.stopPropagation()\"\r\n        (change)=\"$event ? parent()?.selection?.toggle(item(), item().documentId) : null\" [checked]=\"isSelected()\">\r\n      </mat-checkbox>\r\n      }\r\n    </div>\r\n    <div fxFlex=\"*\">\r\n      <div class=\"item-content\">\r\n        @if (displayModelName() && item().modelName) {\r\n        <div class=\"info-2\">{{item().modelName}}</div>\r\n        }\r\n\r\n        @if (item().info && item().model === modelsEnum.Quesiti) {\r\n        @if(item().info) {\r\n        <div class=\"info-1\">{{item().info}}</div>\r\n        }\r\n        }@else{\r\n        @if (item().date) {\r\n        <div class=\"info-1\">{{item().date | format:'D':'d MMM yyyy'}}</div>\r\n        } @else if (item().author && (item().origin === 'LR' || item().origin === 'GR' || item().origin\r\n        ===\r\n        'GN')) {\r\n        <div class=\"info-1\">{{item().author}}</div>\r\n        }\r\n        }\r\n        <div>\r\n          <a class=\"link\" (click)=\"parent()?.open(item().documentId)\"\r\n            [attr.aria-label]=\"'Apri documento ' + item().title1\">{{item().title1 ?? item().title2}}</a>\r\n          @if (item().part > 0) {\r\n          <span class=\"badge\">PARTE {{item().part}}</span>\r\n          }\r\n          @if (item().isCommented) {\r\n          <span class=\"badge\">COMMENTATA</span>\r\n          }\r\n          @if (item().validityState > 0) {\r\n          <span class=\"badge-red\">{{item().validityDescription}}</span>\r\n          }\r\n        </div>\r\n        @if(item().description && item().model === modelsEnum.Coordinamento) {\r\n        <div class=\"title\">{{item().description}}</div>\r\n        }\r\n        @if (item().title2 &&\r\n        item().model !== modelsEnum.Coordinamento &&\r\n        item().model !== modelsEnum.AllerteAlimentari &&\r\n        item().model !== modelsEnum.Scadenze &&\r\n        item().model !== modelsEnum.Segnalazioni) {\r\n        <div class=\"title\">{{item().title2}}</div>\r\n        }\r\n        @if (item().originDescription ) {\r\n        <div class=\"info-1\">\r\n          {{item().originDescription}}</div>\r\n        }\r\n        @if (item().anchors.length > 0) {\r\n        <div class=\"details\">\r\n          <div>DETTAGLIO</div>\r\n          <div class=\"links\">\r\n            @for (a of item().anchors; track $index) {\r\n            <span>\r\n              @if (a.uri && a.text) {\r\n              <a (click)=\"parent()?.open(a.documentId + '#' + a.uri)\" [matTooltip]=\"a.title\">{{a.text}} @if\r\n                (a.veryRelevant) {\r\n                <sup>\r\n                  <mat-icon style='font-size:x-small; height: 10px; width:10px' color=\"primary\"\r\n                    matTooltip=\"Molto rilevante\">thumb_up_alt</mat-icon>\r\n                </sup>\r\n                }</a>\r\n              }\r\n              @if (!a.uri && a.text) {\r\n              <span>{{a.text}}</span>\r\n              }\r\n            </span>\r\n            }\r\n          </div>\r\n        </div>\r\n        }\r\n        @if (item().taxonomy?.length > 0) {\r\n        <div class=\"details\">\r\n          <div>ARGOMENTI</div>\r\n          <div class=\"links\">\r\n            @for (n of item().taxonomy?.split('\\r\\n'); track $index) {\r\n            <div class=\"link\">\r\n              {{n}}\r\n            </div>\r\n            }\r\n          </div>\r\n        </div>\r\n        }\r\n        @if (item().model === modelsEnum.News || item().model === modelsEnum.Articoli || item().model === modelsEnum.Juris) {\r\n        @if (!displayModelName() && item().modelName) {\r\n        <div class=\"info-1\">{{item().modelName}}</div>\r\n        }\r\n        @if (item().info){\r\n          <div class=\"details\">\r\n            <div>ARGOMENTI</div>\r\n            <div class=\"links\">\r\n              <div>{{item().info}}</div>\r\n            </div>\r\n          </div>\r\n        }\r\n        }\r\n        @if (item().model === modelsEnum.Coordinamento) {\r\n        @if (item().title2) {\r\n        <div class=\"details\">\r\n          <div>TITOLO DOCUMENTO MODIFICATO</div>\r\n          <div class=\"links\">\r\n            <div>{{item().title2}}</div>\r\n          </div>\r\n        </div>\r\n        }\r\n        @if (item().description) {\r\n        <div class=\"details\">\r\n          <div>PROSSIMA SCADENZA</div>\r\n          <div class=\"links\">\r\n            <div>{{item().description}}</div>\r\n          </div>\r\n        </div>\r\n        }\r\n        }\r\n      </div>\r\n    </div>\r\n    <div fxFlex=\"48px\" fxLayoutAlign=\"end\">\r\n      @if (item().isOver || item().isMenuOpen || isSelected()) {\r\n      @if (isReadable() && !isRead() && item().model !== modelsEnum.Scadenze && item().model !==\r\n      modelsEnum.Segnalazioni)\r\n      {\r\n      <button type=\"button\" mat-icon-button matTooltip=\"Segna come già letta\" [attr.aria-label]=\"'Segna come già letta'\"\r\n        (click)=\"parent()?.toggleRead(item(), $event)\">\r\n        <mat-icon>flag</mat-icon>\r\n      </button>\r\n      }\r\n      @if(item().model === modelsEnum.Scadenze || item().model === modelsEnum.Segnalazioni) {\r\n      <button type=\"button\" mat-icon-button matTooltip=\"Aggiungi al tuo calendario\"\r\n        [attr.aria-label]=\"'Aggiungi al tuo calendario'\">\r\n        <mat-icon>add</mat-icon>\r\n      </button>\r\n      }\r\n      <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button matTooltip=\"Menu\" [attr.aria-label]=\"'Menu opzioni'\"\r\n        [matMenuTriggerFor]=\"actions()\" [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  } @else {\r\n  <div class=\"tile\" (contextmenu)=\"onContextMenu($event, item())\" (mouseenter)=\"item().isOver = true\"\r\n    (mouseleave)=\"item().isOver = false\" [ngClass]=\"{'item-selected': isSelected(), \r\n    'item-unread': isRead()}\" (click)=\"parent()?.open(item().documentId)\">\r\n    <div class=\"image-mark\" [ngClass]=\"{'image-mark-unread': !isRead()}\"></div>\r\n    <div class=\"image\">\r\n      @if (isReadable() || isSelectable()) {\r\n      <div class=\"buttons\">\r\n        @if (isReadable() && !isRead() && item().isOver === true) {\r\n        <button mat-icon-button class=\"read\" matTooltip=\"Segna come già letto\"\r\n          (click)=\"parent()?.toggleRead(item(), $event)\"><mat-icon>flag</mat-icon></button>\r\n        }\r\n        @if (isSelectable() && (isSelected() || item().isOver === true)) {\r\n        <button mat-icon-button class=\"check\" [ngClass]=\"{'check-selected': isSelected()}\"\r\n          matTooltip=\"Seleziona/Deseleziona\"\r\n          (click)=\"parent()?.toggleSelection(item(), $event)\"><mat-icon>check</mat-icon></button>\r\n        }\r\n      </div>\r\n      }\r\n      <div class=\"info-1\">{{item().modelName}}</div>\r\n      @if (item().info) {\r\n      <div class=\"info-2\">{{item().info}}</div>\r\n      }\r\n      @if (item().pictureId && tilePictureUrl()) {\r\n      <img decoding=\"async\" loading=\"lazy\" [src]=\"tilePictureUrl() + '?id=' + item().pictureId\" [alt]=\"item().title2\" />\r\n      } @else if (tileNoPictureUrl()) {\r\n      <picture>\r\n        <img decoding=\"async\" loading=\"lazy\" [src]=\"tileNoPictureUrl()\"\r\n          [alt]=\"item().title2 || 'immagine non trovata'\" />\r\n      </picture>\r\n      }\r\n    </div>\r\n    <div class=\"body\">\r\n      <div class=\"date\">\r\n        <span class=\"date-day\" [ngClass]=\"{'unread': !item().isRead}\">{{item().date | format:'D':'d\r\n          MMMM'}}</span>\r\n        <span class=\"date-divider\"></span>\r\n        <span>{{item().date| format:'D':'yyyy'}}</span>\r\n      </div>\r\n      <div class=\"title\">{{item().title2}}</div>\r\n    </div>\r\n  </div>\r\n  }\r\n</div>\r\n<div #contextMenuTrigger=\"matMenuTrigger\" style=\"position: fixed\" [style.left]=\"contextMenuPosition.x\"\r\n  [style.top]=\"contextMenuPosition.y\" [matMenuTriggerFor]=\"actions()\" [matMenuTriggerData]=\"{item: item}\">\r\n</div>"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-result-item.component.js","sourceRoot":"","sources":["../../../../../../projects/ars-utils/clipper.ui/ui/search-result-item/search-result-item.component.ts","../../../../../../projects/ars-utils/clipper.ui/ui/search-result-item/search-result-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, inject, input, OnInit, ViewChild } from '@angular/core';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatMenu, MatMenuModule, MatMenuTrigger } from '@angular/material/menu';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { ClipperDocumentInfo, ClipperMessages, ClipperModel } from '@arsedizioni/ars-utils/clipper.common';\r\nimport { BroadcastService, FormatPipe, ScreenService } from '@arsedizioni/ars-utils/core';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { ClipperSearchResultManager } from '../search-result-manager/search-result-manager';\r\n\r\n\r\nexport enum ClipperSearchResultItemDisplayMode {\r\n  List = 1,\r\n  Tile = 2\r\n}\r\n\r\n\r\n@Component({\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  selector: 'clipper-search-result-item',\r\n  templateUrl: './search-result-item.component.html',\r\n  styleUrls: ['./search-result-item.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    NgClass,\r\n    MatCheckboxModule,\r\n    MatButtonModule,\r\n    MatTooltipModule,\r\n    MatIconModule,\r\n    MatMenuModule,\r\n    FlexLayoutModule,\r\n    FormatPipe\r\n  ],\r\n})\r\nexport class ClipperSearchResultItemComponent implements OnInit {\r\n\r\n  @ViewChild('contextMenuTrigger') contextMenuTrigger!: MatMenuTrigger;\r\n  protected unsubscribe: Subject<void> = new Subject<void>();\r\n  protected screenService = inject(ScreenService);\r\n  protected broadcastService = inject(BroadcastService);\r\n  protected changeDetector = inject(ChangeDetectorRef);\r\n  parent = input<ClipperSearchResultManager>();\r\n  item = input<ClipperDocumentInfo>();\r\n  actions = input<MatMenu>();\r\n  tileNoPictureUrl = input<string>();\r\n  tilePictureUrl = input<string>();\r\n  isSelectable = input<boolean>(true);\r\n  isReadable = input<boolean>(true);\r\n  displayModelName = input<boolean>(false);\r\n  displayMode = input<ClipperSearchResultItemDisplayMode>(ClipperSearchResultItemDisplayMode.List);\r\n  protected readonly displayModesEnum: typeof ClipperSearchResultItemDisplayMode = ClipperSearchResultItemDisplayMode;\r\n  protected readonly modelsEnum: typeof ClipperModel = ClipperModel;\r\n  protected contextMenuPosition = { x: '0px', y: '0px' };\r\n\r\n  ngOnInit(): void {\r\n    this.parent()?.selection?.changed\r\n      .pipe(takeUntil(this.unsubscribe))\r\n      .subscribe(() => {\r\n        this.changeDetector.markForCheck();\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 === ClipperMessages.DOCUMENT_NAVIGATED) {\r\n          if (this.isReadable && !this.item().isRead) {\r\n            this.parent()?.setRead(true, this.item());\r\n          }\r\n        }\r\n      });\r\n  }\r\n\r\n  onContextMenu(event: MouseEvent, item: ClipperDocumentInfo) {\r\n    event.preventDefault();\r\n    this.contextMenuPosition.x = event.clientX + 'px';\r\n    this.contextMenuPosition.y = event.clientY + 'px';\r\n    this.contextMenuTrigger.menuData = { item: item };\r\n    this.contextMenuTrigger.openMenu();\r\n  }\r\n\r\n  /**\r\n   * Checks if current item is selected\r\n   * @returns true if current item is selected\r\n   */\r\n  protected isSelected(): boolean {\r\n    return this.isSelectable() && this.parent()?.selection?.isSelected(this.item().documentId);\r\n  };\r\n\r\n  /**\r\n   * Checks if current item is isReadable\r\n   * @returns true if current item is isReadable\r\n   */\r\n  protected isRead(): boolean {\r\n    return this.isReadable() && this.item().isRead === true;\r\n  };\r\n\r\n}\r\n","<div>\r\n  @if (displayMode() === displayModesEnum.List ) {\r\n  <div class=\"item\" fxLayout=\"row\" fxLayoutGap=\"6px\" fxLayoutAlign=\"start center\" fxFill\r\n    [ngClass]=\"{'item-selected': isSelected() }\" (contextmenu)=\"onContextMenu($event, item())\"\r\n    (mouseenter)=\"item().isOver = true\" (mouseleave)=\"item().isOver = false\">\r\n    <div fxFlex=\"6px\" fxFlexAlign=\"stretch\" [ngClass]=\"parent()?.getItemStateCssClass(item())\"\r\n      [matTooltip]=\"parent()?.getItemStateTooltip(item())\"><span></span>\r\n    </div>\r\n    <div [fxFlex]=\"isSelectable() ? '48px' : '18px'\" fxLayoutAlign=\"center\">\r\n      @if (isSelectable() && (screenService.isTouchable || item().isOver || isSelected())) {\r\n      <mat-checkbox (click)=\"$event.stopPropagation()\"\r\n        (change)=\"$event ? parent()?.selection?.toggle(item(), item().documentId) : null\" [checked]=\"isSelected()\">\r\n      </mat-checkbox>\r\n      }\r\n    </div>\r\n    <div fxFlex=\"*\">\r\n      <div class=\"item-content\">\r\n        @if (displayModelName() && item().modelName) {\r\n        <div class=\"info-2\">{{item().modelName}}</div>\r\n        }\r\n\r\n        @if (item().info && item().model === modelsEnum.Quesiti) {\r\n        @if(item().info) {\r\n        <div class=\"info-1\">{{item().info}}</div>\r\n        }\r\n        }@else{\r\n        @if (item().date) {\r\n        <div class=\"info-1\">{{item().date | format:'D':'d MMM yyyy'}}</div>\r\n        } @else if (item().author && (item().origin === 'LR' || item().origin === 'GR' || item().origin\r\n        ===\r\n        'GN')) {\r\n        <div class=\"info-1\">{{item().author}}</div>\r\n        }\r\n        }\r\n        <div>\r\n          <a class=\"link\" (click)=\"parent()?.open(item().documentId)\"\r\n            [attr.aria-label]=\"'Apri documento ' + item().title1\">{{item().title1 ?? item().title2}}</a>\r\n          @if (item().part > 0) {\r\n          <span class=\"badge\">PARTE {{item().part}}</span>\r\n          }\r\n          @if (item().isCommented) {\r\n          <span class=\"badge\">COMMENTATA</span>\r\n          }\r\n          @if (item().validityState > 0) {\r\n          <span class=\"badge-red\">{{item().validityDescription}}</span>\r\n          }\r\n        </div>\r\n        @if(item().description && item().model === modelsEnum.Coordinamento) {\r\n        <div class=\"title\">{{item().description}}</div>\r\n        }\r\n        @if (item().title2 &&\r\n        item().model !== modelsEnum.Coordinamento &&\r\n        item().model !== modelsEnum.AllerteAlimentari &&\r\n        item().model !== modelsEnum.Scadenze &&\r\n        item().model !== modelsEnum.Segnalazioni) {\r\n        <div class=\"title\">{{item().title2}}</div>\r\n        }\r\n        @if (item().originDescription ) {\r\n        <div class=\"info-1\">\r\n          {{item().originDescription}}</div>\r\n        }\r\n        @if (item().anchors.length > 0) {\r\n        <div class=\"details\">\r\n          <div>DETTAGLIO</div>\r\n          <div class=\"links\">\r\n            @for (a of item().anchors; track $index) {\r\n            <span>\r\n              @if (a.uri && a.text) {\r\n              <a (click)=\"parent()?.open(a.documentId + '#' + a.uri)\" [matTooltip]=\"a.title\">{{a.text}} @if\r\n                (a.veryRelevant) {\r\n                <sup>\r\n                  <mat-icon style='font-size:x-small; height: 10px; width:10px' color=\"primary\"\r\n                    matTooltip=\"Molto rilevante\">thumb_up_alt</mat-icon>\r\n                </sup>\r\n                }</a>\r\n              }\r\n              @if (!a.uri && a.text) {\r\n              <span>{{a.text}}</span>\r\n              }\r\n            </span>\r\n            }\r\n          </div>\r\n        </div>\r\n        }\r\n        @if (item().taxonomy?.length > 0) {\r\n        <div class=\"details\">\r\n          <div>ARGOMENTI</div>\r\n          <div class=\"links\">\r\n            @for (n of item().taxonomy?.split('\\r\\n'); track $index) {\r\n            <div class=\"link\">\r\n              {{n}}\r\n            </div>\r\n            }\r\n          </div>\r\n        </div>\r\n        }\r\n        @if (item().model === modelsEnum.News || item().model === modelsEnum.Articoli || item().model === modelsEnum.Juris) {\r\n        @if (!displayModelName() && item().modelName) {\r\n        <div class=\"info-1\">{{item().modelName}}</div>\r\n        }\r\n        @if (item().info){\r\n          <div class=\"details\">\r\n            <div>ARGOMENTI</div>\r\n            <div class=\"links\">\r\n              <div>{{item().info}}</div>\r\n            </div>\r\n          </div>\r\n        }\r\n        }\r\n        @if (item().model === modelsEnum.Coordinamento) {\r\n        @if (item().title2) {\r\n        <div class=\"details\">\r\n          <div>TITOLO DOCUMENTO MODIFICATO</div>\r\n          <div class=\"links\">\r\n            <div>{{item().title2}}</div>\r\n          </div>\r\n        </div>\r\n        }\r\n        @if (item().description) {\r\n        <div class=\"details\">\r\n          <div>PROSSIMA SCADENZA</div>\r\n          <div class=\"links\">\r\n            <div>{{item().description}}</div>\r\n          </div>\r\n        </div>\r\n        }\r\n        }\r\n      </div>\r\n    </div>\r\n    <div fxFlex=\"48px\" fxLayoutAlign=\"end\">\r\n      @if (item().isOver || item().isMenuOpen || isSelected()) {\r\n      @if (isReadable() && !isRead() && item().model !== modelsEnum.Scadenze && item().model !==\r\n      modelsEnum.Segnalazioni)\r\n      {\r\n      <button type=\"button\" mat-icon-button matTooltip=\"Segna come già letta\" [attr.aria-label]=\"'Segna come già letta'\"\r\n        (click)=\"parent()?.toggleRead(item(), $event)\">\r\n        <mat-icon>flag</mat-icon>\r\n      </button>\r\n      }\r\n      @if(item().model === modelsEnum.Scadenze || item().model === modelsEnum.Segnalazioni) {\r\n      <button type=\"button\" mat-icon-button matTooltip=\"Aggiungi al tuo calendario\"\r\n        [attr.aria-label]=\"'Aggiungi al tuo calendario'\">\r\n        <mat-icon>add</mat-icon>\r\n      </button>\r\n      }\r\n      <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button matTooltip=\"Menu\" [attr.aria-label]=\"'Menu opzioni'\"\r\n        [matMenuTriggerFor]=\"actions()\" [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  } @else {\r\n  <div class=\"tile\" (contextmenu)=\"onContextMenu($event, item())\" (mouseenter)=\"item().isOver = true\"\r\n    (mouseleave)=\"item().isOver = false\" [ngClass]=\"{'item-selected': isSelected(), \r\n    'item-unread': isRead()}\" (click)=\"parent()?.open(item().documentId)\">\r\n    <div class=\"image-mark\" [ngClass]=\"{'image-mark-unread': !isRead()}\"></div>\r\n    <div class=\"image\">\r\n      @if (isReadable() || isSelectable()) {\r\n      <div class=\"buttons\">\r\n        @if (isReadable() && !isRead() && item().isOver === true) {\r\n        <button mat-icon-button class=\"read\" matTooltip=\"Segna come già letto\"\r\n          (click)=\"parent()?.toggleRead(item(), $event)\"><mat-icon>flag</mat-icon></button>\r\n        }\r\n        @if (isSelectable() && (isSelected() || item().isOver === true)) {\r\n        <button mat-icon-button class=\"check\" [ngClass]=\"{'check-selected': isSelected()}\"\r\n          matTooltip=\"Seleziona/Deseleziona\"\r\n          (click)=\"parent()?.toggleSelection(item(), $event)\"><mat-icon>check</mat-icon></button>\r\n        }\r\n      </div>\r\n      }\r\n      <div class=\"info-1\">{{item().modelName}}</div>\r\n      @if (item().info) {\r\n      <div class=\"info-2\">{{item().info}}</div>\r\n      }\r\n      @if (item().pictureId && tilePictureUrl()) {\r\n      <img decoding=\"async\" loading=\"lazy\" [src]=\"tilePictureUrl() + '?id=' + item().pictureId\" [alt]=\"item().title2\" />\r\n      } @else if (tileNoPictureUrl()) {\r\n      <picture>\r\n        <img decoding=\"async\" loading=\"lazy\" [src]=\"tileNoPictureUrl()\"\r\n          [alt]=\"item().title2 || 'immagine non trovata'\" />\r\n      </picture>\r\n      }\r\n    </div>\r\n    <div class=\"body\">\r\n      <div class=\"date\">\r\n        <span class=\"date-day\" [ngClass]=\"{'unread': !item().isRead}\">{{item().date | format:'D':'d\r\n          MMMM'}}</span>\r\n        <span class=\"date-divider\"></span>\r\n        <span>{{item().date| format:'D':'yyyy'}}</span>\r\n      </div>\r\n      <div class=\"title\">{{item().title2}}</div>\r\n    </div>\r\n  </div>\r\n  }\r\n</div>\r\n<div #contextMenuTrigger=\"matMenuTrigger\" style=\"position: fixed\" [style.left]=\"contextMenuPosition.x\"\r\n  [style.top]=\"contextMenuPosition.y\" [matMenuTriggerFor]=\"actions()\" [matMenuTriggerData]=\"{item: item}\">\r\n</div>"]}
@@ -1390,6 +1390,7 @@ class ClipperSearchResultItemComponent {
1390
1390
  constructor() {
1391
1391
  this.unsubscribe = new Subject();
1392
1392
  this.screenService = inject(ScreenService);
1393
+ this.broadcastService = inject(BroadcastService);
1393
1394
  this.changeDetector = inject(ChangeDetectorRef);
1394
1395
  this.parent = input();
1395
1396
  this.item = input();
@@ -1410,6 +1411,16 @@ class ClipperSearchResultItemComponent {
1410
1411
  .subscribe(() => {
1411
1412
  this.changeDetector.markForCheck();
1412
1413
  });
1414
+ // React to message broadcasting
1415
+ this.broadcastService.getMessage()
1416
+ .pipe(takeUntil(this.unsubscribe))
1417
+ .subscribe(message => {
1418
+ if (message.id === ClipperMessages.DOCUMENT_NAVIGATED) {
1419
+ if (this.isReadable && !this.item().isRead) {
1420
+ this.parent()?.setRead(true, this.item());
1421
+ }
1422
+ }
1423
+ });
1413
1424
  }
1414
1425
  onContextMenu(event, item) {
1415
1426
  event.preventDefault();