stimulsoft-viewer-angular
Version:
Stimulsoft Viewer Angular
141 lines • 14.2 kB
JavaScript
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"]}