UNPKG

stimulsoft-viewer-angular

Version:
141 lines 14.2 kB
import { Component, ViewChild } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "../services/model.service"; import * as i2 from "../services/controller.service"; import * as i3 from "../services/helper.service"; import * as i4 from "../forms/form.service"; export class AboutPanelComponent { constructor(model, controller, helper, formService) { this.model = model; this.controller = controller; this.helper = helper; this.formService = formService; this.year = new Date().getFullYear(); this.top = 0; this.left = 0; this.opacity = 0; controller.getActionMessage().subscribe((message) => { if (message.action === 'About') { this.formService.form = { name: 'about', left: 0, top: 0, isMooving: false, level: 2 }; this.opacity = 0; setTimeout(() => { this.top = this.model.viewerSize.height / 2 - this.element.nativeElement.offsetHeight / 2; this.left = this.model.viewerSize.width / 2 - this.element.nativeElement.offsetWidth / 2; this.opacity = 1; }); } }); } ngOnInit() { } close() { this.formService.closeForm('about'); } click(event) { if (event) { event.stopPropagation(); event.preventDefault(); } this.helper.openNewWindow('https://www.stimulsoft.com'); } isLicensed() { return !this.model.options.cloudMode && !this.model.options.serverMode && !this.model.options.standaloneJsMode && !this.model.options.reportDesignerMode && !this.model.options.licenseIsValid; } get userLabel() { let userName = this.model.options.licenseUserName || ''; if (this.isLicensed()) { if (userName) { userName += ', '; } return userName + this.helper.getBackText(true) + ' Version'; } else { return userName; } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AboutPanelComponent, deps: [{ token: i1.ModelService }, { token: i2.ControllerService }, { token: i3.HelperService }, { token: i4.FormService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AboutPanelComponent, selector: "sti-about-panel", viewQueries: [{ propertyName: "element", first: true, predicate: ["element"], descendants: true }], ngImport: i0, template: ` <div #element class="stiJsViewerAboutPanel" [style.backgroundSize]="'contain'" [style.display]="formService.form?.name == 'about' ? '' : 'none'" [style.left.px]="left" [style.top.px]="top" [style.opacity]="opacity" (click)="close()" > <div class="stiJsViewerAboutPanelHeader"> Stimulsoft Reports </div> <img src="{{model.img('About.png')}}" [style.marginTop.px]="30" [style.height.px]="94" [style.width.px]="94"> <div class="stiJsViewerAboutPanelCopyright"> {{'Copyright 2003-' + year + ' Stimulsoft'}} </div> <div class="stiJsViewerAboutPanelVersion"> {{model.options.productVersion?.trim()}}, {{model.options?.frameworkType}}, Angular </div> <div class="stiJsViewerAboutPanelVersion"> All rights reserved </div> <div class="stiJsViewerAboutPanelVersion" [style.marginTop.px]="20" [style.fontWeight]="'bold'" [style.color]="isLicensed() ? 'red' : '#444444'" [style.display]="isLicensed() || userLabel ? '' : 'none'"> {{userLabel}} </div> <div class="stiJsViewerFormSeparator" [style.marginTop.px]="20"> </div> <div class="stiJsViewerAboutPanelStiLink" (click)='click($event)'> www.stimulsoft.com </div> </div> `, isInline: true }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AboutPanelComponent, decorators: [{ type: Component, args: [{ selector: 'sti-about-panel', template: ` <div #element class="stiJsViewerAboutPanel" [style.backgroundSize]="'contain'" [style.display]="formService.form?.name == 'about' ? '' : 'none'" [style.left.px]="left" [style.top.px]="top" [style.opacity]="opacity" (click)="close()" > <div class="stiJsViewerAboutPanelHeader"> Stimulsoft Reports </div> <img src="{{model.img('About.png')}}" [style.marginTop.px]="30" [style.height.px]="94" [style.width.px]="94"> <div class="stiJsViewerAboutPanelCopyright"> {{'Copyright 2003-' + year + ' Stimulsoft'}} </div> <div class="stiJsViewerAboutPanelVersion"> {{model.options.productVersion?.trim()}}, {{model.options?.frameworkType}}, Angular </div> <div class="stiJsViewerAboutPanelVersion"> All rights reserved </div> <div class="stiJsViewerAboutPanelVersion" [style.marginTop.px]="20" [style.fontWeight]="'bold'" [style.color]="isLicensed() ? 'red' : '#444444'" [style.display]="isLicensed() || userLabel ? '' : 'none'"> {{userLabel}} </div> <div class="stiJsViewerFormSeparator" [style.marginTop.px]="20"> </div> <div class="stiJsViewerAboutPanelStiLink" (click)='click($event)'> www.stimulsoft.com </div> </div> ` }] }], ctorParameters: () => [{ type: i1.ModelService }, { type: i2.ControllerService }, { type: i3.HelperService }, { type: i4.FormService }], propDecorators: { element: [{ type: ViewChild, args: ['element'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"about-panel.component.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/components/about-panel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ElementRef } from '@angular/core';\r\nimport { ControllerService } from '../services/controller.service';\r\nimport { Message } from '../services/objects';\r\nimport { HelperService } from '../services/helper.service';\r\nimport { FormService } from '../forms/form.service';\r\nimport { ModelService } from '../services/model.service';\r\n\r\n@Component({\r\n  selector: 'sti-about-panel',\r\n  template: `\r\n    <div #element class=\"stiJsViewerAboutPanel\" [style.backgroundSize]=\"'contain'\"\r\n      [style.display]=\"formService.form?.name == 'about' ? '' : 'none'\"\r\n      [style.left.px]=\"left\"\r\n      [style.top.px]=\"top\"\r\n      [style.opacity]=\"opacity\"\r\n      (click)=\"close()\" >\r\n      <div class=\"stiJsViewerAboutPanelHeader\">\r\n        Stimulsoft Reports\r\n      </div>\r\n      <img src=\"{{model.img('About.png')}}\"\r\n          [style.marginTop.px]=\"30\"\r\n          [style.height.px]=\"94\"\r\n          [style.width.px]=\"94\">\r\n      <div class=\"stiJsViewerAboutPanelCopyright\">\r\n        {{'Copyright 2003-' + year + ' Stimulsoft'}}\r\n      </div>\r\n      <div class=\"stiJsViewerAboutPanelVersion\">\r\n        {{model.options.productVersion?.trim()}}, {{model.options?.frameworkType}}, Angular\r\n      </div>\r\n      <div class=\"stiJsViewerAboutPanelVersion\">\r\n        All rights reserved\r\n      </div>\r\n      <div class=\"stiJsViewerAboutPanelVersion\"\r\n        [style.marginTop.px]=\"20\"\r\n        [style.fontWeight]=\"'bold'\"\r\n        [style.color]=\"isLicensed() ? 'red' : '#444444'\"\r\n        [style.display]=\"isLicensed() || userLabel ? '' : 'none'\">\r\n        {{userLabel}}\r\n      </div>\r\n      <div class=\"stiJsViewerFormSeparator\" [style.marginTop.px]=\"20\">\r\n      </div>\r\n      <div class=\"stiJsViewerAboutPanelStiLink\" (click)='click($event)'>\r\n        www.stimulsoft.com\r\n      </div>\r\n    </div>\r\n  `\r\n})\r\n\r\nexport class AboutPanelComponent implements OnInit {\r\n\r\n  @ViewChild('element') element: ElementRef;\r\n\r\n  year: number = new Date().getFullYear();\r\n  jsHelper: any;\r\n  top = 0;\r\n  left = 0;\r\n  opacity = 0;\r\n\r\n  constructor(public model: ModelService, public controller: ControllerService, public helper: HelperService,\r\n    public formService: FormService) {\r\n    controller.getActionMessage().subscribe((message: Message) => {\r\n      if (message.action === 'About') {\r\n        this.formService.form = { name: 'about', left: 0, top: 0, isMooving: false, level: 2 };\r\n        this.opacity = 0;\r\n        setTimeout(() => {\r\n          this.top = this.model.viewerSize.height / 2 - this.element.nativeElement.offsetHeight / 2;\r\n          this.left = this.model.viewerSize.width / 2 - this.element.nativeElement.offsetWidth / 2;\r\n          this.opacity = 1;\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnInit() { }\r\n\r\n  close() {\r\n    this.formService.closeForm('about');\r\n  }\r\n\r\n  click(event: any) {\r\n    if (event) {\r\n      event.stopPropagation();\r\n      event.preventDefault();\r\n    }\r\n    this.helper.openNewWindow('https://www.stimulsoft.com');\r\n  }\r\n\r\n  isLicensed(): boolean {\r\n    return !this.model.options.cloudMode && !this.model.options.serverMode && !this.model.options.standaloneJsMode &&\r\n      !this.model.options.reportDesignerMode && !this.model.options.licenseIsValid;\r\n  }\r\n\r\n  get userLabel(): string {\r\n    let userName = this.model.options.licenseUserName || '';\r\n    if (this.isLicensed()) {\r\n      if (userName) {\r\n        userName += ', ';\r\n      }\r\n      return userName + this.helper.getBackText(true) + ' Version';\r\n    } else {\r\n      return userName;\r\n    }\r\n  }\r\n}\r\n"]}