diff --git a/.env b/.env index 17d84a4..984ea95 100644 --- a/.env +++ b/.env @@ -9,7 +9,7 @@ VITE_INQUIRE_AES_KEY=ff83609b2b24fc73196aac3d3dfb874f VITE_WECHAT_APP_ID=wx442ee1ac1ee75917 VITE_ICP_RECORD=琼ICP备2024048057号-2 -VITE_PUBLIC_SECURITY_RECORD=琼公网安备46010002000584号 +VITE_PUBLIC_SECURITY_RECORD=琼公网安备46010002000443号 VITE_SHOW_PUBLIC_SECURITY_RECORD=true VITE_CHAT_AES_KEY=qw5w6SFE2D1jmxyd diff --git a/env.example b/env.example index 2ffd0e5..51afa66 100644 --- a/env.example +++ b/env.example @@ -5,7 +5,7 @@ VITE_COMPANY_NAME=海南海宇大数据有限公司 VITE_APP_NAME=全能查 VITE_ICP_RECORD=琼ICP备2024038584号-10 -VITE_PUBLIC_SECURITY_RECORD=琼公网安备46010002000584号 +VITE_PUBLIC_SECURITY_RECORD=琼公网安备46010002000443号 VITE_SHOW_PUBLIC_SECURITY_RECORD=false VITE_SERVICE_URL=https://work.weixin.qq.com/kfid/kfc82d4424e4b19e5f3 diff --git a/src/components/Payment.vue b/src/components/Payment.vue index 0bb1f15..47e72dc 100644 --- a/src/components/Payment.vue +++ b/src/components/Payment.vue @@ -70,6 +70,7 @@ import { ref, computed, onMounted } from "vue"; import { useRouter } from "vue-router"; const { isWeChat } = useEnv(); +import { showConfirmDialog, showToast } from "vant"; const props = defineProps({ data: { @@ -113,50 +114,63 @@ const router = useRouter(); const discountPrice = ref(false); // 是否应用折扣 async function getPayment() { - const { data, error } = await useApiFetch("/pay/payment") - .post({ - id: props.id, - pay_method: selectedPaymentMethod.value, - pay_type: props.type, - }) - .json(); + showConfirmDialog({ + title: '重要安全声明', + message: + '为保障您的个人信息与资金安全,请您务必知悉以下事项:\n\n关于平台业务:本平台官方服务仅限于大数据报告查询,不涉及也从未开展“央行征信修复”、“贷款办理”或“征信洗白”等相关业务。请注意,本平台出具的报告仅供决策参考,不可作为任何官方征信凭证或贷款依据。\n\n关于诈骗警示:任何自称与本平台合作,或以“内部渠道”、“百分百包下款”、“修复征信”等为由,诱导您进行支付的行为,均属欺诈。请您切勿相信,谨慎对待任何支付要求。\n\n关于安全提示:请您时刻保持警惕,妥善保管个人敏感信息。如遇任何索款要求或可疑承诺,请务必首先通过我平台官方公布的联系方式进行核实,切勿轻信他人。', + }) + .then(async () => { + const { data, error } = await useApiFetch("/pay/payment") + .post({ + id: props.id, + pay_method: selectedPaymentMethod.value, + pay_type: props.type, + }) + .json(); - if (data.value && !error.value) { - // 测试支付模式:直接跳转到结果页面 - if (selectedPaymentMethod.value === "test" || selectedPaymentMethod.value === "test_empty") { - orderNo.value = data.value.data.order_no; - router.push({ - path: "/payment/result", - query: { orderNo: data.value.data.order_no }, - }); - } else if (selectedPaymentMethod.value === "alipay") { - orderNo.value = data.value.data.order_no; - // 存储订单ID以便支付宝返回时获取 - const prepayUrl = data.value.data.prepay_id; - const paymentForm = document.createElement("form"); - paymentForm.method = "POST"; - paymentForm.action = prepayUrl; - paymentForm.style.display = "none"; - document.body.appendChild(paymentForm); - paymentForm.submit(); - } else { - const payload = data.value.data.prepay_data; - WeixinJSBridge.invoke( - "getBrandWCPayRequest", - payload, - function (res) { - if (res.err_msg == "get_brand_wcpay_request:ok") { - // 支付成功,直接跳转到结果页面 - router.push({ - path: "/payment/result", - query: { orderNo: data.value.data.order_no }, - }); - } + if (data.value && !error.value) { + // 测试支付模式:直接跳转到结果页面 + if (selectedPaymentMethod.value === "test" || selectedPaymentMethod.value === "test_empty") { + orderNo.value = data.value.data.order_no; + router.push({ + path: "/payment/result", + query: { orderNo: data.value.data.order_no }, + }); + } else if (selectedPaymentMethod.value === "alipay") { + orderNo.value = data.value.data.order_no; + // 存储订单ID以便支付宝返回时获取 + const prepayUrl = data.value.data.prepay_id; + const paymentForm = document.createElement("form"); + paymentForm.method = "POST"; + paymentForm.action = prepayUrl; + paymentForm.style.display = "none"; + document.body.appendChild(paymentForm); + paymentForm.submit(); + } else { + const payload = data.value.data.prepay_data; + WeixinJSBridge.invoke( + "getBrandWCPayRequest", + payload, + function (res) { + if (res.err_msg == "get_brand_wcpay_request:ok") { + // 支付成功:短延迟再跳转,给后端回调与异步任务留出时间,避免结果页查报告报错 + showToast({ message: "支付成功,正在跳转...", type: "success" }); + setTimeout(() => { + router.push({ + path: "/payment/result", + query: { orderNo: data.value.data.order_no }, + }); + }, 1500); + } + } + ); } - ); - } - } - show.value = false; + } + show.value = false; + }) + .catch(() => { + return; + }); } diff --git a/src/views/Report.vue b/src/views/Report.vue index 3f85288..806ee22 100644 --- a/src/views/Report.vue +++ b/src/views/Report.vue @@ -135,9 +135,30 @@ const getReport = async () => { } else if (data.value.code === 200003) { isEmpty.value = true; isDone.value = true; - } else if (data.value.code === 200002) { - isPending.value = true; - isDone.value = true; + } else if (data.value.code === 200002 || data.value.code === 100005) { + // 200002:报告生成中;100005:兼容旧后端“报告未就绪”时的 DB_ERROR,按生成中轮询 + queryState.value = "pending"; + if (!pollingInterval.value) { + pollingInterval.value = setInterval(() => { + getReport(); + }, 2000); + } + } + } else if (data.value?.code === 200002) { + // 接口返回 200002 时可能走不到上面分支,单独处理 + queryState.value = "pending"; + if (!pollingInterval.value) { + pollingInterval.value = setInterval(() => { + getReport(); + }, 2000); + } + } else if (data.value?.code === 100005) { + // 兼容:报告未就绪时后端返回 100005,按“生成中”轮询 + queryState.value = "pending"; + if (!pollingInterval.value) { + pollingInterval.value = setInterval(() => { + getReport(); + }, 2000); } } }; diff --git a/src/views/Withdraw.vue b/src/views/Withdraw.vue index 83a7a8f..23fad58 100644 --- a/src/views/Withdraw.vue +++ b/src/views/Withdraw.vue @@ -22,41 +22,96 @@
- 已向 - {{ - alipayAccount - }} - 转账 + + 已向 + {{ alipayAccount }} + 转账 + + + 已向 + 尾号{{ displayBankCardTail }} + 银行卡转账 +
¥{{ amount }} @@ -227,8 +295,9 @@
预计24小时内到账
-可在支付宝账单中查看详情
+预计1-3个工作日到账(需人工审核)
+可在支付宝账单中查看详情
+请留意银行卡到账通知
您的申请已进入处理队列
@@ -289,6 +358,12 @@ const estimatedActualAmount = computed(() => { return Number(amount.value) - estimatedTaxAmount.value; }); +// 银行卡号尾号(成功弹窗展示用) +const displayBankCardTail = computed(() => { + const no = (bankCardNo.value || "").replace(/\s/g, ""); + return no.length >= 4 ? no.slice(-4) : no || "****"; +}); + // 样式配置 const statusIcon = { 1: "clock", @@ -325,11 +400,29 @@ const statusMessages = { 3: "提现失败", }; -// 表单数据 +// 提现方式:1=支付宝,2=银行卡 +const withdrawalType = ref(1); +// 表单数据 - 支付宝 const alipayAccount = ref(""); const amount = ref(0); const availableAmount = ref(null); const realName = ref(""); +// 表单数据 - 银行卡 +const bankCardNo = ref(""); +const bankName = ref(""); +const bankPayeeName = ref(""); + +// 切换提现方式时清空另一侧部分字段(金额保留) +const onWithdrawalTypeChange = () => { + if (withdrawalType.value === 1) { + bankCardNo.value = ""; + bankName.value = ""; + bankPayeeName.value = ""; + } else { + alipayAccount.value = ""; + realName.value = ""; + } +}; const getData = async () => { const { data, error } = await getRevenueInfo(); @@ -350,35 +443,58 @@ const validateAmount = (val) => { }; const validateForm = () => { - if (!realName.value.trim()) { - showToast("请输入账户实名姓名"); - return false; - } - if (!/^[\u4e00-\u9fa5]{2,4}$/.test(realName.value)) { - showToast("请输入2-4位中文姓名"); - return false; - } - if (!alipayAccount.value.trim()) { - showToast("请输入支付宝账号"); - return false; - } - const amountNum = Number(amount.value); if (!amount.value || isNaN(amountNum)) { showToast("请输入有效金额"); return false; } - if (amountNum < 50) { showToast("提现金额不能低于50元"); return false; } - if (amountNum > availableAmount.value) { showToast("超过可提现金额"); return false; } + if (withdrawalType.value === 1) { + // 支付宝 + if (!realName.value.trim()) { + showToast("请输入账户实名姓名"); + return false; + } + if (!/^[\u4e00-\u9fa5]{2,4}$/.test(realName.value)) { + showToast("请输入2-4位中文姓名"); + return false; + } + if (!alipayAccount.value.trim()) { + showToast("请输入支付宝账号"); + return false; + } + } else { + // 银行卡 + if (!bankCardNo.value.trim()) { + showToast("请输入银行卡号"); + return false; + } + if (!/^\d{16,19}$/.test(bankCardNo.value.replace(/\s/g, ""))) { + showToast("请输入正确的银行卡号"); + return false; + } + if (!bankName.value.trim()) { + showToast("请输入开户行名称"); + return false; + } + if (!bankPayeeName.value.trim()) { + showToast("请输入收款人姓名"); + return false; + } + if (!/^[\u4e00-\u9fa5]{2,4}$/.test(bankPayeeName.value)) { + showToast("请输入2-4位中文姓名"); + return false; + } + } + return true; }; @@ -409,11 +525,19 @@ const confirmWithdraw = async () => { isSubmitting.value = true; try { const { applyWithdrawal } = await import('@/api/agent'); - const { data, error } = await applyWithdrawal({ - payee_account: alipayAccount.value, + const payload = { + withdrawal_type: withdrawalType.value, amount: Number(amount.value), - payee_name: realName.value, - }); + payee_name: withdrawalType.value === 1 ? realName.value : bankPayeeName.value, + }; + if (withdrawalType.value === 1) { + payload.payee_account = alipayAccount.value; + } else { + payload.payee_account = bankCardNo.value.replace(/\s/g, ""); + payload.bank_card_no = bankCardNo.value.replace(/\s/g, ""); + payload.bank_name = bankName.value.trim(); + } + const { data, error } = await applyWithdrawal(payload); if (data.value?.code === 200 && !error.value) { status.value = 1; // 新系统:申请后状态为1(待审核) showTaxConfirmPopup.value = false; @@ -450,6 +574,9 @@ const resetForm = () => { alipayAccount.value = ""; amount.value = ""; realName.value = ""; + bankCardNo.value = ""; + bankName.value = ""; + bankPayeeName.value = ""; };