index.vue 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. <template>
  2. <s-layout>
  3. <u-notice-bar mode="horizontal" :list="list"></u-notice-bar>
  4. <view class="form-container">
  5. <u-form :model="form" ref="form1" :border-bottom="false" label-width="220">
  6. <u-form-item label="相关照片" prop="infoImages">
  7. <view class="tpClass">
  8. <s-uploader v-model:url="form.infoImages" fileMediatype="image" limit="9" mode="grid"
  9. :imageStyles="{ width: '168rpx', height: '168rpx' }" />
  10. </view>
  11. <u-button @click="extractClick" type="primary">提取</u-button>
  12. </u-form-item>
  13. <u-form-item label="用户编号" prop="userId">
  14. <u-input v-model="form.userId" placeholder="请输入用户编号" />
  15. </u-form-item>
  16. <u-form-item label="姓名" prop="name">
  17. <u-input v-model="form.name" placeholder="请输入姓名" />
  18. </u-form-item>
  19. <u-form-item label="性别" prop="gender">
  20. <u-input v-model="form.gender" placeholder="请输入性别" />
  21. </u-form-item>
  22. <u-form-item label="民族" prop="ethnicity">
  23. <u-input v-model="form.ethnicity" placeholder="请输入民族" />
  24. </u-form-item>
  25. <u-form-item label="出生日期" prop="birthDate">
  26. <u-input v-model="form.birthDate" type="select" placeholder="选择出生日期" @click="calendar1.show = true" />
  27. <u-calendar v-model="calendar1.show" mode="date" @change="onCalendar1"></u-calendar>
  28. </u-form-item>
  29. <u-form-item label="住址" prop="address">
  30. <u-input v-model="form.address" placeholder="请输入住址" />
  31. </u-form-item>
  32. <u-form-item label="公民身份号码" prop="idCardNumber">
  33. <u-input v-model="form.idCardNumber" placeholder="请输入公民身份号码" />
  34. </u-form-item>
  35. <u-form-item label="签发机关" prop="issuingAuthority">
  36. <u-input v-model="form.issuingAuthority" placeholder="请输入签发机关" />
  37. </u-form-item>
  38. <u-form-item label="有效期开始日期" prop="validityStart">
  39. <u-input v-model="form.validityStart" type="select" placeholder="选择有效期开始日期" @click="calendar2.show = true" />
  40. <u-calendar v-model="calendar2.show" mode="date" @change="onCalendar2"></u-calendar>
  41. </u-form-item>
  42. <u-form-item label="有效期结束日期" prop="validityEnd">
  43. <u-input v-model="form.validityEnd" type="select" placeholder="选择有效期结束日期" @click="calendar3.show = true" />
  44. <u-calendar v-model="calendar3.show" mode="date" @change="onCalendar3"></u-calendar>
  45. </u-form-item>
  46. <!-- <u-form-item label="数据使用状态" prop="infoStatus">
  47. <u-radio-group v-model="form.infoStatus">
  48. <u-radio v-for="(item, index) in infoStatusOptions" :key="index" :name="item.value">
  49. {{ item.label }}
  50. </u-radio>
  51. </u-radio-group>
  52. </u-form-item> -->
  53. </u-form>
  54. <view style="height: 80px;"></view>
  55. <view class="submit-btn">
  56. <u-button @click="submit" type="primary">提交</u-button>
  57. </view>
  58. </view>
  59. </s-layout>
  60. </template>
  61. <script setup>
  62. import { ref, reactive, onMounted } from 'vue';
  63. import { onLoad } from '@dcloudio/uni-app';
  64. import EnterApi from '@/sheep/api/enter/index.js'
  65. import sheep from '@/sheep';
  66. const form1 = ref(null);
  67. const route = ref({});
  68. const list = ref([
  69. '温馨提示:请上传身份证正面照片,照片需清晰可见身份证全部信息。进行提取!',
  70. ])
  71. const form = ref({
  72. name: '',
  73. gender: '',
  74. ethnicity: '',
  75. birthDate: '',
  76. address: '',
  77. idCardNumber: '',
  78. issuingAuthority: '',
  79. validityStart: '',
  80. validityEnd: '',
  81. infoImages: [],
  82. // infoStatus: ''
  83. });
  84. const calendar1 = reactive({
  85. show: false
  86. });
  87. const calendar2 = reactive({
  88. show: false
  89. });
  90. const calendar3 = reactive({
  91. show: false
  92. });
  93. const infoStatusOptions = reactive([
  94. {
  95. value: '1',
  96. label: '启用'
  97. },
  98. {
  99. value: '0',
  100. label: '停用'
  101. }
  102. ]);
  103. const rules = {
  104. userId: [
  105. { required: true, message: '请输入用户编号', trigger: ['change', 'blur'] }
  106. ],
  107. name: [
  108. { required: true, message: '请输入姓名', trigger: ['change', 'blur'] }
  109. ],
  110. idCardNumber: [
  111. { required: true, message: '请输入身份证号码', trigger: ['change', 'blur'] }
  112. ]
  113. };
  114. const getUserIdcardAxios = async () => {
  115. const res = await EnterApi.getUserIdcard(route.value.id);
  116. if (res.code === 0) {
  117. form.value = { ...res.data, infoImages: JSON.parse(res.data.infoImages) };
  118. }
  119. };
  120. onMounted(() => {
  121. form1.value.setRules(rules);
  122. console.log(route.value, 55555)
  123. if (route.value.id) {
  124. getUserIdcardAxios();
  125. }
  126. });
  127. onLoad(async (options) => {
  128. route.value = options;
  129. });
  130. const submit = () => {
  131. form1.value.validate(async (valid) => {
  132. if (valid) {
  133. if (route.value.formType === 'create') {
  134. const res = await EnterApi.createUserIdcard(form.value)
  135. if (res.code === 0) {
  136. uni.showToast({
  137. title: '创建成功',
  138. icon: 'success'
  139. })
  140. sheep.$router.back()
  141. } else {
  142. uni.showToast({
  143. title: res.msg,
  144. icon: 'none'
  145. })
  146. }
  147. } else {
  148. const res = await EnterApi.updateUserIdcard(form.value)
  149. if (res.code === 0) {
  150. uni.showToast({
  151. title: '更新成功',
  152. icon: 'success'
  153. })
  154. sheep.$router.back()
  155. } else {
  156. uni.showToast({
  157. title: res.msg,
  158. icon: 'none'
  159. })
  160. }
  161. }
  162. }
  163. })
  164. };
  165. const extractClick = async () => {
  166. if (form.value.infoImages && form.value.infoImages.length == 0)
  167. return uni.showToast({
  168. icon: "none",
  169. title: "请上传身份证照片"
  170. })
  171. const res = await EnterApi.difyOrcs(
  172. {
  173. "type": "提取身份证",
  174. "images": form.value.infoImages
  175. }
  176. )
  177. const data = JSON.parse(res.data)
  178. for (const key in data) {
  179. if (Object.prototype.hasOwnProperty.call(data, key)) {
  180. const element = data[key];
  181. if (!element) {
  182. delete data[key]
  183. }
  184. }
  185. }
  186. form.value = { ...form.value, ...data }
  187. if (res.code === 0) {
  188. uni.showToast({
  189. icon: "none",
  190. title: "提取成功"
  191. })
  192. } else {
  193. uni.showModal({
  194. content: res.msg,
  195. showCancel: false
  196. })
  197. }
  198. };
  199. const onCalendar1 = (e) => {
  200. form.value.birthDate = e.result;
  201. };
  202. const onCalendar2 = (e) => {
  203. form.value.validityStart = e.result;
  204. };
  205. const onCalendar3 = (e) => {
  206. form.value.validityEnd = e.result;
  207. };
  208. </script>
  209. <style lang="scss" scoped>
  210. .form-container {
  211. padding: 40rpx;
  212. background-color: #ffffff;
  213. .u-form {
  214. background: #fff;
  215. }
  216. .submit-btn {
  217. padding: 40rpx 0;
  218. background: #fff;
  219. position: fixed;
  220. bottom: 0;
  221. width: calc(100% - 80rpx);
  222. }
  223. .form-data {
  224. padding: 20rpx;
  225. background-color: #f8f8f8;
  226. border-radius: 8rpx;
  227. font-size: 24rpx;
  228. color: #666;
  229. }
  230. }
  231. </style>