stimulsoft-viewer-angular
Version:
Stimulsoft Viewer Angular
181 lines • 28.5 kB
JavaScript
import { Component, ViewChild } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "../services/controller.service";
import * as i2 from "../services/model.service";
import * as i3 from "../services/styles.service";
import * as i4 from "../services/interactions.service";
import * as i5 from "@angular/common";
import * as i6 from "./page.component";
export class ReportPanelComponent {
constructor(controller, model, stylesService, interactionService) {
this.controller = controller;
this.model = model;
this.stylesService = stylesService;
this.interactionService = interactionService;
this.touchZoomFirstDistance = 0;
this.touchZoomSecondDistance = 0;
this.touchZoomValue = 0;
this.maxHeights = {};
controller.getMessage().subscribe((message) => {
if (message.action !== 'viewer_loaded' && this.model.reportParams.pagesArray) {
if (this.model.reportParams.repaintOnlyDashboardContent) {
// jsObject.controls.reportPanel.repaintDashboardContent(parameters);
}
else {
this.loadPages();
}
}
if (message.action === 'GetReport' || message.action === 'OpenReport') {
setTimeout(() => {
if (!this.model.options.isParametersReceived && ((this.model.reportParams.type === 'Report' && this.model.options.toolbar.showParametersButton) || this.model.reportParams.type === 'Dashboard')) {
interactionService.postInteraction({ action: 'InitVars' });
}
if (this.model.reportParams.autoZoom) {
this.controller.action({ name: this.model.reportParams.autoZoom === -1 ? 'ZoomPageWidth' : 'ZoomOnePage' });
this.model.reportParams.autoZoom = null;
}
});
}
});
}
ngOnInit() { }
ngAfterViewInit() {
this.model.controls.reportPanel.el = this.element;
}
loadPages() {
this.maxHeights = {};
const pagesArray = this.model.reportParams.pagesArray;
this.stylesService.setupStyle(pagesArray[pagesArray.length - 2], 'page');
const chartScript = pagesArray[pagesArray.length - 1];
this.model.pages = pagesArray.slice(0, pagesArray.length - 2);
setTimeout(() => {
this.model.pages.forEach(page => this.interactionService.initializeInteractions(page.page));
this.interactionService.updateAllHyperLinks();
this.stylesService.addChartScript(chartScript);
});
}
get position() {
return this.model.options.heightType !== 'Percentage' || this.model.options.appearance.scrollbarsMode ? 'absolute' : 'relative';
}
scroll() {
if (this.model.pagesNavigationIsActive()) {
clearTimeout(this.scrollTimeout);
// update current page number
this.scrollTimeout = setTimeout(() => {
let commonPagesHeight = 0;
let index = 0;
for (index = 0; index < this.model.pages.length; index++) {
commonPagesHeight += this.model.pages[index].page.offsetHeight + 10;
if (commonPagesHeight > this.element.nativeElement.scrollTop) {
break;
}
}
if (index < this.model.reportParams.pagesCount && index >= 0 && index !== this.model.reportParams.pageNumber) {
this.model.reportParams.pageNumber = index;
}
}, 300);
}
}
eventTouchStart(e) {
this.touchesLength++;
this.touchStartX = parseInt(e.changedTouches[0].clientX, 10);
if (this.model.options.appearance.allowTouchZoom && this.touchesLength === 1) {
this.touchZoomFirstDistance = 0;
this.touchZoomSecondDistance = 0;
this.touchZoomValue = 0;
}
}
eventTouchMove(e) {
if (this.model.options.appearance.allowTouchZoom && e.touches.length > 1) {
if ('preventDefault' in e) {
e.preventDefault();
}
this.touchZoomSecondDistance = Math.sqrt(Math.pow(e.touches[0].pageX - e.touches[1].pageX, 2) + Math.pow(e.touches[0].pageY - e.touches[1].pageY, 2));
if (this.touchZoomFirstDistance === 0) {
this.touchZoomFirstDistance = Math.sqrt(Math.pow(e.touches[0].pageX - e.touches[1].pageX, 2) + Math.pow(e.touches[0].pageY - e.touches[1].pageY, 2));
}
const touchZoomOffset = Math.trunc((this.touchZoomSecondDistance - this.touchZoomFirstDistance) / 2.5);
if (Math.abs(touchZoomOffset) >= 5) {
this.touchZoomValue = Math.trunc((this.model.reportParams.zoom + touchZoomOffset) / 5) * 5;
this.touchZoomValue = Math.min(Math.max(this.touchZoomValue, 20), 200);
this.controller.actionSubject.next({ action: 'centerText', data: this.touchZoomValue.toString() });
}
}
}
eventTouchEnd(e) {
if (this.touchesLength > 0) {
this.touchesLength--;
}
if (this.model.options.isMobileDevice && this.model.options.toolbar.autoHide) {
if (Math.trunc(this.touchStartX - e.changedTouches[0].clientX) !== 0) {
this.controller.keepToolbar();
}
else {
if (!this.model.controls.toolbar.visible) {
this.controller.showToolbar();
}
else {
this.controller.hideToolbar();
}
}
}
if (this.model.options.appearance.allowTouchZoom && this.touchZoomValue !== 0 && this.touchesLength === 0) {
this.controller.actionSubject.next({ action: 'hideCenterText' });
this.model.reportParams.zoom = this.touchZoomValue;
this.controller.post('GetPages');
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReportPanelComponent, deps: [{ token: i1.ControllerService }, { token: i2.ModelService }, { token: i3.StylesService }, { token: i4.InteractionsService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ReportPanelComponent, selector: "sti-report-panel", viewQueries: [{ propertyName: "element", first: true, predicate: ["element"], descendants: true }], ngImport: i0, template: `
<div #element
[style.textAlign]="model.options.appearance.pageAlignment == 'default' ? 'center' : model.options.appearance.pageAlignment"
[style.top]="0"
[style.bottom]="0"
[style.position]="position"
[style.height]="model.options.heightType != 'Percentage' || model.options.appearance.scrollbarsMode ? 'auto' : 'calc(100% - 35px)'"
[style.overflow] = "model.reportParams.type == 'Report' && model.options.appearance.scrollbarsMode ? 'auto' : 'hidden'"
[style.marginTop.px]="model.controls.reportPanel.layout.top"
[style.marginLeft.px]="model.controls.reportPanel.layout.left"
[style.marginBottom.px]="position == 'absolute' ? model.controls.reportPanel.layout.bottom : 0"
[style.paddingBottom.px]="position == 'relative' ? model.controls.reportPanel.layout.bottom : 0"
[style.transition]="model.options.isMobileDevice ? 'margin 200ms ease' : null"
(scroll)="scroll()"
class="stiJsViewerReportPanel"
(touchstart)="eventTouchStart($event)"
(touchmove)="eventTouchMove($event)"
(touchend)="eventTouchEnd($event)">
<sti-page *ngFor="let page of model.pages" [pageAttributes]="page"></sti-page>
</div>
`, isInline: true, dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i6.PageComponent, selector: "sti-page", inputs: ["pageAttributes"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReportPanelComponent, decorators: [{
type: Component,
args: [{
selector: 'sti-report-panel',
template: `
<div #element
[style.textAlign]="model.options.appearance.pageAlignment == 'default' ? 'center' : model.options.appearance.pageAlignment"
[style.top]="0"
[style.bottom]="0"
[style.position]="position"
[style.height]="model.options.heightType != 'Percentage' || model.options.appearance.scrollbarsMode ? 'auto' : 'calc(100% - 35px)'"
[style.overflow] = "model.reportParams.type == 'Report' && model.options.appearance.scrollbarsMode ? 'auto' : 'hidden'"
[style.marginTop.px]="model.controls.reportPanel.layout.top"
[style.marginLeft.px]="model.controls.reportPanel.layout.left"
[style.marginBottom.px]="position == 'absolute' ? model.controls.reportPanel.layout.bottom : 0"
[style.paddingBottom.px]="position == 'relative' ? model.controls.reportPanel.layout.bottom : 0"
[style.transition]="model.options.isMobileDevice ? 'margin 200ms ease' : null"
(scroll)="scroll()"
class="stiJsViewerReportPanel"
(touchstart)="eventTouchStart($event)"
(touchmove)="eventTouchMove($event)"
(touchend)="eventTouchEnd($event)">
<sti-page *ngFor="let page of model.pages" [pageAttributes]="page"></sti-page>
</div>
`
}]
}], ctorParameters: () => [{ type: i1.ControllerService }, { type: i2.ModelService }, { type: i3.StylesService }, { type: i4.InteractionsService }], propDecorators: { element: [{
type: ViewChild,
args: ['element']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"report-panel.component.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/components/report-panel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ElementRef, AfterViewInit } from '@angular/core';\r\nimport { ControllerService } from '../services/controller.service';\r\nimport { ModelService } from '../services/model.service';\r\nimport { StylesService } from '../services/styles.service';\r\nimport { InteractionsService } from '../services/interactions.service';\r\nimport { Message } from '../services/objects';\r\n\r\n@Component({\r\n  selector: 'sti-report-panel',\r\n  template: `\r\n    <div #element\r\n         [style.textAlign]=\"model.options.appearance.pageAlignment == 'default' ? 'center' : model.options.appearance.pageAlignment\"\r\n         [style.top]=\"0\"\r\n         [style.bottom]=\"0\"\r\n         [style.position]=\"position\"\r\n         [style.height]=\"model.options.heightType != 'Percentage' || model.options.appearance.scrollbarsMode ? 'auto' : 'calc(100% - 35px)'\"\r\n         [style.overflow] = \"model.reportParams.type == 'Report' && model.options.appearance.scrollbarsMode ? 'auto' : 'hidden'\"\r\n         [style.marginTop.px]=\"model.controls.reportPanel.layout.top\"\r\n         [style.marginLeft.px]=\"model.controls.reportPanel.layout.left\"\r\n         [style.marginBottom.px]=\"position == 'absolute' ? model.controls.reportPanel.layout.bottom : 0\"\r\n         [style.paddingBottom.px]=\"position == 'relative' ? model.controls.reportPanel.layout.bottom : 0\"\r\n         [style.transition]=\"model.options.isMobileDevice ? 'margin 200ms ease' : null\"\r\n         (scroll)=\"scroll()\"\r\n         class=\"stiJsViewerReportPanel\"\r\n         (touchstart)=\"eventTouchStart($event)\"\r\n         (touchmove)=\"eventTouchMove($event)\"\r\n         (touchend)=\"eventTouchEnd($event)\">\r\n      <sti-page *ngFor=\"let page of model.pages\" [pageAttributes]=\"page\"></sti-page>\r\n    </div>\r\n  `\r\n})\r\n\r\nexport class ReportPanelComponent implements OnInit, AfterViewInit {\r\n\r\n  @ViewChild('element') element: ElementRef;\r\n\r\n  private scrollTimeout: any;\r\n  private touchesLength: number;\r\n  private touchZoomFirstDistance = 0;\r\n  private touchZoomSecondDistance = 0;\r\n  private touchZoomValue = 0;\r\n  private touchStartX: number;\r\n\r\n  public maxHeights = {};\r\n\r\n  constructor(private controller: ControllerService, public model: ModelService, private stylesService: StylesService, private interactionService: InteractionsService) {\r\n\r\n    controller.getMessage().subscribe((message: Message) => {\r\n\r\n      if (message.action !== 'viewer_loaded' && this.model.reportParams.pagesArray) {\r\n        if (this.model.reportParams.repaintOnlyDashboardContent) {\r\n          // jsObject.controls.reportPanel.repaintDashboardContent(parameters);\r\n        } else {\r\n          this.loadPages();\r\n        }\r\n      }\r\n\r\n      if (message.action === 'GetReport' || message.action === 'OpenReport') {\r\n        setTimeout(() => {\r\n          if (!this.model.options.isParametersReceived && ((this.model.reportParams.type === 'Report' && this.model.options.toolbar.showParametersButton) || this.model.reportParams.type === 'Dashboard')) {\r\n            interactionService.postInteraction({ action: 'InitVars' });\r\n          }\r\n\r\n          if (this.model.reportParams.autoZoom) {\r\n            this.controller.action({ name: this.model.reportParams.autoZoom === -1 ? 'ZoomPageWidth' : 'ZoomOnePage' });\r\n            this.model.reportParams.autoZoom = null;\r\n          }\r\n        });\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  ngOnInit() { }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.model.controls.reportPanel.el = this.element;\r\n  }\r\n\r\n  loadPages() {\r\n    this.maxHeights = {};\r\n    const pagesArray: [] = this.model.reportParams.pagesArray;\r\n    this.stylesService.setupStyle(pagesArray[pagesArray.length - 2], 'page');\r\n    const chartScript = pagesArray[pagesArray.length - 1];\r\n    this.model.pages = pagesArray.slice(0, pagesArray.length - 2);\r\n\r\n    setTimeout(() => {\r\n      this.model.pages.forEach(page => this.interactionService.initializeInteractions(page.page));\r\n      this.interactionService.updateAllHyperLinks();\r\n      this.stylesService.addChartScript(chartScript);\r\n    });\r\n\r\n  }\r\n\r\n  get position(): string {\r\n    return this.model.options.heightType !== 'Percentage' || this.model.options.appearance.scrollbarsMode ? 'absolute' : 'relative';\r\n  }\r\n\r\n  scroll() {\r\n    if (this.model.pagesNavigationIsActive()) {\r\n      clearTimeout(this.scrollTimeout);\r\n\r\n      // update current page number\r\n      this.scrollTimeout = setTimeout(() => {\r\n        let commonPagesHeight = 0;\r\n        let index = 0;\r\n\r\n        for (index = 0; index < this.model.pages.length; index++) {\r\n          commonPagesHeight += this.model.pages[index].page.offsetHeight + 10;\r\n          if (commonPagesHeight > this.element.nativeElement.scrollTop) {\r\n            break;\r\n          }\r\n        }\r\n\r\n        if (index < this.model.reportParams.pagesCount && index >= 0 && index !== this.model.reportParams.pageNumber) {\r\n          this.model.reportParams.pageNumber = index;\r\n        }\r\n      }, 300);\r\n    }\r\n  }\r\n\r\n  public eventTouchStart(e: any) {\r\n    this.touchesLength++;\r\n    this.touchStartX = parseInt(e.changedTouches[0].clientX, 10);\r\n\r\n    if (this.model.options.appearance.allowTouchZoom && this.touchesLength === 1) {\r\n      this.touchZoomFirstDistance = 0;\r\n      this.touchZoomSecondDistance = 0;\r\n      this.touchZoomValue = 0;\r\n    }\r\n  }\r\n\r\n  public eventTouchMove(e: any) {\r\n    if (this.model.options.appearance.allowTouchZoom && e.touches.length > 1) {\r\n      if ('preventDefault' in e) { e.preventDefault(); }\r\n\r\n      this.touchZoomSecondDistance = Math.sqrt(Math.pow(e.touches[0].pageX - e.touches[1].pageX, 2) + Math.pow(e.touches[0].pageY - e.touches[1].pageY, 2));\r\n      if (this.touchZoomFirstDistance === 0) {\r\n        this.touchZoomFirstDistance = Math.sqrt(Math.pow(e.touches[0].pageX - e.touches[1].pageX, 2) + Math.pow(e.touches[0].pageY - e.touches[1].pageY, 2));\r\n      }\r\n\r\n      const touchZoomOffset = Math.trunc((this.touchZoomSecondDistance - this.touchZoomFirstDistance) / 2.5);\r\n      if (Math.abs(touchZoomOffset) >= 5) {\r\n        this.touchZoomValue = Math.trunc((this.model.reportParams.zoom + touchZoomOffset) / 5) * 5;\r\n        this.touchZoomValue = Math.min(Math.max(this.touchZoomValue, 20), 200);\r\n        this.controller.actionSubject.next({ action: 'centerText', data: this.touchZoomValue.toString() });\r\n      }\r\n    }\r\n  }\r\n\r\n  public eventTouchEnd(e: any) {\r\n    if (this.touchesLength > 0) { this.touchesLength--; }\r\n\r\n    if (this.model.options.isMobileDevice && this.model.options.toolbar.autoHide) {\r\n      if (Math.trunc(this.touchStartX - e.changedTouches[0].clientX) !== 0) {\r\n        this.controller.keepToolbar();\r\n      } else {\r\n        if (!this.model.controls.toolbar.visible) {\r\n          this.controller.showToolbar();\r\n        } else {\r\n          this.controller.hideToolbar();\r\n        }\r\n      }\r\n    }\r\n\r\n    if (this.model.options.appearance.allowTouchZoom && this.touchZoomValue !== 0 && this.touchesLength === 0) {\r\n      this.controller.actionSubject.next({ action: 'hideCenterText' });\r\n      this.model.reportParams.zoom = this.touchZoomValue;\r\n      this.controller.post('GetPages');\r\n    }\r\n  }\r\n}\r\n"]}