Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Table of Contents

You can use the adaptive cards to achieve thisAdaptive Cards can be used to build and customize a variety of content. One of which is displaying Login in a Card. Read more about Adaptive Cards here.Adaptive Cards

Please use this code In this document, we will give you a sample code for a login card.

Also, see Login within a chatbubble.

Mask password field

Use the below code in the Bot view template > Custom JS to mask the password field in the Login card.

Code Block
setTimeout(function(){
// Select the node that will be observed for mutations
const targetNode = $('.chat-container');
// Options for the observer (which mutations to observe)
const config = { attributes: true, childList: true, subtree: true };
// Callback function to execute when mutations are observed
const callback = function(mutationsList, observer) {
  if( $('[placeholder=Password]').attr('type') === 'text') {
    $('[placeholder=Password]').attr('type', 'password');
  }
};
// Create an observer instance linked to the callback function
const observer = new MutationObserver(callback);
// Start observing the target node for configured mutations
observer.observe(targetNode[0], config);
}, 3000);

...

Ensure that the placeholder is set as “Password“.

Login Card code

Use this sample code in the function node to get the login card in the Chatbot.

Code Block
if(!msg.payload.orbita) {
    msg.payload.orbita = {};
}
if(!msg.payload.orbita.directive) {
    msg.payload.orbita.directive = [];
}
msg.payload.orbita.directive.push(
    {
    "type": "adaptivecard",
    "template": {
        "type": "AdaptiveCard",
        "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
        "version": "1.3",
        "body": [{
            {
"type": "Image",
            "url": "",
 "type           "horizontalAlignment": "TextBlockCenter",
            "width": "200px",
    "text        "height": "Type your Password here","200px"
        },
            {
      "id      "type": "password_textTextBlock",
            "text": "Please Login",
            "wrap": true,
             },
  "horizontalAlignment": "Center",
            "fontType": "Monospace",
            "size": "Large",
         {   "weight": "Bolder",
            "typecolor": "Input.Text",Warning"
        },
            {
            "placeholdertype": "TextBlock",
            "text": "PasswordUsername:",
            "wrap": true,
   "id         "size": "passwordLarge",
            },"weight": "Bolder",
            "color": "Attention"
        },
   {         {
            "type": "ActionSetInput.Text",
            "placeholder": "Username",
            "actionsid": ["username"
        },
            {
            "type": "TextBlock",
            "typetext": "Action.SubmitPassword:",
            "wrap": true,
            "titleid": "Submitpass",
            "fontType": "Monospace",
            "idsize": "submitLarge",
            "weight": "Bolder",
            "datacolor": {"Attention"
        },
            {
            "messagetype": "Your password is savedInput.Text",
            "placeholder": "Password",
            "id": "Pass"
        }],
     "eventName   "actions": [{
            "type": "A-passwordsubmit"Action.Submit",
            "title": "Submit",
          }   "style": "positive",
            "data": {
           "style     "message": "You have logged in Successfully",
                "eventName": "positiveloginevent"
                }
            },
            {
            ]"type": "Action.Submit",
            "title": "Cancel",
            }"style": "destructive"
        }]
    },
    "templateData": {
    },
    "hostAppName": {
        "name": "default"
    }
    })
return msg;

...