body {
    background-color: white;
}
input, button, select, optgroup, textarea {
    margin-bottom: 5px;
}

#layout[data-v-38d3c614] {
    height:100vh;
}
.hcontainer[data-v-38d3c614] {
  height:100vh;
}
.input-clearfix[data-v-38d3c614] {
  height:100px;
}
.scrollable[data-v-38d3c614] {
    overflow-y: scroll;
  overflow-x: hidden;
}
.flex-fill[data-v-38d3c614] {
    flex:1;
}
.row[data-v-38d3c614] {
    margin-left:0px;
    margin-right:0px;
}


.h-100p[data-v-4fa2d2c8] {
  height:100%;
}
.card-title[data-v-4fa2d2c8]{
text-align: center;
}


.h-100p[data-v-7bca95a2] {
  height:100%;
}


.h-100p[data-v-aa5ceb28] {
  height:100%;
}
.card-title[data-v-aa5ceb28]{
text-align: center;
}


.chat-image[data-v-45347cce] {  
  display: block;
  margin-left: auto;
  margin-right: auto;
}


.message-content[data-v-76728e4d] {
  border-top-left-radius: 5px;
  border-bottom-left-radius: 5px;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
  white-space: break-spaces;
}
.message-check[data-v-76728e4d] {
    margin-top:0.25rem;
    float:right;
    font-size:0.75rem
}
.message-date[data-v-76728e4d] {
    margin-top:0.25rem;
    float:right;
    font-size:0.75rem
}


.h-100p {
  height:100%;
}
.rounded {
    
  border-top-left-radius: 5px;
  border-bottom-left-radius: 5px;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
}
.btn-light{
  margin-bottom:0px!important;
  background: none!important;
  border: none!important;
}
.emoji-btn {
  padding:5px;
  border-top-left-radius: 5px;
  border-bottom-left-radius: 5px;
  margin-right: -1px;
  margin-bottom: 5px!important;
}
.minw-none {
  min-width:3rem!important;
}


