index.vue 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  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: res.data.infoImages };
  119. console.log(form.value, 665555)
  120. }
  121. };
  122. onMounted(() => {
  123. form1.value.setRules(rules);
  124. if (route.value.id) {
  125. getUserBusinessLicenseAxios();
  126. }
  127. });
  128. onLoad(async (options) => {
  129. route.value = options;
  130. });
  131. const submit = () => {
  132. form1.value.validate(async (valid) => {
  133. if (valid) {
  134. if (route.value.formType === 'create') {
  135. const res = await EnterApi.createUserBusinessLicense(form.value)
  136. if (res.code === 0) {
  137. uni.showToast({
  138. title: '创建成功',
  139. icon: 'success'
  140. })
  141. sheep.$router.back()
  142. } else {
  143. uni.showToast({
  144. title: res.msg,
  145. icon: 'none'
  146. })
  147. }
  148. } else {
  149. const res = await EnterApi.updateUserBusinessLicense(form.value)
  150. if (res.code === 0) {
  151. uni.showToast({
  152. title: '更新成功',
  153. icon: 'success'
  154. })
  155. sheep.$router.back()
  156. } else {
  157. uni.showToast({
  158. title: res.msg,
  159. icon: 'none'
  160. })
  161. }
  162. }
  163. }
  164. })
  165. };
  166. const extractClick = async () => {
  167. if (form.value.infoImages && form.value.infoImages.length == 0)
  168. return uni.showToast({
  169. icon: "none",
  170. title: "请上传营业执照照片"
  171. })
  172. const res = await EnterApi.difyOrcs(
  173. {
  174. "type": "提取营业执照",
  175. "images": form.value.infoImages
  176. }
  177. )
  178. const data = JSON.parse(res.data)
  179. for (const key in data) {
  180. if (Object.prototype.hasOwnProperty.call(data, key)) {
  181. const element = data[key];
  182. if (!element) {
  183. delete data[key]
  184. }
  185. }
  186. }
  187. form.value = { ...form.value, ...data }
  188. if (res.code === 0) {
  189. uni.showToast({
  190. icon: "none",
  191. title: "提取成功"
  192. })
  193. } else {
  194. uni.showModal({
  195. content: res.msg,
  196. showCancel: false
  197. })
  198. }
  199. };
  200. const onCalendar1 = (e) => {
  201. form.value.establishmentDate = e.result;
  202. };
  203. const onCalendar2 = (e) => {
  204. form.value.issueDate = e.result;
  205. };
  206. </script>
  207. <style lang="scss" scoped>
  208. .form-container {
  209. padding: 40rpx;
  210. background-color: #ffffff;
  211. .u-form {
  212. background: #fff;
  213. }
  214. .submit-btn {
  215. padding: 40rpx 0;
  216. background: #fff;
  217. position: fixed;
  218. bottom: 0;
  219. width: calc(100% - 80rpx);
  220. }
  221. .form-data {
  222. padding: 20rpx;
  223. background-color: #f8f8f8;
  224. border-radius: 8rpx;
  225. font-size: 24rpx;
  226. color: #666;
  227. }
  228. }
  229. </style>