@selenite/graph-editor
Version:
A graph editor for visual programming, based on rete and svelte.
44 lines (43 loc) • 2.08 kB
JavaScript
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
import { ButtonControl, Socket } from '../../socket';
import { formatXml } from '../../../utils';
import { Node, path, registerNode } from '../Node.svelte';
import { download } from '@selenite/commons';
import { XMLData } from '../XML';
let DownloadNode = class DownloadNode extends Node {
constructor(params = {}) {
super({ label: 'Download', ...params });
this.addInData('name', { type: 'string', alwaysShowLabel: true, initial: 'problem.xml' });
this.addInExec();
this.addOutExec();
this.addInData('data', { alwaysShowLabel: true });
this.addControl('downloadBtn', new ButtonControl({ label: 'Download', onClick: () => this.download(), placeInHeader: true }));
}
async download() {
const inputs = await this.fetchInputs();
let data = this.getData('data', inputs);
if (data instanceof XMLData) {
data = formatXml({ xml: data.toXml() });
}
const name = this.getData('name', inputs);
download(name, data);
}
async execute(input, forward, forwardExec) {
await this.download();
super.execute(input, forward, true);
}
};
DownloadNode = __decorate([
registerNode('io.Download'),
path('I/O'),
__metadata("design:paramtypes", [Object])
], DownloadNode);
export { DownloadNode };