group-invite.vue 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <template>
  2. <view v-if="$store.state.userStore.userInfo.type == 1" class="page group-invite">
  3. <view class="search-bar">
  4. <uni-search-bar v-model="searchText" cancelButton="none" placeholder="输入好友昵称搜索"></uni-search-bar>
  5. </view>
  6. <view class="friend-items">
  7. <scroll-view class="scroll-bar" scroll-with-animation="true" scroll-y="true">
  8. <view v-for="friend in friendItems" v-show="!searchText || friend.nickName.startsWith(searchText)"
  9. :key="friend.id">
  10. <uni-list-chat :avatar="friend.headImage" :title="friend.nickName" :clickable="true"
  11. @click="onSwitchChecked(friend)">
  12. <view class="chat-custom-right">
  13. <radio :checked="friend.checked" :disabled="friend.disabled" @click.stop="onSwitchChecked(friend)"/>
  14. </view>
  15. </uni-list-chat>
  16. </view>
  17. </scroll-view>
  18. </view>
  19. <view>
  20. <button type="primary" :disabled="inviteSize==0" @click="onInviteFriends()">邀请({{inviteSize}}) </button>
  21. </view>
  22. </view>
  23. </template>
  24. <script>
  25. export default {
  26. data() {
  27. return {
  28. groupId: null,
  29. searchText: "",
  30. groupMembers: [],
  31. friendItems: []
  32. }
  33. },
  34. methods: {
  35. onInviteFriends() {
  36. let inviteVo = {
  37. groupId: this.groupId,
  38. friendIds: []
  39. }
  40. this.friendItems.forEach((f) => {
  41. if (f.checked && !f.disabled) {
  42. inviteVo.friendIds.push(f.id);
  43. }
  44. })
  45. if (inviteVo.friendIds.length > 0) {
  46. this.$http({
  47. url: "/group/invite",
  48. method: 'POST',
  49. data: inviteVo
  50. }).then(() => {
  51. uni.showToast({
  52. title: "邀请成功",
  53. icon: 'none'
  54. })
  55. setTimeout(() => {
  56. // 回退并刷新
  57. let pages = getCurrentPages();
  58. let prevPage = pages[pages.length - 2];
  59. prevPage.$vm.loadGroupMembers();
  60. uni.navigateBack();
  61. }, 1000);
  62. })
  63. }
  64. },
  65. onShowUserInfo(userId) {
  66. uni.navigateTo({
  67. url: "/pages/common/user-info?id=" + userId
  68. })
  69. },
  70. onSwitchChecked(friend) {
  71. if (!friend.disabled) {
  72. friend.checked = !friend.checked;
  73. }
  74. console.log(this.inviteSize)
  75. },
  76. initFriendItems() {
  77. this.friendItems = [];
  78. let friends = this.$store.state.friendStore.friends;
  79. friends.forEach((f => {
  80. let item = {
  81. id: f.id,
  82. headImage: f.headImage,
  83. nickName: f.nickName,
  84. }
  85. item.disabled = this.isGroupMember(f.id);
  86. item.checked = item.disabled;
  87. this.friendItems.push(item);
  88. }))
  89. },
  90. loadGroupMembers(id) {
  91. this.$http({
  92. url: `/group/members/${id}`,
  93. method: "GET"
  94. }).then((members) => {
  95. this.groupMembers = members.filter(m => !m.quit);
  96. this.initFriendItems();
  97. })
  98. },
  99. isGroupMember(id) {
  100. return this.groupMembers.some(m => m.userId == id);
  101. }
  102. },
  103. computed: {
  104. inviteSize() {
  105. return this.friendItems.filter(f => !f.disabled && f.checked).length;
  106. }
  107. },
  108. onLoad(options) {
  109. this.groupId = options.id;
  110. this.loadGroupMembers(options.id);
  111. }
  112. }
  113. </script>
  114. <style lang="scss" scoped>
  115. .group-invite {
  116. position: relative;
  117. border: #dddddd solid 1px;
  118. display: flex;
  119. flex-direction: column;
  120. .friend-items {
  121. position: relative;
  122. flex: 1;
  123. overflow: hidden;
  124. .scroll-bar {
  125. height: 100%;
  126. }
  127. }
  128. }
  129. </style>