sequential-workflow-designer-angular
Version:
Angular wrapper for Sequential Workflow Designer component.
274 lines • 37.6 kB
JavaScript
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.onStepUnselectionBlocked = 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.onStepUnselectionBlocked.subscribe(targetStepId => {
this.ngZone.run(() => this.onStepUnselectionBlocked.emit(targetStepId));
});
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", onStepUnselectionBlocked: "onStepUnselectionBlocked", 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
}], onStepUnselectionBlocked: [{
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 onStepUnselectionBlocked = 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.onStepUnselectionBlocked.subscribe(targetStepId => {\n\t\t\t\tthis.ngZone.run(() => this.onStepUnselectionBlocked.emit(targetStepId));\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"]}