consulting.js 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300
  1. var Request = GetRequest()
  2. new Vue({
  3. el: '#main',
  4. data: {
  5. sessionId:null,
  6. sessionType:2,//1对1会话
  7. curDoctorCode:JSON.parse(localStorage.getItem(httpRequest.agentName)).uid,
  8. curDoctorName:"",
  9. otherCode: Request["otherCode"] || "xh1D2017031502222",//对方医生code
  10. otherName: Request["otherName"] || "yoyo1",//对方医生姓名
  11. members:[],
  12. otherInfo:null,//对方的医生信息
  13. consultData:null,
  14. firstMsg:null,
  15. page:1,
  16. pagesize:10
  17. },
  18. mounted: function() {
  19. this.createSession();
  20. this.bindEvents();
  21. },
  22. methods:{
  23. createSession:function(){
  24. var vm = this;
  25. var p = {}
  26. p[vm.curDoctorCode] = 0;
  27. p[vm.otherCode] = 0;
  28. var data = {
  29. session_type: vm.sessionType, session_name: vm.otherName, participants: JSON.stringify(p)
  30. }
  31. consultingAPI.createSession(data).then(function(res){
  32. if(res.status==200){
  33. vm.sessionId = res.data.id;
  34. vm.connectSocket();//创建socket连接
  35. vm.getMembers();//获取成员列表
  36. }else{
  37. layer.msg(res.msg, {icon: 5})
  38. }
  39. });
  40. },
  41. getMembers:function(){
  42. var vm = this;
  43. consultingAPI.getParticipants(vm.sessionId).then(function(rs){
  44. var members = {};
  45. var isSTF=false;//是否是专科对家医聊天,需要隐藏发送名片入口
  46. $.each( rs , function(i, v) {
  47. if(v.level==1) isSTF=true;
  48. if(v.id!=vm.curDoctorCode){
  49. vm.otherInfo = v;
  50. vm.otherCode = v.id;
  51. }else {
  52. vm.curDoctorName = v.name;
  53. }
  54. vm.members.push({
  55. id:v.id,
  56. code: v.id,
  57. name: v.name,
  58. sex: v.sex,
  59. avatar: v.avatar,
  60. role: v.role,
  61. is_patient: v.is_patient,//0 医生,1 患者
  62. last_fetch_time:v.last_fetch_time
  63. });
  64. });
  65. //获取消息
  66. vm.getMessage(true);
  67. });
  68. },
  69. getMessage:function(isInit){
  70. var vm = this;
  71. var params = {
  72. page: vm.page,
  73. pagesize: vm.pagesize,
  74. end_msg_id: '',
  75. start_msg_id: '',
  76. user: vm.curDoctorCode,
  77. session_id: vm.sessionId,
  78. content_type: '',
  79. isoffset: ''
  80. }
  81. consultingAPI.getMessages(params).then(function(res){
  82. var list = res;
  83. if (list && list.length > 0) {
  84. id = list[list.length - 1].id;
  85. var html = '',
  86. length = list.length;
  87. for (var j = list.length-1; j >= 0; j--) {
  88. var reply = list[j];
  89. html += vm.formatMsg(reply);
  90. }
  91. if(isInit){
  92. $("#talkBox").append(html);
  93. $("#talkBox").slimScroll({
  94. height: '100%',
  95. width: '100%',
  96. alwaysVisible: true,
  97. start : 'bottom',
  98. }).bind('slimscroll', function(e, pos) {
  99. if(pos == 'top'){
  100. if(length == 10){
  101. vm.page++;
  102. vm.getMessage();
  103. }
  104. }
  105. });
  106. }else{
  107. $("#talkBox").prepend(html);
  108. $("#talkBox").slimScroll({
  109. scrollTo: 'bottom'
  110. });
  111. }
  112. $(".fancybox").fancybox({openEffect:"none",closeEffect:"none"});
  113. plyr.setup();
  114. }
  115. });
  116. },
  117. bindEvents:function(){
  118. var vm = this;
  119. template.helper('getSourceUrl', function(str){
  120. return httpRequest.getImgUrl(str);
  121. });
  122. //发送图片
  123. $("#file_head").on('change', function(){
  124. var file = this.files[0];
  125. //先上传图片去服务器,然后再发送消息
  126. var fd=new FormData();
  127. fd.append("action", "UploadVMKImagePath");
  128. fd.append("file", file); //加入文件对象
  129. fd.append("type", '2');
  130. var ajaxObj = {
  131. data: fd,
  132. cache: false,
  133. processData: false,
  134. contentType: false
  135. }
  136. consultingAPI.uploadImage(ajaxObj).then(function(res){
  137. if(res.status == 200){
  138. vm.sendMessage(2, res.urls);
  139. var obj = {
  140. content: res.urls,
  141. content_type: '2',
  142. sender_id: vm.curDoctorCode,
  143. timestamp: new Date().getTime()
  144. }
  145. var html = vm.formatMsg(obj);
  146. $("#talkBox").append(html);
  147. $("#talkBox").slimscroll({
  148. scrollTo: 'bottom'
  149. });
  150. }else{
  151. layer.msg(res.msg, {icon: 5})
  152. }
  153. });
  154. });
  155. },
  156. sendClick:function(){
  157. var vm = this;
  158. var $this = $(this);
  159. var text = $.trim($("#input_content").text());
  160. if(text.length == 0){
  161. vm.showWarningMsg('发送内容不能为空');
  162. return false;
  163. }else{
  164. vm.sendMessage(1, text);
  165. $("#input_content").text('');
  166. var obj = {
  167. content: text,
  168. content_type: '1',
  169. sender_id: vm.curDoctorCode,
  170. timestamp: new Date().getTime()
  171. }
  172. var html = vm.formatMsg(obj);
  173. $("#talkBox").append(html);
  174. $("#talkBox").slimscroll({
  175. scrollTo: 'bottom'
  176. });
  177. }
  178. },
  179. sendMessage:function(contentType, content){
  180. var vm = this;
  181. var params = {
  182. sender_id: vm.curDoctorCode,
  183. sender_name: vm.curDoctorName,
  184. content_type: contentType,
  185. content: content,
  186. view: 0
  187. };
  188. consultingAPI.sendMessage(vm.sessionId, {data: params}).then(function(res){
  189. console.log(res);
  190. // var html = "";
  191. // for(var i=0; i<res.messages.length; i++){
  192. // var reply = res.messages[i];
  193. // console.log(reply);
  194. // html += formatMsg(reply);
  195. // }
  196. // $("#talkBox").append(html);
  197. // $("#talkBox").slimscroll({
  198. // scrollTo: this.height
  199. // });
  200. });
  201. },
  202. connectSocket:function(){
  203. var vm = this;
  204. jQuery.getScript(httpRequest.socketUrl+"/socket.io/socket.io.js").done(function() {
  205. var socket = io.connect(httpRequest.socketUrl );
  206. socket.emit('login', {
  207. userId: vm.curDoctorCode,
  208. password: vm.curDoctorCode,
  209. sessionId: vm.sessionId,
  210. clientType: "pc_doctor"
  211. });
  212. socket.on('message', function (data) {
  213. console.log(data);
  214. if(data.read && (data.read == "all" || data.read == "one") ){
  215. return ;
  216. }
  217. var html = vm.formatMsg(data);
  218. $("#talkBox").append(html);
  219. $("#talkBox").slimscroll({
  220. scrollTo: 'bottom'
  221. });
  222. });
  223. socket.on('error', function (data) {
  224. console.log(data)
  225. });
  226. socket.on('ack', function (data) {
  227. });
  228. }).fail(function() {
  229. // dialog({contentType:'tipsbox', skin:'bk-popup' ,bottom:true, content:"医生实时对话连接失败!"}).show();
  230. });
  231. },
  232. formatMsg:function(reply){
  233. var vm = this;
  234. try{
  235. reply = JSON.parse(reply);
  236. }catch(e){
  237. }
  238. var isSelf = (reply.sender_id==vm.curDoctorCode) ? true : false;
  239. var isSystem = reply.sender_id == 'system';
  240. var html = '';
  241. if(reply.content_type == 7 || reply.content_type == 10 || reply.content_type == 13 || reply.content_type == 14){
  242. var content = reply.content;
  243. if(isSystem){
  244. content = '居民24小时内未回复,系统自动结束咨询';
  245. }
  246. html = template('sys_msg_tmp', {content: content});
  247. }else{
  248. var member;
  249. for(var i=0; i<vm.members.length; i++){
  250. if(reply.sender_id == vm.members[i].id){
  251. member = vm.members[i];
  252. break;
  253. }
  254. }
  255. var img = httpRequest.getImgUrl(member.avatar);
  256. if((img.indexOf('http') == -1) && (img.indexOf("https") == -1)){
  257. img = '../../../images/d-male.png';
  258. }
  259. var content = '';
  260. try{
  261. if(reply.content_type == 18 || reply.content_type == 19){//居民名片、聊天记录
  262. content = "暂不支持此类信息";
  263. }else{
  264. content = JSON.parse(reply.content);
  265. }
  266. }catch(e){
  267. if(reply.content_type == 12){ //视频文件
  268. var arr = reply.content.split(",");
  269. content = {};
  270. content.img = arr[0];
  271. content.path = arr[1];
  272. content.time = arr[2];
  273. }else{
  274. content = reply.content;
  275. }
  276. }
  277. var obj = {
  278. isSelf: isSelf,
  279. time: new Date(reply.timestamp).format('yyyy-MM-dd HH:mm:ss'),
  280. type: reply.content_type,
  281. name: member.name,
  282. img: img,
  283. content: content
  284. };
  285. html = template('msg_tmp', obj);
  286. }
  287. return html;
  288. },
  289. showWarningMsg:function(msg){
  290. toastr.warning(msg)
  291. }
  292. }
  293. })