rete-module-plugin
v0.4.2
Published
Rete module plugin ==== #### Rete.js plugin
Downloads
378
Readme
Rete module plugin
Rete.js plugin
import ModulePlugin from 'rete-module-plugin';
const modules = {
moduleName: { data: defaultData() }
}
editor.use(ModulePlugin, { engine, modules });
class InputNumber extends Component {
constructor() {
super('Input number');
this.module = {
nodeType: 'input',
socket: sockets.num,
// or
socket(node) {
return sockets[node.data.socketType];
}
}
}
builder(node) {
var out = new Output('output', 'Number', sockets.num); // the key must be 'output'
var ctrl = new FieldControl(this.editor, 'name', {value: ''}); // the key must be 'name'
var ctrl2 = new FieldControl(this.editor, 'number', {type: 'number', value: 1});
return node
.addControl(ctrl)
.addControl(ctrl2)
.addOutput(out);
}
async worker(node, inputs, outputs) {
if (!outputs['num'])
outputs['num'] = node.data.number; // here you can modify received outputs of Input node
}
};
export default class ModuleComponent extends Component {
constructor() {
super("Module");
this.module = {
nodeType: 'module'
}
}
builder(node) {
var ctrl = new FieldControl(this.editor, 'module', {value: 'Module name..'}); // the key must be 'module'
ctrl.onChange = () => {
this.updateModuleSockets(node);
node.update();
}
return node.addControl(ctrl);
}
change(node, item) {
node.data.module = item;
this.editor.trigger('process');
}
}
class OutputNumber extends Component {
constructor() {
super('Output number');
this.module = {
nodeType: 'output',
socket: sockets.num,
// or
socket(node) {
return sockets[node.data.socketType];
}
}
}
builder(node) {
var inp = new Input('input', 'Number', sockets.num); // the key must be 'input'
var ctrl = new FieldControl(this.editor, 'name', {value: 'num'}); // the key must be 'name'
return node
.addControl(ctrl)
.addInput(inp);
}
}