StatWorkerRefluxForm.vue 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. <template>
  2. <a-spin :spinning="confirmLoading">
  3. <JFormContainer :disabled="disabled">
  4. <template #detail>
  5. <a-form ref="formRef" class="antd-modal-form" :labelCol="labelCol" :wrapperCol="wrapperCol" name="StatWorkerRefluxForm">
  6. <a-row>
  7. <a-col :span="12">
  8. <a-form-item label="身份证号码" v-bind="validateInfos.idCard" id="StatWorkerRefluxForm-idCard" name="idCard">
  9. <a-input v-model:value="formData.idCard" placeholder="请输入身份证号码" allow-clear></a-input>
  10. </a-form-item>
  11. </a-col>
  12. <a-col :span="12">
  13. <a-form-item label="姓名" v-bind="validateInfos.fullName" id="StatWorkerRefluxForm-fullName" name="fullName">
  14. <a-input v-model:value="formData.fullName" placeholder="请输入姓名" allow-clear></a-input>
  15. </a-form-item>
  16. </a-col>
  17. <a-col :span="12">
  18. <a-form-item label="所属区县" v-bind="validateInfos.district" id="StatWorkerRefluxForm-district" name="district">
  19. <a-input v-model:value="formData.district" placeholder="请输入所属区县" allow-clear></a-input>
  20. </a-form-item>
  21. </a-col>
  22. <a-col :span="12">
  23. <a-form-item label="乡村户籍标识" v-bind="validateInfos.ruralRegisterFlag" id="StatWorkerRefluxForm-ruralRegisterFlag" name="ruralRegisterFlag">
  24. <a-input v-model:value="formData.ruralRegisterFlag" placeholder="请输入乡村户籍标识" allow-clear></a-input>
  25. </a-form-item>
  26. </a-col>
  27. <a-col :span="12">
  28. <a-form-item label="原就业外出地市/省份" v-bind="validateInfos.originWorkArea" id="StatWorkerRefluxForm-originWorkArea" name="originWorkArea">
  29. <a-input v-model:value="formData.originWorkArea" placeholder="请输入原就业外出地市/省份" allow-clear></a-input>
  30. </a-form-item>
  31. </a-col>
  32. <a-col :span="12">
  33. <a-form-item label="外出就业结束日期" v-bind="validateInfos.workEndDate" id="StatWorkerRefluxForm-workEndDate" name="workEndDate">
  34. <a-date-picker v-model:value="formData.workEndDate" placeholder="请选择外出就业结束日期" value-format="YYYY-MM-DD" style="width: 100%" allow-clear></a-date-picker>
  35. </a-form-item>
  36. </a-col>
  37. <a-col :span="12">
  38. <a-form-item label="本地新就业登记日期" v-bind="validateInfos.localEmployDate" id="StatWorkerRefluxForm-localEmployDate" name="localEmployDate">
  39. <a-date-picker v-model:value="formData.localEmployDate" placeholder="请选择本地新就业登记日期" value-format="YYYY-MM-DD" style="width: 100%" allow-clear></a-date-picker>
  40. </a-form-item>
  41. </a-col>
  42. <a-col :span="12">
  43. <a-form-item label="人员类别标签" v-bind="validateInfos.personCategoryTag" id="StatWorkerRefluxForm-personCategoryTag" name="personCategoryTag">
  44. <a-input v-model:value="formData.personCategoryTag" placeholder="请输入人员类别标签" allow-clear></a-input>
  45. </a-form-item>
  46. </a-col>
  47. </a-row>
  48. </a-form>
  49. </template>
  50. </JFormContainer>
  51. </a-spin>
  52. </template>
  53. <script lang="ts" setup>
  54. import { computed, defineExpose, defineProps, nextTick, reactive, ref } from 'vue';
  55. import { useMessage } from '/@/hooks/web/useMessage';
  56. import { getDateByPicker, getValueType } from '/@/utils';
  57. import { saveOrUpdate } from '../StatWorkerReflux.api';
  58. import { Form } from 'ant-design-vue';
  59. import JFormContainer from '/@/components/Form/src/container/JFormContainer.vue';
  60. const props = defineProps({
  61. formDisabled: { type: Boolean, default: false },
  62. formData: { type: Object, default: () => ({}) },
  63. formBpm: { type: Boolean, default: true },
  64. });
  65. const formRef = ref();
  66. const useForm = Form.useForm;
  67. const emit = defineEmits(['register', 'ok']);
  68. const formData = reactive<Record<string, any>>({
  69. id: '',
  70. idCard: '',
  71. fullName: '',
  72. district: '',
  73. ruralRegisterFlag: '',
  74. originWorkArea: '',
  75. workEndDate: '',
  76. localEmployDate: '',
  77. personCategoryTag: '',
  78. dataRefluxTime: '',
  79. });
  80. const { createMessage } = useMessage();
  81. const labelCol = ref<any>({ xs: { span: 24 }, sm: { span: 5 } });
  82. const wrapperCol = ref<any>({ xs: { span: 24 }, sm: { span: 16 } });
  83. const confirmLoading = ref<boolean>(false);
  84. //表单验证
  85. const validatorRules = reactive({});
  86. const { resetFields, validate, validateInfos } = useForm(formData, validatorRules, { immediate: false });
  87. //日期个性化选择
  88. const fieldPickers = reactive({});
  89. // 表单禁用
  90. const disabled = computed(() => {
  91. if (props.formBpm === true) {
  92. if (props.formData.disabled === false) {
  93. return false;
  94. } else {
  95. return true;
  96. }
  97. }
  98. return props.formDisabled;
  99. });
  100. /**
  101. * 新增
  102. */
  103. function add() {
  104. edit({});
  105. }
  106. /**
  107. * 编辑
  108. */
  109. function edit(record) {
  110. nextTick(() => {
  111. resetFields();
  112. const tmpData = {};
  113. Object.keys(formData).forEach((key) => {
  114. if (record.hasOwnProperty(key)) {
  115. tmpData[key] = record[key];
  116. }
  117. });
  118. //赋值
  119. Object.assign(formData, tmpData);
  120. });
  121. }
  122. /**
  123. * 提交数据
  124. */
  125. async function submitForm() {
  126. try {
  127. // 触发表单验证
  128. await validate();
  129. } catch ({ errorFields }) {
  130. if (errorFields) {
  131. const firstField = errorFields[0];
  132. if (firstField) {
  133. formRef.value.scrollToField(firstField.name, { behavior: 'smooth', block: 'center' });
  134. }
  135. }
  136. return Promise.reject(errorFields);
  137. }
  138. confirmLoading.value = true;
  139. const isUpdate = ref<boolean>(false);
  140. //时间格式化
  141. let model = formData;
  142. if (model.id) {
  143. isUpdate.value = true;
  144. }
  145. //循环数据
  146. for (let data in model) {
  147. // 更新个性化日期选择器的值
  148. model[data] = getDateByPicker(model[data], fieldPickers[data]);
  149. //如果该数据是数组并且是字符串类型
  150. if (model[data] instanceof Array) {
  151. let valueType = getValueType(formRef.value.getProps, data);
  152. //如果是字符串类型的需要变成以逗号分割的字符串
  153. if (valueType === 'string') {
  154. model[data] = model[data].join(',');
  155. }
  156. }
  157. }
  158. await saveOrUpdate(model, isUpdate.value)
  159. .then((res) => {
  160. if (res.success) {
  161. createMessage.success(res.message);
  162. emit('ok');
  163. } else {
  164. createMessage.warning(res.message);
  165. }
  166. })
  167. .finally(() => {
  168. confirmLoading.value = false;
  169. });
  170. }
  171. defineExpose({
  172. add,
  173. edit,
  174. submitForm,
  175. });
  176. </script>
  177. <style lang="less" scoped>
  178. .antd-modal-form {
  179. padding: 14px 20px;
  180. }
  181. </style>