@arsedizioni/ars-utils 18.2.89 → 18.2.90
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/core/selectable.d.ts +2 -0
- package/esm2022/clipper.ui/ui/search-result-item/search-result-item.component.mjs +3 -2
- package/esm2022/core/selectable.mjs +10 -1
- package/fesm2022/arsedizioni-ars-utils-clipper.ui.mjs +2 -1
- package/fesm2022/arsedizioni-ars-utils-clipper.ui.mjs.map +1 -1
- package/fesm2022/arsedizioni-ars-utils-core.mjs +8 -0
- package/fesm2022/arsedizioni-ars-utils-core.mjs.map +1 -1
- package/package.json +12 -12
package/core/selectable.d.ts
CHANGED
|
@@ -39,9 +39,10 @@ export class ClipperSearchResultItemComponent {
|
|
|
39
39
|
this.contextMenuPosition = { x: '0px', y: '0px' };
|
|
40
40
|
}
|
|
41
41
|
ngOnInit() {
|
|
42
|
-
this.parent()
|
|
42
|
+
this.parent()?.selection?.changed
|
|
43
43
|
.pipe(takeUntil(this.unsubscribe))
|
|
44
44
|
.subscribe(() => {
|
|
45
|
+
console.log("selection-changed");
|
|
45
46
|
this.changeDetector.markForCheck();
|
|
46
47
|
});
|
|
47
48
|
}
|
|
@@ -79,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
79
80
|
type: ViewChild,
|
|
80
81
|
args: ['contextMenuTrigger']
|
|
81
82
|
}] } });
|
|
82
|
-
//# 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  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.current.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: any) {\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.parent()?.selection?.isSelected(this.item().documentId);\r\n  };\r\n\r\n}\r\n","<div>\r\n  @if (displayMode() === displayModesEnum.List ) {\r\n  <div fxLayout=\"row\" fxLayoutGap=\"6px\" fxLayoutAlign=\"start center\" fxFill class=\"item\"\r\n    [ngClass]=\"{'item-selected': isSelected() }\"\r\n    (contextmenu)=\"onContextMenu($event, item())\" (mouseenter)=\"item().isOver = true\"\r\n    (mouseleave)=\"item().isOver = false\">\r\n    <div fxFlex=\"54px\" fxLayoutAlign=\"center\" style=\"padding-left: 6px;\">\r\n      @if (screenService.isTouchable || item().isOver || isSelected()) {\r\n      <mat-checkbox (click)=\"$event.stopPropagation()\"\r\n        (change)=\"$event ? parent()?.selection?.toggle(item(), item().documentId) : null\"\r\n        [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        @if (item().info) {\r\n        <div class=\"info-1\">{{item().info}}</div>\r\n        } @else 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        <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().title2 && item().model === modelsEnum.Coordinamento) {\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 && item().model === modelsEnum.Coordinamento) {\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      </div>\r\n    </div>\r\n    <div fxFlex=\"48px\" fxLayoutAlign=\"end\">\r\n      @if (item().isOver || item().isMenuOpen || isSelected()) {\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\" (mouseenter)=\"item().isOver = true\" (mouseleave)=\"item().isOver = false\" [ngClass]=\"{'item-selected': isSelected(), \r\n    'item-unread': item().isRead !== true}\" (click)=\"parent()?.open(item().documentId)\">\r\n    <div class=\"image-mark\" [ngClass]=\"{'image-mark-unread': item().isRead !== true}\"></div>\r\n    <div class=\"image\">\r\n      @if (isSelected() || item().isOver=== true) {\r\n      <button mat-icon-button class=\"check\"\r\n        [ngClass]=\"{'check-selected': isSelected() ?? false}\"\r\n        matTooltip=\"Seleziona/Deseleziona\"\r\n        (click)=\"parent()?.toggleSelection(item, $event)\"><mat-icon>check</mat-icon></button>\r\n      }\r\n      @if (item().isRead !== true && 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      <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>"]}
|
|
83
|
+
//# 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":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AACxH,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAW,aAAa,EAAkB,MAAM,wBAAwB,CAAC;AAChF,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAuB,YAAY,EAAE,MAAM,uCAAuC,CAAC;AAC1F,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;;;;;;;;AAI1C,MAAM,CAAN,IAAY,kCAGX;AAHD,WAAY,kCAAkC;IAC5C,2FAAQ,CAAA;IACR,2FAAQ,CAAA;AACV,CAAC,EAHW,kCAAkC,KAAlC,kCAAkC,QAG7C;AAoBD,MAAM,OAAO,gCAAgC;IAjB7C;QAoBY,gBAAW,GAAkB,IAAI,OAAO,EAAQ,CAAC;QACjD,kBAAa,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QACtC,mBAAc,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QACrD,WAAM,GAAG,KAAK,EAA8B,CAAC;QAC7C,SAAI,GAAG,KAAK,EAAuB,CAAC;QACpC,YAAO,GAAG,KAAK,EAAW,CAAC;QAC3B,qBAAgB,GAAG,KAAK,EAAU,CAAC;QACnC,mBAAc,GAAG,KAAK,EAAU,CAAC;QACjC,qBAAgB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACzC,gBAAW,GAAG,KAAK,CAAqC,kCAAkC,CAAC,IAAI,CAAC,CAAC;QAC9E,qBAAgB,GAA8C,kCAAkC,CAAC;QACjG,eAAU,GAAwB,YAAY,CAAC;QACxD,wBAAmB,GAAG,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC;KA2BxD;IAzBC,QAAQ;QACN,IAAI,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,OAAO;aAC9B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aACjC,SAAS,CAAC,GAAG,EAAE;YACd,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;YACjC,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;QACrC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,aAAa,CAAC,KAAiB,EAAE,IAAS;QACxC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,mBAAmB,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC;QAClD,IAAI,CAAC,mBAAmB,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC;QAClD,IAAI,CAAC,kBAAkB,CAAC,QAAQ,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAClD,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE,CAAC;IACrC,CAAC;IAED;;;OAGG;IACO,UAAU;QAClB,OAAO,IAAI,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,UAAU,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,UAAU,CAAC,CAAC;IACtE,CAAC;IAAA,CAAC;8GAxCS,gCAAgC;kGAAhC,gCAAgC,ypCCrC7C,w+NA+JM,owQDpIF,OAAO,mFACP,iBAAiB,6WACjB,eAAe,2IACf,gBAAgB,4TAChB,aAAa,mLACb,aAAa,oVACb,gBAAgB,8hHAChB,UAAU;;2FAGD,gCAAgC;kBAjB5C,SAAS;sCACS,uBAAuB,CAAC,MAAM,YACrC,4BAA4B,cAG1B,IAAI,WACP;wBACP,OAAO;wBACP,iBAAiB;wBACjB,eAAe;wBACf,gBAAgB;wBAChB,aAAa;wBACb,aAAa;wBACb,gBAAgB;wBAChB,UAAU;qBACX;8BAIgC,kBAAkB;sBAAlD,SAAS;uBAAC,oBAAoB","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  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        console.log(\"selection-changed\");\r\n        this.changeDetector.markForCheck();\r\n      });\r\n  }\r\n\r\n  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.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.parent()?.selection?.isSelected(this.item().documentId);\r\n  };\r\n\r\n}\r\n","<div>\r\n  @if (displayMode() === displayModesEnum.List ) {\r\n  <div fxLayout=\"row\" fxLayoutGap=\"6px\" fxLayoutAlign=\"start center\" fxFill class=\"item\"\r\n    [ngClass]=\"{'item-selected': isSelected() }\"\r\n    (contextmenu)=\"onContextMenu($event, item())\" (mouseenter)=\"item().isOver = true\"\r\n    (mouseleave)=\"item().isOver = false\">\r\n    <div fxFlex=\"54px\" fxLayoutAlign=\"center\" style=\"padding-left: 6px;\">\r\n      @if (screenService.isTouchable || item().isOver || isSelected()) {\r\n      <mat-checkbox (click)=\"$event.stopPropagation()\"\r\n        (change)=\"$event ? parent()?.selection?.toggle(item(), item().documentId) : null\"\r\n        [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        @if (item().info) {\r\n        <div class=\"info-1\">{{item().info}}</div>\r\n        } @else 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        <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().title2 && item().model === modelsEnum.Coordinamento) {\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 && item().model === modelsEnum.Coordinamento) {\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      </div>\r\n    </div>\r\n    <div fxFlex=\"48px\" fxLayoutAlign=\"end\">\r\n      @if (item().isOver || item().isMenuOpen || isSelected()) {\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\" (mouseenter)=\"item().isOver = true\" (mouseleave)=\"item().isOver = false\" [ngClass]=\"{'item-selected': isSelected(), \r\n    'item-unread': item().isRead !== true}\" (click)=\"parent()?.open(item().documentId)\">\r\n    <div class=\"image-mark\" [ngClass]=\"{'image-mark-unread': item().isRead !== true}\"></div>\r\n    <div class=\"image\">\r\n      @if (isSelected() || item().isOver=== true) {\r\n      <button mat-icon-button class=\"check\"\r\n        [ngClass]=\"{'check-selected': isSelected() ?? false}\"\r\n        matTooltip=\"Seleziona/Deseleziona\"\r\n        (click)=\"parent()?.toggleSelection(item, $event)\"><mat-icon>check</mat-icon></button>\r\n      }\r\n      @if (item().isRead !== true && 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      <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>"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { SelectionModel } from "@angular/cdk/collections";
|
|
2
2
|
import { SystemUtils } from "./system";
|
|
3
|
+
import { EventEmitter } from '@angular/core';
|
|
3
4
|
export class SelectableModel {
|
|
4
5
|
get all() {
|
|
5
6
|
return this._all;
|
|
@@ -8,6 +9,7 @@ export class SelectableModel {
|
|
|
8
9
|
return this._current;
|
|
9
10
|
}
|
|
10
11
|
constructor(allowMultiSelect = true, lookupFieldName = "id") {
|
|
12
|
+
this.changed = new EventEmitter();
|
|
11
13
|
this._all = [];
|
|
12
14
|
this._current = new SelectionModel(allowMultiSelect, []);
|
|
13
15
|
this._all = [];
|
|
@@ -22,6 +24,7 @@ export class SelectableModel {
|
|
|
22
24
|
const p = SystemUtils.arrayFindIndexByKey(this._all, this._lookupFieldName, lookupValue);
|
|
23
25
|
if (p != -1) {
|
|
24
26
|
this._current.toggle(item);
|
|
27
|
+
this.changed.emit(item);
|
|
25
28
|
}
|
|
26
29
|
}
|
|
27
30
|
/**
|
|
@@ -39,6 +42,7 @@ export class SelectableModel {
|
|
|
39
42
|
this._all.splice(p, 1);
|
|
40
43
|
}
|
|
41
44
|
this._current.toggle(item);
|
|
45
|
+
this.changed.emit(item);
|
|
42
46
|
}
|
|
43
47
|
}
|
|
44
48
|
/**
|
|
@@ -55,6 +59,7 @@ export class SelectableModel {
|
|
|
55
59
|
else {
|
|
56
60
|
this._current.select(item);
|
|
57
61
|
}
|
|
62
|
+
this.changed.emit(item);
|
|
58
63
|
}
|
|
59
64
|
}
|
|
60
65
|
/**
|
|
@@ -68,6 +73,7 @@ export class SelectableModel {
|
|
|
68
73
|
if (p != -1) {
|
|
69
74
|
this._all.splice(p, 1);
|
|
70
75
|
this._current.deselect(item);
|
|
76
|
+
this.changed.emit(item);
|
|
71
77
|
}
|
|
72
78
|
}
|
|
73
79
|
}
|
|
@@ -84,6 +90,7 @@ export class SelectableModel {
|
|
|
84
90
|
let item = this._all[p];
|
|
85
91
|
this._all.splice(p, 1);
|
|
86
92
|
this._current.deselect(item);
|
|
93
|
+
this.changed.emit(item);
|
|
87
94
|
}
|
|
88
95
|
});
|
|
89
96
|
}
|
|
@@ -96,6 +103,7 @@ export class SelectableModel {
|
|
|
96
103
|
clearFunc(n);
|
|
97
104
|
});
|
|
98
105
|
this._current.clear();
|
|
106
|
+
this.changed.emit();
|
|
99
107
|
}
|
|
100
108
|
/**
|
|
101
109
|
* Deselect all items
|
|
@@ -103,6 +111,7 @@ export class SelectableModel {
|
|
|
103
111
|
clear() {
|
|
104
112
|
this._all = [];
|
|
105
113
|
this._current.clear();
|
|
114
|
+
this.changed.emit();
|
|
106
115
|
}
|
|
107
116
|
/**
|
|
108
117
|
* Checks if an item is selected using its lookup value
|
|
@@ -121,4 +130,4 @@ export class SelectableModel {
|
|
|
121
130
|
return this._all.length > 0;
|
|
122
131
|
}
|
|
123
132
|
}
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selectable.js","sourceRoot":"","sources":["../../../../projects/ars-utils/core/selectable.ts"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from \"@angular/cdk/collections\";\r\nimport { SystemUtils } from \"./system\";\r\n\r\nexport class SelectableModel<T, V> {\r\n  private _all: T[] = [];\r\n  get all(): T[] {\r\n    return this._all;\r\n  }\r\n  private _current: SelectionModel<T>;\r\n  get current(): SelectionModel<T> {\r\n    return this._current;\r\n  }\r\n  private _lookupFieldName: string;\r\n\r\n  constructor(\r\n    allowMultiSelect: boolean = true,\r\n    lookupFieldName: string = \"id\"\r\n  ) {\r\n    this._current = new SelectionModel<T>(allowMultiSelect, []);\r\n    this._all = [];\r\n    this._lookupFieldName = lookupFieldName;\r\n  }\r\n\r\n  /**\r\n   * Update the view of an item\r\n   * @param item          : the item to update\r\n   * @param lookupValue   : the value\r\n   */\r\n  updateCurrent(item: T, lookupValue: V) {\r\n    const p = SystemUtils.arrayFindIndexByKey(\r\n      this._all,\r\n      this._lookupFieldName,\r\n      lookupValue\r\n    );\r\n    if (p != -1) {\r\n      this._current.toggle(item);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Select an item\r\n   * @param item          : the item to update\r\n   * @param lookupValue   : the value\r\n   */\r\n  toggle(item: T, lookupValue: V | null | undefined) {\r\n    if (lookupValue) {\r\n      const p = SystemUtils.arrayFindIndexByKey(\r\n        this._all,\r\n        this._lookupFieldName,\r\n        lookupValue\r\n      );\r\n      if (p == -1) {\r\n        this._all.push(item);\r\n      } else {\r\n        this._all.splice(p, 1);\r\n      }\r\n      this._current.toggle(item);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Select an item\r\n   * @param item          : the item to update\r\n   * @param lookupValue   : the value\r\n   */\r\n  select(item: T, lookupValue: V | null | undefined) {\r\n    if (lookupValue) {\r\n      const p = SystemUtils.arrayFindIndexByKey(\r\n        this._all,\r\n        this._lookupFieldName,\r\n        lookupValue\r\n      );\r\n      if (p == -1) {\r\n        this._all.push(item);\r\n      } else {\r\n        this._current.select(item);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Deselect an item\r\n   * @param item          : the item to update\r\n   * @param lookupValue   : the value\r\n   */\r\n  deselect(item: T, lookupValue: V | null | undefined) {\r\n    if (lookupValue) {\r\n      const p = SystemUtils.arrayFindIndexByKey(\r\n        this._all,\r\n        this._lookupFieldName,\r\n        lookupValue\r\n      );\r\n      if (p != -1) {\r\n        this._all.splice(p, 1);\r\n        this._current.deselect(item);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Deselect all specified item lookup values\r\n   * @param lookupValues : the values\r\n   */\r\n  deselectByValues(lookupValues: V[]) {\r\n    if (!lookupValues || lookupValues.length === 0) return;\r\n    lookupValues.forEach((n: any) => {\r\n      const p = SystemUtils.arrayFindIndexByKey(\r\n        this._all,\r\n        this._lookupFieldName,\r\n        n.id || n\r\n      );\r\n      if (p != -1) {\r\n        let item = this._all[p];\r\n        this._all.splice(p, 1);\r\n        this._current.deselect(item);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Clear current view\r\n   * @param clearFunc : the function used to clear\r\n   */\r\n  clearCurrent(clearFunc: any) {\r\n    this._current.selected.forEach((n) => {\r\n      clearFunc(n);\r\n    });\r\n    this._current.clear();\r\n  }\r\n\r\n  /**\r\n   * Deselect all items\r\n   */\r\n  clear() {\r\n    this._all = [];\r\n    this._current.clear();\r\n  }\r\n\r\n  /**\r\n   * Checks if an item is selected using its lookup value\r\n   * @param lookupValue : the value\r\n   * @returns           : true if the value is selected\r\n   */\r\n  isSelected(lookupValue: V | null | undefined): boolean {\r\n    return (lookupValue &&\r\n      SystemUtils.arrayFindIndexByKey(\r\n        this._all,\r\n        this._lookupFieldName,\r\n        lookupValue\r\n      ) != -1\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Checks if a selection exists\r\n   * @returns : true if at least one selection exists\r\n   */\r\n  hasValue(): boolean {\r\n    return this._all.length > 0;\r\n  }\r\n}\r\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selectable.js","sourceRoot":"","sources":["../../../../projects/ars-utils/core/selectable.ts"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from \"@angular/cdk/collections\";\r\nimport { SystemUtils } from \"./system\";\r\nimport { EventEmitter } from '@angular/core';\r\n\r\nexport class SelectableModel<T, V> {\r\n\r\n  changed: EventEmitter<T> = new EventEmitter<T>();\r\n\r\n  private _all: T[] = [];\r\n  get all(): T[] {\r\n    return this._all;\r\n  }\r\n  private _current: SelectionModel<T>;\r\n  get current(): SelectionModel<T> {\r\n    return this._current;\r\n  }\r\n  private _lookupFieldName: string;\r\n\r\n  constructor(\r\n    allowMultiSelect: boolean = true,\r\n    lookupFieldName: string = \"id\"\r\n  ) {\r\n    this._current = new SelectionModel<T>(allowMultiSelect, []);\r\n    this._all = [];\r\n    this._lookupFieldName = lookupFieldName;\r\n  }\r\n\r\n  /**\r\n   * Update the view of an item\r\n   * @param item          : the item to update\r\n   * @param lookupValue   : the value\r\n   */\r\n  updateCurrent(item: T, lookupValue: V) {\r\n    const p = SystemUtils.arrayFindIndexByKey(\r\n      this._all,\r\n      this._lookupFieldName,\r\n      lookupValue\r\n    );\r\n    if (p != -1) {\r\n      this._current.toggle(item);\r\n      this.changed.emit(item);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Select an item\r\n   * @param item          : the item to update\r\n   * @param lookupValue   : the value\r\n   */\r\n  toggle(item: T, lookupValue: V | null | undefined) {\r\n    if (lookupValue) {\r\n      const p = SystemUtils.arrayFindIndexByKey(\r\n        this._all,\r\n        this._lookupFieldName,\r\n        lookupValue\r\n      );\r\n      if (p == -1) {\r\n        this._all.push(item);\r\n      } else {\r\n        this._all.splice(p, 1);\r\n      }\r\n      this._current.toggle(item);\r\n      this.changed.emit(item);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Select an item\r\n   * @param item          : the item to update\r\n   * @param lookupValue   : the value\r\n   */\r\n  select(item: T, lookupValue: V | null | undefined) {\r\n    if (lookupValue) {\r\n      const p = SystemUtils.arrayFindIndexByKey(\r\n        this._all,\r\n        this._lookupFieldName,\r\n        lookupValue\r\n      );\r\n      if (p == -1) {\r\n        this._all.push(item);\r\n      } else {\r\n        this._current.select(item);\r\n      }\r\n      this.changed.emit(item);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Deselect an item\r\n   * @param item          : the item to update\r\n   * @param lookupValue   : the value\r\n   */\r\n  deselect(item: T, lookupValue: V | null | undefined) {\r\n    if (lookupValue) {\r\n      const p = SystemUtils.arrayFindIndexByKey(\r\n        this._all,\r\n        this._lookupFieldName,\r\n        lookupValue\r\n      );\r\n      if (p != -1) {\r\n        this._all.splice(p, 1);\r\n        this._current.deselect(item);\r\n        this.changed.emit(item);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Deselect all specified item lookup values\r\n   * @param lookupValues : the values\r\n   */\r\n  deselectByValues(lookupValues: V[]) {\r\n    if (!lookupValues || lookupValues.length === 0) return;\r\n    lookupValues.forEach((n: any) => {\r\n      const p = SystemUtils.arrayFindIndexByKey(\r\n        this._all,\r\n        this._lookupFieldName,\r\n        n.id || n\r\n      );\r\n      if (p != -1) {\r\n        let item = this._all[p];\r\n        this._all.splice(p, 1);\r\n        this._current.deselect(item);\r\n        this.changed.emit(item);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Clear current view\r\n   * @param clearFunc : the function used to clear\r\n   */\r\n  clearCurrent(clearFunc: any) {\r\n    this._current.selected.forEach((n) => {\r\n      clearFunc(n);\r\n    });\r\n    this._current.clear();\r\n    this.changed.emit();\r\n  }\r\n\r\n  /**\r\n   * Deselect all items\r\n   */\r\n  clear() {\r\n    this._all = [];\r\n    this._current.clear();\r\n    this.changed.emit();\r\n  }\r\n\r\n  /**\r\n   * Checks if an item is selected using its lookup value\r\n   * @param lookupValue : the value\r\n   * @returns           : true if the value is selected\r\n   */\r\n  isSelected(lookupValue: V | null | undefined): boolean {\r\n    return (lookupValue &&\r\n      SystemUtils.arrayFindIndexByKey(\r\n        this._all,\r\n        this._lookupFieldName,\r\n        lookupValue\r\n      ) != -1\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Checks if a selection exists\r\n   * @returns : true if at least one selection exists\r\n   */\r\n  hasValue(): boolean {\r\n    return this._all.length > 0;\r\n  }\r\n}\r\n"]}
|
|
@@ -1355,9 +1355,10 @@ class ClipperSearchResultItemComponent {
|
|
|
1355
1355
|
this.contextMenuPosition = { x: '0px', y: '0px' };
|
|
1356
1356
|
}
|
|
1357
1357
|
ngOnInit() {
|
|
1358
|
-
this.parent()
|
|
1358
|
+
this.parent()?.selection?.changed
|
|
1359
1359
|
.pipe(takeUntil(this.unsubscribe))
|
|
1360
1360
|
.subscribe(() => {
|
|
1361
|
+
console.log("selection-changed");
|
|
1361
1362
|
this.changeDetector.markForCheck();
|
|
1362
1363
|
});
|
|
1363
1364
|
}
|