group-invite.vue 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  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" radius="100" 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.includes(searchText)"
  9. :key="friend.id">
  10. <view class="friend-item" @click="onSwitchChecked(friend)">
  11. <head-image :name="friend.nickName"
  12. :online="friend.online" :url="friend.headImage"
  13. :size="100"></head-image>
  14. <view class="friend-name">{{ friend.nickName}}</view>
  15. <view class="friend-checked">
  16. <radio :checked="friend.checked" :disabled="friend.disabled" @click.stop="onSwitchChecked(friend)"/>
  17. </view>
  18. </view>
  19. </view>
  20. </scroll-view>
  21. </view>
  22. <view>
  23. <button type="primary" :disabled="inviteSize==0" @click="onInviteFriends()">邀请({{inviteSize}}) </button>
  24. </view>
  25. </view>
  26. </template>
  27. <script>
  28. export default {
  29. data() {
  30. return {
  31. groupId: null,
  32. searchText: "",
  33. groupMembers: [],
  34. friendItems: []
  35. }
  36. },
  37. methods: {
  38. onInviteFriends() {
  39. let inviteVo = {
  40. groupId: this.groupId,
  41. friendIds: []
  42. }
  43. this.friendItems.forEach((f) => {
  44. if (f.checked && !f.disabled) {
  45. inviteVo.friendIds.push(f.id);
  46. }
  47. })
  48. if (inviteVo.friendIds.length > 0) {
  49. this.$http({
  50. url: "/group/invite",
  51. method: 'POST',
  52. data: inviteVo
  53. }).then(() => {
  54. uni.showToast({
  55. title: "邀请成功",
  56. icon: 'none'
  57. })
  58. setTimeout(() => {
  59. // 回退并刷新
  60. let pages = getCurrentPages();
  61. let prevPage = pages[pages.length - 2];
  62. prevPage.$vm.loadGroupMembers();
  63. uni.navigateBack();
  64. }, 1000);
  65. })
  66. }
  67. },
  68. onShowUserInfo(userId) {
  69. uni.navigateTo({
  70. url: "/pages/common/user-info?id=" + userId
  71. })
  72. },
  73. onSwitchChecked(friend) {
  74. if (!friend.disabled) {
  75. friend.checked = !friend.checked;
  76. }
  77. console.log(this.inviteSize)
  78. },
  79. initFriendItems() {
  80. this.friendItems = [];
  81. let friends = this.$store.state.friendStore.friends;
  82. friends.forEach((f => {
  83. if(f.delete){
  84. return
  85. }
  86. let item = {
  87. id: f.id,
  88. headImage: f.headImage,
  89. nickName: f.nickName,
  90. online: f.online
  91. }
  92. item.disabled = this.isGroupMember(f.id);
  93. item.checked = item.disabled;
  94. this.friendItems.push(item);
  95. }))
  96. },
  97. loadGroupMembers(id) {
  98. this.$http({
  99. url: `/group/members/${id}`,
  100. method: "GET"
  101. }).then((members) => {
  102. this.groupMembers = members.filter(m => !m.quit);
  103. this.initFriendItems();
  104. })
  105. },
  106. isGroupMember(id) {
  107. return this.groupMembers.some(m => m.userId == id);
  108. }
  109. },
  110. computed: {
  111. inviteSize() {
  112. return this.friendItems.filter(f => !f.disabled && f.checked).length;
  113. }
  114. },
  115. onLoad(options) {
  116. this.groupId = options.id;
  117. this.loadGroupMembers(options.id);
  118. }
  119. }
  120. </script>
  121. <style lang="scss" scoped>
  122. .group-invite {
  123. position: relative;
  124. border: #dddddd solid 1px;
  125. display: flex;
  126. flex-direction: column;
  127. .friend-items {
  128. position: relative;
  129. flex: 1;
  130. overflow: hidden;
  131. .friend-item {
  132. height: 120rpx;
  133. display: flex;
  134. margin-bottom: 1rpx;
  135. position: relative;
  136. padding: 0 30rpx ;
  137. align-items: center;
  138. background-color: white;
  139. white-space: nowrap;
  140. .friend-name {
  141. flex:1;
  142. padding-left: 20rpx;
  143. font-size: 30rpx;
  144. font-weight: 600;
  145. line-height: 60rpx;
  146. white-space: nowrap;
  147. overflow: hidden;
  148. }
  149. }
  150. .scroll-bar {
  151. height: 100%;
  152. }
  153. }
  154. }
  155. </style>