index.vue 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812
  1. <template>
  2. <view class="content">
  3. <view class="list">
  4. <view class="list_item hflex acenter" @click="toList(1)">
  5. <div class="item_img">
  6. <image src="/static/images/mine/notice.png" mode="aspectFill" style="width: 100%;height: 100%;"></image>
  7. <u-badge max="99" :absolute="true" :offset="[1,1]" :value="message_count" v-if="message_count>0"></u-badge>
  8. </div>
  9. <!-- <view class="number" v-if="message_count > 0">{{message_count}}</view> -->
  10. <view class="item_right">
  11. <view class="hflex acenter jbetween">
  12. <view class="hflex acenter">
  13. <view class="name">系统通知</view>
  14. </view>
  15. </view>
  16. </view>
  17. </view>
  18. <view class="list_item hflex acenter" @click="toList(2)">
  19. <div class="item_img">
  20. <image src="/static/images/mine/order_msg.png" mode="aspectFill" style="width: 100%;height: 100%;"></image>
  21. <u-badge max="99" :absolute="true" :offset="[1,1]" :value="order_count" v-if="order_count>0"></u-badge>
  22. </div>
  23. <!-- <image class="item_img" src="/static/images/mine/order_msg.png" mode="aspectFill"></image>
  24. <u-badge max="99" :absolute="true" :offset="[1,1]" :value="order_count" v-if="order_count>0"></u-badge> -->
  25. <!-- <view class="number" v-if="order_count > 0">{{order_count>99?'99+': order_count}}</view> -->
  26. <view class="item_right">
  27. <view class="hflex acenter jbetween">
  28. <view class="hflex acenter">
  29. <view class="name">订单消息</view>
  30. </view>
  31. </view>
  32. </view>
  33. </view>
  34. </view>
  35. <view class="chat_list_wraper">
  36. <scroll-view scroll-y="true"
  37. :class="'chat_list_wraper ' + (gotop ? (isIPX ? 'goTopX' : 'goTop') : 'goback')"
  38. :style="'padding-bottom: ' + (isIPX ? '270rpx' : '226rpx')">
  39. <view class="search_input" v-if="search_chats">
  40. <view>
  41. <icon type="search" size="12"></icon>
  42. <input placeholder="搜索" placeholder-style="color:#9B9B9B;line-height:21px;font-size:15px;"
  43. auto-focus confirm-type="search" type="text" @confirm="onSearch" @input="onInput"
  44. :value="input_code" />
  45. <icon type="clear" size="12" @tap.stop="clearInput" v-if="show_clear"></icon>
  46. </view>
  47. <text @tap="cancel">取消</text>
  48. </view>
  49. <view v-for="(item, index) in arr" :key="index" class="chat_list" :data-item="item" @tap.stop="del_chat"
  50. @longpress="longpress">
  51. <swipe-delete>
  52. <!-- 通知模块 -->
  53. <!-- <view class="tap_mask" @tap.stop="into_inform" :data-item="item"
  54. v-if="item.chatType == 'INFORM'">
  55. <view class="list_box">
  56. <view class="list_left">
  57. <view class="list_pic">
  58. <view v-if="unReadTotalNotNum > 0" class="em-unread-spot2">{{
  59. unReadTotalNotNum
  60. }}</view>
  61. <image :class="unReadTotalNotNum > 0 ? 'haveSpot' : ''"
  62. src="/static/images/inform.png"></image>
  63. </view>
  64. <view class="list_text">
  65. <text class="list_user"> 系统通知 </text>
  66. <text class="list_word"
  67. v-if="item.chatType == 'INFORM'">申请通知来自:{{ item.info.from }}</text>
  68. </view>
  69. </view>
  70. <view class="list_right">
  71. <text :data-username="item.username">{{ item.time }}</text>
  72. </view>
  73. </view>
  74. </view> -->
  75. <view class="tap_mask" @tap.stop="into_chatRoom" :data-item="item">
  76. <!-- 消息列表 -->
  77. <view class="list_box">
  78. <view class="list_left" :data-username="item.your?item.your.nickname:item.username">
  79. <view class="list_pic">
  80. <view class="em-msgNum"
  81. v-if="item.unReadCount > 0 || item.unReadCount == '99+'">
  82. {{ item.unReadCount }}</view>
  83. <image :src="item.your?item.your.avatarurl:'/static/images/theme2x.png'"></image>
  84. </view>
  85. <view class="list_text">
  86. <text class="list_user text_hide">{{item.your?item.your.nickname:item.username}}</text>
  87. <text class="list_word" v-if="item.msg.data[0].data">{{
  88. item.msg.data[0].data
  89. }}</text>
  90. <text class="list_word" v-if="item.msg.type == 'img'">[图片]</text>
  91. <text class="list_word" v-if="item.msg.type == 'audio'">[语音]</text>
  92. <!-- <text class="list_word" v-if="item.msg.type == 'video'"
  93. >[视频]</text
  94. > -->
  95. </view>
  96. </view>
  97. <view class="list_right">
  98. <text :data-username="item.username">{{ item.time }}</text>
  99. </view>
  100. </view>
  101. </view>
  102. </swipe-delete>
  103. </view>
  104. <long-press-modal :winSize="winSize" :popButton="popButton" @change="pickerMenuChange"
  105. :showPop="showPop" @hidePop="hidePop" :popStyle="popStyle" />
  106. <!-- <view v-if="arr.length" class="chat_noChat">
  107. <image class="ctbg" src="/static/images/ctbg.png"></image>
  108. 暂无聊天消息
  109. </view> -->
  110. <!-- </view> -->
  111. </scroll-view>
  112. <!-- bug: margin-bottom 不生效 需要加一个空标签-->
  113. <view style="height: 1px"></view>
  114. <view class="mask" @tap="close_mask" v-if="show_mask"></view>
  115. <!-- <view :class="isIPX ? 'chatRoom_tab_X' : 'chatRoom_tab'"> -->
  116. <!-- <view class="tableBar">
  117. <view v-if="unReadSpotNum > 0 || unReadSpotNum == '99+'"
  118. :class="'em-unread-spot ' +(unReadSpotNum == '99+' ? 'em-unread-spot-litleFont' : '')">
  119. {{ unReadSpotNum == '99+'?unReadSpotNum:unReadSpotNum+ unReadTotalNotNum }}</view>
  120. <image :class="unReadSpotNum > 0 || unReadSpotNum == '99+' ? 'haveSpot' : ''"
  121. src="@/static/images/sessionhighlight2x.png"></image>
  122. <text class="activeText">消息</text>
  123. </view>
  124. <view class="tableBar" @tap="tab_contacts">
  125. <image src="/static/images/comtacts2x.png"></image>
  126. <text>联系人</text>
  127. </view> -->
  128. <!-- <view class="tableBar" @tap="tab_notification">
  129. <view v-if="unReadTotalNotNum > 0" class="em-unread-spot">{{
  130. unReadTotalNotNum
  131. }}</view>
  132. <image
  133. :class="unReadTotalNotNum > 0 ? 'haveSpot' : ''"
  134. src="/static/images/notice.png"
  135. ></image>
  136. <text>通知</text>
  137. </view> -->
  138. <!-- <view class="tableBar" @tap="tab_setting">
  139. <image src="/static/images/setting2x.png"></image>
  140. <text>我的</text>
  141. </view> -->
  142. <!-- </view> -->
  143. </view>
  144. </view>
  145. </template>
  146. <script>
  147. import $api from '@/static/js/api.js'
  148. let disp = require("@/utils/broadcast");
  149. var WebIM = require("@/utils/WebIM")["default"];
  150. let isfirstTime = true;
  151. import swipeDelete from "@/components/swipedelete/swipedelete";
  152. import longPressModal from "@/components/longPressModal/index";
  153. var that = ''
  154. export default {
  155. data() {
  156. return {
  157. pageList1:[],
  158. search_btn: true,
  159. search_chats: false,
  160. show_mask: false,
  161. yourname: "",
  162. unReadSpotNum: 0,
  163. unReadNoticeNum: 0,
  164. messageNum: 0,
  165. unReadTotalNotNum: 0,
  166. arr: [],
  167. show_clear: false,
  168. member: "",
  169. isIPX: false,
  170. gotop: false,
  171. input_code: "",
  172. groupName: {},
  173. winSize: {},
  174. popButton: ["删除该聊天"],
  175. showPop: false,
  176. popStyle: "",
  177. currentVal: '',
  178. message_count: 100,
  179. order_count: 100
  180. }
  181. },
  182. components: {
  183. swipeDelete,
  184. longPressModal,
  185. },
  186. props: {},
  187. onLoad() {
  188. that = this
  189. this.getWindowSize();
  190. let me = this;
  191. //监听加好友申请
  192. disp.on("em.subscribe", function() {
  193. me.getChatList();
  194. /* me.setData({
  195. messageNum: getApp().globalData.saveFriendList.length,
  196. unReadTotalNotNum: getApp().globalData.saveFriendList.length +
  197. getApp().globalData.saveGroupInvitedList.length,
  198. }); */
  199. });
  200. //监听解散群
  201. disp.on("em.invite.deleteGroup", function() {
  202. me.listGroups();
  203. me.getRoster();
  204. me.getChatList();
  205. me.messageNum= getApp().globalData.saveFriendList.length
  206. });
  207. //监听未读消息数
  208. disp.on("em.unreadspot", function(message) {
  209. me.getChatList();
  210. me.unReadSpotNum= getApp().globalData.unReadMessageNum > 99 ?
  211. "99+" :
  212. getApp().globalData.unReadMessageNum
  213. });
  214. //监听未读加群“通知”
  215. disp.on("em.invite.joingroup", function() {
  216. me.unReadNoticeNum= getApp().globalData.saveGroupInvitedList.length
  217. me.unReadTotalNotNum= getApp().globalData.saveFriendList.length +
  218. getApp().globalData.saveGroupInvitedList.length
  219. });
  220. disp.on("em.contacts.remove", function() {
  221. me.getChatList();
  222. me.getRoster();
  223. });
  224. this.getRoster();
  225. },
  226. onShow: function() {
  227. that.getNum()
  228. // uni.hideHomeButton();
  229. this.getChatList();
  230. console.log('111111111',this.arr)
  231. this.unReadSpotNum =
  232. getApp().globalData.unReadMessageNum > 99 ?
  233. "99+" :
  234. getApp().globalData.unReadMessageNum
  235. try{
  236. this.messageNum = getApp().globalData.saveFriendList.length
  237. this.unReadNoticeNum = getApp().globalData.saveGroupInvitedList.length
  238. this.unReadTotalNotNum =
  239. getApp().globalData.saveFriendList.length +
  240. getApp().globalData.saveGroupInvitedList.length
  241. }catch(e){
  242. //TODO handle the exception
  243. }
  244. if (getApp().globalData.isIPX) {
  245. this.isIPX = true
  246. }
  247. },
  248. methods: {
  249. getNum() {
  250. $api.req({
  251. url: '/data/api.business.User/messagenoread',
  252. method: 'POST',
  253. }, function(res) {
  254. if(res.code == 1) {
  255. console.log(res)
  256. that.message_count = res.data.message_count
  257. that.order_count = res.data.order_count
  258. }
  259. })
  260. },
  261. listGroups() {
  262. var me = this;
  263. return WebIM.conn.getGroup({
  264. limit: 50,
  265. success: function(res) {
  266. let groupName = {};
  267. let listGroup = res.data || [];
  268. listGroup.forEach((item) => {
  269. groupName[item.groupid] = item.groupname;
  270. });
  271. me.groupName= groupName,
  272. uni.setStorage({
  273. key: "listGroup",
  274. data: res.data,
  275. });
  276. me.getChatList();
  277. },
  278. error: function(err) {
  279. console.log(err);
  280. },
  281. });
  282. },
  283. getRoster() {
  284. let me = this;
  285. let rosters = {
  286. success(roster) {
  287. var member = [];
  288. for (let i = 0; i < roster.length; i++) {
  289. if (roster[i].subscription == "both") {
  290. member.push(roster[i]);
  291. }
  292. }
  293. uni.setStorage({
  294. key: "member",
  295. data: member,
  296. });
  297. me.member= member
  298. me.listGroups();
  299. //if(!systemReady){
  300. disp.fire("em.main.ready");
  301. //systemReady = true;
  302. //}
  303. me.arr= me.getChatList(),
  304. console.log('消息列表:',me.arr);
  305. me.unReadSpotNum= getApp().globalData.unReadMessageNum > 99 ?
  306. "99+" :
  307. getApp().globalData.unReadMessageNum
  308. },
  309. error(err) {
  310. console.log(err);
  311. },
  312. };
  313. WebIM.conn.getRoster(rosters);
  314. },
  315. /* // // 不包含陌生人版本
  316. // getChatList() {
  317. // var array = [];
  318. // var member = uni.getStorageSync("member");
  319. // var myName = uni.getStorageSync("myUsername");
  320. // var listGroups = uni.getStorageSync('listGroup') || [];
  321. // for (let i = 0; i < member.length; i++) {
  322. // let newChatMsgs = uni.getStorageSync(member[i].name + myName) || [];
  323. // let historyChatMsgs = uni.getStorageSync("rendered_" + member[i].name + myName) || [];
  324. // let curChatMsgs = historyChatMsgs.concat(newChatMsgs);
  325. // if (curChatMsgs.length) {
  326. // let lastChatMsg = curChatMsgs[curChatMsgs.length - 1];
  327. // lastChatMsg.unReadCount = newChatMsgs.length;
  328. // if (lastChatMsg.unReadCount > 99) {
  329. // lastChatMsg.unReadCount = "99+";
  330. // }
  331. // let dateArr = lastChatMsg.time.split(' ')[0].split('-');
  332. // let timeArr = lastChatMsg.time.split(' ')[1].split(':');
  333. // let month = dateArr[2] < 10 ? '0' + dateArr[2] : dateArr[2];
  334. // lastChatMsg.dateTimeNum = `${dateArr[1]}${month}${timeArr[0]}${timeArr[1]}${timeArr[2]}`;
  335. // lastChatMsg.time = `${dateArr[1]}月${dateArr[2]}日 ${timeArr[0]}:${timeArr[1]}`;
  336. // array.push(lastChatMsg);
  337. // }
  338. // }
  339. // for(let i = 0; i < listGroups.length; i++){
  340. // let newChatMsgs = uni.getStorageSync(listGroups[i].groupid + myName) || [];
  341. // let historyChatMsgs = uni.getStorageSync("rendered_" + listGroups[i].groupid + myName) || [];
  342. // let curChatMsgs = historyChatMsgs.concat(newChatMsgs);
  343. // if(curChatMsgs.length){
  344. // let lastChatMsg = curChatMsgs[curChatMsgs.length - 1];
  345. // lastChatMsg.unReadCount = newChatMsgs.length;
  346. // if(lastChatMsg.unReadCount > 99) {
  347. // lastChatMsg.unReadCount = "99+";
  348. // }
  349. // let dateArr = lastChatMsg.time.split(' ')[0].split('-')
  350. // let timeArr = lastChatMsg.time.split(' ')[1].split(':')
  351. // let month = dateArr[2] < 10 ? '0' + dateArr[2] : dateArr[2]
  352. // lastChatMsg.time = `${dateArr[1]}月${dateArr[2]}日 ${timeArr[0]}:${timeArr[1]}`
  353. // lastChatMsg.dateTimeNum = `${dateArr[1]}${month}${timeArr[0]}${timeArr[1]}${timeArr[2]}`
  354. // lastChatMsg.groupName = listGroups[i].groupname
  355. // array.push(lastChatMsg);
  356. // }
  357. // }
  358. // array.sort((a, b) => {
  359. // return b.dateTimeNum - a.dateTimeNum;
  360. // });
  361. // return array;
  362. // }, */
  363. // 包含陌生人版本
  364. getChatList() {
  365. var myName = uni.getStorageSync("myUsername");
  366. var array = [];
  367. const me = this;
  368. uni.getStorageInfo({
  369. success: function(res) {
  370. let storageKeys = res.keys;
  371. let newChatMsgKeys = [];
  372. let historyChatMsgKeys = [];
  373. let len = myName.length;
  374. storageKeys.forEach((item) => {
  375. if (item.slice(-len) == myName && item.indexOf("rendered_") == -1) {
  376. newChatMsgKeys.push(item);
  377. } else if (
  378. item.slice(-len) == myName &&
  379. item.indexOf("rendered_") > -1
  380. ) {
  381. historyChatMsgKeys.push(item);
  382. } else if (item === "INFORM") {
  383. newChatMsgKeys.push(item);
  384. }
  385. });
  386. cul.call(me, newChatMsgKeys, historyChatMsgKeys);
  387. },
  388. });
  389. function cul(newChatMsgKeys, historyChatMsgKeys) {
  390. let array = [];
  391. let lastChatMsg;
  392. for (let i = historyChatMsgKeys.length; i > 0, i--;) {
  393. let index = newChatMsgKeys.indexOf(historyChatMsgKeys[i].slice(9));
  394. if (index > -1) {
  395. let newChatMsgs = uni.getStorageSync(newChatMsgKeys[index]) || [];
  396. if (newChatMsgKeys.includes()) {}
  397. if (newChatMsgs.length) {
  398. lastChatMsg = newChatMsgs[newChatMsgs.length - 1];
  399. lastChatMsg.unReadCount = newChatMsgs.length;
  400. if (lastChatMsg.unReadCount > 99) {
  401. lastChatMsg.unReadCount = "99+";
  402. }
  403. let dateArr = lastChatMsg.time.split(" ")[0].split("-");
  404. let timeArr = lastChatMsg.time.split(" ")[1].split(":");
  405. let month = dateArr[2] < 10 ? "0" + dateArr[2] : dateArr[2];
  406. lastChatMsg.dateTimeNum = `${dateArr[1]}${month}${timeArr[0]}${timeArr[1]}${timeArr[2]}`;
  407. lastChatMsg.time = `${dateArr[1]}月${dateArr[2]}日 ${timeArr[0]}:${timeArr[1]}`;
  408. newChatMsgKeys.splice(index, 1);
  409. } else {
  410. let historyChatMsgs = uni.getStorageSync(historyChatMsgKeys[i]);
  411. if (historyChatMsgs.length) {
  412. lastChatMsg = historyChatMsgs[historyChatMsgs.length - 1];
  413. let dateArr = lastChatMsg.time.split(" ")[0].split("-");
  414. let timeArr = lastChatMsg.time.split(" ")[1].split(":");
  415. let month = dateArr[2] < 10 ? "0" + dateArr[2] : dateArr[2];
  416. lastChatMsg.dateTimeNum =
  417. `${dateArr[1]}${month}${timeArr[0]}${timeArr[1]}${timeArr[2]}`;
  418. lastChatMsg.time = `${dateArr[1]}月${dateArr[2]}日 ${timeArr[0]}:${timeArr[1]}`;
  419. }
  420. }
  421. } else {
  422. let historyChatMsgs = uni.getStorageSync(historyChatMsgKeys[i]);
  423. if (historyChatMsgs.length) {
  424. lastChatMsg = historyChatMsgs[historyChatMsgs.length - 1];
  425. let dateArr = lastChatMsg.time.split(" ")[0].split("-");
  426. let timeArr = lastChatMsg.time.split(" ")[1].split(":");
  427. let month = dateArr[2] < 10 ? "0" + dateArr[2] : dateArr[2];
  428. lastChatMsg.dateTimeNum = `${dateArr[1]}${month}${timeArr[0]}${timeArr[1]}${timeArr[2]}`;
  429. lastChatMsg.time = `${dateArr[1]}月${dateArr[2]}日 ${timeArr[0]}:${timeArr[1]}`;
  430. }
  431. }
  432. if (
  433. lastChatMsg &&
  434. (lastChatMsg.chatType == "groupchat" ||
  435. lastChatMsg.chatType == "chatRoom")
  436. ) {
  437. lastChatMsg.groupName = me.groupName[lastChatMsg.info.to];
  438. }
  439. lastChatMsg && lastChatMsg.username != myName &&
  440. array.push(lastChatMsg);
  441. }
  442. for (let i = newChatMsgKeys.length; i > 0, i--;) {
  443. let newChatMsgs = uni.getStorageSync(newChatMsgKeys[i]) || [];
  444. if (newChatMsgs.length) {
  445. lastChatMsg = newChatMsgs[newChatMsgs.length - 1];
  446. lastChatMsg.unReadCount = newChatMsgs.length;
  447. if (lastChatMsg.unReadCount > 99) {
  448. lastChatMsg.unReadCount = "99+";
  449. }
  450. let dateArr = lastChatMsg.time.split(" ")[0].split("-");
  451. let timeArr = lastChatMsg.time.split(" ")[1].split(":");
  452. let month = dateArr[2] < 10 ? "0" + dateArr[2] : dateArr[2];
  453. lastChatMsg.dateTimeNum = `${dateArr[1]}${month}${timeArr[0]}${timeArr[1]}${timeArr[2]}`;
  454. lastChatMsg.time = `${dateArr[1]}月${dateArr[2]}日 ${timeArr[0]}:${timeArr[1]}`;
  455. if (
  456. lastChatMsg.chatType == "groupchat" ||
  457. lastChatMsg.chatType == "chatRoom"
  458. ) {
  459. lastChatMsg.groupName = me.groupName[lastChatMsg.info.to];
  460. }
  461. lastChatMsg.username != myName && array.push(lastChatMsg);
  462. }
  463. }
  464. array.sort((a, b) => {
  465. return b.dateTimeNum - a.dateTimeNum;
  466. });
  467. this.arr= array
  468. console.log('this.arr',this.arr)
  469. }
  470. },
  471. openSearch: function() {
  472. this.search_btn= false
  473. this.search_chats= true
  474. this.gotop= true
  475. },
  476. onSearch: function(val) {
  477. let searchValue = val.detail.value;
  478. var myName = uni.getStorageSync("myUsername");
  479. const me = this;
  480. let serchList = [];
  481. let arr = [];
  482. uni.getStorageInfo({
  483. success: function(res) {
  484. let storageKeys = res.keys;
  485. let chatKeys = [];
  486. let len = myName.length;
  487. storageKeys.forEach((item) => {
  488. if (item.slice(-len) == myName) {
  489. chatKeys.push(item);
  490. }
  491. });
  492. chatKeys.forEach((item, index) => {
  493. if (item.indexOf(searchValue) != -1) {
  494. serchList.push(item);
  495. }
  496. });
  497. let lastChatMsg = "";
  498. serchList.forEach((item, index) => {
  499. let chatMsgs = uni.getStorageSync(item) || [];
  500. if (chatMsgs.length) {
  501. lastChatMsg = chatMsgs[chatMsgs.length - 1];
  502. let dateArr = lastChatMsg.time.split(" ")[0].split("-");
  503. let timeArr = lastChatMsg.time.split(" ")[1].split(":");
  504. let month = dateArr[2] < 10 ? "0" + dateArr[2] : dateArr[2];
  505. lastChatMsg.dateTimeNum =
  506. `${dateArr[1]}${month}${timeArr[0]}${timeArr[1]}${timeArr[2]}`;
  507. lastChatMsg.time =
  508. `${dateArr[1]}月${dateArr[2]}日 ${timeArr[0]}:${timeArr[1]}`;
  509. arr.push(lastChatMsg);
  510. }
  511. });
  512. me.arr = arr
  513. },
  514. });
  515. },
  516. leftClick() {},
  517. cancel: function() {
  518. this.getChatList();
  519. this.search_btn= true
  520. this.search_chats= false
  521. //arr: this.getChatList(),
  522. this.unReadSpotNum= getApp().globalData.unReadMessageNum > 99 ? "99+" : getApp().globalData.unReadMessageNum
  523. this.gotop= false
  524. },
  525. clearInput: function() {
  526. this.input_code= ""
  527. this.show_clear= false
  528. },
  529. onInput: function(e) {
  530. let inputValue = e.detail.value;
  531. if (inputValue) {
  532. this.show_clear= true
  533. } else {
  534. this.show_clear= false
  535. }
  536. },
  537. tab_contacts: function() {
  538. uni.redirectTo({
  539. url: "../main/main?myName=" + uni.getStorageSync("myUsername"),
  540. });
  541. },
  542. close_mask: function() {
  543. this.search_btn= true
  544. this.search_chats= false
  545. this.show_mask= false
  546. },
  547. tab_setting: function() {
  548. uni.redirectTo({
  549. url: "../setting/setting",
  550. });
  551. },
  552. tab_notification: function() {
  553. uni.redirectTo({
  554. url: "../notification/notification",
  555. });
  556. },
  557. into_chatRoom: function(event) {
  558. let detail = event.currentTarget.dataset.item;
  559. if (
  560. detail.chatType == "groupchat" ||
  561. detail.chatType == "chatRoom" ||
  562. detail.groupName
  563. ) {
  564. this.into_groupChatRoom(detail);
  565. } else {
  566. this.into_singleChatRoom(detail);
  567. }
  568. },
  569. // 单聊
  570. into_singleChatRoom: function(detail) {
  571. console.log('detail',detail);
  572. var my = uni.getStorageSync("myUsername");
  573. var nameList = {
  574. myName: my,
  575. your: detail.username,
  576. };
  577. uni.navigateTo({
  578. url: "/pages/chatroom/chatroom?username=" + JSON.stringify(nameList),
  579. });
  580. },
  581. // 群聊 和 聊天室 (两个概念)
  582. into_groupChatRoom: function(detail) {
  583. var my = uni.getStorageSync("myUsername");
  584. var nameList = {
  585. myName: my,
  586. your: detail.groupName,
  587. groupId: detail.info.to,
  588. };
  589. uni.navigateTo({
  590. url: "../groupChatRoom/groupChatRoom?username=" + JSON.stringify(nameList),
  591. });
  592. },
  593. into_inform: function() {
  594. uni.redirectTo({
  595. url: "../notification/notification",
  596. });
  597. },
  598. removeAndRefresh: function(event) {
  599. let removeId = event.currentTarget.dataset.item.info.from
  600. let ary = getApp().globalData.saveFriendList
  601. let idx
  602. if (ary.length > 0) {
  603. ary.forEach((v, k) => {
  604. if (v.from == removeId) {
  605. idx = k
  606. }
  607. })
  608. getApp().globalData.saveFriendList.splice(idx, 1);
  609. }
  610. uni.removeStorageSync('INFORM')
  611. },
  612. del_chat: function(event) {
  613. let detail = event.currentTarget.dataset.item;
  614. let nameList = {};
  615. let me = this;
  616. // 删除当前选中群组聊天列表
  617. if (detail.chatType == "groupchat" || detail.chatType == "chatRoom") {
  618. nameList = {
  619. your: detail.info.to,
  620. };
  621. //删除当前选中通知列表
  622. } else if (detail.chatType === "INFORM") {
  623. nameList = {
  624. your: "INFORM",
  625. };
  626. }
  627. //删除当前选中好友聊天列表
  628. else {
  629. nameList = {
  630. your: detail.username,
  631. };
  632. }
  633. var myName = uni.getStorageSync("myUsername");
  634. var currentPage = getCurrentPages();
  635. uni.showModal({
  636. title: "确认删除?",
  637. confirmText: "删除",
  638. success: function(res) {
  639. if (res.confirm) {
  640. uni.removeStorageSync(nameList.your + myName);
  641. uni.removeStorageSync("rendered_" + nameList.your + myName);
  642. nameList.your === 'INFORM' && me.removeAndRefresh(event);
  643. // if (Object.keys(currentPage[0]).length>0) {
  644. // currentPage[0].onShow();
  645. // }
  646. disp.fire("em.chat.session.remove");
  647. me.getChatList();
  648. }
  649. },
  650. fail: function(err) {
  651. console.log('删除列表', err);
  652. },
  653. });
  654. },
  655. longpress: function(e) {
  656. //将当前选中的值存在data中方便后续操作
  657. this.currentVal = e
  658. let [touches, style, index] = [e.touches[0], "", e.currentTarget.dataset.index, ];
  659. /* 因 非H5端不兼容 style 属性绑定 Object ,所以拼接字符 */
  660. if (touches.clientY > this.winSize.height / 2) {
  661. style = `bottom:${this.winSize.height - touches.clientY}px;`;
  662. } else {
  663. style = `top:${touches.clientY}px;`;
  664. }
  665. if (touches.clientX > this.winSize.witdh / 2) {
  666. style += `right:${this.winSize.witdh - touches.clientX}px`;
  667. } else {
  668. style += `left:${touches.clientX}px`;
  669. }
  670. this.popStyle = style;
  671. // this.pickerUserIndex = Number(index);
  672. this.showShade = true;
  673. this.$nextTick(() => {
  674. setTimeout(() => {
  675. this.showPop = true;
  676. }, 10);
  677. });
  678. },
  679. /* 获取窗口尺寸 */
  680. getWindowSize() {
  681. uni.getSystemInfo({
  682. success: (res) => {
  683. this.winSize = {
  684. witdh: res.windowWidth,
  685. height: res.windowHeight,
  686. };
  687. },
  688. });
  689. },
  690. hidePop() {
  691. this.showPop = false;
  692. },
  693. pickerMenuChange() {
  694. console.log("当前选中>>", this.currentVal);
  695. this.del_chat(this.currentVal)
  696. },
  697. toList(index) {
  698. $api.jump('/pages/mine/message/list?index=' + index)
  699. }
  700. },
  701. }
  702. </script>
  703. <style lang="scss" scoped>
  704. @import "./chat.css";
  705. .content::v-deep {
  706. padding: 0 30rpx;
  707. background-color: #fff;
  708. .list {
  709. width: 100%;
  710. .list_item {
  711. width: 100%;
  712. margin: 48rpx 0 36rpx;
  713. position: relative;
  714. .item_img {
  715. width: 88rpx;
  716. height: 88rpx;
  717. border-radius: 50%;
  718. position: relative;
  719. .u-badge {
  720. right: -20rpx !important;
  721. }
  722. }
  723. .number {
  724. position: absolute;
  725. top: 5rpx;
  726. left: 70rpx;
  727. /* width: 32rpx;
  728. height: 32rpx; */
  729. box-sizing: border-box;
  730. padding: 3px 5px;
  731. background-color: #ff4b4b;
  732. border: 1rpx solid #fff;
  733. border-radius: 50%;
  734. font-size: 24rpx;
  735. color: #fff;
  736. text-align: center;
  737. line-height: 32rpx;
  738. }
  739. .item_right {
  740. width: calc(100% - 108rpx);
  741. padding-left: 20rpx;
  742. .name {
  743. font-size: 28rpx;
  744. color: #222;
  745. }
  746. .text_style1 {
  747. font-size: 24rpx;
  748. color: #999;
  749. }
  750. .text_style2 {
  751. margin-left: 10rpx;
  752. width: 56rpx;
  753. height: 28rpx;
  754. border-radius: 8rpx;
  755. border: 1rpx solid #506dff;
  756. font-size: 20rpx;
  757. color: #506dff;
  758. text-align: center;
  759. line-height: 28rpx;
  760. }
  761. }
  762. }
  763. }
  764. }
  765. </style>