chat_main.html 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. <html lang="cn">
  2. <head>
  3. <meta charset="utf-8">
  4. <meta name="description" content="">
  5. <meta name="author" content="陶士涵">
  6. <title>聊天界面</title>
  7. <link rel="stylesheet" href="/static/css/common.css">
  8. <link rel="stylesheet" href="/static/css/emojione.min.css">
  9. <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/element-ui@2.13.1/lib/theme-chalk/index.css">
  10. <script src="/static/js/functions.js"></script>
  11. <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  12. <script src="https://cdn.jsdelivr.net/npm/element-ui@2.13.1/lib/index.js"></script>
  13. <script src="https://cdn.jsdelivr.net/npm/jquery/dist/jquery.min.js"></script>
  14. <script src="https://cdn.bootcss.com/reconnecting-websocket/1.0.0/reconnecting-websocket.min.js"></script>
  15. <style>
  16. html, body {height: 100%;padding: 0;margin: 0;background-color: #f5f5f5;}
  17. .el-row{width:100%}#app{margin-top: 10px;}
  18. .chatBg{min-height: 100%;background: #fff;border: solid 1px #e6e6e6;overflow: hidden;}
  19. .chatLeft{ margin-left: 4px;}
  20. .sw-bg{background: #fff;border: solid 1px #e6e6e6;boder-top:none;padding:5px 10px;}
  21. .chatBgContext .el-row{margin-bottom: 5px;}
  22. .chatBgContext{position: relative;}
  23. .chatUser{
  24. line-height: 24px;
  25. font-size: 12px;
  26. white-space: nowrap;
  27. color: #999;
  28. }
  29. .chatContent{
  30. text-align: left;
  31. background-color: rgb(166,212,242);
  32. color: #000;
  33. border: 1px solid rgb(152, 199, 230);
  34. padding: 8px 15px;
  35. min-height: 26px;
  36. word-break: break-all;
  37. position: relative;
  38. border-radius: 5px;
  39. display: inline-block;
  40. }
  41. .chatContent:after {
  42. content: '';
  43. position: absolute;
  44. left: -10px;
  45. top: 13px;
  46. width: 0;
  47. height: 0;
  48. border-style: dashed;
  49. border-color: transparent;
  50. overflow: hidden;
  51. border-width: 10px;
  52. border-top-style: solid;
  53. border-top-color: rgb(166,212,242);
  54. }
  55. .chatBoxMe .chatContent{float: right;background-color: rgb(152,225,101);border: 1px solid rgb(145, 215, 96);}
  56. .chatBoxMe .chatContent:after{border-top-color: rgb(152,225,101);}
  57. .chatBoxMe .el-col-3{float: right;text-align: right;}
  58. .chatBoxMe .chatUser{text-align: right}
  59. .chatBoxMe .chatContent:after{left:auto;right: -10px;}
  60. .chatArea{margin: 10px 0;}
  61. .chatBox{max-height: 350px;overflow-y: auto;overflow-x: hidden;}
  62. .chatTime{text-align: center;color: #bbb;margin: 5px 0;font-size: 12px;}
  63. </style>
  64. </head>
  65. <body>
  66. <div id="app">
  67. <template>
  68. <el-row :gutter="2">
  69. <el-col :span="6">
  70. <div class="chatBg chatLeft">
  71. <el-tabs v-model="leftTabActive" @tab-click="handleTabClick">
  72. <el-tab-pane label="在线用户" name="first">
  73. <el-row v-for="item in users" :key="item.uid" class="">
  74. <div :title="item.last_message" style="cursor:pointer" class="onlineUsers hasLastMsg" v-bind:class="{'cur': item.uid==currentGuest }" v-on:click="talkTo(item.uid,item.username)">
  75. <el-col :span="4">
  76. <el-avatar :size="40" :src="item.avator"></el-avatar>
  77. </el-col>
  78. <el-col :span="16">
  79. <div><{item.username}></div>
  80. <div class="lastNewMsg"><{item.last_message}></div>
  81. </el-col>
  82. </div>
  83. </el-row>
  84. </el-tab-pane>
  85. <el-tab-pane label="已接访客" name="second">
  86. <el-row v-for="item in visitors" :key="item.uid" class="">
  87. <div style="cursor:pointer" class="onlineUsers" v-bind:class="{'cur': item.visitor_id==currentGuest }" v-on:click="talkTo(item.visitor_id,item.name)">
  88. <el-col :span="4">
  89. <el-avatar v-bind:class="{'imgGray': item.status==0 }" :size="40" :src="item.avator"></el-avatar>
  90. </el-col>
  91. <el-col :span="16" v-bind:class="{'imgGray': item.status==0 }">
  92. <{item.name}>
  93. </el-col>
  94. </div>
  95. </el-row>
  96. <el-pagination
  97. background
  98. @current-change="visitorPage"
  99. :current-page="visitorCurrentPage"
  100. layout="prev,pager, next"
  101. :page-size="visitorPageSize"
  102. :total="visitorCount">
  103. </el-pagination>
  104. </el-tab-pane>
  105. </el-tabs>
  106. </div>
  107. </el-col>
  108. <el-col :span="12">
  109. <div class="sw-bg chatBgContext">
  110. <el-alert
  111. :title="chatTitle"
  112. type="success">
  113. </el-alert>
  114. <div class="chatBox">
  115. <el-row :gutter="2" v-for="v in msgList" v-bind:class="{'chatBoxMe': v.is_kefu==true}">
  116. <div class="chatTime"><{v.time}></div>
  117. <el-col :span="3"><el-avatar :size="60" :src="v.avator"></el-avatar></el-col>
  118. <el-col :span="21">
  119. <div class="chatUser"><{v.name}></div>
  120. <div class="chatContent" v-html="v.content"></div>
  121. </el-col>
  122. </el-row>
  123. </div>
  124. <div class="faceBox kefuFaceBox">
  125. <ul class="faceBoxList">
  126. <li v-on:click="faceIconClick(i)" class="faceIcon" v-for="(v,i) in face" :title="v">
  127. <!-- <img :src=v.path>-->
  128. <span class="em" :class="v"></span>
  129. </li>
  130. </ul>
  131. <div class="clear"></div>
  132. </div>
  133. <el-input type="textarea" class="chatArea" v-model="messageContent" v-on:keyup.enter.native="chatToUser"></el-input>
  134. <div class="faceBtn"></div>
  135. <div class="imageBtn" id="uploadImg" v-on:click="uploadImg('/uploadimg')"></div>
  136. <el-button class="floatRight" type="primary" v-on:click="chatToUser">发送</el-button>
  137. <div class="clear"></div>
  138. </div>
  139. </el-col>
  140. <el-col :span="6">
  141. <div class="chatBg chatRight">
  142. <el-tabs v-model="rightTabActive" @tab-click="handleTabClick">
  143. <el-tab-pane label="访客信息" name="visitorInfo">
  144. <el-menu>
  145. <el-tooltip content="点击加入黑名单" placement="left">
  146. <el-menu-item v-on:click="addIpblack(visitor.source_ip)" title="点击加入黑名单" style="padding-left:2px;">
  147. <i class="el-icon-s-tools"></i>
  148. <span slot="title">ClientIP:<{visitor.source_ip}></span>
  149. </el-menu-item>
  150. </el-tooltip>
  151. <el-tooltip content="点击加入黑名单" placement="left">
  152. <el-menu-item v-on:click="addIpblack(visitor.client_ip)" title="点击加入黑名单" style="padding-left:2px;">
  153. <i class="el-icon-s-tools"></i>
  154. <span slot="title">IP:<{visitor.client_ip}></span>
  155. </el-menu-item>
  156. </el-tooltip>
  157. <el-menu-item v-on:click="openUrl('https://www.baidu.com/s?wd='+visitor.client_ip)" style="padding-left:2px;">
  158. <i class="el-icon-s-tools"></i>
  159. <span slot="title">城市:<{visitor.city}></span>
  160. </el-menu-item>
  161. <el-popover
  162. ref="popover"
  163. placement="top"
  164. title="来源"
  165. width="300"
  166. trigger="hover"
  167. :content="visitor.refer">
  168. </el-popover>
  169. <el-menu-item v-popover:popover style="padding-left:2px;">
  170. <i class="el-icon-s-tools"></i>
  171. <span slot="title" >来源:<{visitor.refer}></span>
  172. </el-menu-item>
  173. <el-menu-item style="padding-left:2px;">
  174. <i class="el-icon-s-tools"></i>
  175. <span slot="title">时间:<{visitor.created_at}></span>
  176. </el-menu-item>
  177. <el-tooltip content="点击关闭连接" placement="left">
  178. <el-menu-item v-on:click="closeVisitor(visitor.visitor_id)" style="padding-left:2px;">
  179. <i class="el-icon-s-tools"></i>
  180. <span slot="title">状态:<{visitor.status}></span>
  181. </el-menu-item>
  182. </el-tooltip>
  183. </el-menu>
  184. </el-tab-pane>
  185. <el-tab-pane label="黑名单" name="blackList">
  186. <el-row v-for="item in visitors" :key="item.uid" class="">
  187. <div style="cursor:pointer" class="onlineUsers imgGray">
  188. 待开发
  189. </div>
  190. </el-row>
  191. </el-tab-pane>
  192. </el-tabs>
  193. </div>
  194. </el-col>
  195. </el-row>
  196. <!--图片放大-->
  197. <div id="bigPic" class="bigPic">
  198. <img src="/static/images/3.jpg"/>
  199. </div>
  200. <!--//图片放大-->
  201. </template>
  202. </div>
  203. </body>
  204. <script src="/static/js/chat-main.js?v=0.1.1"></script>
  205. </html>