天波h5前端应用
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

422 satır
15KB

  1. <!--
  2. * @Date: 2023-02-24 16:47:33
  3. * @LastEditors: JinxChen
  4. * @LastEditTime: 2023-03-02 01:58:58
  5. * @FilePath: \TelpoH5FrontendWeb\src\views\pay-result\index.vue
  6. * @description:
  7. -->
  8. <!--
  9. * @Date: 2022-05-29 10:23:28
  10. * @LastEditors: JinxChen
  11. * @LastEditTime: 2023-02-25 10:34:31
  12. * @FilePath: \TelpoH5FrontendWeb\src\views\pay-result\index.vue
  13. * @description:
  14. -->
  15. <template>
  16. <div class="pay-result-container">
  17. <div class="check-container" v-show="pageShow">
  18. <van-nav-bar title="支付结果" :left-arrow="false" :border="true" ></van-nav-bar>
  19. <!-- 头部 -->
  20. <div class="header pos-center">
  21. <img src="../../assets/img/ssjl.jpg" alt />
  22. <p>随手精灵</p>
  23. </div>
  24. <!-- 详细 -->
  25. <div class="details">
  26. <div class="details-item">
  27. <p class="left-text">订单状态</p>
  28. <p v-if="payStatus">支付成功</p>
  29. <p v-else class="error">查询失败</p>
  30. </div>
  31. <div class="details-item">
  32. <p class="left-text">订单尾号</p>
  33. <p>{{outTradeNo}}</p>
  34. </div>
  35. <div class="details-item price">
  36. <p class="left-text">支付总额</p>
  37. <p>¥ {{price}}元</p>
  38. </div>
  39. </div>
  40. <!-- 返回 -->
  41. <div class="footer pos-center">
  42. <!-- <div class="back-btn" @click="onNavBack" v-show="!payStatus">
  43. <p>返回重新选择套餐购买</p>
  44. </div> -->
  45. <!-- <div class="back-btn" @click="onNext" v-show="payStatus">
  46. <p>激活电话卡</p>
  47. </div> -->
  48. <div class="back-btn" @click="onBackHome">
  49. <p>第{{isAliPay ? '三' : '二'}}步:去使用功能</p>
  50. </div>
  51. </div>
  52. </div>
  53. <!-- <div class="flush" v-show="isIos">
  54. <div class="back-btn" @click="onFlush">
  55. <p>查询</p>
  56. </div>
  57. </div> -->
  58. </div>
  59. </template>
  60. <script>
  61. import { isNotNull} from "@/utils/index";
  62. import { APIPay } from "@/api/pay";
  63. import APIWx from "@/api/wx";
  64. import axios from "axios";
  65. export default {
  66. name: "payResult",
  67. data() {
  68. return {
  69. pageShow: false, //是否显示页面,备注:需要在查询结果出来后才显示页面
  70. count: 0, //轮询接口时间次数
  71. timer: "", //轮询支付结果定时器
  72. payStatus: null, //支付状态
  73. price: this.$route.query.price, //价格
  74. outTradeNo: this.$route.query.outTradeNo, //支付订单号
  75. isIos: null, //是否是ios,
  76. };
  77. },
  78. created() {
  79. this.checkParams();
  80. this.closeTime();
  81. },
  82. computed: {
  83. isAliPay() {
  84. return this.$route.query.alipayForm
  85. }
  86. },
  87. mounted() {
  88. //this.checkParams();
  89. //this.closeTime();
  90. },
  91. methods: {
  92. // checkIosOrAndroid
  93. checkIosOrAndroid() {
  94. let userAgent = navigator.userAgent;
  95. if (userAgent.indexOf("iPhone") > -1) {
  96. this.isIos = true;
  97. }
  98. },
  99. onNavBack() {
  100. this.$router.replace({
  101. name: "packageList",
  102. query: {
  103. serialNo: this.$route.query.serialNo,
  104. isAdmin: this.$route.query.isAdmin,
  105. iccid: this.$route.query.iccid,
  106. routerName: this.$route.query.routerName,
  107. }
  108. });
  109. },
  110. // 下一步激活
  111. onNext() {
  112. console.log("激活", );
  113. //this.$toast.loading("激活中");
  114. /* this.effective(); */
  115. this.$router.replace({
  116. name: 'activeStatus',
  117. query: {
  118. serialNo: this.$route.query.serialNo,
  119. iccid: this.$route.query.iccid,
  120. issue: Number(this.$route.query.issue) || 0
  121. }
  122. })
  123. },
  124. // 激活接口
  125. effective() {
  126. this.$toast.loading('激活中,请稍候...');
  127. let reqBody = {
  128. imei: this.$route.query.serialNo,
  129. iccid: this.$route.query.iccid || '',
  130. issue: Number(this.$route.query.issue) || 0
  131. };
  132. APIWx.Effective(reqBody)
  133. .then(res => {
  134. console.log("res", res);
  135. let data = res.data;
  136. console.log("data", data);
  137. this.$toast.clear();
  138. if(data.stateCode !== 1) {
  139. this.$dialog.confirm({
  140. title: '温馨提示',
  141. message: `${data.message}`,
  142. showCancelButton: false
  143. })
  144. } else if(data.stateCode === 0 && data.message !== null) {
  145. this.$dialog.confirm({
  146. title: '温馨提示',
  147. message: `电话卡激活失败!请进行实名认证与绑定SIM卡。如您已实名认证,请5分钟后,再进行设备绑定。`,
  148. showCancelButton: false
  149. })
  150. } else if (data.stateCode === 1 && data.message !== 'ok') {
  151. this.$dialog.confirm({
  152. title: "SIM卡激活成功",
  153. message: '卡激活成功,5分钟后则可正常使用。',
  154. showCancelButton: false,
  155. confirmButtonText: '返回首页'}).then(() => {
  156. document.location.replace(" https://xrpt.jiankangtongxue.cn/WCUParentWebUI.WX/Home/")
  157. });
  158. } else if (data.stateCode === 1 && data.message === 'ok') {
  159. this.$dialog.confirm({
  160. title: "SIM卡激活成功",
  161. message: '卡激活成功,5分钟后则可正常使用。',
  162. showCancelButton: false,
  163. confirmButtonText: '返回首页'
  164. }).then(() => {
  165. document.location.replace(" https://xrpt.jiankangtongxue.cn/WCUParentWebUI.WX/Home/")
  166. });
  167. }
  168. })
  169. .catch(error => {
  170. console.log("出错了:;", error);
  171. this.$dialog.confirm({
  172. title: '温馨提示',
  173. message: `${error.message}`,
  174. showCancelButton: false
  175. })
  176. }).finally(() => {
  177. this.$toast.clear();
  178. })
  179. },
  180. // ios需要手动点击按钮查询
  181. onFlush() {
  182. this.isIos = false;
  183. this.checkParams();
  184. },
  185. // storeParams
  186. checkParams() {
  187. let params = this.$route.query;
  188. let isFromWx = this.$store.getters.isFromWx;
  189. if (params.rechargeUrl && isFromWx === true) {
  190. // 如果存在支付宝跳转链接,则打开外部浏览器跳到支付宝h5
  191. console.log("支付宝");
  192. this.$toast.loading({
  193. message: "跳转中",
  194. });
  195. setTimeout(() => {
  196. this.$store.commit("isFromWx", "");
  197. let alipayForm = encodeURIComponent(params.alipayForm); //对接口返回的form进行编码
  198. let url =
  199. process.env.NODE_ENV === "production"
  200. ? `https://ai.ssjlai.com/frontend/#/alipay?goodsNo=${params.productId}&userId=${params.alipayUserId}&isWx=true&alipayForm=${alipayForm}`
  201. : `https://id.ssjlai.com/frontend/#/alipay?goodsNo=${params.productId}&userId=${params.alipayUserId}&isWx=true&alipayForm=${alipayForm}`;
  202. window.location.href = url;
  203. }, 1500);
  204. } else if (params.rechargeUrl && isFromWx === null) {
  205. // todo 轮询支付宝的支付结果
  206. let that = this;
  207. console.log("支付宝结果");
  208. this.$toast.loading({
  209. message: "支付结果查询中"
  210. });
  211. let reqBody = {
  212. outTradeNo: params.outTradeNo
  213. };
  214. let url =
  215. process.env.NODE_ENV === "production"
  216. ? "https://ai.ssjlai.com/telpopay/alipay/order/detail/callback"
  217. : "https://id.ssjlai.com/telpopay/alipay/order/detail/callback";
  218. if (that.count >= 30) {
  219. if (that.timer) {
  220. clearInterval(that.timer);
  221. this.payStatus = false;
  222. this.pageShow = true;
  223. this.$toast.clear();
  224. console.log("关闭轮询1");
  225. }
  226. }
  227. that.timer = setInterval(() => {
  228. that.count++;
  229. APIPay.getWxPayResult(reqBody)
  230. .then(res => {
  231. if (res.data.code === 20000) {
  232. this.pageShow = true;
  233. this.payStatus = true;
  234. this.$toast.clear();
  235. console.log("关闭轮询2");
  236. if (that.timer) {
  237. clearInterval(that.timer);
  238. }
  239. }
  240. })
  241. .catch(e => {
  242. console.log(e);
  243. });
  244. }, 2000);
  245. } else {
  246. // todo 轮询微信支付的订单,支付成功则激活 (只有直播基地的imei才激活操作)
  247. let that = this;
  248. console.log("微信");
  249. this.$toast.loading({message: "支付结果查询中"});
  250. let reqBody = {
  251. outTradeNo: params.outTradeNo
  252. };
  253. let url =
  254. process.env.NODE_ENV === "production"
  255. ? " https://ai.ssjlai.com/telpopay/api/wx/order/callback"
  256. : "https://id.ssjlai.com/telpopay/api/wx/order/callback";
  257. if (that.count >= 30) {
  258. if (that.timer) {
  259. clearInterval(that.timer);
  260. this.payStatus = false;
  261. this.pageShow = true;
  262. this.$toast.clear();
  263. console.log("关闭轮询3");
  264. }
  265. }
  266. that.timer = setInterval(() => {
  267. that.count++;
  268. APIPay.getWxPayResult(reqBody)
  269. .then(res => {
  270. if (res.data.code === 20000) {
  271. this.pageShow = true;
  272. this.payStatus = true;
  273. this.$toast.clear();
  274. console.log("关闭轮询4");
  275. if (that.timer) {
  276. clearInterval(that.timer);
  277. }
  278. }
  279. })
  280. .catch(e => {
  281. console.log(e);
  282. });
  283. }, 2000);
  284. }
  285. },
  286. // 获取微信支付接口
  287. getWxPayResult() {
  288. this.$toast.loading({
  289. message: "正在获取支付结果",
  290. duration: 3000
  291. });
  292. setTimeout(() => {
  293. this.pageShow = true;
  294. }, 3000);
  295. },
  296. closeTime() {
  297. let params = this.$route.query;
  298. let isFromWx = this.$store.getters.isFromWx;
  299. setTimeout(() => {
  300. clearInterval(this.timer);
  301. console.log("即将关闭轮询");
  302. this.$toast.clear();
  303. if (this.pageShow === false) {
  304. this.pageShow = true;
  305. }
  306. }, 31000);
  307. },
  308. onBackHome() {
  309. /* document.location.replace(" https://xrpt.jiankangtongxue.cn/WCUParentWebUI.WX/Home/"); */
  310. document.location.replace("https://xrpt.jiankangtongxue.cn/WCUParentWebUI.WX/Home/SmartDigitalSsjl");
  311. // https://xrpt.jiankangtongxue.cn/WCUParentWebUI.WX/Home/SmartDigitalSsjl
  312. }
  313. }
  314. };
  315. </script>
  316. <style scoped lang="scss">
  317. .pay-result-container {
  318. height: 100vh;
  319. width: 100%;
  320. display: flex;
  321. justify-content: flex-start;
  322. align-items: center;
  323. flex-direction: column;
  324. background-color: white;
  325. overflow: scroll;
  326. .check-container {
  327. width: 100%;
  328. }
  329. .pos-center {
  330. display: flex;
  331. justify-content: flex-start;
  332. align-items: center;
  333. flex-direction: column;
  334. }
  335. .header {
  336. width: 100%;
  337. padding: 10px 0;
  338. img {
  339. height: 60px;
  340. width: 60px;
  341. margin: 10px 0;
  342. border-radius: 50%;
  343. }
  344. p {
  345. font-size: 18px;
  346. }
  347. }
  348. .details {
  349. padding: 20px 0;
  350. width: 100%;
  351. p {
  352. font-size: 16px;
  353. }
  354. .details-item {
  355. width: 80%;
  356. display: flex;
  357. justify-content: space-between;
  358. align-items: center;
  359. margin-left: 10%;
  360. padding: 10px 0;
  361. .left-text {
  362. color: gray;
  363. }
  364. .error {
  365. color: red;
  366. font-size: 24px;
  367. }
  368. }
  369. .price {
  370. padding: 20px 0;
  371. border-bottom: 5px solid $background;
  372. .left-text {
  373. color: gray;
  374. }
  375. }
  376. .details-item:nth-child(2) {
  377. border-bottom: 5px solid $background;
  378. }
  379. }
  380. .footer {
  381. height: 75px;
  382. .back-btn {
  383. height: 45px;
  384. width: 275px;
  385. display: flex;
  386. justify-content: center;
  387. align-items: center;
  388. background: $blue;
  389. border: 1px solid $blue;
  390. border-radius: 25px;
  391. p {
  392. font-size: 18px;
  393. padding: 0;
  394. color: white;
  395. }
  396. }
  397. }
  398. }
  399. .flush {
  400. height: calc(100vh - 2.3784rem);
  401. display: flex;
  402. justify-content: center;
  403. align-items: center;
  404. .back-btn {
  405. height: 45px;
  406. width: 275px;
  407. display: flex;
  408. justify-content: center;
  409. align-items: center;
  410. background: $blue;
  411. border: 1px solid $blue;
  412. border-radius: 25px;
  413. p {
  414. font-size: 18px;
  415. padding: 0;
  416. color: white;
  417. }
  418. }
  419. }
  420. </style>