<object [data]="previewUrl | safeUrl" class="preview-sticky" width="100%"></object>
</ng-template>
</ng-container>
- <ng-container *ngIf="getContentType() === 'text/plain'">
- <div [innerHTML]="previewHtml | safeHtml" class="preview-sticky bg-light p-3" width="100%"></div>
+ <ng-container *ngIf="renderAsPlainText">
+ <div [innerText]="previewText" class="preview-sticky bg-light p-3" width="100%"></div>
</ng-container>
<div *ngIf="requiresPassword" class="password-prompt">
<form>
title: string
titleSubject: Subject<string> = new Subject()
previewUrl: string
- _previewHtml: string
+ previewText: string
downloadUrl: string
downloadOriginalUrl: string
: this.metadata?.original_mime_type
}
+ get renderAsPlainText(): boolean {
+ return ['text/plain', 'application/csv', 'text/csv'].includes(
+ this.getContentType()
+ )
+ }
+
get isRTL() {
if (!this.metadata || !this.metadata.lang) return false
else {
this.previewUrl = this.documentsService.getPreviewUrl(this.documentId)
this.http.get(this.previewUrl, { responseType: 'text' }).subscribe({
next: (res) => {
- this._previewHtml = res.toString()
+ this.previewText = res.toString()
},
error: (err) => {
- this._previewHtml = $localize`An error occurred loading content: ${
+ this.previewText = $localize`An error occurred loading content: ${
err.message ?? err.toString()
}`
},
)
)
}
-
- get previewHtml(): string {
- return this._previewHtml
- }
}