Reply Node(Beta) Added
This commit is contained in:
parent
2fc45ac0ed
commit
33e40fd3ef
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "node-red-contrib-whatsapp-link",
|
"name": "node-red-contrib-whatsapp-link",
|
||||||
"version": "0.1.28",
|
"version": "0.1.28A",
|
||||||
"description": "Node to send and receive whatsapp chats and group messages. | No third party APIs",
|
"description": "Node to send and receive whatsapp chats and group messages. | No third party APIs",
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
@ -25,6 +25,7 @@
|
|||||||
"whatsapp chats-in": "chats-in.js",
|
"whatsapp chats-in": "chats-in.js",
|
||||||
"whatsapp chats-out": "chats-out.js",
|
"whatsapp chats-out": "chats-out.js",
|
||||||
"whatsapp group-out": "group-out.js",
|
"whatsapp group-out": "group-out.js",
|
||||||
|
"whatsapp reply": "reply.js",
|
||||||
"whatsapp Link": "whatsappLink.js"
|
"whatsapp Link": "whatsappLink.js"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|||||||
39
reply.html
Normal file
39
reply.html
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
<script type="text/javascript">
|
||||||
|
RED.nodes.registerType('reply',{
|
||||||
|
category: 'whatsapp',
|
||||||
|
color: '#25D366',
|
||||||
|
defaults: {
|
||||||
|
name: {value:"Reply"},
|
||||||
|
instruction : {value : ""},
|
||||||
|
whatsappLink: {value:"whatsapp-web", type:'whatsappLink'}
|
||||||
|
},
|
||||||
|
inputs:1,
|
||||||
|
icon: 'whatsappLink.svg',
|
||||||
|
label: function() {
|
||||||
|
return this.name||"Reply";
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<script type="text/html" data-template-name="reply">
|
||||||
|
<div class="form-row">
|
||||||
|
<label for="node-input-name"><i class="fa fa-tag"></i> Name</label>
|
||||||
|
<input type="text" id="node-input-name" placeholder="Name">
|
||||||
|
</div>
|
||||||
|
<div class="form-row">
|
||||||
|
<label for="node-input-whatsappLink"><i class="fa fa-gear"></i> Client</label>
|
||||||
|
<input type="text" id="node-input-whatsappLink" placeholder="Name">
|
||||||
|
</div>
|
||||||
|
<div class="form-row">
|
||||||
|
<label for="node-input-instruction"><i class="fa fa-tag"></i> Instruction</label>
|
||||||
|
<input type="text" id="node-input-instruction" placeholder="instruction">
|
||||||
|
</div>
|
||||||
|
<div class="form-tips">
|
||||||
|
<p>Node to reply on message.</p>
|
||||||
|
</div>
|
||||||
|
</script>
|
||||||
|
|
||||||
|
|
||||||
|
<script type="text/markdown" data-help-name="reply">
|
||||||
|
Node to reply on meassage recived.
|
||||||
|
</script>
|
||||||
53
reply.js
Normal file
53
reply.js
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
module.exports = function(RED) {
|
||||||
|
function WhatsappReply(config) {
|
||||||
|
RED.nodes.createNode(this,config);
|
||||||
|
var node = this;
|
||||||
|
node.instruction = config.instruction ;
|
||||||
|
var whatsappLinkNode = RED.nodes.getNode(config.whatsappLink);
|
||||||
|
node.waClient = whatsappLinkNode.client;
|
||||||
|
let instructionPayload = null ;
|
||||||
|
|
||||||
|
function SetStatus(WAStatus, color){
|
||||||
|
node.status({fill:color,shape:"dot",text:WAStatus});
|
||||||
|
};
|
||||||
|
|
||||||
|
node.on('input', (msg)=>{
|
||||||
|
instructionPayload = msg.payload ;
|
||||||
|
});
|
||||||
|
|
||||||
|
node.waClient.on('message_create', async (message) => {
|
||||||
|
if (message.body.startsWith(node.instruction)){
|
||||||
|
if(instructionPayload) {
|
||||||
|
message.reply(instructionPayload)
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
message.react('😅');
|
||||||
|
message.reply('👍');
|
||||||
|
};
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
//whatsapp Status Parameters----
|
||||||
|
node.waClient.on('qr', (qr) => {
|
||||||
|
SetStatus("QR Code Generated", "yellow");
|
||||||
|
});
|
||||||
|
|
||||||
|
node.waClient.on('auth_failure', () => {
|
||||||
|
SetStatus('Not Connected','red');
|
||||||
|
});
|
||||||
|
|
||||||
|
node.waClient.on('loading_screen', () => {
|
||||||
|
SetStatus('Connecting...','yellow');
|
||||||
|
});
|
||||||
|
|
||||||
|
node.waClient.on('ready', () => {
|
||||||
|
SetStatus('Connected','green');
|
||||||
|
});
|
||||||
|
|
||||||
|
node.waClient.on('disconnected', () => {
|
||||||
|
SetStatus("Disconnected","red");
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
RED.nodes.registerType("reply", WhatsappReply);
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user