UNPKG

stimulsoft-viewer-angular

Version:
204 lines 29.8 kB
import { Component, Input, ViewChild } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "../services/model.service"; import * as i2 from "../services/controller.service"; export class PageComponent { constructor(model, controller) { this.model = model; this.controller = controller; this.touchesLength = 0; this.lastTouches = [{ x: 0, y: 0, time: 0 }, { x: 0, y: 0, time: 0 }]; this.touchAllowPageAction = false; this.touchAllowScroll = false; } ngOnInit() { } ngAfterViewInit() { const page = this.element.nativeElement; page.innerHTML = this.pageAttributes.content; this.pageAttributes.page = page; // Correct Watermark if (this.pageAttributes.existsWatermark) { page.style.position = 'relative'; for (const childNode of page.childNodes) { if (childNode.className === 'stiWatermarkImage') { childNode.style.width = 'auto'; childNode.style.height = 'auto'; break; } } } let reportDisplayMode = this.model.options.displayModeFromReport || this.model.options.appearance.reportDisplayMode; if (reportDisplayMode == "Div" || reportDisplayMode == "Span") { const childs = page.getElementsByClassName('StiPageContainer'); if (childs && childs.length > 0) { const pageContainer = childs[0]; pageContainer.style.position = 'relative'; if (reportDisplayMode == "Span") { pageContainer.style.margin = '0 1px'; // fix Chrome bug with SPAN position } page.style.width = (this.pageWidth - this.margins[1] - this.margins[3]) + 'px'; page.style.height = (this.pageHeight - this.margins[0] - this.margins[2]) + 'px'; } } this.element.nativeElement.pageAttributes = this.pageAttributes; /*const pageHeight = this.pageHeight; if (pageHeight !== 0) { // fixed bug with long time execute if (this.model.options.appearance.reportDisplayMode !== 'Table' && this.model.reportParams.viewMode !== 'SinglePage') { setTimeout(() => { const currentPageHeight = page.offsetHeight - this.margins[0] - this.margins[2]; if (this.reportPanel.maxHeights[pageHeight] == null || currentPageHeight > this.reportPanel.maxHeights[pageHeight]) { this.reportPanel.maxHeights[pageHeight] = currentPageHeight; } }); } else { const currentPageHeight = page.offsetHeight - this.margins[0] - this.margins[2]; if (this.reportPanel.maxHeights[pageHeight] === null || currentPageHeight > this.reportPanel.maxHeights[pageHeight]) { this.reportPanel.maxHeights[pageHeight] = currentPageHeight; } } }*/ } get margins() { const margins = [0, 0, 0, 0]; if (this.pageAttributes.margins) { const marginsPx = this.pageAttributes.margins.split(' '); for (let i = 0; i < marginsPx.length; i++) { margins[i] = parseInt(marginsPx[i].replace('px', ''), 10); } } return margins; } get pageWidth() { const pageSizes = this.pageAttributes.sizes ? this.pageAttributes.sizes.split(';') : null; if (pageSizes) { return parseInt(pageSizes[0], 10); } return 0; } get pageHeight() { const pageSizes = this.pageAttributes.sizes ? this.pageAttributes.sizes.split(';') : null; if (pageSizes) { return parseInt(pageSizes[1], 10); } return 0; } eventTouchStart(e) { const reportPanel = this.model.controls.reportPanel.el.nativeElement; this.touchAllowPageAction = this.touchesLength === 0 && Math.abs(reportPanel.offsetWidth - reportPanel.scrollWidth) <= 10; this.touchAllowScroll = reportPanel.offsetWidth === reportPanel.scrollWidth; this.touchesLength++; if (this.touchAllowPageAction) { this.touchStartX = parseInt(e.changedTouches[0].clientX, 10); this.touchStartScrollY = reportPanel.scrollTop; } } eventTouchMove(e) { const reportPanel = this.model.controls.reportPanel.el.nativeElement; if (this.touchAllowPageAction) { this.lastTouches.shift(); this.lastTouches.push({ x: e.changedTouches[0].clientX, y: e.changedTouches[0].clientY, time: new Date().getTime() }); if (this.touchAllowScroll && this.touchStartScrollY === reportPanel.scrollTop) { this.touchPosX = Math.trunc(this.lastTouches[1].x - this.touchStartX); if (scrollX === 0) { this.element.nativeElement.style.transform = `translateX(${this.touchPosX}px)`; } } } } eventTouchEnd(e) { const reportPanel = this.model.controls.reportPanel.el.nativeElement; if (this.touchesLength > 0) { this.touchesLength--; } if (this.touchAllowPageAction && this.touchesLength === 0) { const dX = this.lastTouches[1].x - this.lastTouches[0].x; const dT = new Date().getTime() - this.lastTouches[1].time; if (this.touchStartScrollY !== reportPanel.scrollTop || (dX <= 0 && this.model.reportParams.pageNumber >= this.model.reportParams.pagesCount - 1) || (dX >= 0 && this.model.reportParams.pageNumber <= 0)) { this.translateX(0); } else if ((dX < -5 && dT <= 14 && this.lastTouches[1].x < this.touchStartX) || (dX < 0 && this.touchPosX < -this.pageWidth / 3)) { this.controller.action({ name: 'NextPage' }); this.translateX(-this.pageWidth); } else if ((dX > 5 && dT <= 14 && this.lastTouches[1].x > this.touchStartX) || (dX > 0 && this.touchPosX > this.pageWidth / 3)) { this.controller.action({ name: 'PrevPage' }); this.translateX(this.pageWidth); } else { this.translateX(0); } } } translateX(value) { this.element.nativeElement.style.transitionDuration = '300ms'; this.element.nativeElement.style.transform = value === 0 ? '' : `translateX(${value}px)`; setTimeout(() => { this.element.nativeElement.style.transitionDuration = ''; }, 300); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PageComponent, deps: [{ token: i1.ModelService }, { token: i2.ControllerService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PageComponent, selector: "sti-page", inputs: { pageAttributes: "pageAttributes" }, viewQueries: [{ propertyName: "element", first: true, predicate: ["element"], descendants: true }], ngImport: i0, template: ` <div #element [style.overflow]="'hidden'" [style.textAlign]="'left'" [style.verticalAlign]="'top'" [style.color]="'#000000'" [style.boxSizing]="'content-box'" [style.display]="'inline-block'" [style.margin]="model.reportParams.viewMode === 'Continuous' ? '10px auto 10px auto' : '10px'" [style.display]="this.model.reportParams.viewMode === 'Continuous' ? 'table' : 'inline-block'" [style.border]="'1px solid ' + this.model.options.appearance.pageBorderColor" [style.background]="pageAttributes['background'] == 'Transparent' || pageAttributes.background == 'rgba(255,255,255,0)' ? 'White' : pageAttributes['background']" [style.padding]="pageAttributes['margins']" [style.width]="!pageAttributes['content'] ? pageWidth + 'px' : ''" [style.height]="!pageAttributes['content'] ? pageHeight + 'px' : ''" [class]="model.options.appearance.showPageShadow ? 'stiJsViewerPageShadow' : 'stiJsViewerPage'" (touchstart)="eventTouchStart($event)" (touchmove)="eventTouchMove($event)" (touchend)="eventTouchEnd($event)"> </div> `, isInline: true }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PageComponent, decorators: [{ type: Component, args: [{ selector: 'sti-page', template: ` <div #element [style.overflow]="'hidden'" [style.textAlign]="'left'" [style.verticalAlign]="'top'" [style.color]="'#000000'" [style.boxSizing]="'content-box'" [style.display]="'inline-block'" [style.margin]="model.reportParams.viewMode === 'Continuous' ? '10px auto 10px auto' : '10px'" [style.display]="this.model.reportParams.viewMode === 'Continuous' ? 'table' : 'inline-block'" [style.border]="'1px solid ' + this.model.options.appearance.pageBorderColor" [style.background]="pageAttributes['background'] == 'Transparent' || pageAttributes.background == 'rgba(255,255,255,0)' ? 'White' : pageAttributes['background']" [style.padding]="pageAttributes['margins']" [style.width]="!pageAttributes['content'] ? pageWidth + 'px' : ''" [style.height]="!pageAttributes['content'] ? pageHeight + 'px' : ''" [class]="model.options.appearance.showPageShadow ? 'stiJsViewerPageShadow' : 'stiJsViewerPage'" (touchstart)="eventTouchStart($event)" (touchmove)="eventTouchMove($event)" (touchend)="eventTouchEnd($event)"> </div> ` }] }], ctorParameters: () => [{ type: i1.ModelService }, { type: i2.ControllerService }], propDecorators: { element: [{ type: ViewChild, args: ['element'] }], pageAttributes: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.component.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/components/page.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, ElementRef, AfterViewInit } from '@angular/core';\r\nimport { ModelService } from '../services/model.service';\r\nimport { ControllerService } from '../services/controller.service';\r\n\r\n@Component({\r\n  selector: 'sti-page',\r\n  template: `\r\n    <div #element\r\n      [style.overflow]=\"'hidden'\"\r\n      [style.textAlign]=\"'left'\"\r\n      [style.verticalAlign]=\"'top'\"\r\n      [style.color]=\"'#000000'\"\r\n      [style.boxSizing]=\"'content-box'\"\r\n      [style.display]=\"'inline-block'\"\r\n      [style.margin]=\"model.reportParams.viewMode === 'Continuous' ? '10px auto 10px auto' : '10px'\"\r\n      [style.display]=\"this.model.reportParams.viewMode === 'Continuous' ? 'table' : 'inline-block'\"\r\n      [style.border]=\"'1px solid ' + this.model.options.appearance.pageBorderColor\"\r\n      [style.background]=\"pageAttributes['background'] == 'Transparent' || pageAttributes.background == 'rgba(255,255,255,0)' ? 'White' : pageAttributes['background']\"\r\n      [style.padding]=\"pageAttributes['margins']\"\r\n      [style.width]=\"!pageAttributes['content'] ? pageWidth + 'px' : ''\"\r\n      [style.height]=\"!pageAttributes['content'] ? pageHeight + 'px' : ''\"\r\n      [class]=\"model.options.appearance.showPageShadow ? 'stiJsViewerPageShadow' : 'stiJsViewerPage'\"\r\n      (touchstart)=\"eventTouchStart($event)\"\r\n      (touchmove)=\"eventTouchMove($event)\"\r\n      (touchend)=\"eventTouchEnd($event)\">\r\n      </div>\r\n  `\r\n})\r\n\r\nexport class PageComponent implements OnInit, AfterViewInit {\r\n\r\n  @ViewChild('element') element: ElementRef;\r\n  @Input() pageAttributes: any;\r\n\r\n  private touchesLength = 0;\r\n  private lastTouches = [{ x: 0, y: 0, time: 0 }, { x: 0, y: 0, time: 0 }];\r\n  private touchAllowPageAction = false;\r\n  private touchAllowScroll = false;\r\n  private touchStartX: number;\r\n  private touchStartScrollY: number;\r\n  private touchPosX: number;\r\n\r\n  constructor(public model: ModelService, public controller: ControllerService) { }\r\n\r\n  ngOnInit() {\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    const page = this.element.nativeElement;\r\n    page.innerHTML = this.pageAttributes.content;\r\n    this.pageAttributes.page = page;\r\n\r\n    // Correct Watermark\r\n    if (this.pageAttributes.existsWatermark) {\r\n      page.style.position = 'relative';\r\n      for (const childNode of page.childNodes) {\r\n        if (childNode.className === 'stiWatermarkImage') {\r\n          childNode.style.width = 'auto';\r\n          childNode.style.height = 'auto';\r\n          break;\r\n        }\r\n      }\r\n    }\r\n\r\n    let reportDisplayMode = this.model.options.displayModeFromReport || this.model.options.appearance.reportDisplayMode;\r\n\r\n    if (reportDisplayMode == \"Div\" || reportDisplayMode == \"Span\") {\r\n      const childs = page.getElementsByClassName('StiPageContainer');\r\n      if (childs && childs.length > 0) {\r\n        const pageContainer = childs[0];\r\n        pageContainer.style.position = 'relative';\r\n        if (reportDisplayMode == \"Span\") {\r\n          pageContainer.style.margin = '0 1px'; // fix Chrome bug with SPAN position\r\n        }\r\n        page.style.width = (this.pageWidth - this.margins[1] - this.margins[3]) + 'px';\r\n        page.style.height = (this.pageHeight - this.margins[0] - this.margins[2]) + 'px';\r\n      }\r\n    }\r\n\r\n    this.element.nativeElement.pageAttributes = this.pageAttributes;\r\n\r\n    /*const pageHeight = this.pageHeight;\r\n    if (pageHeight !== 0) {\r\n      // fixed bug with long time execute\r\n      if (this.model.options.appearance.reportDisplayMode !== 'Table' && this.model.reportParams.viewMode !== 'SinglePage') {\r\n        setTimeout(() => {\r\n          const currentPageHeight = page.offsetHeight - this.margins[0] - this.margins[2];\r\n          if (this.reportPanel.maxHeights[pageHeight] == null || currentPageHeight > this.reportPanel.maxHeights[pageHeight]) {\r\n            this.reportPanel.maxHeights[pageHeight] = currentPageHeight;\r\n          }\r\n        });\r\n      } else {\r\n        const currentPageHeight = page.offsetHeight - this.margins[0] - this.margins[2];\r\n        if (this.reportPanel.maxHeights[pageHeight] === null || currentPageHeight > this.reportPanel.maxHeights[pageHeight]) {\r\n          this.reportPanel.maxHeights[pageHeight] = currentPageHeight;\r\n        }\r\n      }\r\n    }*/\r\n  }\r\n\r\n  public get margins(): number[] {\r\n    const margins = [0, 0, 0, 0];\r\n    if (this.pageAttributes.margins) {\r\n      const marginsPx = this.pageAttributes.margins.split(' ');\r\n      for (let i = 0; i < marginsPx.length; i++) {\r\n        margins[i] = parseInt(marginsPx[i].replace('px', ''), 10);\r\n      }\r\n    }\r\n    return margins;\r\n  }\r\n\r\n  public get pageWidth(): number {\r\n    const pageSizes: string[] = this.pageAttributes.sizes ? this.pageAttributes.sizes.split(';') : null;\r\n    if (pageSizes) {\r\n      return parseInt(pageSizes[0], 10);\r\n    }\r\n    return 0;\r\n  }\r\n\r\n  public get pageHeight(): number {\r\n    const pageSizes: string[] = this.pageAttributes.sizes ? this.pageAttributes.sizes.split(';') : null;\r\n    if (pageSizes) {\r\n      return parseInt(pageSizes[1], 10);\r\n    }\r\n    return 0;\r\n  }\r\n\r\n  public eventTouchStart(e: any) {\r\n    const reportPanel = this.model.controls.reportPanel.el.nativeElement;\r\n    this.touchAllowPageAction = this.touchesLength === 0 && Math.abs(reportPanel.offsetWidth - reportPanel.scrollWidth) <= 10;\r\n    this.touchAllowScroll = reportPanel.offsetWidth === reportPanel.scrollWidth;\r\n    this.touchesLength++;\r\n\r\n    if (this.touchAllowPageAction) {\r\n      this.touchStartX = parseInt(e.changedTouches[0].clientX, 10);\r\n      this.touchStartScrollY = reportPanel.scrollTop;\r\n    }\r\n  }\r\n\r\n  public eventTouchMove(e: any) {\r\n    const reportPanel = this.model.controls.reportPanel.el.nativeElement;\r\n    if (this.touchAllowPageAction) {\r\n      this.lastTouches.shift();\r\n      this.lastTouches.push({\r\n        x: e.changedTouches[0].clientX,\r\n        y: e.changedTouches[0].clientY,\r\n        time: new Date().getTime()\r\n      });\r\n      if (this.touchAllowScroll && this.touchStartScrollY === reportPanel.scrollTop) {\r\n        this.touchPosX = Math.trunc(this.lastTouches[1].x - this.touchStartX);\r\n        if (scrollX === 0) {\r\n          this.element.nativeElement.style.transform = `translateX(${this.touchPosX}px)`;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  public eventTouchEnd(e: any) {\r\n    const reportPanel = this.model.controls.reportPanel.el.nativeElement;\r\n    if (this.touchesLength > 0) { this.touchesLength--; }\r\n    if (this.touchAllowPageAction && this.touchesLength === 0) {\r\n      const dX = this.lastTouches[1].x - this.lastTouches[0].x;\r\n      const dT = new Date().getTime() - this.lastTouches[1].time;\r\n\r\n      if (this.touchStartScrollY !== reportPanel.scrollTop ||\r\n        (dX <= 0 && this.model.reportParams.pageNumber >= this.model.reportParams.pagesCount - 1) ||\r\n        (dX >= 0 && this.model.reportParams.pageNumber <= 0)) {\r\n        this.translateX(0);\r\n      } else if ((dX < -5 && dT <= 14 && this.lastTouches[1].x < this.touchStartX) ||\r\n        (dX < 0 && this.touchPosX < -this.pageWidth / 3)) {\r\n        this.controller.action({ name: 'NextPage' });\r\n        this.translateX(-this.pageWidth);\r\n      } else if ((dX > 5 && dT <= 14 && this.lastTouches[1].x > this.touchStartX) ||\r\n        (dX > 0 && this.touchPosX > this.pageWidth / 3)) {\r\n        this.controller.action({ name: 'PrevPage' });\r\n        this.translateX(this.pageWidth);\r\n      } else {\r\n        this.translateX(0);\r\n      }\r\n    }\r\n  }\r\n\r\n  public translateX(value: number) {\r\n    this.element.nativeElement.style.transitionDuration = '300ms';\r\n    this.element.nativeElement.style.transform = value === 0 ? '' : `translateX(${value}px)`;\r\n    setTimeout(() => {\r\n      this.element.nativeElement.style.transitionDuration = '';\r\n    }, 300);\r\n  }\r\n}\r\n"]}