zhengyiming
2 天以前 891a1ad22fdca6bf9ea2433377afd2a0e438c72f
apps/cMiniApp/src/subpackages/authentication/authenticationRealName/InnerPage.vue
@@ -10,6 +10,7 @@
              :limitFileSize="10"
              class="bole-uploader nopaddingtop"
              @my-success="handleFrontImgUrlChange"
              @delete="handleFrontImgUrlDelete"
            >
              <template #upload-icon>
                <div class="photograph-wrapper">
@@ -45,6 +46,7 @@
          v-model.trim="form.name"
          class="nut-input-text bole-input-text"
          placeholder="请填写姓名"
          :formatter="filterNotCN"
          type="text"
        />
      </nut-form-item>
@@ -79,6 +81,7 @@
            class="nut-input-text bole-input-text"
            placeholder="请输入验证码"
            type="number"
            :max-length="6"
          />
        </nut-form-item>
      </template>
@@ -97,13 +100,16 @@
import { FileItem } from '@nutui/nutui-taro/dist/types/__VUE/uploader/type';
import { Photograph } from '@nutui/icons-vue-taro';
import { FormRules } from '@nutui/nutui-taro/dist/types/__VUE/form/types';
import { FormValidator } from '@12333/utils';
import { FormValidator, filterNotCN } from '@12333/utils';
import Taro from '@tarojs/taro';
import { userCredentialVerifyOcrIDCard } from '@12333/hooks';
import { EnumOcrAccess } from '@12333/constants';
defineOptions({
  name: 'InnerPage',
});
const { userDetail, updateUserInfo } = useUser();
const router = Taro.useRouter();
const type = router.params?.type ?? '';
@@ -112,7 +118,7 @@
  identityBackImg: [] as FileItem[],
  name: '',
  identity: '',
  phoneNumber: '',
  phoneNumber: userDetail.value?.contactPhoneNumber,
  verifyCode: '',
});
@@ -150,12 +156,14 @@
}
function handleFrontImgUrlChange(response: FileItem) {
  // userCredentialVerifyOcrIDCard(response, {
  //   onSuccess(res) {
  //     if (res.realName) form.legalPersonName = res.realName;
  //     if (res.idcardNum) form.legalPersonIdNumber = res.idcardNum;
  //   },
  // });
  userCredentialVerifyOcrIDCard({
    url: response?.url,
    access: EnumOcrAccess.Baidu,
    onSuccess(res) {
      if (res.model?.name) form.name = res.model?.name;
      if (res.model?.identity) form.identity = res.model?.identity;
    },
  });
}
function handleSubmit() {
@@ -176,7 +184,7 @@
  }
}
async function personalUserFaceReal() {
async function personalUserIdentity3Real() {
  try {
    let params: API.PersonalUserIdentity3RealCommand = {
      name: form.name,
@@ -188,10 +196,35 @@
    };
    let res = await electronSignServices.personalUserIdentity3Real(params);
    if (res) {
      Taro.navigateTo({ url: `${RouterPath.authenticationResult}` });
    }
  } catch (error) {}
}
async function personalUserIdentity3Real() {}
async function personalUserFaceReal() {
  try {
    let params: API.PersonalUserFaceRealCommand = {
      name: form.name,
      identity: form.identity,
      identityImg: form.identityImg?.[0]?.path ?? '',
      identityBackImg: form.identityBackImg?.[0]?.path ?? '',
    };
    let res = await electronSignServices.personalUserFaceReal(params);
    if (res) {
      // 为了兼容旧版本的api res直接是faceUrl
      const encodedUrl = encodeURIComponent(typeof res === 'string' ? res : res.faceUrl);
      updateUserInfo();
      Taro.navigateTo({ url: `${RouterPath.extraPage}?url=${encodedUrl}` });
    }
  } catch (error) {}
}
function handleFrontImgUrlDelete({ files, fileList, index }) {
  if (fileList?.length === 0) {
    form.name = '';
    form.identity = '';
  }
}
</script>
<style lang="scss">