form.vue 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. <script lang="ts" setup>
  2. import { computed, ref } from 'vue';
  3. import { useVbenModal } from '@vben/common-ui';
  4. import { ElMessage } from 'element-plus';
  5. import { useVbenForm, z } from '#/adapter/form';
  6. import {
  7. addSubsidyApplicationsApi,
  8. editSubsidyApplicationsApi,
  9. getSubsidyApplicationsDetailApi,
  10. } from '#/api/subsidyapplications';
  11. import { $t } from '#/locales';
  12. const emit = defineEmits(['finish']);
  13. const data = ref();
  14. const formType = ref<'create' | 'detail' | 'edit'>('create');
  15. const titleMap = {
  16. create: '新增补贴申请',
  17. detail: '补贴申请详情',
  18. edit: '编辑补贴申请',
  19. } as const;
  20. const getTitle = computed(() => titleMap[formType.value]);
  21. const [BaseForm, baseFormApi] = useVbenForm({
  22. showDefaultActions: false,
  23. // 所有表单项共用,可单独在表单内覆盖
  24. commonConfig: {
  25. labelWidth: 140,
  26. // 所有表单项
  27. componentProps: {
  28. class: 'w-full',
  29. },
  30. },
  31. wrapperClass: 'grid-cols-1 lg:grid-cols-2',
  32. schema: [
  33. // { title: '经销商ID', field: 'subsidyapplicationsmerchantid' },
  34. // { title: '补贴金额', field: 'subsidyapplicationssubsidyamount' },
  35. // { title: '审批状态', field: 'subsidyapplicationsapprovalstatus' },
  36. // { title: '申请日期', field: 'subsidyapplicationsapplydate' },
  37. {
  38. component: 'Input',
  39. fieldName: 'subsidyapplicationsmerchantid',
  40. label: '经销商ID',
  41. componentProps: {
  42. placeholder: $t('ui.placeholder.input'),
  43. allowClear: true,
  44. },
  45. rules: z.string().min(1, { message: '请输入经销商ID' }),
  46. },
  47. {
  48. component: 'Input',
  49. fieldName: 'subsidyapplicationssubsidyamount',
  50. label: '补贴金额',
  51. componentProps: {
  52. placeholder: $t('ui.placeholder.input'),
  53. allowClear: true,
  54. },
  55. rules: z.string().min(1, { message: '请输入补贴金额' }),
  56. },
  57. {
  58. component: 'Input',
  59. fieldName: 'subsidyapplicationsapprovalstatus',
  60. label: '审批状态',
  61. componentProps: {
  62. placeholder: $t('ui.placeholder.input'),
  63. allowClear: true,
  64. },
  65. rules: z.string().min(1, { message: '请输入审批状态' }),
  66. },
  67. ],
  68. });
  69. const [Modal, modalApi] = useVbenModal({
  70. class: 'w-7/12',
  71. onCancel() {
  72. modalApi.close();
  73. },
  74. async onConfirm() {
  75. // 校验输入的数据
  76. const validate = await baseFormApi.validate();
  77. if (!validate.valid) {
  78. return;
  79. }
  80. try {
  81. // 调用新增或编辑接口
  82. const apiMap = {
  83. create: () => {
  84. const params = {
  85. ...validate?.values,
  86. 'subsidyapplicationsmerchantid.value':
  87. validate?.values?.subsidyapplicationsmerchantid,
  88. 'subsidyapplicationstotalsales.value':
  89. validate?.values?.subsidyapplicationstotalsales,
  90. 'subsidyapplicationssubsidyamount.value':
  91. validate?.values?.subsidyapplicationssubsidyamount,
  92. 'subsidyapplicationsapprovalstatus.value':
  93. validate?.values?.subsidyapplicationsapprovalstatus,
  94. } as any;
  95. return addSubsidyApplicationsApi(params);
  96. },
  97. edit: () =>
  98. editSubsidyApplicationsApi({
  99. ...validate.values,
  100. 'subsidyapplicationsmerchantid.value':
  101. data.value.row.subsidyapplicationsmerchantid,
  102. 'subsidyapplicationsid.value': data.value.row.subsidyapplicationsid,
  103. 'subsidyapplicationstotalsales.value':
  104. data.value.row.subsidyapplicationstotalsales,
  105. 'subsidyapplicationssubsidyamount.value':
  106. data.value.row.subsidyapplicationssubsidyamount,
  107. 'subsidyapplicationsapprovalstatus.value':
  108. data.value.row.subsidyapplicationsapprovalstatus,
  109. } as any),
  110. };
  111. if (formType.value === 'detail') {
  112. modalApi.close();
  113. return;
  114. }
  115. await apiMap[formType.value]();
  116. ElMessage.success('操作成功');
  117. emit('finish');
  118. modalApi.close();
  119. } catch {}
  120. },
  121. async onOpenChange(isOpen) {
  122. if (isOpen) {
  123. data.value = modalApi.getData();
  124. formType.value = data.value.formType;
  125. baseFormApi.setState({
  126. commonConfig: { disabled: formType.value === 'detail' },
  127. });
  128. if (data.value.formType === 'create') {
  129. return;
  130. }
  131. try {
  132. modalApi.setState({ loading: true });
  133. const detailData = await getSubsidyApplicationsDetailApi({
  134. subsidyapplicationsid: data.value.row.subsidyapplicationsid,
  135. });
  136. baseFormApi.setValues(detailData);
  137. } catch {
  138. // console.log(error);
  139. }
  140. modalApi.setState({ loading: false });
  141. }
  142. },
  143. });
  144. </script>
  145. <template>
  146. <Modal :title="getTitle">
  147. <BaseForm />
  148. </Modal>
  149. </template>