UNPKG

node-red-contrib-chatbot

Version:

REDBot a Chat bot for a full featured chat bot for Telegram, Facebook Messenger and Slack. Almost no coding skills required

245 lines (243 loc) 93.6 kB
<script type="text/javascript"> RED.nodes.registerType('chatbot-conversation', { category: 'RedBot', color: '#FFCC66', defaults: { name: { value: '' }, botTelegram: { value: "", type: 'chatbot-telegram-node', required: false }, botTelegramProduction: { value: "", type: 'chatbot-telegram-node', required: false }, botSlack: { value: '', type: 'chatbot-slack-node', required: false }, botSlackProduction: { value: '', type: 'chatbot-slack-node', required: false }, botFacebook: { value: '', type: 'chatbot-facebook-node', required: false }, botFacebookProduction: { value: '', type: 'chatbot-facebook-node', required: false }, botViber: { value: '', type: 'chatbot-viber-node', required: false }, botViberProduction: { value: '', type: 'chatbot-viber-node', required: false }, botUniversal: { value: '', type: 'chatbot-universal-node', required: false }, botUniversalProduction: { value: '', type: 'chatbot-universal-node', required: false }, botTwilio: { value: '', type: 'chatbot-twilio-node', required: false }, botTwilioProduction: { value: '', type: 'chatbot-twilio-node', required: false }, botDiscord: { value: '', type: 'chatbot-discord-node', required: false }, botDiscordProduction: { value: '', type: 'chatbot-discord-node', required: false }, chatId: { value: '' }, transport: { value: '' }, messageId: { value: '' }, contextMessageId: { value: false }, store: { value: '', type: 'chatbot-context-store', required: false } }, inputs: 1, outputs: 1, oneditprepare: function() { var _this = this; $.RB_Legend(); $('#node-input-contextMessageId').on('change', function() { var checked = $(this).is(':checked'); if (checked) { $('#node-input-messageId').val('{{messageId}}').attr('disabled', true); } else { $('#node-input-messageId').val(_this.messageId).attr('disabled', false); } }); $('#node-input-transport') .change(function() { var transport = $(this).val(); $('.form-row-bot').hide(); $('.form-row-bot-' + transport).show(); }); $('.form-row-bot').hide(); $('.form-row-bot-' + _this.transport).show(); }, paletteLabel: 'Conversation', icon: 'chatbot-conversation.png', label: function() { return this.name || 'Conversation'; } }); </script> <script type="text/x-red" data-template-name="chatbot-conversation"> <div class="form-row"> <label for="node-input-name"><i class="icon-tag"></i> Name</label> <input type="text" id="node-input-name" placeholder="Name"> </div> <div class="form-row"> <label for="node-input-transport">Transport</label> <select id="node-input-transport"> <option value="">Select transport</option> <option value="facebook">Facebook Messenger</option> <option value="slack">Slack</option> <option value="discord">Discord</option> <option value="smooch">Smooch</option> <option value="telegram">Telegram</option> <option value="twilio">Twilio</option> <option value="viber">Viber</option> <option value="universal">Universal</option> </select> </div> <div class="form-row form-row-bot form-row-bot-discord" style="margin-left:104px;"> <div>Discord Bot <span class="redbot-environment">(development)</span></div> <input type="text" id="node-input-botDiscord" placeholder="Discord Bot"> </div> <div class="form-row form-row-bot form-row-bot-discord" style="margin-left:104px;"> <div>Discord Bot <span class="redbot-environment">(production)</span></div> <input type="text" id="node-input-botDiscordProduction" placeholder="Discord Bot"> </div> <div class="form-row form-row-bot form-row-bot-telegram" style="margin-left:104px;"> <div>Telegram Bot <span class="redbot-environment">(development)</span></div> <input type="text" id="node-input-botTelegram" placeholder="Telegram Bot"> </div> <div class="form-row form-row-bot form-row-bot-telegram" style="margin-left:104px;"> <div>Telegram Bot <span class="redbot-environment">(production)</span></div> <input type="text" id="node-input-botTelegramProduction" placeholder="Telegram Bot"> </div> <div class="form-row form-row-bot form-row-bot-twilio" style="margin-left:104px;"> <div>Twilio Bot <span class="redbot-environment">(development)</span></div> <input type="text" id="node-input-botTwilio" placeholder="Twilio Bot"> </div> <div class="form-row form-row-bot form-row-bot-twilio" style="margin-left:104px;"> <div>Twilio Bot <span class="redbot-environment">(production)</span></div> <input type="text" id="node-input-botTwilioProduction" placeholder="Twilio Bot"> </div> <div class="form-row form-row-bot form-row-bot-slack" style="margin-left:104px;"> <div>Slack Bot <span class="redbot-environment">(development)</span></div> <input type="text" id="node-input-botSlack" placeholder="Slack Bot"> </div> <div class="form-row form-row-bot form-row-bot-slack" style="margin-left:104px;"> <div>Slack Bot <span class="redbot-environment">(production)</span></div> <input type="text" id="node-input-botSlackProduction" placeholder="Slack Bot"> </div> <div class="form-row form-row-bot form-row-bot-facebook" style="margin-left:104px;"> <div>Facebook Bot <span class="redbot-environment">(development)</span></div> <input type="text" id="node-input-botFacebook" placeholder="Facebook Bot"> </div> <div class="form-row form-row-bot form-row-bot-facebook" style="margin-left:104px;"> <div>Facebook Bot <span class="redbot-environment">(production)</span></div> <input type="text" id="node-input-botFacebookProduction" placeholder="Facebook Bot"> </div> <div class="form-row form-row-bot form-row-bot-viber" style="margin-left:104px;"> <div>Viber Bot <span class="redbot-environment">(development)</span></div> <input type="text" id="node-input-botViber" placeholder="Viber Bot"> </div> <div class="form-row form-row-bot form-row-bot-viber" style="margin-left:104px;"> <div>Viber Bot <span class="redbot-environment">(production)</span></div> <input type="text" id="node-input-botViberProduction" placeholder="Viber Bot"> </div> <div class="form-row form-row-bot form-row-bot-universal" style="margin-left:104px;"> <div>Universal Bot <span class="redbot-environment">(development)</span></div> <input type="text" id="node-input-botUniversal" placeholder="Universal Bot"> </div> <div class="form-row form-row-bot form-row-bot-universal" style="margin-left:104px;"> <div>Universal Bot <span class="redbot-environment">(production)</span></div> <input type="text" id="node-input-botUniversalProduction" placeholder="Universal Bot"> </div> <div class="form-row form-row-bot form-row-bot-smooch"> <label for="node-input-bot">Context</label> <input type="text" id="node-input-store" placeholder="Select storage for chat context"> <div class="redbot-form-hint"> Select the chat context provider to use with this message, if none is selected then non-persistent "memory" will be used.<br> To extend <strong>RedBot</strong> with a new chat context provider see <a href="https://github.com/guidone/node-red-contrib-chatbot/wiki/Creating-a-Chat-Context-Provider" target="_blank">this tutorial</a>. </div> </div> <br/> <div class="form-row"> <label for="node-input-name">ChatId</label> <input type="text" id="node-input-chatId" placeholder="Chat id" style="width:150px;"> <div class="redbot-form-hint"> The <code>chatId</code> is needed to initiate the conversation (you can grab the chatId from the logs or a debug node), the <code>chatId</code> is unique per user across the different platforms. </div> </div> <div class="form-row form-row-bot form-row-bot-telegram"> <label for="node-input-name">MessageId</label> <input type="text" id="node-input-messageId" class="platform-telegram" placeholder="Message Id" style="width:150px;"> <input type="checkbox" value="true" id="node-input-contextMessageId" style="width:20px;"> Use context <em>{messageId}</em> <div class="redbot-form-hint"> Specify a <code>messageId</code> to edit a message already sent to the user. Use context <code>messageId</code> to edit the last sent message. </div> </div> <div class="redbot-form-legend"></div> </script> <script type="text/x-red" data-help-name="chatbot-conversation"><p>Start a chat bot conversation, for example to initiate a conversation (sending a message) to a user in response of a Node Red event, chain this node to a <code>Message node</code> (or <code>Image</code>, <code>Location</code>, etc)</p> <p>The <code>chatId</code> is needed to initiate the conversation (you can grab the chatId from the logs or a debug node), the <code>chatId</code> is unique per user across the different platforms.</p> <p>The parameters <code>chatId</code> and <code>transport</code> can be passed through the payload by the upstream node:</p> <pre><code>msg.payload = { chatId: &#39;42&#39;, transport: &#39;telegram&#39; }; return msg; </code></pre><p>In order to edit an already sent message (only <em>Telegram</em>), specify the <code>messageId</code> or use the context <code>messageId</code> which is the id of the last sent message. To set the <code>messageId</code> programmatically in the upstream node</p> <pre><code>msg.payload = { messageId: &#39;123456&#39; }; return msg; </code></pre><p><img src="