12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- module.exports = function(RED) {
- var ui = require('../ui')(RED);
-
- function SliderNode(config) {
- RED.nodes.createNode(this, config);
- this.pt = config.passthru;
- this.state = [" "," "];
- var node = this;
- node.status({});
-
- 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: config.passthru,
- control: {
- type: 'slider',
- label: config.label,
- tooltip: config.tooltip,
- order: config.order,
- value: config.min,
- min: Math.min(config.min, config.max),
- max: Math.max(config.max, config.min),
- invert: (parseFloat(config.min) > parseFloat(config.max)) ? true : undefined,
- step: Math.abs(config.step) || 1,
- outs: config.outs || "all",
- width: config.width || group.config.width || 6,
- height: config.height || 1,
- 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; }
- if (node.pt) {
- node.status({shape:"dot",fill:"grey",text:msg.payload});
- }
- else {
- node.state[1] = msg.payload;
- node.status({shape:"dot",fill:"grey",text:node.state[1] + " | " + node.state[1]});
- }
- },
- convert: ui.toFloat.bind(this, config)
- });
- if (!node.pt) {
- node.on("input", function(msg) {
- node.state[0] = msg.payload;
- node.status({shape:"dot",fill:"grey",text:node.state[0] + " | " + node.state[1]});
- });
- }
- else if (node._wireCount === 0) {
- node.on("input", function(msg) {
- node.status({shape:"dot",fill:"grey",text:msg.payload});
- });
- }
- node.on("close", done);
- }
- RED.nodes.registerType("ui_slider", SliderNode);
- };
|