basic-in.component.ts 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333
  1. import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';
  2. import { languages } from '../../../../services/languages.map';
  3. import { CommonCompModule } from '../../../../services/common.modules';
  4. import { NzSelectModule } from 'ng-zorro-antd/select';
  5. import { ReactiveFormsModule } from '@angular/forms';
  6. import { NzRadioModule } from 'ng-zorro-antd/radio';
  7. import { NzUploadModule } from 'ng-zorro-antd/upload';
  8. import { NzTagModule } from 'ng-zorro-antd/tag';
  9. import { NzMessageService } from 'ng-zorro-antd/message';
  10. import { NzUploadChangeParam } from 'ng-zorro-antd/upload';
  11. import { NzModalService } from 'ng-zorro-antd/modal';
  12. import { textbookServer } from '../../../../services/textbook'
  13. import Parse from 'parse';
  14. import {
  15. FormControl,
  16. FormGroup,
  17. NonNullableFormBuilder,
  18. Validators,
  19. } from '@angular/forms';
  20. @Component({
  21. selector: 'app-basic',
  22. imports: [
  23. CommonCompModule,
  24. ReactiveFormsModule,
  25. NzSelectModule,
  26. NzRadioModule,
  27. NzUploadModule,
  28. NzTagModule
  29. ],
  30. standalone: true,
  31. templateUrl: './basic-in.component.html',
  32. styleUrls: ['./basic-in.component.scss'],
  33. })
  34. export class BasicInComponent implements OnInit {
  35. @Input('eduTextbook') eduTextbook: Parse.Object|any;
  36. @Input('editFrom') editFrom: any;
  37. @Output() state: EventEmitter<any> = new EventEmitter<any>();
  38. @Output() save: EventEmitter<any> = new EventEmitter<any>();
  39. validateForm: FormGroup<{
  40. title: FormControl<string>; //申报教材名称
  41. ISBN: FormControl<string>; //国际标准书号
  42. author: FormControl<string>; //第一主编(作者)
  43. unit: FormControl<string>; //第一主编(作者)单位
  44. type: FormControl<string>; //申报类型
  45. typeNumber: FormControl<number|any>; //全册次数
  46. majorPoniter: FormControl<string>; //教材应用对象及所诉学科专业类
  47. lang: FormControl<string>; //教材主要语种类型
  48. authors: FormControl<string>; //其他主编姓名
  49. editor: FormControl<string>; //其他编者姓名
  50. approval: FormControl<boolean>; //是否为重点立项教材
  51. editionUnit: FormControl<string>; //出版单位
  52. editionFirst: FormControl<Date>; //初版时间
  53. carrierShape: FormControl<string>; //载体形式
  54. editionDate: FormControl<Date>; //出版时间
  55. editionNumber: FormControl<number>; //出版版次
  56. printDate: FormControl<Date>; //最新印次时间
  57. printNumber: FormControl<number>; //最新印次
  58. printSum: FormControl<number>; //初版以来合计印次
  59. importantProject: FormControl<string>; //初版以来是否列为重点项目
  60. importantProjectOther: FormControl<string>; //其他省部级及以上项目
  61. copyrightImgUrl: FormControl<string>; //版权页截图
  62. CIPImgUrl: FormControl<string>; //中国版本图书馆CIP查询截图
  63. // remember: FormControl<boolean>;
  64. }> = this.fb.group({
  65. title: ['', [Validators.required]],
  66. ISBN: ['', [Validators.required]],
  67. author: ['', [Validators.required]],
  68. unit: ['', [Validators.required]],
  69. type: ['', [Validators.required]],
  70. typeNumber: [1],
  71. majorPoniter: ['', [Validators.required]],
  72. lang: ['', [Validators.required]],
  73. authors: ['', [Validators.required]],
  74. editor: ['', [Validators.required]],
  75. approval: [false],
  76. editionUnit: ['', [Validators.required]],
  77. editionFirst: [new Date(), [Validators.required]],
  78. carrierShape: ['', [Validators.required]],
  79. editionDate: [new Date(), [Validators.required]],
  80. editionNumber: [0, [Validators.required]],
  81. printDate: [new Date(), [Validators.required]],
  82. printNumber: [0, [Validators.required]],
  83. printSum: [0, [Validators.required]],
  84. importantProject: ['', [Validators.required]],
  85. importantProjectOther: [''],
  86. copyrightImgUrl: ['https://www.jyvtc.edu.cn/yssj/resource/cms/2022/01/2022010610314324023.pdf'],
  87. CIPImgUrl: ['https://www.jyvtc.edu.cn/yssj/resource/cms/2022/01/2022010610314324023.pdf'],
  88. // remember: [true],
  89. });
  90. //教材应用对象及所诉学科专业类
  91. selectList: Array<any> = [
  92. {
  93. name: '机械与工程',
  94. code: 'M001',
  95. },
  96. {
  97. name: '软件工程',
  98. code: 'M002',
  99. },
  100. {
  101. name: '生物工程学',
  102. code: 'M003',
  103. },
  104. ];
  105. //语言选择
  106. selectLang: Array<any> = languages.options;
  107. //载体形式
  108. carrierOptions: Array<any> = [
  109. {
  110. name: '载体一',
  111. code: 'Z001',
  112. },
  113. {
  114. name: '载体二',
  115. code: 'Z002',
  116. },
  117. {
  118. name: '载体三',
  119. code: 'Z003',
  120. },
  121. ];
  122. importantProjectList: Array<any> = [
  123. {
  124. title: '“十二五”普通高等教育本科国家级规划教材',
  125. value: '“十二五”普通高等教育本科国家级规划教材',
  126. },
  127. {
  128. title: '“十二五”以来省级优秀教材',
  129. value: '“十二五”以来省级优秀教材',
  130. },
  131. {
  132. title: '“十二五”以来省级规划教材',
  133. value: '“十二五”以来省级规划教材',
  134. },
  135. {
  136. title: '其他省部级及以上项目',
  137. value: '其他省部级及以上项目',
  138. },
  139. ];
  140. // get importantProjectState(){
  141. // return this.importantProjectList.some((item:any)=> item.value == this.validateForm.value.importantProject)
  142. // }
  143. constructor(
  144. public tbookSer: textbookServer,
  145. private fb: NonNullableFormBuilder,
  146. private modal: NzModalService,
  147. private msg: NzMessageService
  148. ) {
  149. }
  150. ngOnInit() {
  151. console.log(this.eduTextbook);
  152. this.validateForm = this.fb.group({
  153. title: [this.eduTextbook?.get('title') || '', [Validators.required]],
  154. ISBN: [this.eduTextbook?.get('ISBN') || '', [Validators.required]],
  155. author: [this.eduTextbook?.get('author') || '', [Validators.required]],
  156. unit: [this.eduTextbook?.get('unit') || '', [Validators.required]],
  157. type: [this.eduTextbook?.get('type') || '', [Validators.required]],
  158. typeNumber: [this.eduTextbook?.get('typeNumber') || 1, [Validators.required]],
  159. majorPoniter: [this.eduTextbook?.get('majorPoniter') || '', [Validators.required]],
  160. lang: [this.eduTextbook?.get('lang') || '', [Validators.required]],
  161. authors: [this.eduTextbook?.get('authors') || '', [Validators.required]],
  162. editor: [this.eduTextbook?.get('editor') || '', [Validators.required]],
  163. approval: [this.eduTextbook?.get('approval') || false, [Validators.required]],
  164. editionUnit: [this.eduTextbook?.get('editionUnit') || '', [Validators.required]],
  165. editionFirst: [this.eduTextbook?.get('editionFirst') || new Date(), [Validators.required]],
  166. carrierShape: [this.eduTextbook?.get('carrierShape') || '', [Validators.required]],
  167. editionDate: [this.eduTextbook?.get('editionDate') || new Date(), [Validators.required]],
  168. editionNumber: [this.eduTextbook?.get('editionNumber') || 0, [Validators.required]],
  169. printDate: [this.eduTextbook?.get('printDate') || new Date(), [Validators.required]],
  170. printNumber: [this.eduTextbook?.get('printNumber') || 0, [Validators.required]],
  171. printSum: [this.eduTextbook?.get('printSum') || 0, [Validators.required]],
  172. importantProject: [this.eduTextbook?.get('importantProject') || '', [Validators.required]],
  173. importantProjectOther: [this.eduTextbook?.get('importantProjectOther') || ''],
  174. copyrightImgUrl: [this.eduTextbook?.get('copyrightImgUrl') || 'https://www.jyvtc.edu.cn/yssj/resource/cms/2022/01/2022010610314324023.pdf', [Validators.required]],
  175. CIPImgUrl: [this.eduTextbook?.get('CIPImgUrl') || 'https://www.jyvtc.edu.cn/yssj/resource/cms/2022/01/2022010610314324023.pdf', [Validators.required]],
  176. });
  177. this.onChangeRadio()
  178. }
  179. //校验其他省部级及以上项目是否需填
  180. onChangeRadio(){
  181. if (this.validateForm.value.importantProject != '其他省部级及以上项目') {
  182. this.validateForm.controls.importantProjectOther.clearValidators();
  183. this.validateForm.controls.importantProjectOther.markAsPristine();
  184. } else {
  185. this.validateForm.controls.importantProjectOther.setValidators(Validators.required);
  186. this.validateForm.controls.importantProjectOther.markAsDirty();
  187. }
  188. this.validateForm.controls.importantProjectOther.updateValueAndValidity();
  189. }
  190. //校验全册册数是否需填
  191. requiredTypeNumber(e:boolean){
  192. if (e) {
  193. this.validateForm.controls.typeNumber.clearValidators();
  194. this.validateForm.controls.typeNumber.markAsPristine();
  195. } else {
  196. this.validateForm.controls.typeNumber.setValidators(Validators.required);
  197. this.validateForm.controls.typeNumber.markAsDirty();
  198. }
  199. this.validateForm.controls.typeNumber.updateValueAndValidity();
  200. }
  201. handleChange(info: NzUploadChangeParam): void {
  202. if (info.file.status !== 'uploading') {
  203. console.log(info.file, info.fileList);
  204. }
  205. if (info.file.status === 'done') {
  206. this.msg.success(`${info.file.name} file uploaded successfully`);
  207. } else if (info.file.status === 'error') {
  208. this.msg.error(`${info.file.name} file upload failed.`);
  209. }
  210. }
  211. async submitForm(event?: string): Promise<void> {
  212. console.log(this.validateForm.value);
  213. if (this.validateForm.valid) {
  214. // console.log(this.validateForm.value);
  215. // let {
  216. // title,
  217. // ISBN,
  218. // author,
  219. // unit,
  220. // type,
  221. // typeNumber,
  222. // majorPoniter,
  223. // lang,
  224. // authors,
  225. // editor,
  226. // approval,
  227. // editionUnit,
  228. // editionFirst,
  229. // carrierShape,
  230. // editionDate,
  231. // editionNumber,
  232. // printDate,
  233. // printNumber,
  234. // printSum,
  235. // importantProject,
  236. // importantProjectOther,
  237. // copyrightImgUrl,
  238. // CIPImgUrl,
  239. // } = this.validateForm.value
  240. let params = this.validateForm.value
  241. if(event == 'next'){
  242. await this.saveEduTextbook(params, this.validateForm.valid)
  243. this.state.emit({type:'next',textBook:this.eduTextbook});
  244. }
  245. } else {
  246. if(event == 'save'){
  247. let params = this.validateForm.value
  248. await this.saveEduTextbook(params, this.validateForm.valid)
  249. this.modal.success({
  250. nzTitle: '保存成功',
  251. nzContent: '<p>已保存并且至空间</p>',
  252. nzOnOk: () => console.log('Info OK')
  253. });
  254. return
  255. }
  256. Object.values(this.validateForm.controls).forEach((control) => {
  257. if (control.invalid) {
  258. control.markAsDirty();
  259. control.updateValueAndValidity({ onlySelf: true });
  260. }
  261. });
  262. this.msg.warning('请填写完整的内容')
  263. return
  264. }
  265. if(event == 'save'){
  266. let params = this.validateForm.value
  267. await this.saveEduTextbook(params, this.validateForm.valid)
  268. this.modal.success({
  269. nzTitle: '保存成功',
  270. nzContent: '<p>已保存并且至空间</p>',
  271. nzOnOk: () => console.log('Info OK')
  272. });
  273. }
  274. }
  275. async saveEduTextbook(params: any, isComplete:boolean){
  276. console.log(params);
  277. if(!this.eduTextbook){
  278. let obj = Parse.Object.extend('EduTextbook');
  279. this.eduTextbook = new obj();
  280. }
  281. //如果填写未完整,仅保存,状态修改待完善101
  282. if(this.eduTextbook.get('status') == '102' && !isComplete){
  283. this.eduTextbook?.set('status', '101');
  284. this.eduTextbook.set('complete', false)
  285. }else if(!this.eduTextbook.get('status')){
  286. this.eduTextbook?.set('status', '101');
  287. }
  288. this.eduTextbook?.set('user', Parse.User.current()?.toPointer());
  289. this.eduTextbook?.set('company', {
  290. __type: 'Pointer',
  291. className: 'Company',
  292. objectId: this.tbookSer.company,
  293. });
  294. this.eduTextbook?.set('title', params.title);
  295. this.eduTextbook?.set('ISBN', params.ISBN);
  296. this.eduTextbook?.set('author', params.author);
  297. this.eduTextbook?.set('unit', params.unit);
  298. this.eduTextbook?.set('type', params.type);
  299. this.eduTextbook?.set('typeNumber', params.typeNumber);
  300. this.eduTextbook?.set('majorPoniter', params.majorPoniter);
  301. this.eduTextbook?.set('lang', params.lang);
  302. this.eduTextbook?.set('authors', params.authors);
  303. this.eduTextbook?.set('editor', params.editor);
  304. this.eduTextbook?.set('approval', params.approval);
  305. this.eduTextbook?.set('editionUnit', params.editionUnit);
  306. this.eduTextbook?.set('editionFirst', params.editionFirst);
  307. this.eduTextbook?.set('carrierShape', params.carrierShape);
  308. this.eduTextbook?.set('editionDate', params.editionDate);
  309. this.eduTextbook?.set('editionNumber', params.editionNumber);
  310. this.eduTextbook?.set('printDate', params.printDate);
  311. this.eduTextbook?.set('printNumber', params.printNumber);
  312. this.eduTextbook?.set('printSum', params.printSum);
  313. this.eduTextbook?.set('importantProject', params.importantProject);
  314. this.eduTextbook?.set('importantProjectOther', params.importantProjectOther);
  315. this.eduTextbook?.set('copyrightImgUrl', params.copyrightImgUrl);
  316. this.eduTextbook?.set('CIPImgUrl', params.CIPImgUrl);
  317. await this.eduTextbook?.save();
  318. return
  319. }
  320. }