basic-in.component.ts 15 KB

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