index.vue 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  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="unifiedSocialCreditCode">
  17. <u-input v-model="form.unifiedSocialCreditCode" placeholder="请输入统一社会信用代码" />
  18. </u-form-item>
  19. <u-form-item label="名称" prop="businessName">
  20. <u-input v-model="form.businessName" placeholder="请输入名称" />
  21. </u-form-item>
  22. <u-form-item label="类型" prop="businessType">
  23. <u-input v-model="form.businessType" placeholder="请输入类型" />
  24. </u-form-item>
  25. <u-form-item label="法定代表人" prop="legalRepresentative">
  26. <u-input v-model="form.legalRepresentative" placeholder="请输入法定代表人" />
  27. </u-form-item>
  28. <u-form-item label="注册资本" prop="registeredCapital">
  29. <u-input v-model="form.registeredCapital" placeholder="请输入注册资本" />
  30. </u-form-item>
  31. <u-form-item label="成立日期" prop="establishmentDate">
  32. <u-input v-model="form.establishmentDate" type="select" placeholder="选择成立日期" @click="calendar1.show = true" />
  33. <u-calendar v-model="calendar1.show" mode="date" @change="onCalendar1"></u-calendar>
  34. </u-form-item>
  35. <u-form-item label="住所" prop="businessAddress">
  36. <u-input v-model="form.businessAddress" placeholder="请输入住所" />
  37. </u-form-item>
  38. <u-form-item label="经营范围" prop="businessScope">
  39. <u-input v-model="form.businessScope" placeholder="请输入经营范围" />
  40. </u-form-item>
  41. <u-form-item label="登记机关" prop="registrationAuthority">
  42. <u-input v-model="form.registrationAuthority" placeholder="请输入登记机关" />
  43. </u-form-item>
  44. <u-form-item label="发证日期" prop="issueDate">
  45. <u-input v-model="form.issueDate" type="select" placeholder="选择发证日期" @click="calendar2.show = true" />
  46. <u-calendar v-model="calendar2.show" mode="date" @change="onCalendar2"></u-calendar>
  47. </u-form-item>
  48. <!-- <u-form-item label="数据使用状态" prop="infoStatus">
  49. <u-radio-group v-model="form.infoStatus">
  50. <u-radio v-for="(item, index) in infoStatusOptions" :key="index" :name="item.value">
  51. {{ item.label }}
  52. </u-radio>
  53. </u-radio-group>
  54. </u-form-item> -->
  55. </u-form>
  56. <view style="height: 80px;"></view>
  57. <view class="submit-btn">
  58. <u-button @click="submit" type="primary">提交</u-button>
  59. </view>
  60. </view>
  61. </s-layout>
  62. </template>
  63. <script setup>
  64. import { ref, reactive, onMounted } from 'vue';
  65. import { onLoad } from '@dcloudio/uni-app';
  66. import EnterApi from '@/sheep/api/enter/index.js'
  67. import sheep from '@/sheep';
  68. const form1 = ref(null);
  69. const route = ref({});
  70. const list = ref([
  71. '温馨提示:请上传营业执照照片,照片需清晰可见全部信息。进行提取!',
  72. ])
  73. const form = ref({
  74. // userId: '',
  75. unifiedSocialCreditCode: '',
  76. businessName: '',
  77. businessType: '',
  78. legalRepresentative: '',
  79. registeredCapital: '',
  80. establishmentDate: '',
  81. businessAddress: '',
  82. businessScope: '',
  83. registrationAuthority: '',
  84. issueDate: '',
  85. infoImages: [],
  86. // infoStatus: ''
  87. });
  88. const calendar1 = reactive({
  89. show: false
  90. });
  91. const calendar2 = reactive({
  92. show: false
  93. });
  94. const infoStatusOptions = reactive([
  95. {
  96. value: '1',
  97. label: '启用'
  98. },
  99. {
  100. value: '0',
  101. label: '停用'
  102. }
  103. ]);
  104. const rules = {
  105. userId: [
  106. { required: true, message: '请输入用户编号', trigger: ['change', 'blur'] }
  107. ],
  108. unifiedSocialCreditCode: [
  109. { required: true, message: '请输入统一社会信用代码', trigger: ['change', 'blur'] }
  110. ],
  111. businessName: [
  112. { required: true, message: '请输入名称', trigger: ['change', 'blur'] }
  113. ]
  114. };
  115. const getUserBusinessLicenseAxios = async () => {
  116. const res = await EnterApi.getUserBusinessLicense(route.value.id);
  117. if (res.code === 0) {
  118. form.value = { ...res.data, infoImages: JSON.parse(res.data.infoImages) };
  119. }
  120. };
  121. onMounted(() => {
  122. form1.value.setRules(rules);
  123. if (route.value.id) {
  124. getUserBusinessLicenseAxios();
  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.createUserBusinessLicense(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.updateUserBusinessLicense(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.establishmentDate = e.result;
  201. };
  202. const onCalendar2 = (e) => {
  203. form.value.issueDate = e.result;
  204. };
  205. </script>
  206. <style lang="scss" scoped>
  207. .form-container {
  208. padding: 40rpx;
  209. background-color: #ffffff;
  210. .u-form {
  211. background: #fff;
  212. }
  213. .submit-btn {
  214. padding: 40rpx 0;
  215. background: #fff;
  216. position: fixed;
  217. bottom: 0;
  218. width: calc(100% - 80rpx);
  219. }
  220. .form-data {
  221. padding: 20rpx;
  222. background-color: #f8f8f8;
  223. border-radius: 8rpx;
  224. font-size: 24rpx;
  225. color: #666;
  226. }
  227. }
  228. </style>