mirror of
https://github.com/node-red/node-red-nodes.git
synced 2023-10-10 13:36:58 +02:00
Enable the use of environment variables to define GPIO pin number (#676)
* Enable the use of environment variables to define GPIO pin number * Pin field moved below table. Field width made the same as table. Restored fa-icon and "Pin" label. Closed validation escapes.
This commit is contained in:
parent
46f3dfc382
commit
0b4c1ff977
@ -71,7 +71,6 @@
|
|||||||
|
|
||||||
<div class="form-row" style="min-width: 540px">
|
<div class="form-row" style="min-width: 540px">
|
||||||
<label><i class="fa fa-circle"></i> <span data-i18n="rpi-gpio.pinname"></span></label>
|
<label><i class="fa fa-circle"></i> <span data-i18n="rpi-gpio.pinname"></span></label>
|
||||||
<input type="text" id="node-input-pin" style="display:none;">
|
|
||||||
<div class="rpi-gpio-pinTable">
|
<div class="rpi-gpio-pinTable">
|
||||||
<div class="pinTableBody" id="pinform">
|
<div class="pinTableBody" id="pinform">
|
||||||
<div class="pinTableRow">
|
<div class="pinTableRow">
|
||||||
@ -157,6 +156,10 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-row">
|
||||||
|
<label> </label>
|
||||||
|
<input type="text" id="node-input-pin" style="width: 352px">
|
||||||
|
</div>
|
||||||
<div class="form-row">
|
<div class="form-row">
|
||||||
<label for="node-input-intype"><i class="fa fa-level-up"></i> <span data-i18n="rpi-gpio.label.resistor"></span></label>
|
<label for="node-input-intype"><i class="fa fa-level-up"></i> <span data-i18n="rpi-gpio.label.resistor"></span></label>
|
||||||
<select type="text" id="node-input-intype" style="width:100px;">
|
<select type="text" id="node-input-intype" style="width:100px;">
|
||||||
@ -187,12 +190,29 @@
|
|||||||
"5":"29", "6":"31", "12":"32", "13":"33", "19":"35", "16":"36", "26":"37", "20":"38", "21":"40"
|
"5":"29", "6":"31", "12":"32", "13":"33", "19":"35", "16":"36", "26":"37", "20":"38", "21":"40"
|
||||||
};
|
};
|
||||||
var pinsInUse = {};
|
var pinsInUse = {};
|
||||||
|
var validPinValues = Object.values(bcm2pin);
|
||||||
|
var isEnvVar = function (value) {
|
||||||
|
var re = /^\${([0-9a-zA-Z_]+)}$/;
|
||||||
|
var match = value.match(re);
|
||||||
|
return Boolean(match);
|
||||||
|
};
|
||||||
|
var isInt = function (value) {
|
||||||
|
return parseInt(value).toString() === value.trim();
|
||||||
|
};
|
||||||
|
var uncheckAll = function() {
|
||||||
|
for (var i=0; i< validPinValues.length; i++) {
|
||||||
|
$("#pinform input[value="+validPinValues[i]+"]").prop('checked', false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var validatePin = function (value) {
|
||||||
|
return isEnvVar(value) || (isInt(value) && validPinValues.includes(value));
|
||||||
|
};
|
||||||
RED.nodes.registerType('rpi-gpio in',{
|
RED.nodes.registerType('rpi-gpio in',{
|
||||||
category: 'Raspberry Pi',
|
category: 'Raspberry Pi',
|
||||||
color:"#c6dbef",
|
color:"#c6dbef",
|
||||||
defaults: {
|
defaults: {
|
||||||
name: { value:"" },
|
name: { value:"" },
|
||||||
pin: { value:"tri",required:true,validate:RED.validators.number() },
|
pin: { value:"tri",required:true,validate:validatePin },
|
||||||
intype: { value:"tri" },
|
intype: { value:"tri" },
|
||||||
debounce: { value:"25" },
|
debounce: { value:"25" },
|
||||||
read: { value:false }
|
read: { value:false }
|
||||||
@ -227,11 +247,20 @@
|
|||||||
pinsInUse = data || {};
|
pinsInUse = data || {};
|
||||||
$('#pin-tip').html(pintip + Object.keys(data));
|
$('#pin-tip').html(pintip + Object.keys(data));
|
||||||
});
|
});
|
||||||
$("#node-input-pin").on("change", function() {
|
|
||||||
if ($("#node-input-pin").val()) {
|
for (var i=0; i< validPinValues.length; i++) {
|
||||||
$("#pinform input[value="+$("#node-input-pin").val()+"]").prop('checked', true);
|
$("#pinform input[value="+validPinValues[i]+"]").on("change", function (evt) {
|
||||||
|
$("#node-input-pin").val(evt.currentTarget.value);
|
||||||
|
$("#node-input-pin").removeClass("input-error");
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
$("#node-input-pin").on("change", function() {
|
||||||
var pinnew = $("#node-input-pin").val();
|
var pinnew = $("#node-input-pin").val();
|
||||||
|
if (pinnew && isInt(pinnew) && validPinValues.includes(pinnew)) {
|
||||||
|
$("#pinform input[value="+pinnew+"]").prop('checked', true);
|
||||||
|
} else {
|
||||||
|
uncheckAll();
|
||||||
|
}
|
||||||
if ((pinnew) && (pinnew !== pinnow)) {
|
if ((pinnew) && (pinnew !== pinnow)) {
|
||||||
if (pinsInUse.hasOwnProperty(pinnew)) {
|
if (pinsInUse.hasOwnProperty(pinnew)) {
|
||||||
RED.notify(pinname+" "+pinnew+" "+alreadyuse,"warn");
|
RED.notify(pinname+" "+pinnew+" "+alreadyuse,"warn");
|
||||||
@ -256,7 +285,6 @@
|
|||||||
<script type="text/html" data-template-name="rpi-gpio out">
|
<script type="text/html" data-template-name="rpi-gpio out">
|
||||||
<div class="form-row" style="min-width: 540px">
|
<div class="form-row" style="min-width: 540px">
|
||||||
<label><i class="fa fa-circle"></i> <span data-i18n="rpi-gpio.pinname"></span></label>
|
<label><i class="fa fa-circle"></i> <span data-i18n="rpi-gpio.pinname"></span></label>
|
||||||
<input type="text" id="node-input-pin" style="display:none;">
|
|
||||||
<div class="rpi-gpio-pinTable">
|
<div class="rpi-gpio-pinTable">
|
||||||
<div class="pinTableBody" id="pinform">
|
<div class="pinTableBody" id="pinform">
|
||||||
<div class="pinTableRow">
|
<div class="pinTableRow">
|
||||||
@ -342,6 +370,10 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-row">
|
||||||
|
<label> </label>
|
||||||
|
<input type="text" id="node-input-pin" style="width: 352px">
|
||||||
|
</div>
|
||||||
<div class="form-row" id="node-set-pwm">
|
<div class="form-row" id="node-set-pwm">
|
||||||
<label> <span data-i18n="rpi-gpio.label.type"></span></label>
|
<label> <span data-i18n="rpi-gpio.label.type"></span></label>
|
||||||
<select id="node-input-out" style="width: 250px;">
|
<select id="node-input-out" style="width: 250px;">
|
||||||
@ -381,12 +413,29 @@
|
|||||||
"5":"29", "6":"31", "12":"32", "13":"33", "19":"35", "16":"36", "26":"37", "20":"38", "21":"40"
|
"5":"29", "6":"31", "12":"32", "13":"33", "19":"35", "16":"36", "26":"37", "20":"38", "21":"40"
|
||||||
};
|
};
|
||||||
var pinsInUse = {};
|
var pinsInUse = {};
|
||||||
|
var validPinValues = Object.values(bcm2pin);
|
||||||
|
var isEnvVar = function (value) {
|
||||||
|
var re = /^\${([0-9a-zA-Z_]+)}$/;
|
||||||
|
var match = value.match(re);
|
||||||
|
return Boolean(match);
|
||||||
|
};
|
||||||
|
var isInt = function (value) {
|
||||||
|
return parseInt(value).toString() === value.trim();
|
||||||
|
};
|
||||||
|
var uncheckAll = function() {
|
||||||
|
for (var i=0; i< validPinValues.length; i++) {
|
||||||
|
$("#pinform input[value="+validPinValues[i]+"]").prop('checked', false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var validatePin = function (value) {
|
||||||
|
return isEnvVar(value) || (isInt(value) && validPinValues.includes(value));
|
||||||
|
};
|
||||||
RED.nodes.registerType('rpi-gpio out',{
|
RED.nodes.registerType('rpi-gpio out',{
|
||||||
category: 'Raspberry Pi',
|
category: 'Raspberry Pi',
|
||||||
color:"#c6dbef",
|
color:"#c6dbef",
|
||||||
defaults: {
|
defaults: {
|
||||||
name: { value:"" },
|
name: { value:"" },
|
||||||
pin: { value:"",required:true,validate:RED.validators.number() },
|
pin: { value:"",required:true,validate:validatePin },
|
||||||
set: { value:"" },
|
set: { value:"" },
|
||||||
level: { value:"0" },
|
level: { value:"0" },
|
||||||
freq: {value:""},
|
freq: {value:""},
|
||||||
@ -428,11 +477,19 @@
|
|||||||
$('#pin-tip').html(pintip + Object.keys(data));
|
$('#pin-tip').html(pintip + Object.keys(data));
|
||||||
});
|
});
|
||||||
|
|
||||||
$("#node-input-pin").on("change", function() {
|
for (var i=0; i< validPinValues.length; i++) {
|
||||||
if ($("#node-input-pin").val()) {
|
$("#pinform input[value="+validPinValues[i]+"]").on("change", function (evt) {
|
||||||
$("#pinform input[value="+$("#node-input-pin").val()+"]").prop('checked', true);
|
$("#node-input-pin").val(evt.currentTarget.value);
|
||||||
|
$("#node-input-pin").removeClass("input-error");
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
$("#node-input-pin").on("change", function() {
|
||||||
var pinnew = $("#node-input-pin").val();
|
var pinnew = $("#node-input-pin").val();
|
||||||
|
if (pinnew && isInt(pinnew) && validPinValues.includes(pinnew)) {
|
||||||
|
$("#pinform input[value="+pinnew+"]").prop('checked', true);
|
||||||
|
} else {
|
||||||
|
uncheckAll();
|
||||||
|
}
|
||||||
if ((pinnew) && (pinnew !== pinnow)) {
|
if ((pinnew) && (pinnew !== pinnow)) {
|
||||||
if (pinsInUse.hasOwnProperty(pinnew)) {
|
if (pinsInUse.hasOwnProperty(pinnew)) {
|
||||||
RED.notify(pinname+" "+pinnew+" "+alreadyuse,"warn");
|
RED.notify(pinname+" "+pinnew+" "+alreadyuse,"warn");
|
||||||
|
Loading…
Reference in New Issue
Block a user