UNPKG

ngx-extended-pdf-viewer

Version:

Embedding PDF files in your Angular application. Highly configurable viewer including the toolbar, sidebar, and all the features you're used to.

238 lines (219 loc) 18.5 kB
import { DOCUMENT, isPlatformBrowser } from '@angular/common'; import { Component, Inject, Input, PLATFORM_ID } from '@angular/core'; import { PdfBreakpoints } from '../responsive-visibility'; import { addTrustedHTML } from '../theme/sanitized-css-injector'; import * as i0 from "@angular/core"; export class DynamicCssComponent { constructor(renderer, document, platformId) { this.renderer = renderer; this.document = document; this.platformId = platformId; this.zoom = 1.0; this.width = 3.14159265359; this.xxs = 455; this.xs = 490; this.sm = 560; this.md = 610; this.lg = 660; this.xl = 740; this.xxl = 830; if (isPlatformBrowser(this.platformId)) { this.width = document.body.clientWidth; } } get style() { return ` #toolbarContainer .always-in-secondary-menu { display: none; } #secondaryToolbar .always-in-secondary-menu { display: inline-flex; } #outerContainer #mainContainer .visibleXXSView, #outerContainer #mainContainer .visibleTinyView, #outerContainer #mainContainer .visibleSmallView, #outerContainer #mainContainer .visibleMediumView, #outerContainer #mainContainer .visibleLargeView, #outerContainer #mainContainer .visibleXLView, #outerContainer #mainContainer .visibleXXLView { display: none; } @media all and (max-width: ${this.xl}px) { #toolbarViewerMiddle { display: table; margin: auto; left: auto; position: inherit; transform: none; } } @media all and (max-width: ${this.xxl}) { #sidebarContent { background-color: rgba(0, 0, 0, 0.7); } html[dir='ltr'] #outerContainer.sidebarOpen #viewerContainer { left: 0px !important; } html[dir='rtl'] #outerContainer.sidebarOpen #viewerContainer { right: 0px !important; } #outerContainer .hiddenLargeView, #outerContainer .hiddenMediumView { display: inherit; } } @media all and (max-width: ${this.lg}px) { .toolbarButtonSpacer { width: 15px; } #outerContainer .hiddenLargeView { display: none; } #outerContainer #mainContainer .visibleLargeView { display: inherit; } } @media all and (max-width: ${this.md}px) { .toolbarButtonSpacer { display: none; } #outerContainer .hiddenMediumView { display: none; } #outerContainer #mainContainer .visibleMediumView { display: inherit; } } @media all and (max-width: ${this.sm}px) { #outerContainer .hiddenSmallView, #outerContainer .hiddenSmallView * { display: none; } #outerContainer #mainContainer .visibleSmallView { display: inherit; } .toolbarButtonSpacer { width: 0; } html[dir='ltr'] .findbar { left: 38px; } html[dir='rtl'] .findbar { right: 38px; } } @media all and (max-width: ${this.sm}px) { #scaleSelectContainer { display: none; } } #outerContainer .visibleXLView, #outerContainer .visibleXXLView, #outerContainer .visibleTinyView { display: none; } #outerContainer .hiddenXLView, #outerContainer .hiddenXXLView { display: unset; } @media all and (max-width: ${this.xl}px) { #outerContainer .hiddenXLView { display: none; } #outerContainer .visibleXLView { display: inherit; } #toolbarViewerMiddle { -webkit-transform: translateX(-36%); transform: translateX(-36%); display: unset; margin: unset; left: 50%; position: absolute; } } @media all and (max-width: ${this.xxl}px) { #outerContainer .hiddenXXLView { display: none; } #outerContainer #mainContainer .visibleXXLView { display: inherit; } } @media all and (max-width: ${this.md}px) { #toolbarViewerMiddle { -webkit-transform: translateX(-26%); transform: translateX(-26%); } } @media all and (max-width: ${this.xs}px) { #outerContainer .hiddenTinyView, #outerContainer .hiddenTinyView * { display: none; } #outerContainer #mainContainer .visibleTinyView { display: inherit; } } @media all and (max-width: ${this.xxs}px) { #outerContainer .hiddenXXSView, #outerContainer .hiddenXXSView * { display: none; } #outerContainer #mainContainer .visibleXXSView { display: inherit; } } `; } ngOnInit() { this.injectStyle(); } ngOnChanges() { const fullWith = this.document.body.clientWidth; const partialViewScale = fullWith / this.width; const scaleFactor = partialViewScale * (this.zoom ? this.zoom : 1); this.xs = scaleFactor * PdfBreakpoints.xs; this.sm = scaleFactor * PdfBreakpoints.sm; this.md = scaleFactor * PdfBreakpoints.md; this.lg = scaleFactor * PdfBreakpoints.lg; this.xl = scaleFactor * PdfBreakpoints.xl; this.xxl = scaleFactor * PdfBreakpoints.xxl; let styles = this.document.getElementById('pdf-dynamic-css'); if (!styles) { styles = this.document.createElement('STYLE'); styles.id = 'pdf-dynamic-css'; addTrustedHTML(styles, this.style); this.renderer.appendChild(this.document.head, styles); } addTrustedHTML(styles, this.style); } injectStyle() { if (this.width === 3.14159265359) { setTimeout(() => this.ngOnChanges(), 1); } } ngOnDestroy() { const styles = this.document.getElementById('pdf-dynamic-css'); if (styles?.parentElement) { styles.parentElement.removeChild(styles); } } } DynamicCssComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DynamicCssComponent, deps: [{ token: i0.Renderer2 }, { token: DOCUMENT }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component }); DynamicCssComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: DynamicCssComponent, selector: "pdf-dynamic-css", inputs: { zoom: "zoom", width: "width" }, usesOnChanges: true, ngImport: i0, template: "", styles: [""] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DynamicCssComponent, decorators: [{ type: Component, args: [{ selector: 'pdf-dynamic-css', template: "", styles: [""] }] }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: Document, decorators: [{ type: Inject, args: [DOCUMENT] }] }, { type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID] }] }]; }, propDecorators: { zoom: [{ type: Input }], width: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-css.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-extended-pdf-viewer/src/lib/dynamic-css/dynamic-css.component.ts","../../../../../projects/ngx-extended-pdf-viewer/src/lib/dynamic-css/dynamic-css.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport { Component, Inject, Input, OnChanges, OnDestroy, OnInit, PLATFORM_ID, Renderer2 } from '@angular/core';\nimport { PdfBreakpoints } from '../responsive-visibility';\nimport { addTrustedHTML } from '../theme/sanitized-css-injector';\n\n@Component({\n  selector: 'pdf-dynamic-css',\n  templateUrl: './dynamic-css.component.html',\n  styleUrls: ['./dynamic-css.component.css'],\n})\nexport class DynamicCssComponent implements OnInit, OnChanges, OnDestroy {\n  @Input()\n  public zoom = 1.0;\n\n  @Input()\n  public width = 3.14159265359;\n\n  public xxs = 455;\n\n  public xs = 490;\n\n  public sm = 560;\n\n  public md = 610;\n\n  public lg = 660;\n\n  public xl = 740;\n\n  public xxl = 830;\n\n  public get style(): string {\n    return `\n#toolbarContainer .always-in-secondary-menu {\n  display: none;\n}\n\n#secondaryToolbar .always-in-secondary-menu {\n  display: inline-flex;\n}\n\n#outerContainer #mainContainer .visibleXXSView,\n#outerContainer #mainContainer .visibleTinyView,\n#outerContainer #mainContainer .visibleSmallView,\n#outerContainer #mainContainer .visibleMediumView,\n#outerContainer #mainContainer .visibleLargeView,\n#outerContainer #mainContainer .visibleXLView,\n#outerContainer #mainContainer .visibleXXLView {\n  display: none;\n}\n\n@media all and (max-width: ${this.xl}px) {\n  #toolbarViewerMiddle {\n    display: table;\n    margin: auto;\n    left: auto;\n    position: inherit;\n    transform: none;\n  }\n}\n\n@media all and (max-width: ${this.xxl}) {\n  #sidebarContent {\n    background-color: rgba(0, 0, 0, 0.7);\n  }\n\n  html[dir='ltr'] #outerContainer.sidebarOpen #viewerContainer {\n    left: 0px !important;\n  }\n  html[dir='rtl'] #outerContainer.sidebarOpen #viewerContainer {\n    right: 0px !important;\n  }\n\n  #outerContainer .hiddenLargeView,\n  #outerContainer .hiddenMediumView {\n    display: inherit;\n  }\n}\n\n@media all and (max-width: ${this.lg}px) {\n  .toolbarButtonSpacer {\n    width: 15px;\n  }\n\n  #outerContainer .hiddenLargeView {\n    display: none;\n  }\n  #outerContainer  #mainContainer .visibleLargeView {\n    display: inherit;\n  }\n}\n\n@media all and (max-width: ${this.md}px) {\n  .toolbarButtonSpacer {\n    display: none;\n  }\n  #outerContainer .hiddenMediumView {\n    display: none;\n  }\n  #outerContainer  #mainContainer .visibleMediumView {\n    display: inherit;\n  }\n}\n\n@media all and (max-width: ${this.sm}px) {\n  #outerContainer .hiddenSmallView,\n  #outerContainer .hiddenSmallView * {\n    display: none;\n  }\n  #outerContainer  #mainContainer .visibleSmallView {\n    display: inherit;\n  }\n  .toolbarButtonSpacer {\n    width: 0;\n  }\n  html[dir='ltr'] .findbar {\n    left: 38px;\n  }\n  html[dir='rtl'] .findbar {\n    right: 38px;\n  }\n}\n\n@media all and (max-width: ${this.sm}px) {\n  #scaleSelectContainer {\n    display: none;\n  }\n}\n\n#outerContainer .visibleXLView,\n#outerContainer .visibleXXLView,\n#outerContainer .visibleTinyView {\n  display: none;\n}\n\n#outerContainer .hiddenXLView,\n#outerContainer .hiddenXXLView {\n  display: unset;\n}\n\n@media all and (max-width: ${this.xl}px) {\n  #outerContainer .hiddenXLView {\n    display: none;\n  }\n  #outerContainer .visibleXLView {\n    display: inherit;\n  }\n\n  #toolbarViewerMiddle {\n    -webkit-transform: translateX(-36%);\n    transform: translateX(-36%);\n    display: unset;\n    margin: unset;\n    left: 50%;\n    position: absolute;\n  }\n}\n\n@media all and (max-width: ${this.xxl}px) {\n  #outerContainer .hiddenXXLView {\n    display: none;\n  }\n  #outerContainer  #mainContainer .visibleXXLView {\n    display: inherit;\n  }\n}\n\n@media all and (max-width: ${this.md}px) {\n  #toolbarViewerMiddle {\n    -webkit-transform: translateX(-26%);\n    transform: translateX(-26%);\n  }\n}\n\n@media all and (max-width: ${this.xs}px) {\n  #outerContainer .hiddenTinyView,\n  #outerContainer .hiddenTinyView * {\n    display: none;\n  }\n  #outerContainer  #mainContainer .visibleTinyView {\n    display: inherit;\n  }\n}\n\n@media all and (max-width: ${this.xxs}px) {\n  #outerContainer .hiddenXXSView,\n  #outerContainer .hiddenXXSView * {\n    display: none;\n  }\n  #outerContainer #mainContainer .visibleXXSView {\n    display: inherit;\n  }\n}\n  `;\n  }\n\n  constructor(private renderer: Renderer2, @Inject(DOCUMENT) private document: Document, @Inject(PLATFORM_ID) private platformId) {\n    if (isPlatformBrowser(this.platformId)) {\n      this.width = document.body.clientWidth;\n    }\n  }\n\n  public ngOnInit() {\n    this.injectStyle();\n  }\n\n  public ngOnChanges() {\n    const fullWith = this.document.body.clientWidth;\n    const partialViewScale = fullWith / this.width;\n    const scaleFactor = partialViewScale * (this.zoom ? this.zoom : 1);\n\n    this.xs = scaleFactor * PdfBreakpoints.xs;\n    this.sm = scaleFactor * PdfBreakpoints.sm;\n    this.md = scaleFactor * PdfBreakpoints.md;\n    this.lg = scaleFactor * PdfBreakpoints.lg;\n    this.xl = scaleFactor * PdfBreakpoints.xl;\n    this.xxl = scaleFactor * PdfBreakpoints.xxl;\n\n    let styles = this.document.getElementById('pdf-dynamic-css') as HTMLStyleElement;\n    if (!styles) {\n      styles = this.document.createElement('STYLE') as HTMLStyleElement;\n      styles.id = 'pdf-dynamic-css';\n      addTrustedHTML(styles, this.style);\n\n      this.renderer.appendChild(this.document.head, styles);\n    }\n    addTrustedHTML(styles, this.style);\n  }\n\n  private injectStyle() {\n    if (this.width === 3.14159265359) {\n      setTimeout(() => this.ngOnChanges(), 1);\n    }\n  }\n\n  public ngOnDestroy() {\n    const styles = this.document.getElementById('pdf-dynamic-css') as HTMLElement;\n    if (styles?.parentElement) {\n      (styles.parentElement as any).removeChild(styles);\n    }\n  }\n}\n",""]}