123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644 |
- import { Component, OnInit, ViewChild } from '@angular/core';
- import { ActivatedRoute, Route, Router, RouterOutlet } from '@angular/router';
- import { CompTableListComponent } from '../../../app/comp-table/comp-table-list/comp-table-list.component';
- import _Role from '../../../schemas/_Role';
- // import { TranslateService } from '@ngx-translate/core';
- import * as Parse from 'parse';
- import { CommonModule } from '@angular/common';
- import { Department } from '../../../schemas/Department';
- import { NzSpaceModule } from 'ng-zorro-antd/space';
- import { NzPageHeaderModule } from 'ng-zorro-antd/page-header';
- import { NzBreadCrumbModule } from 'ng-zorro-antd/breadcrumb';
- import { CommonCompModule } from '../../../services/common.modules';
- import { NzModalModule, NzModalService } from 'ng-zorro-antd/modal';
- import {
- NzFormatEmitEvent,
- NzTreeModule,
- NzTreeNode,
- } from 'ng-zorro-antd/tree';
- import {
- NzContextMenuService,
- NzDropdownMenuComponent,
- } from 'ng-zorro-antd/dropdown';
- import { NzCheckboxModule } from 'ng-zorro-antd/checkbox';
- import { NzEmptyModule } from 'ng-zorro-antd/empty';
- import { NzRadioModule } from 'ng-zorro-antd/radio';
- import { NzMessageService } from 'ng-zorro-antd/message';
- import { NzSelectModule } from 'ng-zorro-antd/select';
- import { textbookServer } from '../../../services/textbook';
- import { NzSpinModule } from 'ng-zorro-antd/spin';
- interface nodes {
- title: string;
- key: string;
- isLeaf?: boolean;
- branch?: string;
- children?: Array<any>;
- }
- interface depart {
- name: string;
- id?: string;
- code?: string;
- desc?: string;
- parent?: object | any;
- branch: string;
- }
- @Component({
- selector: 'app-page-role',
- templateUrl: './page-role.component.html',
- styleUrls: ['./page-role.component.scss'],
- imports: [
- CommonModule,
- CommonCompModule,
- RouterOutlet,
- CompTableListComponent,
- NzSpaceModule,
- NzPageHeaderModule,
- NzBreadCrumbModule,
- NzTreeModule,
- NzCheckboxModule,
- NzEmptyModule,
- NzModalModule,
- NzRadioModule,
- NzSelectModule,
- NzSpinModule
- ],
- standalone: true,
- })
- export class PageRoleComponent implements OnInit {
- @ViewChild(CompTableListComponent) list: CompTableListComponent | undefined;
- // _Role = _Role
- Department = Department;
- user: Parse.User | undefined;
- className: string | undefined;
- queryParams: any | undefined;
- fieldsArray: Array<any> | undefined;
- searchValue: string = ''; //搜索内容
- searchValueNode: string = '';
- nodes: Array<nodes | any> = [];
- currentDepart: nodes | any = null;
- profiles: Array<Parse.Object> = [];
- checkedShowFilter: boolean = false;
- checkedAll: boolean = false; //全选
- indeterminate = false;
- loading = false;
- pageSize: number = 10;
- pageIndex: number = 1;
- profileLength:number = 0
- isVisible: boolean = false;
- activatedNode: NzTreeNode | any; //当前选择节点
- editType: string = 'add'; //弹窗类型
- activeDepart?: Parse.Object; //当前编辑部门
- editObject: depart = {
- name: '',
- code: '',
- desc: '',
- parent: {},
- branch: '',
- };
- parentMap: Array<any> = [];
- parentList: Array<any> = [];
- radio: string = '';
- /* 添加账号 */
- accountIsVisible: boolean = false;
- account: any = {
- name: '',
- phone: '',
- email: '',
- password: '',
- identity: '',
- department: {},
- companyType: '',
- };
- userType: Array<string> = ['工作联系人', '评审专家', '高校联系人', '个人'];
- parents: Array<any> = []; //所有一级列表
- nzExpandedKeys:any = [] //默认展开节点数
- constructor(
- private route: Router,
- private activeRoute: ActivatedRoute,
- private nzContextMenuService: NzContextMenuService,
- public tbookSer: textbookServer,
- private modal: NzModalService,
- private message: NzMessageService
- ) {
- this.user = Parse.User.current();
- this.className = this.Department.className;
- this.fieldsArray = this.Department.fieldsArray;
- this.queryParams = {
- where: {
- // user:this.user?.toPointer(),
- isDeleted: { $ne: true },
- },
- };
- }
- ngOnInit(): void {
- this.activeRoute.paramMap.subscribe(async (params) => {
- let nodes:Array<any> = await this.getDepart();
- this.parents = [...nodes]
- Promise.all(nodes.map(async (item,index)=>{
- nodes[index].children = await this.getDepart(item.key);
- // nodes[index]['isExpanded'] = true
- this.nzExpandedKeys.push(nodes[index]?.key)
- })).then(()=>{
- this.nodes = nodes
- })
- });
- }
- async getDepart(
- parent?: string,
- searchValue?: string,
- filter?: boolean
- ): Promise<Array<nodes>> {
- let nodes: any = [];
- let query = new Parse.Query('Department');
- if (!filter) {
- query.equalTo('parent', parent ? parent : undefined);
- }
- searchValue && query.contains('name', searchValue);
- query.notEqualTo('isDeleted', true);
- query.select('code', 'name', 'branch', 'parent', 'type','hasChildren');
- query.descending('createdAt');
- query.limit(2000);
- if (this.activeDepart) query.notEqualTo('objectId', this.activeDepart?.id);
- let res = await query.find();
- res.forEach((item) => {
- nodes.push({
- title: item.get('name'),
- key: item.id,
- children: [],
- branch: item.get('branch'),
- parent: item.get('parent')?.id, //上级
- isLeaf: !item.get('hasChildren'), //是否是最下级
- type: item.get('type')
- });
- });
- return nodes;
- }
- //搜索
- async onSearchNodes(e: string, modal?: boolean) {
- if (modal) {
- this.parentList = await this.getDepart('', e, true);
- return;
- }
- this.nodes = await this.getDepart('', e, e ? true : false);
- }
- //展开/合并
- async nzEvent(event: NzFormatEmitEvent): Promise<void> {
- console.log(event);
- let node: any = event.node;
- if (event.eventName === 'expand') {
- // if (node.origin.isParent) {
- // node.addChildren([]);
- // return;
- // }
- if (node?._children.length <= 0) {
- let data = await this.getDepart(node.key);
- node.addChildren(data);
- }
- console.log(this.nodes);
- } else {
- // if (node.origin.isParent) {
- this.currentDepart = node.origin;
- this.getProfile();
- // }
- }
- }
- async getProfile() {
- this.profiles = [];
- this.loading = true;
- let childrens = [this.currentDepart.key]
- if(!this.checkedShowFilter){
- childrens = await this.tbookSer.getChild(this.currentDepart.key)
- }
- let queryParams = {
- where: {
- $or: [
- {
- user: {
- $inQuery: {
- where: {
- $or: [
- {
- department: { $in: [childrens] },
- },
- ],
- },
- className: '_User',
- },
- },
- },
- ],
- },
- };
- let query = Parse.Query.fromJSON('Profile', queryParams);
- query.include('user');
- query.notEqualTo('identity', '国家级管理员');
- query.notEqualTo('isDeleted', true);
- this.profileLength = await query.count()
- query.limit(this.pageSize)
- query.skip((this.pageIndex - 1) * this.pageSize)
- let r = await query.find();
- this.profiles = r;
- this.loading = false;
- this.resetChange()
- }
- //分页切换
- pageIndexChange(e: any) {
- console.log(e);
- this.pageIndex = e;
- this.getProfile();
- }
- onChecked(){
- this.pageIndex = 1;
- this.getProfile()
- }
- //搜索触发
- onSearch(event: NzFormatEmitEvent) {
- this.pageIndex = 1;
- console.log(event);
- }
- contextMenu(
- $event: MouseEvent,
- menu: NzDropdownMenuComponent,
- node?: any
- ): void {
- console.log(node);
- this.activatedNode = node;
- this.nzContextMenuService.create($event, menu);
- }
- //删除部门
- async onDelDepart() {
- this.modal.confirm({
- nzTitle: '删除',
- nzContent: '删除后数据不可恢复,请谨慎操作',
- nzOkText: '确认',
- nzOkType: 'primary',
- nzOkDanger: true,
- nzOnOk: async () => {
- new Promise(async (resolve, reject) => {
- if (this.activatedNode) {
- let query = new Parse.Query('Department');
- let r = await query.get(this.activatedNode?.key);
- if (r?.id) {
- r.set('isDeleted', true);
- await r.save();
- }
- this.message.success('删除成功');
- this.nodes = await this.getDepart();
- resolve(true);
- }
- }).catch(() => console.log('Oops errors!'));
- },
- nzCancelText: '取消',
- nzOnCancel: () => console.log('Cancel'),
- });
- }
- onAllChecked(checked: boolean): void {
- this.profiles.forEach((item) => {
- if (checked) {
- this.setOfCheckedId.add(item.id);
- } else {
- this.setOfCheckedId.delete(item.id);
- }
- });
- this.checkedAll = checked;
- }
- onItemChecked(id: string, e: boolean) {
- if (e) {
- this.setOfCheckedId.add(id);
- } else {
- this.setOfCheckedId.delete(id);
- }
- this.checkedAll = this.profiles.every((item) =>
- this.setOfCheckedId.has(item.id)
- );
- }
- //添加成员
- addMember() {
- this.parentList = this.nodes;
- this.account = {
- name: '',
- phone: '',
- email: '',
- password: '',
- identity: '',
- department: {},
- companyType: '',
- };
- this.accountIsVisible = true;
- }
- //新建打开弹窗
- async showModalDepart(type: string) {
- this.parentList = this.nodes;
- this.editObject = {
- name: '',
- code: '',
- desc: '',
- parent: '',
- branch: '',
- };
- if (type == 'edit') {
- let query = new Parse.Query('Department');
- query.include('parent','parent.parent')
- let r = await query.get(this.activatedNode?.key);
- this.activeDepart = r;
- this.editObject = {
- name: this.activeDepart.get('name'),
- code: this.activeDepart.get('code'),
- desc: this.activeDepart.get('desc'),
- parent: {
- title: this.activeDepart.get('parent')?.get('name'),
- id: this.activeDepart.get('parent')?.id,
- },
- branch: this.activeDepart.get('branch'),
- };
- this.parentMap = await this.tbookSer.formatNode(
- this.activeDepart.get('parent')?.id
- );
- if (r?.get('parent')?.get('parent')?.id) {
- this.parentList = await this.getDepart(r.get('parent')?.get('parent').id);
- }else{
- this.parentList = this.parents
- }
- this.radio = this.activeDepart.get('parent')?.id
- } else if (type == 'add' && this.activatedNode) {
- this.editObject.parent = {
- title: this.activatedNode.origin.title,
- id: this.activatedNode.origin.key,
- };
- this.radio = this.activatedNode.origin.key
- this.editObject.branch =
- this.activatedNode.origin.branch || this.activatedNode.origin.title;
- this.parentMap = await this.tbookSer.formatNode(this.activatedNode.origin.key);
- if (this.activatedNode?.origin.branch) {
- this.parentList = await this.getDepart(
- this.activatedNode?.origin.branch
- );
- }
- }
- console.log(this.parentMap);
- this.editType = type;
- this.isVisible = true;
- }
- async onPre(data?: any, index?: number) {
- if (!data) {
- this.parentList = await this.getDepart();
- this.parentMap = [];
- return;
- }
- if (index == this.parentMap.length - 1) return;
- this.parentMap.splice((index || 0) + 1);
- this.parentList = await this.getDepart(data?.key);
- this.radio = '';
- }
- //选择所属类别下级列表
- async onCheckedDepart(type: string, e: any, checked?: boolean) {
- this.radio = e.key;
- if (type == 'account') this.account.identity = '';
- this.parentMap = await this.tbookSer.formatNode(e.key);
- if (checked) {
- // this.editObject.name = e.title
- if (type == 'account' && e.parent) {
- this.account.department = { title: e.title, id: e.key };
- this.account.companyType = e.branch || e.title;
- this.userType = this.parents.some((item) => e.parent == item.key)
- ? !e.type ? ['工作联系人', '评审专家', '个人'] : ['评审专家', '工作联系人', '个人']
- : e.type
- ? ['评审专家', '高校联系人', '个人']
- : ['评审专家', '个人'];
- } else {
- this.editObject.parent = {
- title: e.title,
- id: e.key,
- };
- this.editObject.branch = e.branch || e.title;
- }
- return;
- }
- if (e.isLeaf) {
- return;
- }
- this.parentList = await this.getDepart(e?.key);
- }
- async handleOk(): Promise<void> {
- if (!this.editObject?.name || !this.editObject.parent?.id) {
- this.message.error('请填写完整信息');
- return;
- }
- if (this.activeDepart?.id && this.editType == 'edit') {
- this.activeDepart.set('name', this.editObject?.name);
- this.activeDepart.set('code', this.editObject?.code);
- this.activeDepart.set('desc', this.editObject.desc);
- this.activeDepart.set('parent', {
- __type: 'Pointer',
- className: 'Department',
- objectId: this.editObject.parent?.id,
- });
- this.activeDepart.set('branch', this.editObject.branch);
- } else {
- let obj = Parse.Object.extend('Department');
- this.activeDepart = new obj();
- this.activeDepart?.set('name', this.editObject?.name);
- this.activeDepart?.set('code', this.editObject?.code);
- this.activeDepart?.set('desc', this.editObject.desc);
- this.activeDepart?.set('parent', {
- __type: 'Pointer',
- className: 'Department',
- objectId: this.editObject.parent?.id,
- });
- this.activeDepart?.set('branch', this.editObject.branch);
- }
- let type
- let filters = ['出版单位','教育部直属高校']
- if(filters.includes(this.editObject.parent?.title)){
- type = '单位'
- }
- this.activeDepart?.set('type', type);
- await this.activeDepart?.save();
- if(!type && this.activeDepart?.id){
- //判断添加的是部门还是单位
- let leng = await this.tbookSer.formatNode(this.activeDepart.id)
- if(leng.length > 2){
- console.log(leng.length);
- if(filters.includes(leng[0].title)){
- this.activeDepart?.set('type', '部门');
- }else{
- this.activeDepart?.set('type',leng.length > 3 ? '部门' : '单位');
- }
- leng.slice()
- await this.activeDepart?.save();
- }
- }
- await this.updateChildren();
- this.isVisible = false;
- this.message.success(this.editType == 'edit' ? '保存' : '添加' + '成功');
- this.activeDepart = undefined;
- this.nodes = await this.getDepart();
- }
- //更新上级children字段
- async updateChildren() {
- let query = new Parse.Query('Department');
- query.equalTo('objectId', this.editObject.parent?.id);
- query.select('hasChildren')
- let r = await query.first();
- if (r?.id && !r.get('hasChildren')) {
- r?.set('hasChildren', true);
- await r.save();
- }
- return;
- }
- handleCancel(): void {
- console.log('Button cancel clicked!');
- this.isVisible = false;
- this.activatedNode = undefined;
- this.parentMap = [];
- this.accountIsVisible = false;
- this.account = null;
- }
- /* 组织 */
- showModalOrganize() {
- this.message.warning('权限灰度中');
- }
- goDateil(id: string) {
- this.route.navigate(['/nav-admin/manage/user/edit', { id: id }]);
- }
- randomPassword() {
- this.account.password = this.tbookSer.randomPassword()
- console.log(this.account.password);
- }
- /* 添加账号 */
- async accountComplete(){
- this.account.email = this.account?.email.trim();
- this.account.phone = this.account?.phone.trim();
- this.account.name = this.account?.name.trim();
- this.account.password = this.account?.password.trim();
- if(!this.authVrifly()) return
- try{
- let obj = Parse.Object.extend('_User');
- let user = new obj()
- user?.set('username', this.account?.email || this.account?.phone);
- user?.set('name', this.account?.name);
- user?.set('phone', this.account?.phone);
- this.account?.email && user?.set('email', this.account?.email);
- user?.set('password', this.account.password);
- user?.set('accountState', '已认证');
- user?.set('department', {
- __type: 'Pointer',
- className: 'Department',
- objectId: this.account.department?.id,
- });
- let u = await user.save()
- let p = Parse.Object.extend('Profile');
- let profile = new p()
- profile?.set('user', u?.toPointer());
- profile?.set('companyType', this.account.companyType);
- profile?.set('email', this.account.email);
- profile?.set('identity', this.account.identity);
- let res = await profile?.save();
- this.accountIsVisible = false;
- this.account = null;
- this.modal.success({
- nzTitle: '添加成功',
- nzContent: '',
- nzOnOk: () =>{
- this.currentDepart && this.getProfile()
- },
- });
- }
- catch(err:any){
- console.warn('添加用户错误',err);
- this.message.error(err?.Error || '错误:请检查用户邮箱或手机号是否已存在');
- return;
- }
- }
- authVrifly():boolean | undefined{
- this.account.email = this.account?.email.trim();
- this.account.phone = this.account?.phone.trim();
- this.account.name = this.account?.name.trim();
- this.account.password = this.account?.password.trim();
- if(!this.account?.name|| !this.account.department?.id || !this.account.password
- || !this.account.phone || !this.account?.email){
- this.message.warning('请填写必填项');
- return
- }
- if(!this.account.identity){
- this.message.error("请选择人员类型");
- return;
- }
- let a = /^(?:(?:\+|00)86)?1[3-9]\d{9}$/
- if(this.account.phone && !String(this.account.phone).match(a)){
- this.message.error("请填写正确手机号");
- return;
- }
- let m = /^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/
- if(!String(this.account.email).match(m)){
- this.message.error("邮箱格式有误");
- return;
- }
- // if(!this.account?.email && !this.account?.phone){
- // this.message.error("邮箱或手机号必须填写一项");
- // return;
- // }
- console.log(this.account.password);
- if(!(this.account.password.length >= 6 && this.account.password.length <= 18)){
- this.message.error('密码格式错误,请填写6-18位非空字符串(数字、大小写字母或英文符号)');
- return;
- }
- return true
- }
- setOfCheckedId = new Set<string>();
- //移除部门
- async removeBranch(data:Parse.Object){
- if(data?.get('user')?.id){
- data?.get('user')?.set('department',null)
- await data?.get('user')?.save()
- this.message.error("移除成功");
- this.getProfile();
- }
- }
- removeBranchAll(){
- this.modal.confirm({
- nzTitle: '批量移除',
- nzContent: `请谨慎操作`,
- nzOkText: '确认',
- nzOkType: 'primary',
- nzOkDanger: true,
- nzOnOk: async () => {
- let selectedList = this.profiles.filter((item: any) =>
- this.setOfCheckedId.has(item?.id)
- );
- let romovePromiseList = selectedList.map((item: any) => {
- return new Promise(async (resolve) => {
- item?.get('user')?.set('department',null)
- await item?.get('user')?.save()
- resolve(true)
- });
- });
- try {
- await Promise.all(romovePromiseList);
- this.message.error("移除成功");
- this.getProfile();
- this.resetChange()
- } catch (err) {}
- },
- nzCancelText: '取消',
- nzOnCancel: () => console.log('Cancel'),
- });
- }
- resetChange(){
- this.setOfCheckedId = new Set<string>();
- this.checkedAll = false;
- }
- }
|