UNPKG

ngx-tencent-im

Version:
121 lines 22.5 kB
import { ChangeDetectionStrategy, Component, ViewChild } from '@angular/core'; import { debounceTime, distinctUntilChanged } from 'rxjs/operators'; import { MESSAGE_STATUS, TIM } from '../../shared.data'; import { showAction } from '../../store/actions'; import { groupListSelector } from '../../store/selectors/group.selector'; import { CreateGroupComponent } from '../create-group/create-group.component'; import * as i0 from "@angular/core"; import * as i1 from "@ngrx/store"; import * as i2 from "ng-zorro-antd/modal"; import * as i3 from "../../tim-helper.service"; import * as i4 from "ng-zorro-antd/select"; import * as i5 from "../group-item/group-item.component"; import * as i6 from "@angular/forms"; import * as i7 from "@angular/common"; export class GroupListComponent { constructor(store, cd, modal, timHelper) { this.store = store; this.cd = cd; this.modal = modal; this.timHelper = timHelper; this.loading = false; this.groupList = []; this.groupListOfOption = []; } ngOnInit() { this.subscription = this.store.select(groupListSelector).subscribe(res => { this.groupList = res; this.cd.markForCheck(); }); this.selectGroup.nzOnSearch.pipe(debounceTime(600), distinctUntilChanged()) .subscribe((res) => { this.searchGroupByID(res); }); } searchGroupByID(queryString) { if (queryString.trim().length > 0) { this.loading = true; this.timHelper.tim .searchGroupByID(queryString) .then(({ data: { group } }) => { this.groupListOfOption = [group]; this.cd.markForCheck(); this.loading = false; }) .catch(() => { this.store.dispatch(showAction({ msgType: MESSAGE_STATUS.error, message: '没有找到该群' })); this.loading = false; }); } } applyJoinGroup(group) { this.timHelper.tim .joinGroup({ groupID: group.groupID, applyMessage: '' }) .then(async (res) => { switch (res.data.status) { case TIM.TYPES.JOIN_STATUS_WAIT_APPROVAL: this.store.dispatch(showAction({ msgType: MESSAGE_STATUS.info, message: '申请成功,等待群管理员确认!' })); this.group = null; this.groupListOfOption = []; break; case TIM.TYPES.JOIN_STATUS_SUCCESS: await this.timHelper.checkoutConversation(`GROUP${res.data.group.groupID}`); this.store.dispatch(showAction({ msgType: MESSAGE_STATUS.success, message: '加群成功' })); this.group = null; this.groupListOfOption = []; break; case TIM.TYPES.JOIN_STATUS_ALREADY_IN_GROUP: this.store.dispatch(showAction({ msgType: MESSAGE_STATUS.warning, message: '您已经是群成员了,请勿重复加群哦!' })); this.group = null; this.groupListOfOption = []; break; default: break; } this.cd.markForCheck(); }) .catch(error => { this.store.dispatch(showAction({ msgType: MESSAGE_STATUS.error, message: error.message })); }); } createGroup() { this.modal.create({ nzTitle: `创建群组`, nzContent: CreateGroupComponent, nzMaskClosable: false, nzFooter: null, nzWidth: '40%', nzStyle: { top: '20px' }, // nzComponentParams: {} }); } ngOnDestroy() { if (this.subscription) { this.subscription.unsubscribe(); } } } GroupListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: GroupListComponent, deps: [{ token: i1.Store }, { token: i0.ChangeDetectorRef }, { token: i2.NzModalService }, { token: i3.TimHelperService }], target: i0.ɵɵFactoryTarget.Component }); GroupListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: GroupListComponent, selector: "app-group-list", viewQueries: [{ propertyName: "selectGroup", first: true, predicate: ["search"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"list-container\">\r\n <div class=\"header-bar\">\r\n <nz-select #search nzShowSearch nzServerSearch nzSize=\"small\" [nzLoading]=\"loading\"\r\n nzPlaceHolder=\"\u8F93\u5165\u7FA4ID\u641C\u7D22\" [(ngModel)]=\"group\" (ngModelChange)=\"applyJoinGroup($event)\">\r\n <nz-option *ngFor=\"let item of groupListOfOption\" [nzLabel]=\"item.groupID\" [nzValue]=\"item\">\r\n </nz-option>\r\n </nz-select>\r\n <button title=\"\u521B\u5EFA\u7FA4\u7EC4\" (click)=\"createGroup()\">\r\n <i class=\"tim-icon-add\"></i>\r\n </button>\r\n </div>\r\n <div class=\"group-container\">\r\n <app-group-item [group]=\"group\" *ngFor=\"let group of groupList\">\r\n </app-group-item>\r\n </div>\r\n</div>\r\n", styles: [".list-container{height:100%;width:100%;display:flex;flex-direction:column}.list-container .group-container{overflow-y:scroll}.list-container .header-bar{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;justify-content:center;align-content:center;flex-shrink:0;height:50px;border-bottom:1px solid #303841;padding:10px 10px 10px 20px}.list-container .header-bar nz-select{width:100%}.list-container .header-bar .group-seach-bar{width:100%;margin-right:10px}.list-container .header-bar button{float:right;display:inline-block;cursor:pointer;background:#303841;border:none;color:#76828c;box-sizing:border-box;transition:.3s;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;margin:0;padding:0;width:30px;height:30px;line-height:34px;font-size:24px;text-align:center;white-space:nowrap;border-radius:50%;outline:0;flex-shrink:0}.list-container .header-bar button:hover{transform:rotate(360deg);color:#5cadff}.list-container .scroll-container{overflow-y:scroll;flex:1}\n"], components: [{ type: i4.NzSelectComponent, selector: "nz-select", inputs: ["nzId", "nzSize", "nzOptionHeightPx", "nzOptionOverflowSize", "nzDropdownClassName", "nzDropdownMatchSelectWidth", "nzDropdownStyle", "nzNotFoundContent", "nzPlaceHolder", "nzMaxTagCount", "nzDropdownRender", "nzCustomTemplate", "nzSuffixIcon", "nzClearIcon", "nzRemoveIcon", "nzMenuItemSelectedIcon", "nzTokenSeparators", "nzMaxTagPlaceholder", "nzMaxMultipleCount", "nzMode", "nzFilterOption", "compareWith", "nzAllowClear", "nzBorderless", "nzShowSearch", "nzLoading", "nzAutoFocus", "nzAutoClearSearchValue", "nzServerSearch", "nzDisabled", "nzOpen", "nzBackdrop", "nzOptions", "nzShowArrow"], outputs: ["nzOnSearch", "nzScrollToBottom", "nzOpenChange", "nzBlur", "nzFocus"], exportAs: ["nzSelect"] }, { type: i4.NzOptionComponent, selector: "nz-option", inputs: ["nzLabel", "nzValue", "nzDisabled", "nzHide", "nzCustomContent"], exportAs: ["nzOption"] }, { type: i5.GroupItemComponent, selector: "app-group-item", inputs: ["group"] }], directives: [{ type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: GroupListComponent, decorators: [{ type: Component, args: [{ selector: 'app-group-list', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"list-container\">\r\n <div class=\"header-bar\">\r\n <nz-select #search nzShowSearch nzServerSearch nzSize=\"small\" [nzLoading]=\"loading\"\r\n nzPlaceHolder=\"\u8F93\u5165\u7FA4ID\u641C\u7D22\" [(ngModel)]=\"group\" (ngModelChange)=\"applyJoinGroup($event)\">\r\n <nz-option *ngFor=\"let item of groupListOfOption\" [nzLabel]=\"item.groupID\" [nzValue]=\"item\">\r\n </nz-option>\r\n </nz-select>\r\n <button title=\"\u521B\u5EFA\u7FA4\u7EC4\" (click)=\"createGroup()\">\r\n <i class=\"tim-icon-add\"></i>\r\n </button>\r\n </div>\r\n <div class=\"group-container\">\r\n <app-group-item [group]=\"group\" *ngFor=\"let group of groupList\">\r\n </app-group-item>\r\n </div>\r\n</div>\r\n", styles: [".list-container{height:100%;width:100%;display:flex;flex-direction:column}.list-container .group-container{overflow-y:scroll}.list-container .header-bar{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;justify-content:center;align-content:center;flex-shrink:0;height:50px;border-bottom:1px solid #303841;padding:10px 10px 10px 20px}.list-container .header-bar nz-select{width:100%}.list-container .header-bar .group-seach-bar{width:100%;margin-right:10px}.list-container .header-bar button{float:right;display:inline-block;cursor:pointer;background:#303841;border:none;color:#76828c;box-sizing:border-box;transition:.3s;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;margin:0;padding:0;width:30px;height:30px;line-height:34px;font-size:24px;text-align:center;white-space:nowrap;border-radius:50%;outline:0;flex-shrink:0}.list-container .header-bar button:hover{transform:rotate(360deg);color:#5cadff}.list-container .scroll-container{overflow-y:scroll;flex:1}\n"] }] }], ctorParameters: function () { return [{ type: i1.Store }, { type: i0.ChangeDetectorRef }, { type: i2.NzModalService }, { type: i3.TimHelperService }]; }, propDecorators: { selectGroup: [{ type: ViewChild, args: ['search', { static: true }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-list.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-tencent-im/src/group/group-list/group-list.component.ts","../../../../../projects/ngx-tencent-im/src/group/group-list/group-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { Store } from '@ngrx/store';\r\n\r\nimport { NzModalService } from 'ng-zorro-antd/modal';\r\nimport { NzSelectComponent } from 'ng-zorro-antd/select';\r\nimport { Subscription } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\r\n\r\n\r\nimport { Group } from 'tim-js-sdk';\r\nimport { MESSAGE_STATUS, TIM } from '../../shared.data';\r\nimport { showAction } from '../../store/actions';\r\nimport { groupListSelector } from '../../store/selectors/group.selector';\r\nimport { TimHelperService } from '../../tim-helper.service';\r\nimport { CreateGroupComponent } from '../create-group/create-group.component';\r\n\r\n\r\n@Component({\r\n  selector: 'app-group-list',\r\n  templateUrl: './group-list.component.html',\r\n  styleUrls: ['./group-list.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class GroupListComponent implements OnInit, OnDestroy {\r\n  group: Group;\r\n  loading = false;\r\n  groupList: Array<Group> = [];\r\n  groupListOfOption = [];\r\n  subscription: Subscription;\r\n\r\n  @ViewChild('search', { static: true }) private selectGroup: NzSelectComponent;\r\n\r\n  constructor(\r\n    private store: Store,\r\n    private cd: ChangeDetectorRef,\r\n    private modal: NzModalService,\r\n    private timHelper: TimHelperService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n\r\n    this.subscription = this.store.select(groupListSelector).subscribe(res => {\r\n      this.groupList = res;\r\n      this.cd.markForCheck();\r\n    });\r\n\r\n    this.selectGroup.nzOnSearch.pipe(debounceTime(600), distinctUntilChanged())\r\n      .subscribe((res: string) => {\r\n        this.searchGroupByID(res);\r\n      });\r\n  }\r\n\r\n  searchGroupByID(queryString: string) {\r\n    if (queryString.trim().length > 0) {\r\n      this.loading = true;\r\n      this.timHelper.tim\r\n        .searchGroupByID(queryString)\r\n        .then(({ data: { group } }) => {\r\n          this.groupListOfOption = [group];\r\n          this.cd.markForCheck();\r\n          this.loading = false;\r\n        })\r\n        .catch(() => {\r\n          this.store.dispatch(showAction({\r\n            msgType: MESSAGE_STATUS.error,\r\n            message: '没有找到该群'\r\n          }));\r\n          this.loading = false;\r\n        });\r\n    }\r\n  }\r\n\r\n  applyJoinGroup(group: Group) {\r\n    this.timHelper.tim\r\n      .joinGroup({ groupID: group.groupID, applyMessage: '' })\r\n      .then(async (res: any) => {\r\n        switch (res.data.status) {\r\n          case TIM.TYPES.JOIN_STATUS_WAIT_APPROVAL:\r\n            this.store.dispatch(\r\n              showAction({\r\n                msgType: MESSAGE_STATUS.info,\r\n                message: '申请成功，等待群管理员确认！'\r\n              })\r\n            );\r\n            this.group = null;\r\n            this.groupListOfOption = [];\r\n            break;\r\n          case TIM.TYPES.JOIN_STATUS_SUCCESS:\r\n            await this.timHelper.checkoutConversation(`GROUP${res.data.group.groupID}`);\r\n            this.store.dispatch(\r\n              showAction({\r\n                msgType: MESSAGE_STATUS.success,\r\n                message: '加群成功'\r\n              })\r\n            );\r\n            this.group = null;\r\n            this.groupListOfOption = [];\r\n            break;\r\n          case TIM.TYPES.JOIN_STATUS_ALREADY_IN_GROUP:\r\n            this.store.dispatch(\r\n              showAction({\r\n                msgType: MESSAGE_STATUS.warning,\r\n                message: '您已经是群成员了，请勿重复加群哦！'\r\n              })\r\n            );\r\n            this.group = null;\r\n            this.groupListOfOption = [];\r\n            break;\r\n          default: break;\r\n        }\r\n        this.cd.markForCheck();\r\n      })\r\n      .catch(error => {\r\n        this.store.dispatch(showAction({\r\n          msgType: MESSAGE_STATUS.error,\r\n          message: error.message\r\n        }));\r\n      });\r\n  }\r\n\r\n  createGroup() {\r\n    this.modal.create({\r\n      nzTitle: `创建群组`,\r\n      nzContent: CreateGroupComponent,\r\n      nzMaskClosable: false,\r\n      nzFooter: null,\r\n      nzWidth: '40%',\r\n      nzStyle: { top: '20px' },\r\n      // nzComponentParams: {}\r\n    });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.subscription) {\r\n      this.subscription.unsubscribe();\r\n    }\r\n  }\r\n}\r\n","<div class=\"list-container\">\r\n  <div class=\"header-bar\">\r\n    <nz-select #search nzShowSearch nzServerSearch nzSize=\"small\" [nzLoading]=\"loading\"\r\n      nzPlaceHolder=\"输入群ID搜索\" [(ngModel)]=\"group\" (ngModelChange)=\"applyJoinGroup($event)\">\r\n      <nz-option *ngFor=\"let item of groupListOfOption\" [nzLabel]=\"item.groupID\" [nzValue]=\"item\">\r\n      </nz-option>\r\n    </nz-select>\r\n    <button title=\"创建群组\" (click)=\"createGroup()\">\r\n      <i class=\"tim-icon-add\"></i>\r\n    </button>\r\n  </div>\r\n  <div class=\"group-container\">\r\n    <app-group-item [group]=\"group\" *ngFor=\"let group of groupList\">\r\n    </app-group-item>\r\n  </div>\r\n</div>\r\n"]}