12345678910111213141516171819202122232425262728293031323334353637383940414243444546 |
- module.exports = function(RED) {
- var ui = require('../ui')(RED);
-
- function FormNode(config) {
- RED.nodes.createNode(this, config);
- var node = this;
- var group = RED.nodes.getNode(config.group);
- if (!group) { return; }
- var tab = RED.nodes.getNode(group.config.tab);
- if (!tab) { return; }
-
- node.on("input", function(msg) {
- node.topi = msg.topic;
- });
-
- var done = ui.add({
- node: node,
- tab: tab,
- group: group,
- forwardInputMessages: false,
- storeFrontEndInputAsState: false,
- control: {
- type: 'form',
- label: config.label,
- order: config.order,
- value: config.payload || node.id,
- width: config.width || group.config.width || 6,
- height: config.height || config.splitLayout == true ? Math.ceil(config.options.length/2) : config.options.length,
- options: config.options,
- formValue: config.formValue,
- submit: config.submit,
- cancel: config.cancel,
- splitLayout: config.splitLayout || false,
- sy: ui.getSizes().sy,
- cy: ui.getSizes().cy,
- className: config.className || '',
- },
- beforeSend: function (msg) {
- var t = RED.util.evaluateNodeProperty(config.topic,config.topicType || "str",node,msg) || node.topi;
- if (t) { msg.topic = t; }
- }
- });
- node.on("close", done);
- }
- RED.nodes.registerType("ui_form", FormNode);
- };
|