UNPKG

stimulsoft-viewer-angular

Version:

The Viewer component is designed to view reports and dashboards in the web browser.

228 lines 34.2 kB
import { Component, ViewChild } from '@angular/core'; import { trigger, state, transition, animate, style, keyframes } from '@angular/animations'; import * as i0 from "@angular/core"; import * as i1 from "../services/model.service"; import * as i2 from "../services/helper.service"; import * as i3 from "../services/controller.service"; import * as i4 from "@angular/common"; export class BookmarksPanelComponent { constructor(model, helper, controller) { this.model = model; this.helper = helper; this.controller = controller; controller.getMessage().subscribe((message) => { if (message.action === 'GetReport' || message.action === 'OpenReport') { setTimeout(() => { if (this.model.reportParams.bookmarksContent != null) { this.create(); } this.model.controls.bookmarksPanel.visible = this.model.reportParams.bookmarksContent !== null && !this.model.options.isMobileDevice && !(this.model.options.toolbar?.showBookmarksButton === false); }); } else { // Go to the bookmark, if it present setTimeout(() => { if (this.model.options.bookmarkAnchor != null) { this.helper.scrollToAnchor(this.model.options.bookmarkAnchor, this.model.options.componentGuid); this.model.options.bookmarkAnchor = null; this.model.options.componentGuid = null; } }); } }); this.model.controls.bookmarksPanel.getVisibility().subscribe((value) => { if (!value) { this.helper.removeBookmarksLabel(); this.clearSelected(); } }); } ngAfterViewInit() { this.model.controls.bookmarksPanel.el = this.element; } ngOnInit() { } getImg1(node, i) { if (node.nodes?.length === 0) { return i !== this.model.nodes.length - 1 ? this.model.imagesForBookmark['join'] : this.model.imagesForBookmark['joinBottom']; } return node.open ? (i === this.model.nodes.length - 1 ? this.model.imagesForBookmark['minusBottom'] : this.model.imagesForBookmark['minus']) : (i === this.model.nodes.length - 1 ? this.model.imagesForBookmark['plusBottom'] : this.model.imagesForBookmark['plus']); } postAction(node) { this.clearSelected(); this.controller.postBookmarkNodeAction(node); } clearSelected() { this.model.nodes?.forEach((n) => { n.selected = false; n.nodes.forEach(element => element.selected = false); }); } create() { let bookmarks = JSON.parse(this.model.reportParams.bookmarksContent); this.rootName = bookmarks.bookmarksTree[0].title; const nodes = []; this.parseNodes(bookmarks, 0, nodes); this.model.nodes = nodes; } parseNodes(bookmarks, index, nodes) { let folder; bookmarks.bookmarksTree.splice(1).forEach((bookmark) => { let page = bookmark.componentGuid != null && bookmarks.bookmarksPageIndexes != null ? (bookmarks.bookmarksPageIndexes[bookmark.componentGuid] - 1 ?? 0) : 0; const node = { name: bookmark.title, url: bookmark.url, page: page, compunentGuid: bookmark.componentGuid, nodes: [], open: false, selected: false }; if (bookmark.parent === 0) { nodes.push(node); folder = node; } else { folder.nodes.push(node); } }); } unescape(str) { return str.replace(/\\&apos;/g, '\'') .replace(/\\&quot;/g, '"') .replace(/\\&gt;/g, '>') .replace(/\\&lt;/g, '<') .replace(/\\&amp;/g, '&'); } get bottom() { if (this.model.options.isMobileDevice) { return this.model.options.toolbar.autoHide ? '0' : '0.5in'; } else { return this.model.options.toolbar.displayMode === 'Separated' && this.model.options.toolbar.visible ? '35px' : '0'; } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BookmarksPanelComponent, deps: [{ token: i1.ModelService }, { token: i2.HelperService }, { token: i3.ControllerService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: BookmarksPanelComponent, selector: "sti-bookmarks-panel", viewQueries: [{ propertyName: "element", first: true, predicate: ["element"], descendants: true }, { propertyName: "bookmarksPanel", first: true, predicate: ["bookmarksPanel"], descendants: true }], ngImport: i0, template: ` <div #element [style]="{fontFamily: model.options.toolbar.fontFamily, fontColor: helper.val(model.options.toolbar.fontColor)}" [class]="'stiJsViewerBookmarksPanel' + (model.options.toolbar.displayMode == 'Separated' ? ' stiJsViewerBookmarksPanelSeparated' : '')" [style.width.px]="model.options.appearance.bookmarksTreeWidth - (model.options.toolbar.displayMode == 'Simple' ? 0 : 1)" [style.bottom]="bottom" [style.top.px]="model.controls.bookmarksPanel.layout.top" [style.transition]="model.options.isMobileDevice ? 'opacity 300ms ease' : null" [style.display]="!this.model.options.isMobileDevice ? (model.controls.bookmarksPanel.visible ? '' : 'none') : null" [@visibility]="!this.model.options.isMobileDevice ? null : (model.controls.bookmarksPanel.visible ? 'visible' : 'hidden')"> <div #bookmarksPanel [class]="'stiJsViewerBookmarksContainer' + (model.options.toolbar.displayMode == 'Simple' ? ' stiJsViewerBookmarksContainerSimple' : '')" [style.background]="helper.val(model.options.toolbar.backgroundColor)" [style.border]="helper.val(model.options.toolbar.borderColor) != '' ? '1px solid ' + helper.val(model.options.toolbar.borderColor): ''"> <div class="stiTree"> <div class="stiTreeNode"> <img [style.width.px]="16" [style.height.px]="16" [src]="model.imagesForBookmark['root']"/> <a class="node">{{rootName}}</a> </div> <div class="clip" [style.display]="'block'"> <ng-container *ngFor="let node of model.nodes; index as i"> <div class="stiTreeNode"> <a (click)="node.open = !node.open"> <img [style.width.px]="18" [style.height.px]="18" [src]="getImg1(node, i)"/> </a> <img [style.width.px]="16" [style.height.px]="16" [src]="node.nodes?.length == 0 ? model.imagesForBookmark['node'] :(node.open ? model.imagesForBookmark['folderOpen'] : model.imagesForBookmark['folder'])"/> <a [class]="node.selected ? 'nodeSel' : 'node'" (click)="postAction(node)">{{node.name}}</a> </div> <div class="clip" [style.display]="node.open ? 'block' : 'none'"> <div *ngFor="let subNode of node.nodes; index as k" class="stiTreeNode"> <img [style.width.px]="18" [style.height.px]="18" [src]="i != model.nodes.length - 1 ? model.imagesForBookmark['line'] : model.imagesForBookmark['empty']"/> <img [style.width.px]="18" [style.height.px]="18" [src]="k == node.nodes.length - 1 ? model.imagesForBookmark['joinBottom'] : model.imagesForBookmark['join']"/> <img [style.width.px]="16" [style.height.px]="16" [src]="model.imagesForBookmark['node']" /> <a [class]="subNode.selected ? 'nodeSel' : 'node'" (click)="postAction(subNode)">{{subNode.name}}</a> </div> </div> </ng-container> </div> </div> </div> </div> `, isInline: true, dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], animations: [ trigger('visibility', [ state('visible', style({ opacity: 1, display: 'block' })), state('hidden', style({ opacity: 0, display: 'none' })), transition('hidden => visible', [ animate('300ms ease-in-out', keyframes([ style({ display: 'block', opacity: 0, offset: 0 }), style({ display: 'block', opacity: 1, offset: 1 }), ])) ]), transition('visible => hidden', [ animate('300ms ease-in-out', keyframes([ style({ display: 'block', opacity: 1, offset: 0 }), style({ display: 'none', opacity: 0, offset: 1 }), ])) ]) ]) ] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BookmarksPanelComponent, decorators: [{ type: Component, args: [{ selector: 'sti-bookmarks-panel', template: ` <div #element [style]="{fontFamily: model.options.toolbar.fontFamily, fontColor: helper.val(model.options.toolbar.fontColor)}" [class]="'stiJsViewerBookmarksPanel' + (model.options.toolbar.displayMode == 'Separated' ? ' stiJsViewerBookmarksPanelSeparated' : '')" [style.width.px]="model.options.appearance.bookmarksTreeWidth - (model.options.toolbar.displayMode == 'Simple' ? 0 : 1)" [style.bottom]="bottom" [style.top.px]="model.controls.bookmarksPanel.layout.top" [style.transition]="model.options.isMobileDevice ? 'opacity 300ms ease' : null" [style.display]="!this.model.options.isMobileDevice ? (model.controls.bookmarksPanel.visible ? '' : 'none') : null" [@visibility]="!this.model.options.isMobileDevice ? null : (model.controls.bookmarksPanel.visible ? 'visible' : 'hidden')"> <div #bookmarksPanel [class]="'stiJsViewerBookmarksContainer' + (model.options.toolbar.displayMode == 'Simple' ? ' stiJsViewerBookmarksContainerSimple' : '')" [style.background]="helper.val(model.options.toolbar.backgroundColor)" [style.border]="helper.val(model.options.toolbar.borderColor) != '' ? '1px solid ' + helper.val(model.options.toolbar.borderColor): ''"> <div class="stiTree"> <div class="stiTreeNode"> <img [style.width.px]="16" [style.height.px]="16" [src]="model.imagesForBookmark['root']"/> <a class="node">{{rootName}}</a> </div> <div class="clip" [style.display]="'block'"> <ng-container *ngFor="let node of model.nodes; index as i"> <div class="stiTreeNode"> <a (click)="node.open = !node.open"> <img [style.width.px]="18" [style.height.px]="18" [src]="getImg1(node, i)"/> </a> <img [style.width.px]="16" [style.height.px]="16" [src]="node.nodes?.length == 0 ? model.imagesForBookmark['node'] :(node.open ? model.imagesForBookmark['folderOpen'] : model.imagesForBookmark['folder'])"/> <a [class]="node.selected ? 'nodeSel' : 'node'" (click)="postAction(node)">{{node.name}}</a> </div> <div class="clip" [style.display]="node.open ? 'block' : 'none'"> <div *ngFor="let subNode of node.nodes; index as k" class="stiTreeNode"> <img [style.width.px]="18" [style.height.px]="18" [src]="i != model.nodes.length - 1 ? model.imagesForBookmark['line'] : model.imagesForBookmark['empty']"/> <img [style.width.px]="18" [style.height.px]="18" [src]="k == node.nodes.length - 1 ? model.imagesForBookmark['joinBottom'] : model.imagesForBookmark['join']"/> <img [style.width.px]="16" [style.height.px]="16" [src]="model.imagesForBookmark['node']" /> <a [class]="subNode.selected ? 'nodeSel' : 'node'" (click)="postAction(subNode)">{{subNode.name}}</a> </div> </div> </ng-container> </div> </div> </div> </div> `, animations: [ trigger('visibility', [ state('visible', style({ opacity: 1, display: 'block' })), state('hidden', style({ opacity: 0, display: 'none' })), transition('hidden => visible', [ animate('300ms ease-in-out', keyframes([ style({ display: 'block', opacity: 0, offset: 0 }), style({ display: 'block', opacity: 1, offset: 1 }), ])) ]), transition('visible => hidden', [ animate('300ms ease-in-out', keyframes([ style({ display: 'block', opacity: 1, offset: 0 }), style({ display: 'none', opacity: 0, offset: 1 }), ])) ]) ]) ] }] }], ctorParameters: () => [{ type: i1.ModelService }, { type: i2.HelperService }, { type: i3.ControllerService }], propDecorators: { element: [{ type: ViewChild, args: ['element'] }], bookmarksPanel: [{ type: ViewChild, args: ['bookmarksPanel'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bookmarks-panel.component.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/components/bookmarks-panel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ElementRef, AfterViewInit } from '@angular/core';\r\nimport { ModelService } from '../services/model.service';\r\nimport { HelperService } from '../services/helper.service';\r\nimport { ControllerService } from '../services/controller.service';\r\nimport { BookmarkNode, Message } from '../services/objects';\r\nimport { trigger, state, transition, animate, style, keyframes, AnimationEvent } from '@angular/animations';\r\n\r\n@Component({\r\n  selector: 'sti-bookmarks-panel',\r\n  template: `\r\n    <div #element [style]=\"{fontFamily: model.options.toolbar.fontFamily, fontColor: helper.val(model.options.toolbar.fontColor)}\"\r\n      [class]=\"'stiJsViewerBookmarksPanel' + (model.options.toolbar.displayMode == 'Separated' ? ' stiJsViewerBookmarksPanelSeparated' : '')\"\r\n      [style.width.px]=\"model.options.appearance.bookmarksTreeWidth - (model.options.toolbar.displayMode == 'Simple' ? 0 : 1)\"\r\n      [style.bottom]=\"bottom\"\r\n      [style.top.px]=\"model.controls.bookmarksPanel.layout.top\"\r\n      [style.transition]=\"model.options.isMobileDevice ? 'opacity 300ms ease' : null\"\r\n      [style.display]=\"!this.model.options.isMobileDevice ? (model.controls.bookmarksPanel.visible ? '' : 'none') : null\"\r\n      [@visibility]=\"!this.model.options.isMobileDevice ? null : (model.controls.bookmarksPanel.visible ? 'visible' : 'hidden')\">\r\n      <div #bookmarksPanel [class]=\"'stiJsViewerBookmarksContainer' + (model.options.toolbar.displayMode == 'Simple' ? ' stiJsViewerBookmarksContainerSimple' : '')\"\r\n           [style.background]=\"helper.val(model.options.toolbar.backgroundColor)\"\r\n           [style.border]=\"helper.val(model.options.toolbar.borderColor) != '' ? '1px solid ' + helper.val(model.options.toolbar.borderColor): ''\">\r\n           <div class=\"stiTree\">\r\n              <div class=\"stiTreeNode\">\r\n                <img [style.width.px]=\"16\" [style.height.px]=\"16\" [src]=\"model.imagesForBookmark['root']\"/>\r\n                <a class=\"node\">{{rootName}}</a>\r\n              </div>\r\n              <div class=\"clip\" [style.display]=\"'block'\">\r\n                <ng-container *ngFor=\"let node of model.nodes; index as i\">\r\n                    <div class=\"stiTreeNode\">\r\n                        <a (click)=\"node.open = !node.open\">\r\n                            <img [style.width.px]=\"18\" [style.height.px]=\"18\"\r\n                             [src]=\"getImg1(node, i)\"/>\r\n                        </a>\r\n                        <img [style.width.px]=\"16\" [style.height.px]=\"16\" [src]=\"node.nodes?.length == 0 ? model.imagesForBookmark['node'] :(node.open ? model.imagesForBookmark['folderOpen'] : model.imagesForBookmark['folder'])\"/>\r\n                        <a [class]=\"node.selected ? 'nodeSel' : 'node'\" (click)=\"postAction(node)\">{{node.name}}</a>\r\n                    </div>\r\n                    <div class=\"clip\" [style.display]=\"node.open ? 'block' : 'none'\">\r\n                      <div *ngFor=\"let subNode of node.nodes; index as k\" class=\"stiTreeNode\">\r\n                        <img [style.width.px]=\"18\" [style.height.px]=\"18\" [src]=\"i != model.nodes.length - 1 ? model.imagesForBookmark['line'] : model.imagesForBookmark['empty']\"/>\r\n                        <img [style.width.px]=\"18\" [style.height.px]=\"18\" [src]=\"k == node.nodes.length - 1 ? model.imagesForBookmark['joinBottom'] : model.imagesForBookmark['join']\"/>\r\n                        <img [style.width.px]=\"16\" [style.height.px]=\"16\" [src]=\"model.imagesForBookmark['node']\" />\r\n                        <a [class]=\"subNode.selected ? 'nodeSel' : 'node'\" (click)=\"postAction(subNode)\">{{subNode.name}}</a>\r\n                      </div>\r\n                    </div>\r\n                </ng-container>\r\n              </div>\r\n          </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  animations: [\r\n    trigger('visibility', [\r\n      state('visible', style({ opacity: 1, display: 'block' })),\r\n      state('hidden', style({ opacity: 0, display: 'none' })),\r\n      transition('hidden => visible', [\r\n        animate('300ms ease-in-out', keyframes([\r\n          style({ display: 'block', opacity: 0, offset: 0 }),\r\n          style({ display: 'block', opacity: 1, offset: 1 }),\r\n        ]))\r\n      ]),\r\n      transition('visible => hidden', [\r\n        animate('300ms ease-in-out', keyframes([\r\n          style({ display: 'block', opacity: 1, offset: 0 }),\r\n          style({ display: 'none', opacity: 0, offset: 1 }),\r\n        ]))\r\n      ])\r\n    ])\r\n  ]\r\n})\r\n\r\nexport class BookmarksPanelComponent implements OnInit, AfterViewInit {\r\n\r\n  @ViewChild('element') element: ElementRef;\r\n  @ViewChild('bookmarksPanel') bookmarksPanel: ElementRef;\r\n\r\n  public rootName: string;\r\n\r\n  constructor(public model: ModelService, public helper: HelperService, public controller: ControllerService) {\r\n    controller.getMessage().subscribe((message: Message) => {\r\n      if (message.action === 'GetReport' || message.action === 'OpenReport') {\r\n        setTimeout(() => {\r\n          if (this.model.reportParams.bookmarksContent != null) {\r\n            this.create();\r\n          }\r\n          this.model.controls.bookmarksPanel.visible = this.model.reportParams.bookmarksContent !== null && !this.model.options.isMobileDevice && !(this.model.options.toolbar?.showBookmarksButton === false);\r\n        });\r\n      } else {\r\n        // Go to the bookmark, if it present\r\n        setTimeout(() => {\r\n          if (this.model.options.bookmarkAnchor != null) {\r\n            this.helper.scrollToAnchor(this.model.options.bookmarkAnchor, this.model.options.componentGuid);\r\n            this.model.options.bookmarkAnchor = null;\r\n            this.model.options.componentGuid = null;\r\n          }\r\n        });\r\n      }\r\n    });\r\n\r\n    this.model.controls.bookmarksPanel.getVisibility().subscribe((value) => {\r\n      if (!value) {\r\n        this.helper.removeBookmarksLabel();\r\n        this.clearSelected();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.model.controls.bookmarksPanel.el = this.element;\r\n  }\r\n\r\n  ngOnInit() { }\r\n\r\n  public getImg1(node: BookmarkNode, i: number): string {\r\n    if (node.nodes?.length === 0) {\r\n      return i !== this.model.nodes.length - 1 ? this.model.imagesForBookmark['join'] : this.model.imagesForBookmark['joinBottom'];\r\n    }\r\n    return node.open ? (i === this.model.nodes.length - 1 ? this.model.imagesForBookmark['minusBottom'] : this.model.imagesForBookmark['minus']) :\r\n      (i === this.model.nodes.length - 1 ? this.model.imagesForBookmark['plusBottom'] : this.model.imagesForBookmark['plus']);\r\n  }\r\n\r\n  public postAction(node: BookmarkNode) {\r\n    this.clearSelected();\r\n    this.controller.postBookmarkNodeAction(node);\r\n  }\r\n\r\n  clearSelected() {\r\n    this.model.nodes?.forEach((n) => {\r\n      n.selected = false;\r\n      n.nodes.forEach(element => element.selected = false);\r\n    });\r\n  }\r\n\r\n  create() {\r\n    let bookmarks = JSON.parse(this.model.reportParams.bookmarksContent);\r\n    this.rootName = bookmarks.bookmarksTree[0].title;\r\n\r\n    const nodes: BookmarkNode[] = [];\r\n    this.parseNodes(bookmarks, 0, nodes);\r\n    this.model.nodes = nodes;\r\n  }\r\n\r\n  parseNodes(bookmarks: any, index: number, nodes: BookmarkNode[]) {\r\n    let folder: BookmarkNode;\r\n    bookmarks.bookmarksTree.splice(1).forEach((bookmark) => {\r\n      let page = bookmark.componentGuid != null && bookmarks.bookmarksPageIndexes != null ? (bookmarks.bookmarksPageIndexes[bookmark.componentGuid] - 1 ?? 0) : 0;\r\n      const node: BookmarkNode = { name: bookmark.title, url: bookmark.url, page: page, compunentGuid: bookmark.componentGuid, nodes: [], open: false, selected: false };\r\n      if (bookmark.parent === 0) {\r\n        nodes.push(node);\r\n        folder = node;\r\n      } else {\r\n        folder.nodes.push(node);\r\n      }\r\n    });\r\n  }\r\n\r\n  unescape(str: string): string {\r\n    return str.replace(/\\\\&apos;/g, '\\'')\r\n      .replace(/\\\\&quot;/g, '\"')\r\n      .replace(/\\\\&gt;/g, '>')\r\n      .replace(/\\\\&lt;/g, '<')\r\n      .replace(/\\\\&amp;/g, '&');\r\n  }\r\n\r\n  get bottom(): string {\r\n    if (this.model.options.isMobileDevice) {\r\n      return this.model.options.toolbar.autoHide ? '0' : '0.5in';\r\n    } else {\r\n      return this.model.options.toolbar.displayMode === 'Separated' && this.model.options.toolbar.visible ? '35px' : '0';\r\n    }\r\n  }\r\n\r\n}\r\n"]}