basic-in.component.ts 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371
  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. import { CompUploadComponent } from '../../../../app/comp-upload/comp-upload.component';
  21. import { NzInputModule } from 'ng-zorro-antd/input';
  22. import * as major from '../../../../services/majors.map'
  23. @Component({
  24. selector: 'app-basic',
  25. imports: [
  26. CommonCompModule,
  27. ReactiveFormsModule,
  28. NzSelectModule,
  29. NzRadioModule,
  30. NzUploadModule,
  31. NzInputModule,
  32. NzTagModule,
  33. CompUploadComponent
  34. ],
  35. standalone: true,
  36. templateUrl: './basic-in.component.html',
  37. styleUrls: ['./basic-in.component.scss'],
  38. })
  39. export class BasicInComponent implements OnInit {
  40. @Input('eduTextbook') eduTextbook: Parse.Object|any;
  41. @Input('editFrom') editFrom: any;
  42. @Output() state: EventEmitter<any> = new EventEmitter<any>();
  43. @Output() save: EventEmitter<any> = new EventEmitter<any>();
  44. /**
  45. * 书号自动补全函数
  46. * @param isbn 书号
  47. */
  48. async autoCompleteByISBN(){
  49. let isbn = this.validateForm.value?.ISBN;
  50. let result = await Parse.Cloud.run("tbookISBN",{
  51. isbn:isbn
  52. })
  53. if(!result?.isbn){
  54. this.msg.warning('未找到该书号的图书信息,请手动填写')
  55. }
  56. // 其他字段,需补充接口与数据库对应关系
  57. this.validateForm.get("title")?.setValue(result?.book_name)
  58. this.validateForm.get("author")?.setValue(result?.author_name)
  59. this.validateForm.get("authors")?.setValue(result?.author)
  60. this.validateForm.get("majorPoniter")?.setValue(result?.major)
  61. this.validateForm.get("lang")?.setValue(languages.options?.[result?.languages]?.name)
  62. this.validateForm.get("editionUnit")?.setValue(result?.publisher)
  63. this.validateForm.get("editionDate")?.setValue(new Date(result?.publish_time))
  64. this.validateForm.get("carrierShape")?.setValue(result?.publication_class)
  65. console.log(result)
  66. }
  67. validateForm: FormGroup<{
  68. title: FormControl<string>; //申报教材名称
  69. ISBN: FormControl<string>; //国际标准书号
  70. author: FormControl<string>; //第一主编(作者)
  71. unit: FormControl<string>; //第一主编(作者)单位
  72. type: FormControl<string>; //申报类型
  73. typeNumber: FormControl<number|any>; //全册次数
  74. majorPoniter: FormControl<string>; //教材应用对象及所诉学科专业类
  75. lang: FormControl<string>; //教材主要语种类型
  76. authors: FormControl<string>; //其他主编姓名
  77. editor: FormControl<string>; //其他编者姓名
  78. approval: FormControl<string>; //是否为重点立项教材
  79. editionUnit: FormControl<string>; //出版单位
  80. editionFirst: FormControl<Date>; //初版时间
  81. carrierShape: FormControl<string>; //载体形式
  82. editionDate: FormControl<Date>; //出版时间
  83. editionNumber: FormControl<number>; //出版版次
  84. printDate: FormControl<Date>; //最新印次时间
  85. printNumber: FormControl<number>; //最新印次
  86. printSum: FormControl<number>; //初版以来合计印数
  87. importantProject: FormControl<string>; //初版以来是否列为重点项目
  88. importantProjectOther: FormControl<string>; //其他省部级及以上项目
  89. approvedImgUrl:FormControl<string>//重点立项教材获批截图
  90. // remember: FormControl<boolean>;
  91. }> = this.fb.group({
  92. title: ['', [Validators.required]],
  93. ISBN: ['', [Validators.required]],
  94. author: ['', [Validators.required]],
  95. unit: ['', [Validators.required]],
  96. type: ['', [Validators.required]],
  97. typeNumber: [1],
  98. majorPoniter: ['', [Validators.required]],
  99. lang: ['', [Validators.required]],
  100. authors: ['', [Validators.required]],
  101. editor: ['', [Validators.required]],
  102. approval: ['', [Validators.required]],
  103. editionUnit: ['', [Validators.required]],
  104. editionFirst: [new Date(), [Validators.required]],
  105. carrierShape: ['', [Validators.required]],
  106. editionDate: [new Date(), [Validators.required]],
  107. editionNumber: [0, [Validators.required]],
  108. printDate: [new Date(), [Validators.required]],
  109. printNumber: [0, [Validators.required]],
  110. printSum: [0, [Validators.required]],
  111. importantProject: ['', [Validators.required]],
  112. importantProjectOther: [''],
  113. approvedImgUrl:[''],
  114. // copyrightImgUrl: [''],
  115. // CIPImgUrl: [''],
  116. // remember: [true],
  117. });
  118. /** 所属学科专业类显示数量*/
  119. nzOptionOverflowSize=5
  120. //教材应用对象及所诉学科专业类
  121. selectList=major.majors.options
  122. //语言选择
  123. selectLang: Array<any> = languages.options;
  124. //载体形式
  125. carrierOptions: Array<any> = [
  126. {
  127. name: '纸质教材',
  128. code: 'Z001',
  129. },
  130. {
  131. name: '电子教材',
  132. code: 'Z002',
  133. },
  134. {
  135. name: '纸质教材附带电子资源',
  136. code: 'Z003',
  137. },
  138. ];
  139. importantProjectList: Array<any> = [
  140. {
  141. title: '“十二五”普通高等教育本科国家级规划教材',
  142. value: '“十二五”普通高等教育本科国家级规划教材',
  143. },
  144. {
  145. title: '“十二五”以来省级优秀教材',
  146. value: '“十二五”以来省级优秀教材',
  147. },
  148. {
  149. title: '“十二五”以来省级规划教材',
  150. value: '“十二五”以来省级规划教材',
  151. },
  152. {
  153. title: '其他省部级及以上项目',
  154. value: '其他省部级及以上项目',
  155. },
  156. ];
  157. // get importantProjectState(){
  158. // return this.importantProjectList.some((item:any)=> item.value == this.validateForm.value.importantProject)
  159. // }
  160. constructor(
  161. public tbookSer: textbookServer,
  162. private fb: NonNullableFormBuilder,
  163. private modal: NzModalService,
  164. private msg: NzMessageService
  165. ) {
  166. }
  167. ngOnInit() {
  168. console.log(this.eduTextbook);
  169. this.validateForm = this.fb.group({
  170. title: [this.eduTextbook?.get('title') || '', [Validators.required]],
  171. ISBN: [this.eduTextbook?.get('ISBN') || '', [Validators.required]],
  172. author: [this.eduTextbook?.get('author') || '', [Validators.required]],
  173. unit: [this.eduTextbook?.get('unit') || '', [Validators.required]],
  174. type: [this.eduTextbook?.get('type') || '', [Validators.required]],
  175. typeNumber: [this.eduTextbook?.get('typeNumber') || 1, [Validators.required]],
  176. majorPoniter: [this.eduTextbook?.get('majorPoniter') || '', [Validators.required]],
  177. lang: [this.eduTextbook?.get('lang') || '', [Validators.required]],
  178. authors: [this.eduTextbook?.get('authors') || '', ],
  179. editor: [this.eduTextbook?.get('editor') || '',],
  180. approval: [this.eduTextbook?.get('approval') || '', [Validators.required]],
  181. editionUnit: [this.eduTextbook?.get('editionUnit') || '', [Validators.required]],
  182. editionFirst: [this.eduTextbook?.get('editionFirst') || new Date(), [Validators.required]],
  183. carrierShape: [this.eduTextbook?.get('carrierShape') || '', [Validators.required]],
  184. editionDate: [this.eduTextbook?.get('editionDate') || new Date(), [Validators.required]],
  185. editionNumber: [this.eduTextbook?.get('editionNumber') || 0, [Validators.required]],
  186. printDate: [this.eduTextbook?.get('printDate') || new Date(), [Validators.required]],
  187. printNumber: [this.eduTextbook?.get('printNumber') || 0, [Validators.required]],
  188. printSum: [this.eduTextbook?.get('printSum') || 0, [Validators.required]],
  189. importantProject: [this.eduTextbook?.get('importantProject') || '', [Validators.required]],
  190. importantProjectOther: [this.eduTextbook?.get('importantProjectOther') || ''],
  191. approvedImgUrl: [this.eduTextbook?.get('approvedImgUrl') || '', [Validators.required]],
  192. // copyrightImgUrl: [this.eduTextbook?.get('copyrightImgUrl') || '', [Validators.required]],
  193. // CIPImgUrl: [this.eduTextbook?.get('CIPImgUrl') || '', [Validators.required]],
  194. });
  195. this.onChangeRadio()
  196. }
  197. //校验其他省部级及以上项目是否需填
  198. onChangeRadio(){
  199. if (this.validateForm.value.importantProject != '其他省部级及以上项目') {
  200. this.validateForm.controls.importantProjectOther.clearValidators();
  201. this.validateForm.controls.importantProjectOther.markAsPristine();
  202. } else {
  203. this.validateForm.controls.importantProjectOther.setValidators(Validators.required);
  204. this.validateForm.controls.importantProjectOther.markAsDirty();
  205. }
  206. this.validateForm.controls.importantProjectOther.updateValueAndValidity();
  207. }
  208. //校验全册册数是否需填
  209. requiredTypeNumber(e:boolean){
  210. if (e) {
  211. this.validateForm.controls.typeNumber.clearValidators();
  212. this.validateForm.controls.typeNumber.markAsPristine();
  213. } else {
  214. this.validateForm.controls.typeNumber.setValidators(Validators.required);
  215. this.validateForm.controls.typeNumber.markAsDirty();
  216. }
  217. this.validateForm.controls.typeNumber.updateValueAndValidity();
  218. }
  219. handleChange(info: NzUploadChangeParam): void {
  220. if (info.file.status !== 'uploading') {
  221. console.log(info.file, info.fileList);
  222. }
  223. if (info.file.status === 'done') {
  224. this.msg.success(`${info.file.name} file uploaded successfully`);
  225. } else if (info.file.status === 'error') {
  226. this.msg.error(`${info.file.name} file upload failed.`);
  227. }
  228. }
  229. upload(e: any, type:string) {
  230. console.log(e);
  231. let file = e[0];
  232. // if(type == 'copyrightImgUrl' || type == 'CIPImgUrl' ||type=='approvedImgUrl'){
  233. if(type=='approvedImgUrl'){
  234. this.validateForm.value[type] = file
  235. }
  236. }
  237. async submitForm(event?: string): Promise<void> {
  238. console.log(this.validateForm.value);
  239. if (this.validateForm.valid) {
  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. if(event == 'next'){
  257. let params = this.validateForm.value
  258. await this.saveEduTextbook(params, this.validateForm.valid)
  259. this.state.emit({type:'next',textBook:this.eduTextbook});
  260. }
  261. // Object.values(this.validateForm.controls).forEach((control) => {
  262. // if (control.invalid) {
  263. // control.markAsDirty();
  264. // control.updateValueAndValidity({ onlySelf: true });
  265. // }
  266. // });
  267. // this.msg.warning('请填写完整的内容')
  268. // return
  269. }
  270. if(event == 'save'){
  271. let params = this.validateForm.value
  272. await this.saveEduTextbook(params, this.validateForm.valid)
  273. this.modal.success({
  274. nzTitle: '保存成功',
  275. nzContent: '<p>已保存并且至空间</p>',
  276. nzOnOk: () => console.log('Info OK')
  277. });
  278. }
  279. }
  280. async saveEduTextbook(params: any, isComplete:boolean){
  281. console.log(params);
  282. if(!this.eduTextbook){
  283. let obj = Parse.Object.extend('EduTextbook');
  284. this.eduTextbook = new obj();
  285. }
  286. //如果填写未完整,仅保存,状态修改待完善101
  287. if(this.eduTextbook.get('status') == '102' && !isComplete){
  288. this.eduTextbook?.set('status', '101');
  289. this.eduTextbook.set('complete', false)
  290. }else if(!this.eduTextbook.get('status')){
  291. this.eduTextbook?.set('status', '101');
  292. }
  293. this.eduTextbook?.set('user', Parse.User.current()?.toPointer());
  294. this.eduTextbook?.set('company', {
  295. __type: 'Pointer',
  296. className: 'Company',
  297. objectId: this.tbookSer.company,
  298. });
  299. this.eduTextbook?.set('title', params.title);
  300. this.eduTextbook?.set('ISBN', params.ISBN);
  301. this.eduTextbook?.set('author', params.author);
  302. this.eduTextbook?.set('unit', params.unit);
  303. this.eduTextbook?.set('type', params.type);
  304. this.eduTextbook?.set('typeNumber', params.typeNumber);
  305. this.eduTextbook?.set('majorPoniter', params.majorPoniter);
  306. this.eduTextbook?.set('lang', params.lang);
  307. this.eduTextbook?.set('authors', params.authors);
  308. this.eduTextbook?.set('editor', params.editor);
  309. this.eduTextbook?.set('approval', params.approval);
  310. this.eduTextbook?.set('editionUnit', params.editionUnit);
  311. this.eduTextbook?.set('editionFirst', params.editionFirst);
  312. this.eduTextbook?.set('carrierShape', params.carrierShape);
  313. this.eduTextbook?.set('editionDate', params.editionDate);
  314. this.eduTextbook?.set('editionNumber', params.editionNumber);
  315. this.eduTextbook?.set('printDate', params.printDate);
  316. this.eduTextbook?.set('printNumber', params.printNumber);
  317. this.eduTextbook?.set('printSum', params.printSum);
  318. this.eduTextbook?.set('importantProject', params.importantProject);
  319. this.eduTextbook?.set('importantProjectOther', params.importantProjectOther);
  320. // this.eduTextbook?.set('copyrightImgUrl', params.copyrightImgUrl);
  321. // this.eduTextbook?.set('CIPImgUrl', params.CIPImgUrl);
  322. this.eduTextbook?.set('approvedImgUrl',params.approvedImgUrl)
  323. if(this.tbookSer.profile?.user?.department?.objectId){
  324. this.eduTextbook?.set('department', {
  325. __type: 'Pointer',
  326. className: 'Department',
  327. objectId: this.tbookSer?.profile?.user?.department?.objectId,
  328. });
  329. }
  330. await this.eduTextbook?.save();
  331. return
  332. }
  333. selectedValue = null;
  334. listOfOption: Array<{ value: string; text: string }> = [];
  335. nzFilterOption = (): boolean => true;
  336. eduTimeout:any
  337. /**出版单位列表 */
  338. eduList:Array<Parse.Object>=[]
  339. /**搜索出版单位 */
  340. async search(value: string) {
  341. clearTimeout(this.eduTimeout)
  342. this.eduTimeout = setTimeout(async() => {
  343. let query = new Parse.Query('EduProcess')
  344. query.equalTo('company', this.tbookSer.company)
  345. query.equalTo('branch','66865d66ad23a23355b12aa7')
  346. query.contains('name',value)
  347. query.limit(10)
  348. this.eduList = await query.find()
  349. }, 500);
  350. }
  351. }