UNPKG

sequential-workflow-designer-angular

Version:

Angular wrapper for Sequential Workflow Designer component.

268 lines 36.5 kB
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core'; import { Designer } from 'sequential-workflow-designer'; import * as i0 from "@angular/core"; export class DesignerComponent { constructor(ngZone, applicationRef) { this.ngZone = ngZone; this.applicationRef = applicationRef; this.onReady = new EventEmitter(); this.onDefinitionChanged = new EventEmitter(); this.onSelectedStepIdChanged = new EventEmitter(); this.onIsToolboxCollapsedChanged = new EventEmitter(); this.onIsEditorCollapsedChanged = new EventEmitter(); this.rootEditorProvider = (definition, context, isReadonly) => { if (!this.rootEditor) { throw new Error('Input "rootEditor" is not set'); } if (typeof this.rootEditor === 'function') { return this.rootEditor(definition, context, isReadonly); } return this.editorProvider(this.rootEditor, { definition, context, isReadonly }); }; this.stepEditorProvider = (step, context, definition, isReadonly) => { if (!this.stepEditor) { throw new Error('Input "stepEditor" is not set'); } if (typeof this.stepEditor === 'function') { return this.stepEditor(step, context, definition, isReadonly); } return this.editorProvider(this.stepEditor, { step, context, definition, isReadonly }); }; } ngAfterViewInit() { this.attach(); } ngOnChanges(changes) { const isFirstChange = Object.keys(changes).every(key => changes[key].firstChange); if (isFirstChange) { return; } if (this.designer) { const isSameDefinition = !changes['definition'] || changes['definition'].currentValue === this.designer.getDefinition(); if (isSameDefinition) { const isReadonlyChange = changes['isReadonly']; if (isReadonlyChange && isReadonlyChange.currentValue !== this.designer.isReadonly()) { this.designer.setIsReadonly(isReadonlyChange.currentValue); } const selectedStepIdChange = changes['selectedStepId']; if (selectedStepIdChange && selectedStepIdChange.currentValue !== this.designer.getSelectedStepId()) { if (selectedStepIdChange.currentValue) { this.designer.selectStepById(selectedStepIdChange.currentValue); } else { this.designer.clearSelectedStep(); } } const isToolboxCollapsedChange = changes['isToolboxCollapsed']; if (isToolboxCollapsedChange && isToolboxCollapsedChange.currentValue !== this.designer.isToolboxCollapsed()) { this.designer.setIsToolboxCollapsed(isToolboxCollapsedChange.currentValue); } const isEditorCollapsedChange = changes['isEditorCollapsed']; if (isEditorCollapsedChange && isEditorCollapsedChange.currentValue !== this.designer.isEditorCollapsed()) { this.designer.setIsEditorCollapsed(isEditorCollapsedChange.currentValue); } // The same reference of the definition = no change. return; } } this.attach(); } ngOnDestroy() { if (this.lastEmbeddedView) { this.applicationRef.detachView(this.lastEmbeddedView); this.lastEmbeddedView.destroy(); } } attach() { this.ngZone.runOutsideAngular(() => { if (!this.placeholder) { return; } if (!this.definition) { throw new Error('Input "definition" is not set'); } if (!this.stepsConfiguration) { throw new Error('Input "stepsConfiguration" is not set'); } if (this.toolboxConfiguration === undefined) { throw new Error('Input "toolboxConfiguration" is not set'); } if (this.controlBar === undefined) { throw new Error('Input "controlBar" is not set'); } if (this.designer) { this.designer.destroy(); this.designer = undefined; } let customActionHandler = this.customActionHandler; if (customActionHandler) { const cah = customActionHandler; customActionHandler = (action, step, sequence, context) => { this.ngZone.run(() => cah(action, step, sequence, context)); }; } const designer = Designer.create(this.placeholder.nativeElement, this.definition, { theme: this.theme, undoStackSize: this.undoStackSize, editors: this.areEditorsHidden ? false : { isCollapsed: this.isEditorCollapsed, rootEditorProvider: this.rootEditorProvider, stepEditorProvider: this.stepEditorProvider }, steps: this.stepsConfiguration, validator: this.validatorConfiguration, placeholder: this.placeholderConfiguration, toolbox: this.toolboxConfiguration ? { isCollapsed: this.isToolboxCollapsed, ...this.toolboxConfiguration } : false, controlBar: this.controlBar, contextMenu: this.contextMenu, keyboard: this.keyboard, preferenceStorage: this.preferenceStorage, extensions: this.extensions, isReadonly: this.isReadonly, i18n: this.i18n, uidGenerator: this.uidGenerator, customActionHandler }); designer.onReady.subscribe(() => { this.ngZone.run(() => this.onReady.emit(designer)); }); designer.onDefinitionChanged.subscribe(definition => { this.ngZone.run(() => this.onDefinitionChanged.emit(definition)); }); designer.onSelectedStepIdChanged.subscribe(stepId => { this.ngZone.run(() => this.onSelectedStepIdChanged.emit(stepId)); }); designer.onIsToolboxCollapsedChanged.subscribe(isCollapsed => { this.ngZone.run(() => this.onIsToolboxCollapsedChanged.emit(isCollapsed)); }); designer.onIsEditorCollapsedChanged.subscribe(isCollapsed => { this.ngZone.run(() => this.onIsEditorCollapsedChanged.emit(isCollapsed)); }); this.designer = designer; if (this.selectedStepId) { this.designer.selectStepById(this.selectedStepId); } }); } editorProvider(templateRef, editor) { return this.ngZone.run(() => { if (this.lastEmbeddedView) { this.applicationRef.detachView(this.lastEmbeddedView); this.lastEmbeddedView.destroy(); this.lastEmbeddedView = undefined; } this.lastEmbeddedView = templateRef.createEmbeddedView({ $implicit: editor }); this.applicationRef.attachView(this.lastEmbeddedView); const container = document.createElement('div'); container.className = 'sqd-editor-angular'; for (const node of this.lastEmbeddedView.rootNodes) { container.appendChild(node); } return container; }); } } DesignerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: DesignerComponent, deps: [{ token: i0.NgZone }, { token: i0.ApplicationRef }], target: i0.ɵɵFactoryTarget.Component }); DesignerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: DesignerComponent, selector: "sqd-designer", inputs: { theme: "theme", undoStackSize: "undoStackSize", definition: "definition", stepsConfiguration: "stepsConfiguration", validatorConfiguration: "validatorConfiguration", placeholderConfiguration: "placeholderConfiguration", toolboxConfiguration: "toolboxConfiguration", controlBar: "controlBar", contextMenu: "contextMenu", keyboard: "keyboard", preferenceStorage: "preferenceStorage", extensions: "extensions", i18n: "i18n", customActionHandler: "customActionHandler", isReadonly: "isReadonly", selectedStepId: "selectedStepId", uidGenerator: "uidGenerator", isToolboxCollapsed: "isToolboxCollapsed", isEditorCollapsed: "isEditorCollapsed", areEditorsHidden: "areEditorsHidden", rootEditor: "rootEditor", stepEditor: "stepEditor" }, outputs: { onReady: "onReady", onDefinitionChanged: "onDefinitionChanged", onSelectedStepIdChanged: "onSelectedStepIdChanged", onIsToolboxCollapsedChanged: "onIsToolboxCollapsedChanged", onIsEditorCollapsedChanged: "onIsEditorCollapsedChanged" }, viewQueries: [{ propertyName: "placeholder", first: true, predicate: ["placeholder"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div #placeholder class=\"sqd-designer-angular\"></div>\n" }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: DesignerComponent, decorators: [{ type: Component, args: [{ selector: 'sqd-designer', template: "<div #placeholder class=\"sqd-designer-angular\"></div>\n" }] }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ApplicationRef }]; }, propDecorators: { placeholder: [{ type: ViewChild, args: ['placeholder', { static: true }] }], theme: [{ type: Input, args: ['theme'] }], undoStackSize: [{ type: Input, args: ['undoStackSize'] }], definition: [{ type: Input, args: ['definition'] }], stepsConfiguration: [{ type: Input, args: ['stepsConfiguration'] }], validatorConfiguration: [{ type: Input, args: ['validatorConfiguration'] }], placeholderConfiguration: [{ type: Input, args: ['placeholderConfiguration'] }], toolboxConfiguration: [{ type: Input, args: ['toolboxConfiguration'] }], controlBar: [{ type: Input, args: ['controlBar'] }], contextMenu: [{ type: Input, args: ['contextMenu'] }], keyboard: [{ type: Input, args: ['keyboard'] }], preferenceStorage: [{ type: Input, args: ['preferenceStorage'] }], extensions: [{ type: Input, args: ['extensions'] }], i18n: [{ type: Input, args: ['i18n'] }], customActionHandler: [{ type: Input, args: ['customActionHandler'] }], isReadonly: [{ type: Input, args: ['isReadonly'] }], selectedStepId: [{ type: Input, args: ['selectedStepId'] }], uidGenerator: [{ type: Input, args: ['uidGenerator'] }], isToolboxCollapsed: [{ type: Input, args: ['isToolboxCollapsed'] }], isEditorCollapsed: [{ type: Input, args: ['isEditorCollapsed'] }], areEditorsHidden: [{ type: Input, args: ['areEditorsHidden'] }], rootEditor: [{ type: Input, args: ['rootEditor'] }], stepEditor: [{ type: Input, args: ['stepEditor'] }], onReady: [{ type: Output }], onDefinitionChanged: [{ type: Output }], onSelectedStepIdChanged: [{ type: Output }], onIsToolboxCollapsedChanged: [{ type: Output }], onIsEditorCollapsedChanged: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer.component.js","sourceRoot":"","sources":["../../designer/src/designer.component.ts","../../designer/src/designer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n\tAfterViewInit,\n\tApplicationRef,\n\tComponent,\n\tElementRef,\n\tEmbeddedViewRef,\n\tEventEmitter,\n\tInput,\n\tNgZone,\n\tOnChanges,\n\tOnDestroy,\n\tOutput,\n\tSimpleChanges,\n\tTemplateRef,\n\tViewChild\n} from '@angular/core';\nimport {\n\tCustomActionHandler,\n\tDefinition,\n\tDesigner,\n\tDesignerExtension,\n\tRootEditorContext,\n\tRootEditorProvider,\n\tKeyboardConfiguration,\n\tStep,\n\tStepEditorContext,\n\tStepEditorProvider,\n\tStepsConfiguration,\n\tToolboxConfiguration,\n\tUidGenerator,\n\tValidatorConfiguration,\n\tPlaceholderConfiguration,\n\tI18n,\n\tPreferenceStorage\n} from 'sequential-workflow-designer';\n\nexport interface RootEditorWrapper {\n\tdefinition: Definition;\n\tcontext: RootEditorContext;\n\tisReadonly: boolean;\n}\n\nexport interface StepEditorWrapper {\n\tstep: Step;\n\tdefinition: Definition;\n\tcontext: StepEditorContext;\n\tisReadonly: boolean;\n}\n\nexport type AngularToolboxConfiguration = Omit<ToolboxConfiguration, 'isCollapsed'>;\n\n@Component({\n\tselector: 'sqd-designer',\n\ttemplateUrl: './designer.component.html'\n})\nexport class DesignerComponent implements AfterViewInit, OnChanges, OnDestroy {\n\tprivate designer?: Designer;\n\tprivate lastEmbeddedView?: EmbeddedViewRef<unknown>;\n\n\t@ViewChild('placeholder', { static: true })\n\tprivate placeholder?: ElementRef<HTMLElement>;\n\n\t@Input('theme')\n\tpublic theme?: string;\n\t@Input('undoStackSize')\n\tpublic undoStackSize?: number;\n\t@Input('definition')\n\tpublic definition?: Definition;\n\t@Input('stepsConfiguration')\n\tpublic stepsConfiguration?: StepsConfiguration;\n\t@Input('validatorConfiguration')\n\tpublic validatorConfiguration?: ValidatorConfiguration;\n\t@Input('placeholderConfiguration')\n\tpublic placeholderConfiguration?: PlaceholderConfiguration;\n\t@Input('toolboxConfiguration')\n\tpublic toolboxConfiguration?: AngularToolboxConfiguration | false;\n\t@Input('controlBar')\n\tpublic controlBar?: boolean;\n\t@Input('contextMenu')\n\tpublic contextMenu?: boolean;\n\t@Input('keyboard')\n\tpublic keyboard?: boolean | KeyboardConfiguration;\n\t@Input('preferenceStorage')\n\tpublic preferenceStorage?: PreferenceStorage;\n\t@Input('extensions')\n\tpublic extensions?: DesignerExtension[];\n\t@Input('i18n')\n\tpublic i18n?: I18n;\n\t@Input('customActionHandler')\n\tpublic customActionHandler?: CustomActionHandler;\n\t@Input('isReadonly')\n\tpublic isReadonly?: boolean;\n\t@Input('selectedStepId')\n\tpublic selectedStepId?: string | null;\n\t@Input('uidGenerator')\n\tpublic uidGenerator?: UidGenerator;\n\t@Input('isToolboxCollapsed')\n\tpublic isToolboxCollapsed?: boolean;\n\t@Input('isEditorCollapsed')\n\tpublic isEditorCollapsed?: boolean;\n\n\t@Input('areEditorsHidden')\n\tpublic areEditorsHidden?: boolean;\n\t@Input('rootEditor')\n\tpublic rootEditor?: TemplateRef<unknown> | RootEditorProvider;\n\t@Input('stepEditor')\n\tpublic stepEditor?: TemplateRef<unknown> | StepEditorProvider;\n\n\t@Output()\n\tpublic readonly onReady = new EventEmitter<Designer>();\n\t@Output()\n\tpublic readonly onDefinitionChanged = new EventEmitter<Definition>();\n\t@Output()\n\tpublic readonly onSelectedStepIdChanged = new EventEmitter<string | null>();\n\t@Output()\n\tpublic readonly onIsToolboxCollapsedChanged = new EventEmitter<boolean>();\n\t@Output()\n\tpublic readonly onIsEditorCollapsedChanged = new EventEmitter<boolean>();\n\n\tpublic constructor(\n\t\tprivate readonly ngZone: NgZone,\n\t\tprivate readonly applicationRef: ApplicationRef\n\t) {}\n\n\tpublic ngAfterViewInit() {\n\t\tthis.attach();\n\t}\n\n\tpublic ngOnChanges(changes: SimpleChanges) {\n\t\tconst isFirstChange = Object.keys(changes).every(key => changes[key].firstChange);\n\t\tif (isFirstChange) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (this.designer) {\n\t\t\tconst isSameDefinition = !changes['definition'] || changes['definition'].currentValue === this.designer.getDefinition();\n\t\t\tif (isSameDefinition) {\n\t\t\t\tconst isReadonlyChange = changes['isReadonly'];\n\t\t\t\tif (isReadonlyChange && isReadonlyChange.currentValue !== this.designer.isReadonly()) {\n\t\t\t\t\tthis.designer.setIsReadonly(isReadonlyChange.currentValue);\n\t\t\t\t}\n\n\t\t\t\tconst selectedStepIdChange = changes['selectedStepId'];\n\t\t\t\tif (selectedStepIdChange && selectedStepIdChange.currentValue !== this.designer.getSelectedStepId()) {\n\t\t\t\t\tif (selectedStepIdChange.currentValue) {\n\t\t\t\t\t\tthis.designer.selectStepById(selectedStepIdChange.currentValue);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.designer.clearSelectedStep();\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst isToolboxCollapsedChange = changes['isToolboxCollapsed'];\n\t\t\t\tif (isToolboxCollapsedChange && isToolboxCollapsedChange.currentValue !== this.designer.isToolboxCollapsed()) {\n\t\t\t\t\tthis.designer.setIsToolboxCollapsed(isToolboxCollapsedChange.currentValue);\n\t\t\t\t}\n\n\t\t\t\tconst isEditorCollapsedChange = changes['isEditorCollapsed'];\n\t\t\t\tif (isEditorCollapsedChange && isEditorCollapsedChange.currentValue !== this.designer.isEditorCollapsed()) {\n\t\t\t\t\tthis.designer.setIsEditorCollapsed(isEditorCollapsedChange.currentValue);\n\t\t\t\t}\n\n\t\t\t\t// The same reference of the definition = no change.\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tthis.attach();\n\t}\n\n\tpublic ngOnDestroy(): void {\n\t\tif (this.lastEmbeddedView) {\n\t\t\tthis.applicationRef.detachView(this.lastEmbeddedView);\n\t\t\tthis.lastEmbeddedView.destroy();\n\t\t}\n\t}\n\n\tprivate attach() {\n\t\tthis.ngZone.runOutsideAngular(() => {\n\t\t\tif (!this.placeholder) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (!this.definition) {\n\t\t\t\tthrow new Error('Input \"definition\" is not set');\n\t\t\t}\n\t\t\tif (!this.stepsConfiguration) {\n\t\t\t\tthrow new Error('Input \"stepsConfiguration\" is not set');\n\t\t\t}\n\t\t\tif (this.toolboxConfiguration === undefined) {\n\t\t\t\tthrow new Error('Input \"toolboxConfiguration\" is not set');\n\t\t\t}\n\t\t\tif (this.controlBar === undefined) {\n\t\t\t\tthrow new Error('Input \"controlBar\" is not set');\n\t\t\t}\n\n\t\t\tif (this.designer) {\n\t\t\t\tthis.designer.destroy();\n\t\t\t\tthis.designer = undefined;\n\t\t\t}\n\n\t\t\tlet customActionHandler = this.customActionHandler;\n\t\t\tif (customActionHandler) {\n\t\t\t\tconst cah = customActionHandler;\n\t\t\t\tcustomActionHandler = (action, step, sequence, context) => {\n\t\t\t\t\tthis.ngZone.run(() => cah(action, step, sequence, context));\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tconst designer = Designer.create(this.placeholder.nativeElement, this.definition, {\n\t\t\t\ttheme: this.theme,\n\t\t\t\tundoStackSize: this.undoStackSize,\n\t\t\t\teditors: this.areEditorsHidden\n\t\t\t\t\t? false\n\t\t\t\t\t: {\n\t\t\t\t\t\t\tisCollapsed: this.isEditorCollapsed,\n\t\t\t\t\t\t\trootEditorProvider: this.rootEditorProvider,\n\t\t\t\t\t\t\tstepEditorProvider: this.stepEditorProvider\n\t\t\t\t\t\t},\n\t\t\t\tsteps: this.stepsConfiguration,\n\t\t\t\tvalidator: this.validatorConfiguration,\n\t\t\t\tplaceholder: this.placeholderConfiguration,\n\t\t\t\ttoolbox: this.toolboxConfiguration\n\t\t\t\t\t? {\n\t\t\t\t\t\t\tisCollapsed: this.isToolboxCollapsed,\n\t\t\t\t\t\t\t...this.toolboxConfiguration\n\t\t\t\t\t\t}\n\t\t\t\t\t: false,\n\t\t\t\tcontrolBar: this.controlBar,\n\t\t\t\tcontextMenu: this.contextMenu,\n\t\t\t\tkeyboard: this.keyboard,\n\t\t\t\tpreferenceStorage: this.preferenceStorage,\n\t\t\t\textensions: this.extensions,\n\t\t\t\tisReadonly: this.isReadonly,\n\t\t\t\ti18n: this.i18n,\n\t\t\t\tuidGenerator: this.uidGenerator,\n\t\t\t\tcustomActionHandler\n\t\t\t});\n\t\t\tdesigner.onReady.subscribe(() => {\n\t\t\t\tthis.ngZone.run(() => this.onReady.emit(designer));\n\t\t\t});\n\t\t\tdesigner.onDefinitionChanged.subscribe(definition => {\n\t\t\t\tthis.ngZone.run(() => this.onDefinitionChanged.emit(definition));\n\t\t\t});\n\t\t\tdesigner.onSelectedStepIdChanged.subscribe(stepId => {\n\t\t\t\tthis.ngZone.run(() => this.onSelectedStepIdChanged.emit(stepId));\n\t\t\t});\n\t\t\tdesigner.onIsToolboxCollapsedChanged.subscribe(isCollapsed => {\n\t\t\t\tthis.ngZone.run(() => this.onIsToolboxCollapsedChanged.emit(isCollapsed));\n\t\t\t});\n\t\t\tdesigner.onIsEditorCollapsedChanged.subscribe(isCollapsed => {\n\t\t\t\tthis.ngZone.run(() => this.onIsEditorCollapsedChanged.emit(isCollapsed));\n\t\t\t});\n\t\t\tthis.designer = designer;\n\n\t\t\tif (this.selectedStepId) {\n\t\t\t\tthis.designer.selectStepById(this.selectedStepId);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate readonly rootEditorProvider = (definition: Definition, context: RootEditorContext, isReadonly: boolean) => {\n\t\tif (!this.rootEditor) {\n\t\t\tthrow new Error('Input \"rootEditor\" is not set');\n\t\t}\n\t\tif (typeof this.rootEditor === 'function') {\n\t\t\treturn this.rootEditor(definition, context, isReadonly);\n\t\t}\n\t\treturn this.editorProvider<RootEditorWrapper>(this.rootEditor, {\n\t\t\tdefinition,\n\t\t\tcontext,\n\t\t\tisReadonly\n\t\t});\n\t};\n\n\tprivate readonly stepEditorProvider = (step: Step, context: StepEditorContext, definition: Definition, isReadonly: boolean) => {\n\t\tif (!this.stepEditor) {\n\t\t\tthrow new Error('Input \"stepEditor\" is not set');\n\t\t}\n\t\tif (typeof this.stepEditor === 'function') {\n\t\t\treturn this.stepEditor(step, context, definition, isReadonly);\n\t\t}\n\t\treturn this.editorProvider<StepEditorWrapper>(this.stepEditor, {\n\t\t\tstep,\n\t\t\tcontext,\n\t\t\tdefinition,\n\t\t\tisReadonly\n\t\t});\n\t};\n\n\tprivate editorProvider<E>(templateRef: TemplateRef<unknown>, editor: E) {\n\t\treturn this.ngZone.run(() => {\n\t\t\tif (this.lastEmbeddedView) {\n\t\t\t\tthis.applicationRef.detachView(this.lastEmbeddedView);\n\t\t\t\tthis.lastEmbeddedView.destroy();\n\t\t\t\tthis.lastEmbeddedView = undefined;\n\t\t\t}\n\n\t\t\tthis.lastEmbeddedView = templateRef.createEmbeddedView({\n\t\t\t\t$implicit: editor\n\t\t\t});\n\t\t\tthis.applicationRef.attachView(this.lastEmbeddedView);\n\n\t\t\tconst container = document.createElement('div');\n\t\t\tcontainer.className = 'sqd-editor-angular';\n\t\t\tfor (const node of this.lastEmbeddedView.rootNodes) {\n\t\t\t\tcontainer.appendChild(node);\n\t\t\t}\n\t\t\treturn container;\n\t\t});\n\t}\n}\n","<div #placeholder class=\"sqd-designer-angular\"></div>\n"]}