Javascript : typing indicator functionality










0















Technologies :



ForntEnd : ReactJs



BackEnd : NodeJs



DB: FireStore



Project Overview :



This typing indicator is not similar to what app, messenger or any other application that you/me are using for daily usage.this functionality is for internal use of our company agents.



Think as customer care chat application. We’ve many customer chat and company have many agent who chat with customers.



Ex: we have customer A, and Agents B, C, D. One more thing is only our agent have access to company software and customer can chat from any applications like messenger, line chat etc. we are using twillo to integrate all these platform with our system.



Now think about the scenario where agent B is chatting with customer A as the same time if agent C want to chat with customer A then agent C must see the message that a is typing and if agent D also want to chat with customer s/he must see that B, C is typing and so on.



To achieve above functionality from frontend (reactjs) I’ve idea about it and implemented.



Code example :



<input 
type="text"
placeholder=
typingstate && typingstate !== null
? `$typingstate.join(', ') is typing..`
: 'Type a message here..'

value=inputMessage
onChange=this.handleInputChange
onKeyPress=this.handleSubmitMessage
onKeyUp=this.TypingIndicatior
/>

Let typingTimer;
Let TypingInterval = 5000 // 5 second

//on keyup I'm changing typing-state

TypingIndicatior = event =>

if (event.keyCode === 13)
// if press enter then submit message
this.SubmitMessage(event);
else event.target.value === '')
typingTimer = setTimeout(() =>

// if user will not type anything for 5 second then will change/update DB for typingstatus to null

, TypingInterval);


;


Above code is working find and update as I expect from frontend side.one more thing is to get fast response from firestore here I directly call firebase query without using backend.



Now think about the scenario if Agent B and C both are typing so I’ve updated DB typingstate with array like this [“B”, “C”] so when agent D want to chat with customer at that time it’ll read typingstate from DB and show to him that B, C is typing But for any reason (close browser, electricity down) agent B gone from application
And not able to update DB typing state from [“B”, “C”] to [“C”] then agent B will remain for all time in DB so whenever any agent want to chat with customer s/he will be see message that B is typing.



I’m not able to solve this one scenario and I’m sure that to solve this issue I must need to use backend(nodejs) but how that I don’t know.



That’s it. If have any solution let me know. If you have any better solution you can share with me.










