@mescius/activereportsjs-angular
Version:
ActiveReportsJS components for Angular
253 lines • 29.4 kB
JavaScript
import { Component, ViewChild, Input, Output, EventEmitter, } from '@angular/core';
import { ReportDesigner as DesignerNS } from '@mescius/activereportsjs';
import * as i0 from "@angular/core";
export { ColorThemes } from '@mescius/activereportsjs/reportdesigner';
function isReportDef(report) {
return !!(report && report.definition);
}
function hasReportChanged(curr, prev) {
const definitionChanged = (isReportDef(curr) && curr.definition) !== (isReportDef(curr) && curr.definition);
return (definitionChanged || (curr && curr.id) !== (prev && prev.id) || (curr && curr.displayName) !== (prev && prev.displayName));
}
export class DesignerComponent {
constructor() {
/** Sets componets width */
this.width = '100%';
/** Sets componets height */
this.height = '100%';
this._actionHandlers = {};
this._disposables = [];
/** documentChanged event. */
this.documentChanged = new EventEmitter();
}
/**
* Sets DataSource templates
* @param value List of DataSource templates
*/
set dataSources(value) {
this._dataSources = value;
if (this._designer)
this._designer.setDataSourceTemplates(this._dataSources || []);
}
/* Gets DataSource templates */
get dataSources() {
return this._dataSources;
}
/**
* Sets handler to be called on open report.
* Handler return Promise with report info or 'undefined' if operation was cancelled.
*/
set onCreate(value) {
this._actionHandlers.onCreate = value;
if (this._designer)
this._designer.setActionHandlers(this._actionHandlers);
}
get onCreate() {
return this._actionHandlers.onCreate;
}
/**
* Sets handler to be called on opening report.
* Handler returns Promise with report info or 'undefined' if operation was cancelled.
*/
set onOpen(value) {
this._actionHandlers.onOpen = value;
if (this._designer)
this._designer.setActionHandlers(this._actionHandlers);
}
get onOpen() {
return this._actionHandlers.onOpen;
}
/**
* Sets handler to be called on request to render current report.
*/
set onRender(value) {
this._actionHandlers.onRender = value;
if (this._designer)
this._designer.setActionHandlers(this._actionHandlers);
}
get onRender() {
return this._actionHandlers.onRender;
}
/**
* Sets handler to be called on saving report.
* Handler returns Promise with new report info if report was saved or 'undefined' if operation was cancelled.
*/
set onSave(value) {
this._actionHandlers.onSave = value;
if (this._designer)
this._designer.setActionHandlers(this._actionHandlers);
}
get onSave() {
return this._actionHandlers.onSave;
}
/**
* Sets handler to be called on saving report as new.
* Handler returns Promise with new report info if report was saved or 'undefined' if operation was cancelled.
*/
set onSaveAs(value) {
this._actionHandlers.onSaveAs = value;
if (this._designer)
this._designer.setActionHandlers(this._actionHandlers);
}
get onSaveAs() {
return this._actionHandlers.onSaveAs;
}
/**
* Sets handler to be called on open custom file menu.
*/
set onOpenFileMenu(value) {
this._actionHandlers.onOpenFileMenu = value;
if (this._designer)
this._designer.setActionHandlers(this._actionHandlers);
}
get onOpenFileMenu() {
return this._actionHandlers.onOpenFileMenu;
}
/**
* Watch report property
*/
set report(value) {
if (hasReportChanged(value, this._report)) {
this._report = value;
if (value)
this.setReport(value, 'override');
else {
if (!this._designer)
return;
this._designer.createReport({ reportType: 'CPL' }, 'override');
}
}
}
ngAfterViewInit() {
const config = this.onInit?.();
this._designer = new DesignerNS.Designer(this.rootElement.nativeElement, config);
this._designer.setResourceProvider({
getImagesList: async () => this.imageList || [],
getReportsList: async () => this.reportList || [],
getMasterReportList: async () => this.masterReportList || [],
getThemesList: async () => this.themeList || [],
});
this._designer.setActionHandlers(this._actionHandlers);
if (this.dataSources)
this._designer.setDataSourceTemplates(this._dataSources || []);
if (this._report)
this.setReport(this._report, 'override');
this._disposables.push(this._designer.documentChanged.register(args => this.documentChanged.emit(args)));
}
/**
* Sets report.
* @param report Report info to load.
* @param whenDirty Action to perform in case of 'dirty' report.
* @param isDirtyInitial Initial value for 'dirty' state after load.
*/
setReport(report, whenDirty, isDirtyInitial) {
if (!this._designer)
return Promise.resolve();
return this._designer.setReport(report, whenDirty, isDirtyInitial);
}
/** Gets current report. */
getReport() {
if (!this._designer)
return Promise.resolve();
return this._designer.getReport();
}
/**
* Creates report.
* @param reportInfo Report info to load.
* @param whenDirty Action to perform in case of 'dirty' report.
*/
createReport(reportInfo, whenDirty) {
if (!this._designer)
return Promise.resolve();
return this._designer.createReport(reportInfo, whenDirty);
}
/**
* Process command.
* @param cmd Command name.
*/
processCommand(cmd) {
if (!this._designer)
return Promise.resolve();
return this._designer.processCommand(cmd);
}
/**
* Returns focus to Designer.
*/
focus() {
if (this._designer == null)
throw new Error("Designer is not initialized yet");
this._designer.focus();
}
/**
* Gets API to manipulate designer.
*/
getEditorAPI() {
if (this._designer == null)
throw new Error("Designer is not initialized yet");
return this._designer.getEditorAPI();
}
/*
* Access to the menu and sidebar panels
*/
getPanelsAPI() {
if (this._designer == null)
throw new Error("Designer is not initialized yet");
return this._designer.getPanelsAPI();
}
/*
* Manipulate notifications panel.
*/
getNotificationsAPI() {
if (this._designer == null)
throw new Error("Designer is not initialized yet");
return this._designer.getNotificationsAPI();
}
ngOnDestroy() {
while (this._disposables.length) {
this._disposables.shift()();
}
// this._designer.dispose();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DesignerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DesignerComponent, selector: "gc-activereports-designer", inputs: { width: "width", height: "height", onInit: "onInit", dataSources: "dataSources", reportList: "reportList", masterReportList: "masterReportList", imageList: "imageList", themeList: "themeList", onCreate: "onCreate", onOpen: "onOpen", onRender: "onRender", onSave: "onSave", onSaveAs: "onSaveAs", onOpenFileMenu: "onOpenFileMenu", report: "report" }, outputs: { documentChanged: "documentChanged" }, viewQueries: [{ propertyName: "rootElement", first: true, predicate: ["designerRoot"], descendants: true }], ngImport: i0, template: "<div #designerRoot [style.width]=\"width\" [style.height]=\"height\"></div>\n", styles: [""] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DesignerComponent, decorators: [{
type: Component,
args: [{ selector: 'gc-activereports-designer', template: "<div #designerRoot [style.width]=\"width\" [style.height]=\"height\"></div>\n" }]
}], ctorParameters: function () { return []; }, propDecorators: { rootElement: [{
type: ViewChild,
args: ['designerRoot', { static: false }]
}], width: [{
type: Input
}], height: [{
type: Input
}], onInit: [{
type: Input
}], dataSources: [{
type: Input
}], reportList: [{
type: Input
}], masterReportList: [{
type: Input
}], imageList: [{
type: Input
}], themeList: [{
type: Input
}], onCreate: [{
type: Input
}], onOpen: [{
type: Input
}], onRender: [{
type: Input
}], onSave: [{
type: Input
}], onSaveAs: [{
type: Input
}], onOpenFileMenu: [{
type: Input
}], report: [{
type: Input
}], documentChanged: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer.component.js","sourceRoot":"","sources":["../../../../../projects/activereports/src/lib/designer/designer.component.ts","../../../../../projects/activereports/src/lib/designer/designer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  AfterViewInit,\n  ViewChild,\n  ElementRef,\n  Input,\n  Output,\n  EventEmitter,\n  OnDestroy,\n} from '@angular/core';\n\nimport { ReportDesigner as DesignerNS } from '@grapecity/activereports';\nimport { DocumentChangedEventArgs } from '@grapecity/activereports/reportdesigner';\n\nexport { ColorThemes } from '@grapecity/activereports/reportdesigner';\nexport type { ColorTheme } from '@grapecity/activereports/reportdesigner';\n\nfunction isReportDef(report?: DesignerNS.Report): report is DesignerNS.ReportDefinition {\n  return !!(report && (report as DesignerNS.ReportDefinition).definition);\n}\n\nfunction hasReportChanged(curr: DesignerNS.Report, prev: DesignerNS.Report) {\n  const definitionChanged = (isReportDef(curr) && curr.definition) !== (isReportDef(curr) && curr.definition);\n  return (\n    definitionChanged || (curr && curr.id) !== (prev && prev.id) || (curr && curr.displayName) !== (prev && prev.displayName)\n  );\n}\n\n@Component({\n  selector: 'gc-activereports-designer',\n  templateUrl: './designer.component.html',\n  styleUrls: ['./designer.component.css']\n})\nexport class DesignerComponent implements AfterViewInit, OnDestroy {\n\n  @ViewChild('designerRoot', { static: false }) rootElement: ElementRef;\n\n  private _designer?: DesignerNS.Designer;\n\n  constructor() { }\n\n  /** Sets componets width */\n  @Input() width = '100%';\n  /** Sets componets height */\n  @Input() height = '100%';\n\n  \t/**\n\t * Called before designer initialization.\n\t * @returns DesignerConfig to initialize designer instance.\n\t */\n\t@Input() onInit?: () => DesignerNS.DesignerConfig;\n\n  private _dataSources?: DesignerNS.DataSourceTemplate[];\n\t/**\n\t * Sets DataSource templates\n\t * @param value List of DataSource templates\n\t */\n  @Input() set dataSources(value) {\n    this._dataSources = value;\n    if (this._designer) this._designer.setDataSourceTemplates(this._dataSources || []);\n  }\n\t/* Gets DataSource templates */\n  get dataSources() {\n    return this._dataSources;\n  }\n\n\t/** Sets external report list. */\n  @Input() reportList?: DesignerNS.ReportResourceInfo[];\n  /** Sets external master report list. */\n  @Input() masterReportList?: DesignerNS.ReportResourceInfo[];\n\t/** Sets external image list. */\n  @Input() imageList?: DesignerNS.ImageResourceInfo[];\n\t/** Sets theme list. */\n  @Input() themeList?: DesignerNS.ThemeResourceInfo[];\n\n  private _actionHandlers: DesignerNS.ActionHandlers = {};\n\n\t/**\n\t * Sets handler to be called on open report.\n\t * Handler return Promise with report info or 'undefined' if operation was cancelled.\n\t */\n  @Input() set onCreate(value: DesignerNS.ActionHandlers['onCreate']) {\n    this._actionHandlers.onCreate = value;\n    if (this._designer) this._designer.setActionHandlers(this._actionHandlers);\n  }\n  get onCreate() {\n    return this._actionHandlers.onCreate;\n  }\n\n\t/**\n\t * Sets handler to be called on opening report.\n\t * Handler returns Promise with report info or 'undefined' if operation was cancelled.\n\t */\n  @Input() set onOpen(value: DesignerNS.ActionHandlers['onOpen']) {\n    this._actionHandlers.onOpen = value;\n    if (this._designer) this._designer.setActionHandlers(this._actionHandlers);\n  }\n  get onOpen() {\n    return this._actionHandlers.onOpen;\n  }\n\n\t/**\n\t * Sets handler to be called on request to render current report.\n\t */\n  @Input() set onRender(value: DesignerNS.ActionHandlers['onRender']) {\n    this._actionHandlers.onRender = value;\n    if (this._designer) this._designer.setActionHandlers(this._actionHandlers);\n  }\n  get onRender() {\n    return this._actionHandlers.onRender;\n  }\n\n\t/**\n\t * Sets handler to be called on saving report.\n\t * Handler returns Promise with new report info if report was saved or 'undefined' if operation was cancelled.\n\t */\n  @Input() set onSave(value: DesignerNS.ActionHandlers['onSave']) {\n    this._actionHandlers.onSave = value;\n    if (this._designer) this._designer.setActionHandlers(this._actionHandlers);\n  }\n  get onSave() {\n    return this._actionHandlers.onSave;\n  }\n\n\t/**\n\t * Sets handler to be called on saving report as new.\n\t * Handler returns Promise with new report info if report was saved or 'undefined' if operation was cancelled.\n\t */\n  @Input() set onSaveAs(value: DesignerNS.ActionHandlers['onSaveAs']) {\n    this._actionHandlers.onSaveAs = value;\n    if (this._designer) this._designer.setActionHandlers(this._actionHandlers);\n  }\n  get onSaveAs() {\n    return this._actionHandlers.onSaveAs;\n  }\n\n\t/**\n\t * Sets handler to be called on open custom file menu.\n\t */\n  @Input() set onOpenFileMenu(value: DesignerNS.ActionHandlers['onOpenFileMenu']) {\n    this._actionHandlers.onOpenFileMenu = value;\n    if (this._designer) this._designer.setActionHandlers(this._actionHandlers);\n  }\n  get onOpenFileMenu() {\n    return this._actionHandlers.onOpenFileMenu;\n  }\n\n  private _report: DesignerNS.Report;\n\n  private _disposables: Array<() => void> = [];\n\n  /**\n   * Watch report property\n  */\n  @Input() set report(value: DesignerNS.Report) {\n    if (hasReportChanged(value, this._report)) {\n      this._report = value;\n      if (value) this.setReport(value , 'override');\n      else {\n        if (!this._designer) return;\n        this._designer.createReport({ reportType: 'CPL' }, 'override');\n      }\n    }\n  }\n\n  /** documentChanged event. */\n  @Output() documentChanged = new EventEmitter<DocumentChangedEventArgs>();\n\n  ngAfterViewInit() {\n    const config = this.onInit?.();\n    this._designer = new DesignerNS.Designer(this.rootElement.nativeElement, config);\n    this._designer.setResourceProvider({\n      getImagesList: async () => this.imageList || [],\n      getReportsList: async () => this.reportList || [],\n      getMasterReportList: async () => this.masterReportList || [],\n      getThemesList: async () => this.themeList || [],\n    });\n    this._designer.setActionHandlers(this._actionHandlers);\n    if (this.dataSources) this._designer.setDataSourceTemplates(this._dataSources || []);\n    if (this._report) this.setReport(this._report, 'override');\n\n    this._disposables.push(\n      this._designer.documentChanged.register(args => this.documentChanged.emit(args)),\n    );\n  }\n\n\t/**\n\t * Sets report.\n\t * @param report Report info to load.\n\t * @param whenDirty Action to perform in case of 'dirty' report.\n   * @param isDirtyInitial Initial value for 'dirty' state after load.\n\t */\n  setReport(report: DesignerNS.Report, whenDirty?: DesignerNS.WhenDirty, isDirtyInitial?: boolean): Promise<void> {\n    if (!this._designer) return Promise.resolve();\n\n    return this._designer.setReport(report, whenDirty, isDirtyInitial);\n  }\n\n  /** Gets current report. */\n  getReport(): Promise<DesignerNS.ReportInfo> {\n    if (!this._designer) return Promise.resolve() as any;\n\n    return this._designer.getReport();\n  }\n\n  /**\n    * Creates report.\n    * @param reportInfo Report info to load.\n    * @param whenDirty Action to perform in case of 'dirty' report.\n    */\n  createReport(reportInfo: DesignerNS.NewReportInfo, whenDirty?: DesignerNS.WhenDirty): Promise<void> {\n    if (!this._designer) return Promise.resolve();\n    return this._designer.createReport(reportInfo, whenDirty);\n  }\n\n\t/**\n\t * Process command.\n\t * @param cmd Command name.\n\t */\n  processCommand(cmd: DesignerNS.DesignerCommand) {\n    if (!this._designer) return Promise.resolve();\n\n    return this._designer.processCommand(cmd);\n  }\n\n  /**\n   * Returns focus to Designer.\n   */\n\tfocus() {\n\t\tif(this._designer == null) throw new Error(\"Designer is not initialized yet\");\n\t\tthis._designer.focus();\n\t}\n\n\t/**\n   * Gets API to manipulate designer.\n   */\n  getEditorAPI(): Promise<DesignerNS.EditorAPI> {\n\t\tif(this._designer == null) throw new Error(\"Designer is not initialized yet\");\n\t\treturn this._designer.getEditorAPI();\n\t}\n\n\t/*\n   * Access to the menu and sidebar panels\n   */\n\tgetPanelsAPI(): Promise<DesignerNS.PanelsAPI> {\n\t\tif(this._designer == null) throw new Error(\"Designer is not initialized yet\");\n\t\treturn this._designer.getPanelsAPI();\n\t}\n\n\t/*\n   * Manipulate notifications panel.\n   */\n\tgetNotificationsAPI(): Promise<DesignerNS.NotificationsAPI> {\n\t\tif(this._designer == null) throw new Error(\"Designer is not initialized yet\");\n\t\treturn this._designer.getNotificationsAPI();\n\t}\n\n  ngOnDestroy() {\n    while (this._disposables.length) {\n      this._disposables.shift()!();\n    }\n    // this._designer.dispose();\n  }\n}\n","<div #designerRoot [style.width]=\"width\" [style.height]=\"height\"></div>\n"]}