account-info.component.ts 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297
  1. import { Component, OnInit, ViewChild } from '@angular/core';
  2. import { ReactiveFormsModule } from '@angular/forms';
  3. import { HttpClient } from '@angular/common/http';
  4. import { Router } from '@angular/router';
  5. import { catchError } from 'rxjs/operators';
  6. import { NzUploadModule } from 'ng-zorro-antd/upload';
  7. import { NzModalModule, NzModalService } from 'ng-zorro-antd/modal';
  8. import {
  9. FormControl,
  10. FormGroup,
  11. NonNullableFormBuilder,
  12. Validators,
  13. } from '@angular/forms';
  14. import { CommonCompModule } from '../common.modules';
  15. import { textbookServer } from '../../../services/textbook';
  16. import { AuthServr } from '../../../services/auth.service';
  17. import { CaptchaComponent } from '../../../app/captcha/captcha.component';
  18. import { NzMessageService } from 'ng-zorro-antd/message';
  19. import { provinces } from '../../../services/provinces';
  20. import { CompUploadComponent } from '../../../app/comp-upload/comp-upload.component';
  21. import Parse from 'parse';
  22. import { NzGridModule } from 'ng-zorro-antd/grid';
  23. import { NzSpinModule } from 'ng-zorro-antd/spin';
  24. @Component({
  25. selector: 'app-account-info',
  26. standalone: true,
  27. imports: [
  28. ReactiveFormsModule,
  29. CommonCompModule,
  30. CaptchaComponent,
  31. NzUploadModule,
  32. NzModalModule,
  33. CompUploadComponent,
  34. NzGridModule,
  35. NzSpinModule
  36. ],
  37. templateUrl: './account-info.component.html',
  38. styleUrls: ['./account-info.component.scss'],
  39. })
  40. export class AccountInfoComponent implements OnInit {
  41. url: string = `"http://hep-textbook.oss-cn-beijing.aliyuncs.com/6687b9417f823ff53c74cfd6/2024-7-15/1721044465100-%E2%80%9C%E5%8D%81%E5%9B%9B%E4%BA%94%E2%80%9D%E6%99%AE%E9%80%9A%E9%AB%98%E7%AD%89%E6%95%99%E8%82%B2%E6%9C%AC%E7%A7%91%E5%9B%BD%E5%AE%B6%E7%BA%A7%E8%A7%84%E5%88%92%E6%95%99%E6%9D%90%E6%8E%A8%E8%8D%90%E9%81%B4%E9%80%89%E5%B7%A5%E4%BD%9C%E8%81%94%E7%B3%BB%E4%BA%BA%E4%BF%A1%E6%81%AF%E8%A1%A8.doc"`;
  42. user: Parse.Object | undefined;
  43. validateForm: FormGroup<{
  44. username: FormControl<string>;
  45. password: FormControl<string>;
  46. name: FormControl<string>; //姓名
  47. phone: FormControl<string>; //手机号
  48. email: FormControl<string>; //电子邮箱
  49. identity: FormControl<string>; //人员类型
  50. // telephone: FormControl<string>; //办公电话
  51. // province: FormControl<string>; //省份
  52. // idcard: FormControl<string>; //身份证号
  53. // departmentName: FormControl<string>; //所在部门
  54. // postName: FormControl<string>; //职务
  55. }> = this.fb.group({
  56. username: ['', [Validators.required]],
  57. password: ['', [Validators.required]],
  58. name: ['', [Validators.required]],
  59. phone: [''],
  60. email: ['', [Validators.required]],
  61. identity: ['', [Validators.required]],
  62. // telephone: [''],
  63. // province: [''],
  64. // idcard: ['', [Validators.required]],
  65. // departmentName: [''],
  66. // postName: [''],
  67. });
  68. companyType: string = ''; //单位类型
  69. identityFile: string = ''; //单位联系人认证文件
  70. companyId: string = ''; //单位名称
  71. provinces: Array<string> = provinces.options; //省份
  72. unitTypes: Array<any> = [];
  73. companys: Array<any> = [];
  74. userType: Array<string> = ['工作联系人', '评审专家', '高校联系人', '个人'];
  75. constructor(
  76. public tbookSer: textbookServer,
  77. private fb: NonNullableFormBuilder,
  78. public router: Router,
  79. private authServr: AuthServr,
  80. private message: NzMessageService,
  81. private modal: NzModalService,
  82. private http: HttpClient
  83. ) {}
  84. async ngOnInit() {
  85. let user = Parse.User.current();
  86. if (user?.id) {
  87. this.message.success('请先退出登录');
  88. history.back();
  89. }
  90. // this.user = user;
  91. await this.getUnitTypes();
  92. // if (user?.get('accountState') == '已认证') {
  93. // this.message.success('账号已认证,无需重复认证');
  94. // this.authServr.profileVerify(this.modal);
  95. // return;
  96. // } else if (user?.get('accountState') == '已禁用') {
  97. // this.message.success('账号已禁用');
  98. // this.router.navigate(['/user/register'], { replaceUrl: true });
  99. // return;
  100. // }
  101. // let queryProfile = new Parse.Query('Profile');
  102. // queryProfile.equalTo('user', user?.id);
  103. // let profile = await queryProfile.first();
  104. // this.validateForm = this.fb.group({
  105. // username: [user?.get('username'), [Validators.required]],
  106. // password: ['', [Validators.required]],
  107. // name: [user?.get('name') || '', [Validators.required]],
  108. // phone: [user?.get('phone') || ''],
  109. // email: [user?.get('email') || '', [Validators.required]],
  110. // // telephone: [profile?.get('telephone') || ''],
  111. // // province: [user?.get('province') || ''],
  112. // identity: [profile?.get('identity') || '', [Validators.required]],
  113. // // departmentName: [user?.get('departmentName') || ''],
  114. // // postName: [profile?.get('postName') || ''],
  115. // });
  116. // this.identityFile = profile?.get('identityFile') || ''
  117. // this.companyId = user?.get('department')?.id || '';
  118. // this.companyType = profile?.get('companyType') || ''
  119. this.provinceChange();
  120. }
  121. async getUnitTypes() {
  122. let query = new Parse.Query('Department');
  123. query.equalTo('branch', undefined);
  124. query.equalTo('parent', undefined);
  125. query.notEqualTo('isDeleted', true);
  126. query.select('name');
  127. let r = await query.find();
  128. r.forEach((item) => {
  129. this.unitTypes.push({ id: item.id, name: item.get('name') });
  130. });
  131. }
  132. //根据所选单位类型获取对应单位
  133. async provinceChange(val?: string, isChange?: boolean) {
  134. // console.log(val);
  135. if (isChange) this.companyId = '';
  136. this.companys = [];
  137. let parent = this.unitTypes.find((item) => item.name == this.companyType);
  138. // console.log(parent);
  139. if (!parent?.id) return;
  140. let query = new Parse.Query('Department');
  141. query.equalTo('parent', parent?.id);
  142. query.select('name', 'branch');
  143. query.limit(100);
  144. val && query.contains('name', val);
  145. let r = await query.find();
  146. if (r.length > 0) {
  147. this.companys = r.map((item: Parse.Object) => {
  148. return { id: item.id, name: item.get('name') };
  149. });
  150. }
  151. }
  152. submitForm(): void {
  153. console.log(this.validateForm.value);
  154. console.log(this.companyId);
  155. if (this.validateForm.valid) {
  156. if (!this.companyId) {
  157. this.message.error('单位名称未选择或与单位类型不匹配,请重新选择');
  158. return;
  159. }
  160. let a =
  161. /^(([^<>()[\]\\.,;:\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,}))$/;
  162. if (!String(this.validateForm.value.email).match(a)) {
  163. this.message.error('邮箱格式不正确');
  164. return;
  165. }
  166. let m =
  167. /^(?:(?:\+|00)86)?1(?:(?:3[\d])|(?:4[5-79])|(?:5[0-35-9])|(?:6[5-7])|(?:7[0-8])|(?:8[\d])|(?:9[1589]))\d{8}$/;
  168. if (!String(this.validateForm.value.phone).match(m)) {
  169. this.message.error('手机号格式不正确');
  170. return;
  171. }
  172. if (!this.identityFile) {
  173. this.message.error('请上传单位联系人认证文件');
  174. return;
  175. }
  176. let params = this.validateForm.value;
  177. this.profileSave(params);
  178. } else {
  179. this.message.warning('请填写完整的信息');
  180. Object.values(this.validateForm.controls).forEach((control) => {
  181. if (control.invalid) {
  182. control.markAsDirty();
  183. control.updateValueAndValidity({ onlySelf: true });
  184. }
  185. });
  186. }
  187. }
  188. loading:boolean = false
  189. async profileSave(params: any) {
  190. this.loading = true
  191. try {
  192. let queryDepart = new Parse.Query('Department');
  193. queryDepart.equalTo('objectId', this.companyId);
  194. queryDepart.select('objectId');
  195. let depart = await queryDepart.first();
  196. if (!depart?.id) {
  197. this.message.error('单位名称未选择或与单位类型不匹配,请重新选择');
  198. this.loading = false
  199. return;
  200. }
  201. let u = Parse.Object.extend('_User');
  202. this.user = new u();
  203. this.user?.set('username', params.username);
  204. this.user?.set('password', params.password);
  205. this.user?.set('name', params.name);
  206. this.user?.set('email', params.email);
  207. this.user?.set('phone', params.phone);
  208. // this.user?.set('province', params.province);
  209. this.user?.set('companyName', depart?.get('name'));
  210. // if(this.validateForm.value.identity == '工作联系人'){
  211. this.user?.set('department', {
  212. __type: 'Pointer',
  213. className: 'Department',
  214. objectId: depart?.id,
  215. });
  216. // }
  217. !this.user?.get('accountState') &&
  218. this.user?.set('accountState', '待认证');
  219. // this.user?.set('departmentName', params.departmentName);
  220. await this.user?.save();
  221. let query = new Parse.Query('Profile');
  222. query.equalTo('user', Parse.User.current()?.id);
  223. query.notEqualTo('isDeleted', true);
  224. let profile = await query.first();
  225. if (!profile?.id) {
  226. let obj = Parse.Object.extend('Profile');
  227. profile = new obj();
  228. }
  229. profile?.set('user', Parse.User.current()?.toPointer());
  230. profile?.set('company', {
  231. __type: 'Pointer',
  232. className: 'Company',
  233. objectId: this.tbookSer.company,
  234. });
  235. // profile?.set('telephone', params.telephone);
  236. // if(this.validateForm.value.identity == '工作联系人'){
  237. profile?.set('companyType', this.companyType);
  238. profile?.set('identityFile', this.identityFile);
  239. // }
  240. profile?.set('email', params.email);
  241. // profile?.set('idcard', params.idcard);
  242. // profile?.set('postName', params.postName);
  243. profile?.set('identity', params.identity);
  244. let res = await profile?.save();
  245. this.loading = false
  246. this.modal.success({
  247. nzTitle: '提交成功',
  248. nzContent: '',
  249. nzOnOk: () =>
  250. this.router.navigate(['/user/login'], { replaceUrl: true }),
  251. });
  252. } catch (err: any) {
  253. this.loading = false
  254. console.log(err?.message);
  255. let msg = '注册失败';
  256. switch (err?.message) {
  257. case 'Account already exists for this email address.':
  258. msg = '注册失败,邮箱已存在';
  259. break;
  260. case 'Account already exists for this username.':
  261. msg = '注册失败,用户名已存在';
  262. break;
  263. }
  264. this.message.error(msg);
  265. }
  266. }
  267. upload(e: any) {
  268. console.log(e);
  269. let file = e[0];
  270. this.identityFile = file?.name;
  271. }
  272. //验证手机号或邮箱是否注册
  273. async authUser(): Promise<boolean> {
  274. let query = new Parse.Query('_User');
  275. if (this.validateForm.value.phone) {
  276. query.equalTo('phone', this.validateForm.value.phone);
  277. let r = await query.first();
  278. if (r?.id) {
  279. this.message.warning('手机号已被注册');
  280. return false;
  281. }
  282. } else if (this.validateForm.value.email) {
  283. query.equalTo('email', this.validateForm.value.email);
  284. let r = await query.first();
  285. if (r?.id) {
  286. this.message.warning('邮箱已被注册');
  287. return false;
  288. }
  289. }
  290. return true;
  291. }
  292. }