share|improve this question


























    0















    Technologies :



    ForntEnd : ReactJs



    BackEnd : NodeJs



    DB: FireStore



    Project Overview :



    This typing indicator is not similar to what app, messenger or any other application that you/me are using for daily usage.this functionality is for internal use of our company agents.



    Think as customer care chat application. We’ve many customer chat and company have many agent who chat with customers.



    Ex: we have customer A, and Agents B, C, D. One more thing is only our agent have access to company software and customer can chat from any applications like messenger, line chat etc. we are using twillo to integrate all these platform with our system.



    Now think about the scenario where agent B is chatting with customer A as the same time if agent C want to chat with customer A then agent C must see the message that a is typing and if agent D also want to chat with customer s/he must see that B, C is typing and so on.



    To achieve above functionality from frontend (reactjs) I’ve idea about it and implemented.



    Code example :



    <input 
    type="text"
    placeholder=
    typingstate && typingstate !== null
    ? `$typingstate.join(', ') is typing..`
    : 'Type a message here..'

    value=inputMessage
    onChange=this.handleInputChange
    onKeyPress=this.handleSubmitMessage
    onKeyUp=this.TypingIndicatior
    />

    Let typingTimer;
    Let TypingInterval = 5000 // 5 second

    //on keyup I'm changing typing-state

    TypingIndicatior = event =>

    if (event.keyCode === 13)
    // if press enter then submit message
    this.SubmitMessage(event);
    else event.target.value === '')
    typingTimer = setTimeout(() =>

    // if user will not type anything for 5 second then will change/update DB for typingstatus to null

    , TypingInterval);


    ;


    Above code is working find and update as I expect from frontend side.one more thing is to get fast response from firestore here I directly call firebase query without using backend.



    Now think about the scenario if Agent B and C both are typing so I’ve updated DB typingstate with array like this [“B”, “C”] so when agent D want to chat with customer at that time it’ll read typingstate from DB and show to him that B, C is typing But for any reason (close browser, electricity down) agent B gone from application
    And not able to update DB typing state from [“B”, “C”] to [“C”] then agent B will remain for all time in DB so whenever any agent want to chat with customer s/he will be see message that B is typing.



    I’m not able to solve this one scenario and I’m sure that to solve this issue I must need to use backend(nodejs) but how that I don’t know.



    That’s it. If have any solution let me know. If you have any better solution you can share with me.










    share|improve this question
























      0












      0








      0








      Technologies :



      ForntEnd : ReactJs



      BackEnd : NodeJs



      DB: FireStore



      Project Overview :



      This typing indicator is not similar to what app, messenger or any other application that you/me are using for daily usage.this functionality is for internal use of our company agents.



      Think as customer care chat application. We’ve many customer chat and company have many agent who chat with customers.



      Ex: we have customer A, and Agents B, C, D. One more thing is only our agent have access to company software and customer can chat from any applications like messenger, line chat etc. we are using twillo to integrate all these platform with our system.



      Now think about the scenario where agent B is chatting with customer A as the same time if agent C want to chat with customer A then agent C must see the message that a is typing and if agent D also want to chat with customer s/he must see that B, C is typing and so on.



      To achieve above functionality from frontend (reactjs) I’ve idea about it and implemented.



      Code example :



      <input 
      type="text"
      placeholder=
      typingstate && typingstate !== null
      ? `$typingstate.join(', ') is typing..`
      : 'Type a message here..'

      value=inputMessage
      onChange=this.handleInputChange
      onKeyPress=this.handleSubmitMessage
      onKeyUp=this.TypingIndicatior
      />

      Let typingTimer;
      Let TypingInterval = 5000 // 5 second

      //on keyup I'm changing typing-state

      TypingIndicatior = event =>

      if (event.keyCode === 13)
      // if press enter then submit message
      this.SubmitMessage(event);
      else event.target.value === '')
      typingTimer = setTimeout(() =>

      // if user will not type anything for 5 second then will change/update DB for typingstatus to null

      , TypingInterval);


      ;


      Above code is working find and update as I expect from frontend side.one more thing is to get fast response from firestore here I directly call firebase query without using backend.



      Now think about the scenario if Agent B and C both are typing so I’ve updated DB typingstate with array like this [“B”, “C”] so when agent D want to chat with customer at that time it’ll read typingstate from DB and show to him that B, C is typing But for any reason (close browser, electricity down) agent B gone from application
      And not able to update DB typing state from [“B”, “C”] to [“C”] then agent B will remain for all time in DB so whenever any agent want to chat with customer s/he will be see message that B is typing.



      I’m not able to solve this one scenario and I’m sure that to solve this issue I must need to use backend(nodejs) but how that I don’t know.



      That’s it. If have any solution let me know. If you have any better solution you can share with me.










      share|improve this question














      Technologies :



      ForntEnd : ReactJs



      BackEnd : NodeJs



      DB: FireStore



      Project Overview :



      This typing indicator is not similar to what app, messenger or any other application that you/me are using for daily usage.this functionality is for internal use of our company agents.



      Think as customer care chat application. We’ve many customer chat and company have many agent who chat with customers.



      Ex: we have customer A, and Agents B, C, D. One more thing is only our agent have access to company software and customer can chat from any applications like messenger, line chat etc. we are using twillo to integrate all these platform with our system.



      Now think about the scenario where agent B is chatting with customer A as the same time if agent C want to chat with customer A then agent C must see the message that a is typing and if agent D also want to chat with customer s/he must see that B, C is typing and so on.



      To achieve above functionality from frontend (reactjs) I’ve idea about it and implemented.



      Code example :



      <input 
      type="text"
      placeholder=
      typingstate && typingstate !== null
      ? `$typingstate.join(', ') is typing..`
      : 'Type a message here..'

      value=inputMessage
      onChange=this.handleInputChange
      onKeyPress=this.handleSubmitMessage
      onKeyUp=this.TypingIndicatior
      />

      Let typingTimer;
      Let TypingInterval = 5000 // 5 second

      //on keyup I'm changing typing-state

      TypingIndicatior = event =>

      if (event.keyCode === 13)
      // if press enter then submit message
      this.SubmitMessage(event);
      else event.target.value === '')
      typingTimer = setTimeout(() =>

      // if user will not type anything for 5 second then will change/update DB for typingstatus to null

      , TypingInterval);


      ;


      Above code is working find and update as I expect from frontend side.one more thing is to get fast response from firestore here I directly call firebase query without using backend.



      Now think about the scenario if Agent B and C both are typing so I’ve updated DB typingstate with array like this [“B”, “C”] so when agent D want to chat with customer at that time it’ll read typingstate from DB and show to him that B, C is typing But for any reason (close browser, electricity down) agent B gone from application
      And not able to update DB typing state from [“B”, “C”] to [“C”] then agent B will remain for all time in DB so whenever any agent want to chat with customer s/he will be see message that B is typing.



      I’m not able to solve this one scenario and I’m sure that to solve this issue I must need to use backend(nodejs) but how that I don’t know.



      That’s it. If have any solution let me know. If you have any better solution you can share with me.







      javascript node.js reactjs google-cloud-firestore






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 16 '18 at 6:51









      DhavalDhaval

      5221928




      5221928






















          0






          active

          oldest

          votes












          Your Answer






          StackExchange.ifUsing("editor", function ()
          StackExchange.using("externalEditor", function ()
          StackExchange.using("snippets", function ()
          StackExchange.snippets.init();
          );
          );
          , "code-snippets");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "1"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53332802%2fjavascript-typing-indicator-functionality%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes















          draft saved

          draft discarded
















































          Thanks for contributing an answer to Stack Overflow!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53332802%2fjavascript-typing-indicator-functionality%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Top Tejano songwriter Luis Silva dead of heart attack at 64

          ReactJS Fetched API data displays live - need Data displayed static

          Evgeni Malkin