.stickyInput[data-v-494ddb16] {
  height:100px;
  padding-left:1em;
  padding-right:1em;
    z-index:1;
    bottom:0px;
    width:100%;
    position: fixed;
    left: 0;
}
.chat-inner-container[data-v-494ddb16]{
  min-height:3rem;
}
.stickyButton[data-v-494ddb16] {
  z-index:1;
  right: 1rem;
  position: fixed;
  top: 3.5rem;
}
hr[data-v-494ddb16] {
margin-bottom:0.5em;margin-top:0.25em;
}
.border-primary[data-v-494ddb16] {
  border: 1px solid #0d6efd;
}
.alert-secondary[data-v-494ddb16]{
  margin-left:8em;
}
textarea[data-v-494ddb16] {
  resize: none;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
  border-left: 0!important;
}
.rounded[data-v-494ddb16] {
  border-top-left-radius: 5px;
  border-bottom-left-radius: 5px;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
}
.icon-group[data-v-494ddb16] {
  z-index:2;
  border:1px solid grey;
  padding:5px;
  border-radius:5px;
  background-color:white;
  border-bottom:0px;
  bottom:55px;
}
.row[data-v-494ddb16] {
  margin-left:0px!important;
  margin-right:0px!important;
}
.alert[data-v-494ddb16] {
  margin-bottom:4px!important;
  padding:0.5rem!important;
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"app.css","mappings":"AAAA;IACI,uBAAuB;AAC3B;AACA;IACI,kBAAkB;AACtB,C;;AC4CA;IACA;AACA;AACA;EACA;AACA;AACA;EACA;AACA;AACA;IACA;EACA;AACA;AACA;IACA;AACA;AACA;IACA;IACA;AACA;;;ACzDA;EACA;AACA;AACA;AACA;AAEA;;;ACoBA;EACA;AACA;;;ACnBA;EACA;AACA;AACA;AACA;AAEA;;;ACnBA;EACA;EACA;EACA;AACA;;;ACqBA;EACA;EACA;EACA;EACA;EACA;AACA;AACA;IACA;IACA;IACA;AACA;AACA;IACA;IACA;IACA;AACA;;;AC4BA;EACA;AACA;AACA;;EAEA;EACA;EACA;EACA;AACA;AACA;EACA;EACA;EACA;AACA;AACA;EACA;EACA;EACA;EACA;EACA;AACA;AACA;EACA;AACA;;;AAIA;EACA;EACA;EACA;IACA;IACA;IACA;IACA;IACA;AACA;AACA;EACA;AACA;AACA;EACA;EACA;EACA;EACA;AACA;AACA;AACA;AACA;AACA;EACA;AACA;AACA;EACA;AACA;AACA;EACA;EACA;EACA;EACA;AACA;AACA;EACA;EACA;EACA;EACA;AACA;AACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAEA;AACA;EACA;EACA;AACA;AACA;EACA;EACA;AACA","sources":["webpack:///./assets/styles/app.css","webpack:///./assets/components/App.vue","webpack:///./assets/components/App/Contacts.vue","webpack:///./assets/components/App/Chats.vue","webpack:///./assets/components/App/Settings.vue","webpack:///./assets/components/App/Chats/Chat/Message/File.vue","webpack:///./assets/components/App/Chats/Chat/Message.vue","webpack:///./assets/components/App/Chats/Chat.vue"],"sourcesContent":["body {\n    background-color: white;\n}\ninput, button, select, optgroup, textarea {\n    margin-bottom: 5px;\n}","<!-- Author: Stefan Sander <mail@stefan-sander.online> -->\n<template>\n    <div id=\"layout \" style=\"height:100vh;\">\n        <div class=\"container-fluid d-flex hcontainer flex-column p-0\">\n            <div class=\"row p-0\">\n                <div class=\"col p-0\">\n                    <ul class=\"nav nav-tabs p-0\">\n                        <li class=\"nav-item\"  @click=\"go('app_contacts')\">\n                            <a  href=\"#\" target=\"_self\" class=\"nav-link\" v-bind:class=\"{ active: currentRoute('app_contacts')}\" >  \n                                <font-awesome-icon icon=\"address-book\" /> Contacts \n                            </a>\n                        </li>\n\n                        <li class=\"nav-item\"  @click=\"go('app_chats')\"  >\n                            <a  href=\"#\" target=\"_self\" class=\"nav-link\" v-bind:class=\"{ active: (currentRoute('app_chat') || currentRoute('app_chats')) }\">\n                                <font-awesome-icon icon=\"edit\" /> Chats \n                            </a>\n                        </li>\n\n                        <li class=\"nav-item\"  @click=\"go('app_settings')\" >\n                            <a  href=\"#\" target=\"_self\" class=\"nav-link\" v-bind:class=\"{ active: currentRoute('app_settings')}\">\n                                <font-awesome-icon icon=\"cogs\" />  Settings \n                            </a>\n                        </li>\n                    </ul>\n                </div>\n            </div>\n              <div class=\"row flex-fill d-flex justify-content-start scrollable\">\n                  <div class=\"col portlet-container portlet-dropzone content p-3 pb-1\">\n\n                      <router-view></router-view>\n               \n\n\n\n\n                  </div> <div id=\"bottom\">\n  </div>\n              </div>\n             \n                <div class=\"row \">\n                    <div class=\"col input-clearfix\" v-if=\"currentRoute('app_chat')\">\n                    </div>\n                </div>\n        </div>\n    </div>\n</template>\n\n<style scoped>\n#layout {\n    height:100vh;\n}\n.hcontainer {\n  height:100vh;\n}\n.input-clearfix {\n  height:100px;\n}\n.scrollable {\n    overflow-y: scroll;\n  overflow-x: hidden;\n}\n.flex-fill {\n    flex:1;\n}\n.row {\n    margin-left:0px;\n    margin-right:0px;\n}\n</style>\n\n<script>\nexport default {\n  name: 'App',\n  data: function() {\n    return {\n        active:null,\n      }\n  },\n  methods: {\n      currentRoute(route) {\n       return route==this.$router.currentRoute.name\n      },\n      go(page) {\n        this.$router.push({ name: page})\n      },\n  },\n  mounted: function() {\n  },\n  updated: function() {\n  },\n  created: function() {\n      this.$root.$on('chat:typing', (result) => {\n        this.$root.$emit('Chat::chat:typing',result);\n      });\n      this.$root.$on('chat:message:status', (result) => {\n        this.$root.$emit('ChatMessage::chat:message:status',result);\n      });\n      this.$root.$on('user:change:password', (result) => {\n        this.$root.$emit('AppSettings::user:change:password',result);\n      });\n      this.$root.$on('chat:load:userchats', (result) => {\n        this.$root.$emit('AppChats::chat:load:userchats',result);\n      });\n      this.$root.$on('contact:add', (result) => {\n        this.$root.$emit('AppContacts::contact:add',result);\n      });\n      this.$root.$on('contact:search', (result) => {\n        this.$root.$emit('AppContacts::contact:search',result);\n      });\n      this.$root.$on('user:contacts', (result) => {\n        this.$root.$emit('AppContacts::user:contacts',result);\n      });\n      this.$root.$on('chat:unblock', (result) => {\n        this.$root.$emit('AppChats::chat:unblock',result);\n        this.$root.$emit('Chat::chat:unblock',result);\n      });\n      this.$root.$on('chat:block', (result) => {\n        this.$root.$emit('AppChats::chat:block',result);\n        this.$root.$emit('Chat::chat:block',result);\n      });\n      this.$root.$on('chat:message:send', (result) => {\n        this.$root.$emit('Chat::chat:message:send',result);\n      });\n      this.$root.$on('chat:load', (result) => {\n        this.$root.$emit('Chat::chat:load',result);\n      });\n      this.$root.$on('chat:load:messages', (result) => {\n        this.$root.$emit('Chat::chat:load:messages',result);\n      });\n      this.$root.$on('file:upload', (result) => {\n        this.$root.$emit('Chat::file:upload',result);\n      });\n\n        if (!(\"Notification\" in window)) {\n       //  alert(\"This browser does not support desktop notification\");\n        }\n        else if (Notification.permission !== \"denied\") {\n          Notification.requestPermission().then((permission) => {\n            // If the user accepts, let's create a notification\n            if (permission === \"granted\") {\n              this.$root.notify_permission = true;\n            }\n          });\n        }\n        else if (Notification.permission === \"granted\") {\n          // If it's okay let's create a notification\n              this.$root.notify_permission = true;\n        }\n  }\n}\n</script>","<!-- Author: Stefan Sander <mail@stefan-sander.online> -->\n<template>\n    <div id=\"contacts\" class=\"h-100p\">\n\n      <input id=\"contact_search\" type=\"text\" class=\"w-100\" placeholder=\"find new contacts\" v-on:keyup=\"findContacts()\" v-model=\"search\" />\n      <button type=\"button\" v-for=\"user in contacts\" :key=\"user.id\" class=\"w-100 btn btn-outline-primary\" @click=\"addContact(user)\">Add {{user.username}}</button>\n\n    </div>\n</template>\n\n<style scoped>\n.h-100p {\n  height:100%;\n}\n.card-title{\ntext-align: center;\n\n}\n</style>\n\n<script>\nexport default {\n  name: 'AppContacts',\n  data: function() {\n    return {\n      \n        search:'',\n        contacts:null,\n        mycontacts:null\n      }\n  },\n  methods: {\n    addContact(user) {\n        this.$root.connection.send(\n            JSON.stringify({\n                'action': 'contact:add',\n                'params': {\n                  'token': this.$root.token,\n                  'bob' :user.id,\n                }\n            })\n        );\n    },\n    findContacts() {\n      if (this.search!='') {\n        this.$root.connection.send(\n            JSON.stringify({\n                'action': 'contact:search',\n                'params': {\n                  'token': this.$root.token,\n                    'username': this.search,    \n                }\n            })\n        );\n      }\n    }\n  },\n  updated: function() {\n  },\n  mounted() {\n     document.getElementById('contact_search').focus()\n  },\n  beforeDestroy () {\n    this.$root.$off('AppContacts::contact:add')\n    this.$root.$off('AppContacts::user:contacts')\n    this.$root.$off('AppContacts::contact:search')\n  },\n  created: function() {\n        this.$root.connection.send(\n            JSON.stringify({\n                'action': 'user:contacts',\n                'params': {\n                          'token': this.$root.token,\n                }\n            })\n        );\n\n    this.$root.$on('AppContacts::contact:add', (result) => {\n        if (result.command=='contact:add') {\n          this.$router.push({ name: 'app_chat', params: { id: result.data }})\n        }\n     });\n    this.$root.$on('AppContacts::user:contacts', (result) => {\n        if (result.command=='user:contacts') {\n            this.mycontacts = JSON.parse(result.data);\n        }\n     });\n    this.$root.$on('AppContacts::contact:search', (result) => {\n        if (result.command=='contact:search') {\n            this.contacts = JSON.parse(result.data).filter((u) => {\n              if (u.username==this.$root.claim.username) {\n                return false;\n              }\n              for(var contact of this.mycontacts) {\n                if (u.username==contact.username) {\n                  return false;\n                }\n              }\n              return true;\n            });\n        }\n     });\n  }\n}\n</script>","<!-- Author: Stefan Sander <mail@stefan-sander.online> -->\n<template>\n    <div class=\"h-100p\">\n\n\n      <div id=\"loading\" v-if=\"ready==false\">\n        loading\n      </div>\n      <div id=\"chats\" v-if=\"ready==true\">\n        <div v-if=\"chats.length==0\">\n          <p>you have no contacts added yet to chat with. </p>\n        <button type=\"button\" class=\"w-100 btn btn-outline-primary\" @click=\"$router.push({ name: 'app_contacts'})\">Find Contacts <font-awesome-icon icon=\"address-book\" /></button>\n        </div>\n          <div v-for=\"chat in chats\" :key=\"chat.id\">  \n            <b-button-group class=\"w-100\"  v-if=\"chat.blockedBy!=null\" >\n              <button type=\"button\" disabled class=\"w-75 btn btn-outline-secondary\"   > {{renderUsernames(chat.users)}}</button>\n              <button type=\"button\" class=\"w-25 btn btn-outline-danger\"  @click=\"unblockChat(chat.id)\"\n                v-if=\"$root.claim.id==chat.blockedBy.id\" >\n                unblock  <font-awesome-icon icon=\"unlock\" />\n              </button>\n                <!--   \n                  <b-dropdown-item><font-awesome-icon icon=\"camera\" /></b-dropdown-item>\n                  <b-dropdown-divider /> \n                -->\n            </b-button-group>\n            <button type=\"button\" v-if=\"chat.blockedBy==null\"\n              class=\"w-100 btn btn-outline-primary\"\n              @click=\"startChat(chat.id)\" >\n                {{renderUsernames(chat.users)}}  <font-awesome-icon icon=\"comments\" />\n            </button>\n          </div>\n      </div>\n\n    </div>\n</template>\n\n<style scoped>\n.h-100p {\n  height:100%;\n}\n</style>\n\n<script>\nexport default {\n  name: 'Chats',\n  data: function() {\n    return {\n      ready: false,\n      chats: []\n      }\n  },\n  methods: {\n    unblockChat(chatId) {\n        this.$confirm({\n          message: `Are you sure to unblock?`,\n          button: {\n            no: 'No',\n            yes: 'Yes'\n          },\n          callback: confirm => {\n            if (confirm) {\n              this.$root.connection.send(\n                  JSON.stringify({\n                      'action': 'chat:unblock',\n                      'params': {\n                          'token': this.$root.token,\n                          'chatId': chatId,    \n                      }\n                  })\n              );\n            }\n          }\n        })\n\n              \n    },\n    startChat(chatId) {\n          this.$router.push({ name: 'app_chat', params: { id: chatId }})\n    },\n    renderUsernames(users) {\n      var names = [];\n      for(var user of users) {\n        if (user.id!=this.$root.claim.id) {\n            names.push(user.username)\n        }\n      }\n      return names.join(', ')\n    },\n  },\n  updated: function() {\n  },\n  mounted: function() {\n  },\n  beforeDestroy () {\n    this.$root.$off('AppChats::chat:unblock') \n    this.$root.$off('AppChats::chat:block') \n    this.$root.$off('AppChats::chat:load:userchats')\n  },\n  created: function() {\n        \n    this.$root.$on('AppChats::chat:load:userchats', (result) => {\n        if (result.command=='chat:load:userchats') {\n          this.chats = JSON.parse(result.data);\n          this.ready = true;\n        }\n     });\n\n      this.$root.$on('AppChats::chat:block', (result) => {\n\n        for(var i in this.chats) {\n          var data = JSON.parse(result.data)\n          if (this.chats[i].id == data.id) {\n            this.$root.connection.send(\n                JSON.stringify({\n                    'action': 'chat:load:userchats',\n                    'params': {\n                          'token': this.$root.token,\n                    }\n                })\n            );\n          }\n        }\n      });\n      this.$root.$on('AppChats::chat:unblock', (result) => {\n        for(var i in this.chats) {\n          var data = JSON.parse(result.data)\n          if (this.chats[i].id == data.id) {\n            this.$root.connection.send(\n                JSON.stringify({\n                    'action': 'chat:load:userchats',\n                    'params': {\n                          'token': this.$root.token,\n                    }\n                })\n            );\n          }\n          }\n      });\n\n        this.$root.connection.send(\n            JSON.stringify({\n                'action': 'chat:load:userchats',\n                'params': {\n                          'token': this.$root.token,\n                }\n            })\n        );\n  }\n}\n</script>","<!-- Author: Stefan Sander <mail@stefan-sander.online> -->\n<template>\n    <div id=\"settings\"  class=\" h-100p\">\n      \n          <div class=\"w-100\">\n            <div class=\"alert row \" v-if=\"message\"\n             v-bind:class=\"{\n                'alert-success':  message.status==0,\n                'alert-danger':  message.status==1,\n                }\">{{message.data}}</div>\n          </div>\n          <input type=\"oldpassword\" placeholder=\"old password\" name=\"oldpassword\" v-model=\"oldpassword\"   class=\"w-100\" />\n          <input type=\"password\" placeholder=\"new password\" name=\"password\" v-model=\"password\"   class=\"w-100\" />\n          <input type=\"password\" placeholder=\"repeat new password\" name=\"password2\" v-model=\"password2\"   class=\"w-100\" />\n          <button v-on:click=\"save()\"  class=\"btn btn-outline-primary w-100\">change password <font-awesome-icon icon=\"save\" /></button>\n\n    </div>\n</template>\n\n<style scoped>\n.h-100p {\n  height:100%;\n}\n.card-title{\ntext-align: center;\n\n}\n</style>\n\n<script>\nexport default {\n  name: 'Settings',\n  data: function() {\n    return {\n        oldpassword: null,\n        password: null,\n        password2: null,\n        message: null,\n      }\n  },\n  methods: {\n    save: function() {\n    \n        this.$root.connection.send(\n            JSON.stringify({\n                'action': 'user:change:password',\n                'params': {\n                  'token': this.$root.token,\n                  'oldpassword': this.oldpassword,\n                  'password': this.password,\n                  'password2': this.password2,\n                }\n            })\n        );\n        this.$root.$on('AppSettings::user:change:password', (result) => {\n          console.log(result)\n            this.message = {\n              status: result.status,\n              data: result.data,\n            }\n        });\n    }\n  },\n  beforeDestroy () {\n    this.$root.$off('AppSettings::user:change:password')\n  },\n  updated: function() {\n  },\n  created: function() {\n  }\n}\n</script>","<!-- Author: Stefan Sander <mail@stefan-sander.online> -->\n<template>\n    <div>\n        <img class=\"chat-image\" :src=\"content\" />\n    </div>\n</template>\n<style scoped>\n.chat-image {  \n  display: block;\n  margin-left: auto;\n  margin-right: auto;\n}\n</style>\n\n<script>\nexport default {\n  name: 'ChatMessagFile',\n  props: ['data'],\n  data: function() {\n    return {\n        id:this.data.id,\n        user:this.data.user,\n        filename:this.data.filename,\n        content:this.data.content,\n        windowWidth: window.innerWidth,\n        allowed_file_types:[\n          'image/jpeg',\n          'image/png'\n        ],\n        allowed_file_size:1024 * 1024 * 0.5, // 0.5 mb\n      }\n  },\n  methods: {\n      save() {\n          \n      }\n  },\n  mounted: function() {\n  },\n  updated: function() {\n  },\n  beforeDestroy () {\n  },\n  created: function() {\n        \n  }\n}\n</script>","<!-- Author: Stefan Sander <mail@stefan-sander.online> -->\n<template>\n    <div> \n        <div class=\"row pb-1\" ref=\"message\" >\n            <div class=\"\" v-bind:class=\"{\n                'col-1':  isSender(),\n                'col-2':  !isSender(),\n                }\">\n            </div>\n            <div class=\"col-9 message-content\" v-bind:class=\"{ \n                'alert-primary': isSender(),\n                'alert-secondary': !isSender()\n                }\">\n                {{message}}\n                <ChatMessageFile :data=\"file\" v-if=\"file\" />\n                <div  class=\"message-check\" v-if=\"isSender()\">\n                    <font-awesome-icon class=\"check-icon\" icon=\"check\" v-if=\"seen\" />\n                    <font-awesome-icon class=\"check-icon\" icon=\"check\" v-if=\"sent\" />\n                </div>\n\n                <div class=\"message-date\">{{ sent | moment(\"D.MM.YYYY hh:mm\") }} </div>\n            </div>\n            <div ref=\"sc\" v-bind:class=\"{\n                'col-1':  !isSender(),\n                'col-2':  isSender(),\n                }\">\n            </div>\n        </div>\n    </div>\n</template>\n\n<style scoped>\n.message-content {\n  border-top-left-radius: 5px;\n  border-bottom-left-radius: 5px;\n  border-top-right-radius: 5px;\n  border-bottom-right-radius: 5px;\n  white-space: break-spaces;\n}\n.message-check {\n    margin-top:0.25rem;\n    float:right;\n    font-size:0.75rem\n}\n.message-date {\n    margin-top:0.25rem;\n    float:right;\n    font-size:0.75rem\n}\n</style>\n\n<script>\nimport  ChatMessageFile  from './Message/File.vue'\nexport default {\n  name: 'Message',\n  components: {ChatMessageFile},\n  props: ['data'],\n  data: function() {\n    return {\n        id:this.data.id,\n        sender:this.data.sender,\n        message:this.data.message,\n        file:this.data.file,\n        sent:this.data.sent,\n        delivered:this.data.delivered,\n        seen:this.data.seen,\n        status:this.data.status,\n      }\n  },\n  \n  methods: {\n      isSender() {\n          return  this.sender.id==this.$root.claim.id\n      },\n      save() {\n          this.$root.connection.send(\n              JSON.stringify({\n                  'action': 'chat:message:send',\n                  'params': {\n                          'token': this.$root.token,\n                      'chatId': this.$route.params.id,    \n                      'message': message,    \n                  }\n              })\n          );\n      }\n  },\n  mounted: function() {\n   //document.getElementById('bottom').scrollIntoView({behavior: \"smooth\", block: \"end\"});  \n  },\n  updated: function() {\n   //document.getElementById('bottom').scrollIntoView({behavior: \"smooth\", block: \"end\"});  \n  },\n  created: function() {\n    if (this.sender.id!=this.$root.claim.id && this.status!='seen') {\n        this.$root.connection.send(\n            JSON.stringify({\n                'action': 'chat:message:status',\n                'params': {\n                          'token': this.$root.token,\n                    'messageId': this.id,\n                    'status': 'seen',    \n                }\n            })\n        );\n    }\n\n      this.$root.$on('ChatMessage::chat:message:status', (result) => {\n            if (result.command == 'chat:message:status') {\n                var _message = JSON.parse(result.data);\n                if (_message.id == this.id) {\n                    this.id = _message.id;\n                    this.sender = _message.sender;\n                    this.message = _message.message;\n                    this.file = _message.file;\n                    this.sent = _message.sent;\n                    this.delivered = _message.delivered;\n                    this.seen = _message.seen;\n                this.$forceUpdate();\n                }\n            }\n      });  \n      \n  }\n}\n</script>","<!-- Author: Stefan Sander <mail@stefan-sander.online> -->\n<template>\n    <div>\n      <div id=\"loading\" v-if=\"ready==false\">\n        loading\n      </div>\n    <div class=\"chat-wrapper\">\n      <div @dragover.prevent @drop.prevent> \n      <div class=\" stickyButton\">\n        <b-dropdown dropdown menu-class=\"minw-none\" variant=\"secondary\"  >\n          <template #button-content>\n            <font-awesome-icon icon=\"cog\" /> {{renderUsernames(users)}}\n          </template>\n          <!--   \n            <b-dropdown-item  @click=\"clearChat()\"><font-awesome-icon icon=\"eraser\" /> Clear</b-dropdown-item>\n            <b-dropdown-divider /> \n          -->\n          <b-dropdown-item class=\"alert-danger\"  @click=\"blockChat()\"><font-awesome-icon icon=\"ban\" /> Block</b-dropdown-item>\n        </b-dropdown>\n        </div>\n        <div class=\"chat-container\" @drop=\"dragFile\" > \n          <div @click=\"hide('.icon-group')\" class=\"chat-inner-container\" >\n            <div v-for=\"(chatMessage,index) in chatMessages\" :key=\"chatMessage.id\">\n                <ChatMessage :data=\"chatMessage\" v-if=\"chatMessages.length-visible<index\" />\n            </div>\n            <div>\n                <div v-if=\"timerCount>0\">\n                    <div class=\"row pb-1\" ref=\"message\">\n                        <div class=\"col-3\" >\n                        </div>\n                        <div class=\"col-6 alert alert-info rounded\" >\n                            <font-awesome-icon icon=\"keyboard\" /> \n                            {{typingUser}} is typing <font-awesome-icon icon=\"spinner\" spin />\n                        </div>\n                        <div class=\"col-3\">\n                        </div>\n                    </div>\n                </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n          <div class=\"stickyInput\">\n            <b-button-group class=\"w-100\" >\n              <b-dropdown dropup menu-class=\"minw-none\" class=\"emoji-btn btn btn-outline-primary\" variant=\"light\" >\n                <template #button-content>😊</template>\n                <b-dropdown-item v-for=\"k,group in this.emojis\" :key=\"group\" @click=\"showgroup(group)\"> {{group}}</b-dropdown-item>\n              </b-dropdown>\n                <div v-for=\"arr,group in this.emojis\" :key=\"group\" :class=\"group+' icon-group w-100'\" style=\"display:none;position:absolute;\">\n                  <div v-for=\"k,v in arr\" :key=\"k\" style=\"display:inline;\" role='button' @click=\"addSmiley(v)\">{{v}}</div>\n                </div>\n              <textarea rows=\"1\" id=\"chat_input\" class=\"disabled border-primary w-100 \" placeholder=\"write a message\" v-on:keydown=\"isTyping()\" v-on:keyup=\"replaceEmoji\" @click=\"hide('.icon-group')\" />\n            </b-button-group>\n            <div  @click=\"hide('.icon-group')\">\n              <b-button-group class=\"w-100\"  >\n                <button type=\"button\" class=\"w-100 btn btn-outline-primary \" @click=\"send()\" >send <font-awesome-icon icon=\"paper-plane\" /></button>\n                <b-dropdown dropup menu-class=\"minw-none\" variant=\"primary\" >\n                  <template #button-content>\n                    <font-awesome-icon icon=\"file\" />\n                  </template>\n                  <!--   \n                    <b-dropdown-item><font-awesome-icon icon=\"camera\" /></b-dropdown-item>\n                    <b-dropdown-divider /> \n                  -->\n                  <b-dropdown-item  @click=\"$refs.file.click()\"><font-awesome-icon icon=\"image\" /></b-dropdown-item>\n                </b-dropdown>\n              </b-button-group>\n              <input type=\"file\" ref=\"file\" style=\"display: none\" @change=\"fileAdded\">\n            </div>\n            \n          </div>\n      </div>\n</template>\n\n<style>\n.h-100p {\n  height:100%;\n}\n.rounded {\n    \n  border-top-left-radius: 5px;\n  border-bottom-left-radius: 5px;\n  border-top-right-radius: 5px;\n  border-bottom-right-radius: 5px;\n}\n.btn-light{\n  margin-bottom:0px!important;\n  background: none!important;\n  border: none!important;\n}\n.emoji-btn {\n  padding:5px;\n  border-top-left-radius: 5px;\n  border-bottom-left-radius: 5px;\n  margin-right: -1px;\n  margin-bottom: 5px!important;\n}\n.minw-none {\n  min-width:3rem!important;\n}\n</style>\n\n<style scoped>\n.stickyInput {\n  height:100px;\n  padding-left:1em;\n  padding-right:1em;\n    z-index:1;\n    bottom:0px;\n    width:100%;\n    position: fixed;\n    left: 0;\n}\n.chat-inner-container{\n  min-height:3rem;\n}\n.stickyButton {\n  z-index:1;\n  right: 1rem;\n  position: fixed;\n  top: 3.5rem;\n}\nhr {\nmargin-bottom:0.5em;margin-top:0.25em;\n}\n.border-primary {\n  border: 1px solid #0d6efd;\n}\n.alert-secondary{\n  margin-left:8em;\n}\ntextarea {\n  resize: none;\n  border-top-right-radius: 5px;\n  border-bottom-right-radius: 5px;\n  border-left: 0!important;\n}\n.rounded {\n  border-top-left-radius: 5px;\n  border-bottom-left-radius: 5px;\n  border-top-right-radius: 5px;\n  border-bottom-right-radius: 5px;\n}\n.icon-group {\n  z-index:2;\n  border:1px solid grey;\n  padding:5px;\n  border-radius:5px;\n  background-color:white;\n  border-bottom:0px;\n  bottom:55px;\n\n}\n.row {\n  margin-left:0px!important;\n  margin-right:0px!important;\n}\n.alert {\n  margin-bottom:4px!important;\n  padding:0.5rem!important;\n}\n</style>\n\n<script>\nimport moment from 'moment';\nimport  ChatMessage  from './Chat/Message.vue'\nimport { emojis } from './Chat/emojis.json'\n  import $ from 'jquery'\n  export default {\n    name: 'Chat',\n    components: {ChatMessage},\n    data: function() {\n      return {       \n        visible:99999,\n        page:0,\n        typingUser:null,\n        timerCount:0,\n        ready:false,\n        id:null,\n        users:[],\n        chatMessages:[],\n        blockedBy:null,\n        emojis,\n        windowWidth: window.innerWidth,\n        allowed_file_types:[\n          'image/jpeg',\n          'image/png'\n        ],\n        allowed_file_size:1024 * 1024 * 5, // 0.5 mb\n      }\n    },    \n    methods: {\n      getMessage(msgId) {\n       for (var msg in messages) {\n         if (msg.id == msgId) {\n           return msg;\n         }\n       }\n      },\n      hide(group) {\n        $(group).hide();\n      },\n      addSmiley(smiley) {\n       document.getElementById('chat_input').value = document.getElementById('chat_input').value + smiley\n      },\n      showgroup(group) {\n        $('.icon-group').hide();\n        $('.' + group).show();\n      },\n      isTyping() {\n              this.$root.connection.send(\n                  JSON.stringify({\n                      'action': 'chat:typing',\n                      'params': {\n                          'token': this.$root.token,\n                          'chatId': this.id,   \n                      }\n                  })\n              );\n      },\n      replaceEmoji() {\n       var txt = document.getElementById('chat_input').value\n       for (var group in this.emojis) {\n        for (var [code,smiley] in this.emojis[group]) {\n            txt = txt.replace(this.emojis[group][code], code);\n        }\n      }\n      document.getElementById('chat_input').value = txt\n      },\n      clearChat() {\n        this.$confirm({\n          message: `Are you sure to delete all previous messages?`,\n          button: {\n            no: 'No',\n            yes: 'Yes'\n          },\n          callback: confirm => {\n            if (confirm) {\n            }\n          }\n        })\n\n      },\n      blockChat() {\n        this.$confirm({\n          message: `Are you sure to close and block this chat?`,\n          button: {\n            no: 'No',\n            yes: 'Yes'\n          },\n          callback: confirm => {\n            if (confirm) {\n              this.$root.connection.send(\n                  JSON.stringify({\n                      'action': 'chat:block',\n                      'params': {\n                          'token': this.$root.token,\n                          'chatId': this.id,    \n                      }\n                  })\n              );\n            }\n          }\n        })\n\n      },\n        onResize() {\n          this.windowWidth = window.innerWidth\n              $('.chat-image').css('maxWidth',window.innerWidth-150);\n          },\n        fileAdded(e) {\n            this.files = this.$refs.file.files;\n            this.uploadFile();\n        },\n        uploadFile() {\n          if (this.allowed_file_types.includes(this.files[0]['type'])) {\n              if (this.files[0].size<this.allowed_file_size) {\n                var reader = new FileReader();\n                  reader.onloadend =  () => {\n                    this.$root.connection.send(\n                        JSON.stringify({\n                            'action': 'file:upload',\n                            'params': {\n                          'token': this.$root.token,\n                                'content': reader.result,    \n                                'filename': this.files[0].name, \n                            }\n                        })\n                    );\n                  }\n                  reader.readAsDataURL(this.files[0]);\n              } else { alert (\"the file is too big.\")}\n          } else { alert (\"the filetype is not allowed.\")}\n        },\n        dragFile(e) {\n          this.files = e.dataTransfer.files;\n            this.uploadFile();\n        },\n      setStatus(msg,status) {\n        if (msg.status!=status) {\n          this.$root.connection.send(\n              JSON.stringify({\n                  'action': 'chat:message:status',\n                  'params': {\n                          'token': this.$root.token,\n                      'messageId': msg.id,\n                      'status': status,    \n                  }\n              })\n          );\n        }\n      },\n      send() {\n        var  msg = document.getElementById('chat_input').value\n        if (msg) {\n          this.$root.connection.send(\n              JSON.stringify({\n                  'action': 'chat:message:send',\n                  'params': {\n                          'token': this.$root.token, \n                      'chatId': this.$route.params.id,    \n                      'message': msg,    \n                  }\n              })\n          );\n          document.getElementById('chat_input').value = \"\";\n        }\n      },\n      renderUsernames(users) {\n        var names = [];\n        for(var user of users) {\n          if (user.id!=this.$root.claim.id) {\n              names.push(user.username)\n          }\n        }\n        return names.join(', ')\n      },    \n    },\n    updated: function() {\n            this.onResize();\n    },\n    mounted() {\n            window.addEventListener('resize', this.onResize);\n    }, \n      beforeDestroy () {\n        this.$root.$off('Chat::chat:load')\n        this.$root.$off('Chat::file:upload')\n        this.$root.$off('Chat::chat:message:send')\n        this.$root.$off('Chat::chat:block')\n        this.$root.$off('Chat::chat:typing')\n        this.$root.$off('Chat::chat:unblock')\n        this.$root.$off('Chat::chat:load:messages')\n    },\n    \n        watch: {\n            timerCount: {\n                handler(value) {\n                    if (value > 0) {\n                        setTimeout(() => {\n                                    this.timerCount--;\n                        }, 1);\n                    }\n                },\n            }\n        },\n    created: function() {\n        this.$root.connection.send(\n            JSON.stringify({\n                'action': 'chat:load',\n                'params': {\n                          'token': this.$root.token,\n                    'chatId': this.$route.params.id,    \n                }\n            })\n        );\n      this.$root.$on('Chat::chat:typing', (result) => {\n       var data = JSON.parse(result.data);\n        if (data.chat.id==this.id) {\n            if (data.user.id!=this.$root.claim.id) {\n                this.timerCount = 50;\n                this.typingUser = data.user.username;                \n\n              setTimeout(function() {    \n                document.getElementById('bottom').scrollIntoView({behavior: \"smooth\", block: \"end\"});  \n              \n              }, 1);\n            }\n        }\n      })\n      this.$root.$on('Chat::chat:unblock', (result) => {\n       var data = JSON.parse(result.data);\n        if (data.id==this.id) {\n          this.$root.connection.send(\n              JSON.stringify({\n                  'action': 'chat:load',\n                  'params': {\n                          'token': this.$root.token,\n                      'chatId': this.$route.params.id,    \n                  }\n              })\n          );\n        }\n      });\n      this.$root.$on('Chat::chat:block', (result) => {\n       var data = JSON.parse(result.data);\n        if (data.id==this.id) {\n          this.$router.push({ name: \"app_chats\"})\n        }\n      });\n      this.$root.$on('Chat::chat:load', (result) => {\n            var chat = JSON.parse(result.data);\n            this.id = chat.id;\n            this.page = 0;\n            this.chatMessages = [];\n            this.users = chat.users;\n            this.ready=true;   \n            this.$root.connection.send(\n                JSON.stringify({\n                    'action': 'chat:load:messages',\n                    'params': {\n                          'token': this.$root.token,\n                        'chatId': this.$route.params.id,   \n                        'page': this.page,\n                        'steps': 1,\n                    }\n                })\n            );\n      });\n      this.$root.$on('Chat::chat:load:messages', (result) => {\n            var messages = JSON.parse(result.data);\n            if (messages.length==1) {\n              this.page++;\n              var message = messages[0];\n              this.chatMessages.unshift(message);     \n              document.getElementById('bottom').scrollIntoView({behavior: \"auto\", block: \"end\"}); \n                  this.$root.connection.send(\n                    JSON.stringify({\n                        'action': 'chat:load:messages',\n                        'params': {\n                          'token': this.$root.token,\n                            'chatId': this.$route.params.id,   \n                            'page': this.page,\n                            'steps': 1,\n                        }\n                    })\n                );\n            }\n      });\n\n      this.$root.$on('Chat::chat:message:send', (result) => {\n            var msg = JSON.parse(result.data);\n            this.chatMessages.push(msg);\n            \n              setTimeout(function() {    \n                document.getElementById('bottom').scrollIntoView({behavior: \"smooth\", block: \"end\"});  \n              \n              }, 1);\n              if (msg.sender.id!=this.$root.claim.id) {\n                this.$root.notify(msg.sender.username + \": \" + msg.message)\n              }\n      });\n      this.$root.$on('Chat::file:upload', (result) => {\n            this.$root.connection.send(\n                JSON.stringify({\n                    'action': 'chat:message:send',\n                    'params': {\n                          'token': this.$root.token,\n                        'chatId': this.$route.params.id,    \n                        'message': '',   \n                        'file': JSON.parse(result.data)\n                    }\n                })\n            );\n      });\n\n    }\n  }\n</script>"],"names":[],"sourceRoot":""}*/