basic-in.component.ts 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  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 { NzMessageService } from 'ng-zorro-antd/message';
  9. import { NzUploadChangeParam } from 'ng-zorro-antd/upload';
  10. import {
  11. FormControl,
  12. FormGroup,
  13. NonNullableFormBuilder,
  14. Validators,
  15. } from '@angular/forms';
  16. @Component({
  17. selector: 'app-basic',
  18. imports: [
  19. CommonCompModule,
  20. ReactiveFormsModule,
  21. NzSelectModule,
  22. NzRadioModule,
  23. NzUploadModule,
  24. ],
  25. standalone: true,
  26. templateUrl: './basic-in.component.html',
  27. styleUrls: ['./basic-in.component.scss'],
  28. })
  29. export class BasicInComponent implements OnInit {
  30. @Input('editFrom') editFrom: any;
  31. @Output() next: EventEmitter<any> = new EventEmitter<any>();
  32. @Output() save: EventEmitter<any> = new EventEmitter<any>();
  33. validateForm: FormGroup<{
  34. name: FormControl<string>; //申报教材名称
  35. ISBN: FormControl<string>; //国际标准书号
  36. author: FormControl<string>; //第一主编(作者)
  37. unit: FormControl<string>; //第一主编(作者)单位
  38. type: FormControl<string>; //申报类型
  39. typeNumber: FormControl<number|any>; //全册次数
  40. majorPoniter: FormControl<string>; //教材应用对象及所诉学科专业类
  41. lang: FormControl<string>; //教材主要语种类型
  42. authors: FormControl<string>; //其他主编姓名
  43. editor: FormControl<string>; //其他编者姓名
  44. approval: FormControl<string>; //是否重点立项教材
  45. edition: FormControl<string>; //出版单位
  46. editionFirst: FormControl<Date>; //初版时间
  47. carrierShape: FormControl<string>; //载体形式
  48. editionDate: FormControl<Date>; //出版时间
  49. editionNumber: FormControl<number>; //出版版次
  50. printDate: FormControl<Date>; //最新印次时间
  51. printNumber: FormControl<number>; //最新印次
  52. printSum: FormControl<number>; //初版以来合计印次
  53. importantProject: FormControl<string>; //初版以来是否列为重点项目
  54. importantProjectOther: FormControl<string>; //其他省部级及以上项目
  55. copyrightImgUrl: FormControl<string>; //版权页截图
  56. CIPImgUrl: FormControl<string>; //中国版本图书馆CIP查询截图
  57. // remember: FormControl<boolean>;
  58. }> = this.fb.group({
  59. name: ['', [Validators.required]],
  60. ISBN: ['', [Validators.required]],
  61. author: ['', [Validators.required]],
  62. unit: ['', [Validators.required]],
  63. type: ['', [Validators.required]],
  64. typeNumber: ['', [Validators.required]],
  65. majorPoniter: ['', [Validators.required]],
  66. lang: ['', [Validators.required]],
  67. authors: ['', [Validators.required]],
  68. editor: ['', [Validators.required]],
  69. approval: ['', [Validators.required]],
  70. edition: ['', [Validators.required]],
  71. editionFirst: [new Date(), [Validators.required]],
  72. carrierShape: ['', [Validators.required]],
  73. editionDate: [new Date(), [Validators.required]],
  74. editionNumber: [0, [Validators.required]],
  75. printDate: [new Date(), [Validators.required]],
  76. printNumber: [0, [Validators.required]],
  77. printSum: [0, [Validators.required]],
  78. importantProject: ['', [Validators.required]],
  79. importantProjectOther: ['', [Validators.required]],
  80. copyrightImgUrl: ['', [Validators.required]],
  81. CIPImgUrl: ['', [Validators.required]],
  82. // remember: [true],
  83. });
  84. //教材应用对象及所诉学科专业类
  85. selectList: Array<any> = [
  86. {
  87. name: '机械与工程',
  88. code: 'M001',
  89. },
  90. {
  91. name: '软件工程',
  92. code: 'M002',
  93. },
  94. {
  95. name: '生物工程学',
  96. code: 'M003',
  97. },
  98. ];
  99. //语言选择
  100. selectLang: Array<any> = languages.options;
  101. //重点项目选择
  102. directorys: Array<any> = [
  103. {
  104. name: '电气设计原理',
  105. code: 'T001',
  106. },
  107. {
  108. name: '微生物学',
  109. code: 'T002',
  110. },
  111. {
  112. name: '细胞学',
  113. code: 'T003',
  114. },
  115. ];
  116. //载体形式
  117. carrierOptions: Array<any> = [
  118. {
  119. name: '载体一',
  120. code: 'Z001',
  121. },
  122. {
  123. name: '载体二',
  124. code: 'Z002',
  125. },
  126. {
  127. name: '载体三',
  128. code: 'Z003',
  129. },
  130. ];
  131. importantProjectList: Array<any> = [
  132. {
  133. title: '“十二五”普通高等教育本科国家级规划教材',
  134. value: '“十二五”普通高等教育本科国家级规划教材',
  135. },
  136. {
  137. title: '“十二五”以来省级优秀教材',
  138. value: '“十二五”以来省级优秀教材',
  139. },
  140. {
  141. title: '“十二五”以来省级规划教材',
  142. value: '“十二五”以来省级规划教材',
  143. },
  144. {
  145. title: '其他省部级及以上项目',
  146. value: '其他省部级及以上项目',
  147. },
  148. ];
  149. // get importantProjectState(){
  150. // return this.importantProjectList.some((item:any)=> item.value == this.validateForm.value.importantProject)
  151. // }
  152. constructor(
  153. private fb: NonNullableFormBuilder,
  154. private msg: NzMessageService
  155. ) {}
  156. ngOnInit() {}
  157. changeMajor() {}
  158. getMajor(e: any) {
  159. console.log(e);
  160. }
  161. onChange(e: any) {
  162. console.log(e);
  163. console.log(this.validateForm);
  164. }
  165. handleChange(info: NzUploadChangeParam): void {
  166. if (info.file.status !== 'uploading') {
  167. console.log(info.file, info.fileList);
  168. }
  169. if (info.file.status === 'done') {
  170. this.msg.success(`${info.file.name} file uploaded successfully`);
  171. } else if (info.file.status === 'error') {
  172. this.msg.error(`${info.file.name} file upload failed.`);
  173. }
  174. }
  175. submitForm(event?: string): void {
  176. console.log(this.validateForm.value);
  177. if (this.validateForm.valid) {
  178. console.log(this.validateForm.value);
  179. } else {
  180. Object.values(this.validateForm.controls).forEach((control) => {
  181. if (control.invalid) {
  182. control.markAsDirty();
  183. control.updateValueAndValidity({ onlySelf: true });
  184. }
  185. });
  186. }
  187. if (event == 'next') {
  188. this.next.emit();
  189. }
  190. }
  191. }