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.
201 lines (186 loc) • 14.6 kB
JavaScript
import { DOCUMENT } from '@angular/common';
import { Component, Inject, Input } from '@angular/core';
import * as i0 from "@angular/core";
export class DynamicCssComponent {
constructor(renderer, document) {
this.renderer = renderer;
this.document = document;
this.zoom = 1.0;
this.width = 100;
this.xs = 490;
this.sm = 560;
this.md = 610;
this.lg = 660;
this.xl = 740;
this.xxl = 830;
}
get style() {
return `
all and (max-width: ${this.xl}px) {
#toolbarViewerMiddle {
display: table;
margin: auto;
left: auto;
position: inherit;
transform: none;
}
}
all and (max-width: 840px) {
#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;
}
#outerContainer .visibleLargeView,
#outerContainer .visibleMediumView {
display: none;
}
}
all and (max-width: ${this.lg}px) {
.toolbarButtonSpacer {
width: 15px;
}
#outerContainer .hiddenLargeView {
display: none;
}
#outerContainer .visibleLargeView {
display: inherit;
}
}
all and (max-width: ${this.md}px) {
.toolbarButtonSpacer {
display: none;
}
#outerContainer .hiddenMediumView {
display: none;
}
#outerContainer .visibleMediumView {
display: inherit;
}
}
all and (max-width: ${this.sm}px) {
#outerContainer .hiddenSmallView,
#outerContainer .hiddenSmallView * {
display: none;
}
#outerContainer .visibleSmallView {
display: inherit;
}
.toolbarButtonSpacer {
width: 0;
}
html[dir='ltr'] .findbar {
left: 38px;
}
html[dir='rtl'] .findbar {
right: 38px;
}
}
all and (max-width: ${this.xs}px) {
#scaleSelectContainer {
display: none;
}
}
#outerContainer .visibleXLView,
#outerContainer .visibleXXLView,
#outerContainer .visibleTinyView {
display: none;
}
#outerContainer .hiddenXLView,
#outerContainer .hiddenXXLView {
display: unset;
}
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;
}
}
all and (max-width: ${this.xxl}px) {
#outerContainer .hiddenXXLView {
display: none;
}
#outerContainer .visibleXXLView {
display: inherit;
}
}
all and (max-width: ${this.md}px) {
#toolbarViewerMiddle {
-webkit-transform: translateX(-26%);
transform: translateX(-26%);
}
}
all and (max-width: ${this.xs}px) {
#outerContainer .hiddenTinyView,
#outerContainer .hiddenTinyView * {
display: none;
}
#outerContainer .visibleTinyView {
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 * 490;
this.sm = scaleFactor * 560;
this.md = scaleFactor * 610;
this.lg = scaleFactor * 660;
this.xl = scaleFactor * 740;
this.xxl = scaleFactor * 830;
const styles = this.document.getElementById('pdf-dynamic-css');
if (styles) {
styles.innerHTML = this.style;
}
}
injectStyle() {
const styles = this.document.createElement('STYLE');
styles.id = 'pdf-dynamic-css';
styles.innerHTML = this.style;
this.renderer.appendChild(this.document.head, styles);
}
ngOnDestroy() {
const styles = this.document.getElementById('pdf-dynamic-css');
if (styles && styles.parentElement) {
styles.parentElement.removeChild(styles);
}
}
}
DynamicCssComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: DynamicCssComponent, deps: [{ token: i0.Renderer2 }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component });
DynamicCssComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", 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.2.3", ngImport: i0, type: DynamicCssComponent, decorators: [{
type: Component,
args: [{ selector: 'pdf-dynamic-css', template: "", styles: [""] }]
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: undefined, decorators: [{
type: Inject,
args: [DOCUMENT]
}] }]; }, 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 } from '@angular/common';\nimport { Component, Inject, Input, OnChanges, OnDestroy, OnInit, Renderer2 } from '@angular/core';\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 = 100;\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@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: 840px) {\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  #outerContainer .visibleLargeView,\n  #outerContainer .visibleMediumView {\n    display: none;\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 .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 .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 .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.xs}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 .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 .visibleTinyView {\n    display: inherit;\n  }\n}\n  `;\n}\n\n  constructor(private renderer: Renderer2, @Inject(DOCUMENT) private document: any) {}\n\n  ngOnInit() {\n    this.injectStyle();\n  }\n\n  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 * 490;\n    this.sm = scaleFactor * 560;\n    this.md = scaleFactor * 610;\n    this.lg = scaleFactor * 660;\n    this.xl = scaleFactor * 740;\n    this.xxl = scaleFactor * 830;\n\n    const styles = this.document.getElementById('pdf-dynamic-css');\n    if (styles) {\n      styles.innerHTML = this.style;\n    }\n  }\n\n  private injectStyle() {\n    const styles = this.document.createElement('STYLE') as HTMLStyleElement;\n    styles.id = 'pdf-dynamic-css';\n    styles.innerHTML = this.style;\n    this.renderer.appendChild(this.document.head, styles);\n  }\n\n  public ngOnDestroy() {\n    const styles = this.document.getElementById('pdf-dynamic-css') as HTMLElement;\n    if (styles && styles.parentElement) {\n      (styles.parentElement as any).removeChild(styles);\n    }\n  }\n}\n",""]}