stimulsoft-designer-angular
Version:
The Angular Designer component is developed to create reports and dashboards in web browser.
137 lines • 16.9 kB
JavaScript
import { Component, Input, ViewChild, Output, EventEmitter } from '@angular/core';
import { ProxyService } from './proxy.service';
import { EMPTY, catchError } from 'rxjs';
import { FileSaverService } from './file.saver.service';
import * as i0 from "@angular/core";
import * as i1 from "./proxy.service";
import * as i2 from "@angular/common/http";
export class StimulsoftDesignerComponent {
constructor(proxy, httpClient) {
this.proxy = proxy;
this.httpClient = httpClient;
/**
* Occurs when designer loaded
*/
this.designerLoaded = new EventEmitter();
this.id = 'aDesigner' + (Math.random() * 10000000).toString();
this.scriptLoading = false;
this.loaded = false;
}
ngOnDestroy() {
if (this.chartScripts) {
this.head.removeChild(this.chartScripts);
}
let options = this.designerEl.nativeElement?.firstChild?.jsObject?.options;
try {
clearTimeout(options.timerAjax);
}
catch { }
try {
clearTimeout(options.timerUpdateCache);
}
catch { }
try {
clearTimeout(options.timerAutoSave);
}
catch { }
}
ngOnInit() {
this.addScript();
}
ngOnChanges(changes) {
this.addScript();
}
addScript() {
if (this.scriptLoading)
return;
this.scriptLoading = true;
if (this.chartScripts) {
this.head.removeChild(this.chartScripts);
}
this.chartScripts = document.createElement('Script');
this.chartScripts.setAttribute('type', 'text/javascript');
this.head.appendChild(this.chartScripts);
let observable = this.httpClient.get(this.requestUrl, { responseType: 'text' }).pipe(catchError((error) => {
console.log(error);
this.scriptLoading = false;
return EMPTY;
}));
observable.subscribe(data => {
if (!this.loaded) {
try {
this.chartScripts.innerHTML = data;
const options = new Stimulsoft.Designer.StiDesignerOptions();
this.loaded = true;
setTimeout(() => {
this.scriptLoading = false;
});
this.showDesigner();
this.designerLoadedF();
}
catch {
this.scriptLoading = false;
}
}
});
}
designerLoadedF() {
let jsObject = this.designerEl.nativeElement?.firstChild?.jsObject;
if (!jsObject) {
setTimeout(() => {
this.designerLoadedF();
});
return;
}
this.designerLoaded.next(null);
}
showDesigner() {
const options = new Stimulsoft.Designer.StiDesignerOptions();
let defaultOptions = Stimulsoft?.Designer?.defaultOptions;
if (defaultOptions) {
for (let k in defaultOptions)
options[k] = defaultOptions[k];
options.useAliasesDictionary = defaultOptions.dictionary.useAliases;
}
if (this.width) {
options.width = this.width;
}
if (this.height) {
options.height = this.height;
}
this.designer = new Stimulsoft.Designer.StiDesigner(options, 'StiDesigner', false);
this.proxy.postParametersFunction_ = this.postParametersFunction;
this.designerEl.nativeElement.proxy = this.proxy;
this.designer.renderHtml(this.designerEl.nativeElement);
}
get head() {
return document.getElementsByTagName('head')[0];
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: StimulsoftDesignerComponent, deps: [{ token: i1.ProxyService }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: StimulsoftDesignerComponent, selector: "stimulsoft-designer-angular", inputs: { requestUrl: "requestUrl", width: "width", height: "height", postParametersFunction: "postParametersFunction" }, outputs: { designerLoaded: "designerLoaded" }, providers: [ProxyService, FileSaverService], viewQueries: [{ propertyName: "designerEl", first: true, predicate: ["designer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
<div #designer [attr.id]="id">
<ng-content></ng-content>
</div>
`, isInline: true }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: StimulsoftDesignerComponent, decorators: [{
type: Component,
args: [{ selector: 'stimulsoft-designer-angular', template: `
<div #designer [attr.id]="id">
<ng-content></ng-content>
</div>
`, providers: [ProxyService, FileSaverService] }]
}], ctorParameters: () => [{ type: i1.ProxyService }, { type: i2.HttpClient }], propDecorators: { designerEl: [{
type: ViewChild,
args: ['designer']
}], designerLoaded: [{
type: Output
}], requestUrl: [{
type: Input
}], width: [{
type: Input
}], height: [{
type: Input
}], postParametersFunction: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stimulsoft-designer-angular.component.js","sourceRoot":"","sources":["../../../../projects/stimulsoft-designer-angular/src/lib/stimulsoft-designer-angular.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ElementRef, ViewChild, OnChanges, Output, EventEmitter, OnDestroy } from '@angular/core';\r\nimport { ProxyService } from './proxy.service';\r\nimport { HttpClient, HttpErrorResponse } from '@angular/common/http';\r\nimport { EMPTY, catchError } from 'rxjs';\r\nimport { FileSaverService } from './file.saver.service';\r\n\r\ndeclare var Stimulsoft: any;\r\n\r\n@Component({\r\n  selector: 'stimulsoft-designer-angular',\r\n  template: `\r\n    <div #designer [attr.id]=\"id\">\r\n      <ng-content></ng-content>\r\n    </div>\r\n  `,\r\n  styles: [],\r\n  providers: [ProxyService, FileSaverService]\r\n})\r\nexport class StimulsoftDesignerComponent implements OnInit, OnChanges, OnDestroy {\r\n\r\n  @ViewChild('designer') designerEl: ElementRef;\r\n\r\n  /**\r\n   * Occurs when designer loaded\r\n   */\r\n  @Output() designerLoaded: EventEmitter<any> = new EventEmitter();\r\n\r\n  /**\r\n   * Url to server instance (designer controller)\r\n   * Example: http://server.url:51528/api/designer\r\n   */\r\n  @Input() requestUrl: string;\r\n\r\n  /**\r\n   * The width of Designer\r\n   */\r\n  @Input() width: string;\r\n\r\n  /**\r\n   * The height of Designer\r\n   */\r\n  @Input() height: string;\r\n\r\n  @Input() postParametersFunction: any;\r\n\r\n  id = 'aDesigner' + (Math.random() * 10000000).toString();\r\n  designer: any;\r\n  chartScripts: any;\r\n  scriptLoading = false;\r\n\r\n  private loaded = false;\r\n\r\n  constructor(private proxy: ProxyService, private httpClient: HttpClient) { }\r\n  ngOnDestroy(): void {\r\n    if (this.chartScripts) {\r\n      this.head.removeChild(this.chartScripts);\r\n    }\r\n\r\n    let options = this.designerEl.nativeElement?.firstChild?.jsObject?.options;\r\n    try {\r\n      clearTimeout(options.timerAjax);\r\n    } catch { }\r\n\r\n    try {\r\n      clearTimeout(options.timerUpdateCache);\r\n    } catch { }\r\n\r\n    try {\r\n      clearTimeout(options.timerAutoSave);\r\n    } catch { }\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.addScript();\r\n  }\r\n\r\n  ngOnChanges(changes: import('@angular/core').SimpleChanges): void {\r\n    this.addScript();\r\n  }\r\n\r\n  addScript() {\r\n    if (this.scriptLoading) return;\r\n    this.scriptLoading = true;\r\n\r\n    if (this.chartScripts) {\r\n      this.head.removeChild(this.chartScripts);\r\n    }\r\n    this.chartScripts = document.createElement('Script') as HTMLScriptElement;\r\n    this.chartScripts.setAttribute('type', 'text/javascript');\r\n    this.head.appendChild(this.chartScripts);\r\n\r\n    let observable = this.httpClient.get(this.requestUrl, { responseType: 'text' }).pipe(\r\n      catchError((error: HttpErrorResponse) => {\r\n        console.log(error);\r\n        this.scriptLoading = false;\r\n        return EMPTY;\r\n      }));\r\n\r\n    observable.subscribe(data => {\r\n      if (!this.loaded) {\r\n        try {\r\n          this.chartScripts.innerHTML = data;\r\n          const options = new Stimulsoft.Designer.StiDesignerOptions();\r\n          this.loaded = true;\r\n          setTimeout(() => {\r\n            this.scriptLoading = false;\r\n          });\r\n          this.showDesigner();\r\n          this.designerLoadedF();\r\n        } catch {\r\n          this.scriptLoading = false;\r\n        }\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  designerLoadedF() {\r\n    let jsObject = this.designerEl.nativeElement?.firstChild?.jsObject;\r\n    if (!jsObject) {\r\n      setTimeout(() => {\r\n        this.designerLoadedF();\r\n      });\r\n      return;\r\n    }\r\n    this.designerLoaded.next(null);\r\n  }\r\n\r\n  showDesigner() {\r\n    const options = new Stimulsoft.Designer.StiDesignerOptions();\r\n    let defaultOptions = Stimulsoft?.Designer?.defaultOptions;\r\n    if (defaultOptions) {\r\n      for (let k in defaultOptions)\r\n        options[k] = defaultOptions[k];\r\n\r\n      options.useAliasesDictionary = defaultOptions.dictionary.useAliases;\r\n    }\r\n\r\n    if (this.width) {\r\n      options.width = this.width;\r\n    }\r\n    if (this.height) {\r\n      options.height = this.height;\r\n    }\r\n\r\n    this.designer = new Stimulsoft.Designer.StiDesigner(options, 'StiDesigner', false);\r\n\r\n    this.proxy.postParametersFunction_ = this.postParametersFunction;\r\n    this.designerEl.nativeElement.proxy = this.proxy;\r\n\r\n    this.designer.renderHtml(this.designerEl.nativeElement);\r\n  }\r\n\r\n  public get head(): HTMLHeadElement {\r\n    return document.getElementsByTagName('head')[0];\r\n  }\r\n\r\n}\r\n"]}