Skip to content

lux‐file‐preview v14

Thomas Dickhut edited this page Apr 9, 2024 · 2 revisions

LUX-File-Preview

Beispielbild LUX-File-Preview Beispielbild LUX-File-Preview

Overview / API

Wichtig! Bevor die LuxFilePreview verwendet werden kann, muss das Projekt einmalig angepasst werden.

Datei Änderungen
package.json Im Abschnitt "dependencies" müssen die Abhängigkeiten "ng2-pdf-viewer": "x.x.x" und "pdfjs-dist": "x.x.x" ergänzt werden. Es müssen dieselben Versionen verwendet werden, welche auch von den LUX-Components im eigenen Projekt verwendet werden.

D.h. die entsprechenden Versionen können der Datei "package.json" der zum Projekt passenden LUX-Componentsversion (siehe Releases -> Asstes -> Source code (zip) -> "package.json") entnommen werden.
npm install im Anschluss nicht vergessen!
angular.json LUX-Components 13+:

Im Abschnitt "assets" müssen die Zeilen {"glob":"pdf.worker.min.js","input":"./node_modules/ng2-pdf-viewer/node_modules/pdfjs-dist/build","output":"./assets/pdf"} und {"glob":"**/*","input":"./node_modules/pdfjs-dist/cmaps/","output":"./assets/cmaps"} ergänzt werden.

LUX-Components 11:

Im Abschnitt "assets" müssen die Zeilen {"glob":"pdf.worker.js","input":"./node_modules/pdfjs-dist/build","output":"./assets/pdf"} und {"glob":"**/*","input":"./node_modules/pdfjs-dist/cmaps/","output":"./assets/cmaps"} ergänzt werden.
app.module.ts Im Abschnitt "imports" muss das LuxFilePreviewModule ergänzt werden.

Im Konstruktor oder in der Methode "ngDoBootstrap" muss der Assets-Ordner "assets/pdf" (siehe oben) verlinkt werden. Dazu muss die Zeile (window as any).pdfWorkerSrc = '/assets/pdf/pdf.worker.min.js'; (LUX-Components 13+) oder (window as any).pdfWorkerSrc = '/assets/pdf/pdf.worker.js'; (LUX-Components 11) ergänzt werden. Alternativ zur lokalen Worker-Auslieferung, kann auch eine externe URL als pdfWorkerSrc angegeben werden. In diesem Fall muss der Worker auch nicht in den lokalen Assets-Ordner kopiert werden. Jedoch muss die externe URL in der CSP ergänzt werden, da ansonsten das Laden des Workers verhindert wird.

Im Abschnitt "entryComponents" muss die LuxFilePreviewComponent ergänzt werden.
Ab Version 13.0.0 entfällt dieser Teil, da die Angabe der "entryComponent" obsolet geworden ist.
Gilt nur für JAST-Projekte:

Alle application*.yml-Dateien (z.B. application-dev.yml)
Anpassung der Content Security Policy (siehe csp:) Die font-src muss um 'self' data: ergänzt werden. Bitte die einfachen Anführungszeichen beachten. Die worker-src muss um 'self' blob: ergänzt werden. Die img-src muss um blob: ergänzt werden. Die connect-src muss um blob: ergänzt werden.

Allgemein

Name Beschreibung
import LuxFilePreviewModule
selector lux-file-preview

Classes / Services

LuxFilePreviewService

Name Beschreibung
open(config: LuxFilePreviewConfig): LuxFilePreviewRef Öffnet die Dateivorschau.

LuxFilePreviewRef

Name Beschreibung
close(): void Schließt die Dateivorschau.

LuxFilePreviewConfig

Name Typ
previewData LuxFilePreviewData

LuxFilePreviewData

Name Typ
fileComponent LuxFormFileBase
fileObject ILuxFileObject

Beispiel

Wichtig! Bitte alle Hinweise auf dem Tab "Overview / API" beachten!!!

Beispielbild 01-01 Beispielbild 01-02

Ts

  @ViewChild('fileListComponent', { static: false }) fileComponent!: LuxFileListComponent;

  viewActionConfig: ILuxFileActionConfig = {
    disabled: false,
    hidden  : false,
    iconName: 'fas fa-eye',
    label   : 'Ansehen',
    onClick : (fileObject: ILuxFileObject) => {
      this.filePreviewService.open({
        previewData: {
          fileComponent: this.fileComponent,
          fileObject   : fileObject
        }
      });
    }
  };

  form: FormGroup;

  constructor(private filePreviewService: LuxFilePreviewService) {
    this.form = new FormGroup({
      file: new FormControl<ILuxFileObject[] | null>(null)
    });
  }

Html

<form [formGroup]="form">
  <lux-file-list
    luxLabel="Bescheinigung"
    luxControlBinding="file"
    [luxViewActionConfig]="viewActionConfig"
    #fileListComponent
  ></lux-file-list>
</form>
Clone this wiki locally