天波h5前端应用
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

824 行
34KB

  1. <!--
  2. * @Date: 2022-03-29 16:57:58
  3. * @LastEditors: JinxChen
  4. * @LastEditTime: 2023-04-08 22:05:03
  5. * @FilePath: \TelpoH5FrontendWeb\src\views\package-list\index.vue
  6. * @description: TODO 小台风充值h5
  7. -->
  8. <template>
  9. <div class="package-list-container">
  10. <van-nav-bar :left-arrow="false" :border="true">
  11. <template #title>
  12. <h5 style="font-size: 16px">{{topupTitle}}</h5>
  13. </template>
  14. </van-nav-bar>
  15. <!-- 灰色线条 -->
  16. <div class="gray-line"></div>
  17. <!-- 套餐列表 -->
  18. <div class="topup-container">
  19. <div class="main">
  20. <!-- 无套餐时显示 -->
  21. <div class="noData_container" v-show="packageOrderList.length === 0 && !isShowNoData">
  22. <p>暂无相关套餐数据,请您联系管理员~</p>
  23. </div>
  24. <!-- 套餐订购 -->
  25. <div
  26. class="package-order-container"
  27. v-for="(item, index) in packageOrderList"
  28. :key="index"
  29. >
  30. <!-- 推荐 -->
  31. <div class="recom" v-show="false">
  32. <div class="shape"></div>
  33. <div class="square">
  34. <p>推荐</p>
  35. </div>
  36. </div>
  37. <!-- 套餐内容 -->
  38. <div class="order-content">
  39. <div class="title">
  40. <p>{{item.packageName}}<!-- :{{(item.packagesPrice/item.packageIssue).toFixed(0)}}元/月 --></p>
  41. </div>
  42. <div class="remark">
  43. <p>每月200分钟通话时长,1G流量</p>
  44. </div>
  45. <div class="details">
  46. <p>
  47. <span class="orange large">¥{{(item.packagesPrice/(item.packageIssue === 0 ? 1: item.packageIssue)).toFixed(0)}}</span>元/月,
  48. </p>
  49. <p class="total">
  50. <span>合计</span><span class="orange price">{{item.packagesPrice}}元</span>
  51. </p>
  52. </div>
  53. <!-- <div class="package-buy">
  54. <div class="buy-btn" @click="onBuy(item)">
  55. <p>第一步:充值话费</p>
  56. </div>
  57. </div> -->
  58. <div class="radios-con">
  59. <div class="pay-type">
  60. <p>支付方式:</p>
  61. </div>
  62. <van-radio-group v-model="radio" direction="horizontal" @change="onRaidoChange">
  63. <van-radio name="1">
  64. <template #default>
  65. <div class="radio-con">
  66. <span>微信</span>
  67. <img src="../../assets/wx-pay.png"/>
  68. </div>
  69. </template>
  70. </van-radio>
  71. <van-radio name="2">
  72. <template #default>
  73. <div class="radio-con">
  74. <span>支付宝</span>
  75. <img src="../../assets/alipay.png"/>
  76. </div>
  77. </template>
  78. </van-radio>
  79. <van-radio name="3">
  80. <template #default>
  81. <div class="radio-con">
  82. <span>12期花呗</span>
  83. <img src="../../assets/antpay.png"/>
  84. </div>
  85. </template>
  86. </van-radio>
  87. </van-radio-group>
  88. </div>
  89. <div class="package-buy">
  90. <div class="buy-btn" @click="onBuy(item)">
  91. <p>第一步:充值话费</p>
  92. </div>
  93. </div>
  94. </div>
  95. </div>
  96. </div>
  97. </div>
  98. </div>
  99. </template>
  100. <script>
  101. import APIWx from "@/api/wx";
  102. import AppId from "@/config/appId";
  103. import { APIPay } from "@/api/pay";
  104. import APICore from "@/api/core";
  105. let wx = require("weixin-js-sdk"); // TODO 再封装,可拦截错误提示等操作
  106. import { isNotNull } from "@/utils/index";
  107. import { VERSION_MODEL } from '@/config/models';
  108. export default {
  109. name: "packageList",
  110. data() {
  111. return {
  112. topupTitle: "请选择套餐充值电话卡", //充值页面标题
  113. // 套餐列表, todo 需要从接口获取
  114. packageOrderList: [
  115. /* {
  116. packageName: '语音卡套餐(1年)',
  117. packagePayType: 1,
  118. packagesPrice: 240,
  119. packageIssue: 12,
  120. payWxPayProductId: process.env.NODE_ENV === "production" ? '1635123463911587840' : '1635122887959592960', //微信支付
  121. payAliPayProductId: process.env.NODE_ENV === "production" ? '1629407413618294784' : '1629405716684029952', //支付宝全额支付
  122. payAntPayProductId: process.env.NODE_ENV === "production" ? '1629407705558630400': '1629405558344859648', //支付宝花呗支付
  123. } */
  124. ],
  125. outTradeNo: "", //订单号
  126. price: "", //价格,
  127. isShowNoData: false, //是否显示无套餐内容, 默认false
  128. // 获取从路由的参数,import 调取激活接口需要用到
  129. params: {
  130. imei: '',
  131. iccid: '',
  132. manufactorId: '', //厂商id,一般用来获取core接口token
  133. appId: '', //公众号appId,需要对接多个不同公众号时动态从页面路由获取,
  134. },
  135. radio: '1', //支付方式单选按钮默认值
  136. payProductId: null, //套餐id
  137. packageIssue: null, //套餐分期
  138. payType: '1', //支付方式 1 微信, 2 支付宝,支付宝又分为花呗和全额支付,全额支付分期数传0 或者1 ,花呗则传 3 6 12
  139. openId: '',
  140. code: ''
  141. };
  142. },
  143. created() {
  144. this.getAuth();
  145. this.getToken();
  146. this.getParams();
  147. this.getCode();
  148. //this.getWxAutograph();
  149. // 套餐列表
  150. this.getDevicePayPackage();
  151. console.log("当前版本", VERSION_MODEL);
  152. },
  153. methods: {
  154. // 根据code获取openId
  155. getOpenId(code) {
  156. APIPay.getOpenId(code).then(res => {
  157. let data= res.data;
  158. if(data.code === 20000) {
  159. this.openId = data.data.openId;
  160. this.$store.commit("openId", data.data.openId);
  161. } else if (data.state === false) {
  162. console.log("token过期");
  163. this.getToken();
  164. this.getOpenId(this.code);
  165. }
  166. })
  167. },
  168. // 获取b端接口的token
  169. getAuth() {
  170. let manufactorId = "5bf13062-a41e-4d00-ba14-1101aad12650";
  171. APICore.getAuth({ manufactorId: manufactorId }).then(res => {
  172. this.$store.commit("gatewayToken", res.data.data);
  173. });
  174. },
  175. // 获取token
  176. getToken() {
  177. let manufacturerNo = '9f166b07-ff83-4991-84dc-ca6ad4a6b95b';
  178. APIPay.getToken(manufacturerNo).then(res => {
  179. console.log("token的数据", res.data)
  180. let data = res.data;
  181. if(data.code === 20000) {
  182. this.$store.commit("token", data.token);
  183. console.log("token的数据", localStorage.getItem('token'))
  184. }
  185. })
  186. },
  187. getCode() {
  188. let url = window.location.href.split("?code=")[1];
  189. console.log("url", url);
  190. if (isNotNull(url) ||window.location.href.indexOf("code") > -1) {
  191. let code = url.split("&")[0];
  192. this.code = code;
  193. if (isNotNull(code)) {
  194. this.getOpenId(code);
  195. } else {
  196. this.$dialog.confirm({
  197. message: '系统错误,请重新进入',
  198. showCancelButton: false
  199. })
  200. }
  201. }
  202. },
  203. // 获取url传过来的参数
  204. getParams() {
  205. let params = this.$route.query;
  206. console.log("params", params);
  207. if (params) {
  208. this.params = {...params};
  209. }
  210. },
  211. // 获取基本套餐信息
  212. getDevicePayPackage() {
  213. this.$toast.loading({
  214. message: "加载中",
  215. duration: 1500
  216. });
  217. APICore.devicePayPackage(this.params.imei)
  218. .then(res => {
  219. console.log("data", res.data);
  220. if (res.data.code === 106 || res.data.code === 104) {
  221. // token过期
  222. this.getAuth();
  223. setTimeout(() => {
  224. this.getDevicePayPackage();
  225. }, 1500);
  226. } else if (res.data.code === 0 && res.data.data === null) {
  227. this.isShowNoData = true;
  228. } else {
  229. if(res.data.data === null) {
  230. this.isShowNoData = false;
  231. } else {
  232. let data = res.data.data.packagesList;
  233. // 处理获取套餐的逻辑
  234. // 筛选 基础套餐,producModelId 1 是基础套餐;2 是加油包
  235. let packageList = data.filter(item => {
  236. return item.producModelId === 1
  237. });
  238. this.packageOrderList = packageList;
  239. console.log("套餐数据::", packageList);
  240. }
  241. this.$toast.success({
  242. message: "加载完成",
  243. duration: 1500
  244. });
  245. }
  246. })
  247. .catch(error => {
  248. this.$dialog.confirm({
  249. title: "获取套餐数据失败",
  250. message: error.message,
  251. showCancelButton: false,
  252. });
  253. })
  254. .finally(() => {
  255. setTimeout(() => {
  256. this.$toast.clear();
  257. }, 1500);
  258. });
  259. },
  260. // 返回
  261. onNavBack() {
  262. },
  263. // 获取微信jssdk
  264. getWxAutograph() {
  265. let that = this;
  266. return new Promise((resolve, reject) => {
  267. APIWx.createJSSDK({
  268. sUrl: window.location.href.split("#")[0],
  269. userId: '',
  270. appId: this.params.appId || AppId
  271. })
  272. .then(res => {
  273. let item = res.data.data;
  274. wx.config({
  275. debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
  276. appId: item.appId, // 必填,公众号的唯一标识
  277. timestamp: item.timeStamp, // 必填,生成签名的时间戳
  278. nonceStr: item.nonceStr, // 必填,生成签名的随机串
  279. signature: item.signature, // 必填,签名
  280. jsApiList: ["chooseWXPay"] // 必填,需要使用的JS接口列表
  281. });
  282. wx.ready(() => {
  283. resolve(true);
  284. });
  285. })
  286. .catch(err => {
  287. reject(false);
  288. console.log(err);
  289. });
  290. });
  291. },
  292. // 话费充值
  293. onBuy(data) {
  294. this.price = data.packagesPrice;
  295. // 遍历数据找到属于三种支付方式对应的套餐id, 1 微信 2 支付宝全额 3 支付宝分期
  296. let payTypeToPackAgeId = data.payTypeList;
  297. console.log("购买的套餐数据data", payTypeToPackAgeId);
  298. // 需要区分是要用微信支付还是支付宝花呗支付
  299. if (this.payType === '2') {
  300. // 全额
  301. this.payProductId = payTypeToPackAgeId.filter(item => {
  302. return item.payType === '2' || item.payType === 2
  303. })[0].productId;
  304. this.packageIssue = 0;
  305. console.log("this.payProductId", this.payProductId);
  306. this.aliPay(data);
  307. } else if (this.payType === '3') {
  308. // 分期
  309. this.payProductId = payTypeToPackAgeId.filter(item => {
  310. return item.payType === '3' || item.payType === 3
  311. })[0].productId;
  312. this.packageIssue = 12;
  313. this.payType = '2';
  314. console.log("this.payProductId2", this.payProductId);
  315. this.aliPay(data);
  316. } else {
  317. // 微信
  318. let openId = this.openId;
  319. this.payProductId = payTypeToPackAgeId.filter(item => {
  320. return item.payType === '1' || item.payType === 1
  321. })[0].productId;
  322. this.packageIssue = 0;
  323. console.log("this.payProductId3", this.payProductId);
  324. if(openId === null || openId === 'null') {
  325. this.$dialog.confirm({
  326. message: '获取OpenId失败,请您重新进入',
  327. showCancelButton: false,
  328. })
  329. } else {
  330. this.wxPay(data);
  331. }
  332. }
  333. },
  334. // 微信支付
  335. wxPay(data) {
  336. this.$toast.loading({
  337. message: "加载中"
  338. });
  339. console.log("微信支付", data);
  340. let orderData = data;
  341. let reqBody = {
  342. openId: this.openId, //openId
  343. imei: this.params.imei, //imei
  344. iccid: this.params.iccid,
  345. productId: this.payProductId, //套餐id
  346. packageName: /* data.productModel */ data.packagesName, //套餐名字
  347. packagePayType: Number(this.payType), //支付类型
  348. packageIssue: 0, //分期
  349. packagePrice: process.env.NODE_ENV === "production" ? data.packagesPrice * 100 : 1 //总金额单位为分,测试环境写死
  350. };
  351. this.$toast.clear();
  352. APICore.payLiveBaseDevice(reqBody)
  353. .then(res => {
  354. if (res.data.code === 104 || res.data.code === 106) {
  355. this.getAuth();
  356. setTimeout(() => {
  357. this.wxPay(orderData);
  358. }, 1000);
  359. } else if (res.data.code === 104) {
  360. this.$dialog.confirm({
  361. message: `${res.data.message}`
  362. })
  363. }
  364. let that = this;
  365. let wxData = res.data.data;
  366. that.outTradeNo = wxData.out_trade_no;
  367. console.log("wxData", wxData);
  368. // 本地测试
  369. /* that.$router.push({
  370. name: "payResult",
  371. query: {
  372. outTradeNo: that.outTradeNo,
  373. price: that.price,
  374. rechargeUrl: data.rechargeUrl || '',
  375. iccid: this.params.iccid,
  376. isAdmin: this.$route.query.isAdmin,
  377. serialNo: this.params.imei,
  378. routerName: this.params.routerName,
  379. issue: data.packageIssue
  380. }
  381. }); */
  382. /* wx.chooseWXPay({
  383. timestamp: wxData.timeStamp, // 支付签名时间戳,注意微信 jssdk 中的所有使用 timestamp 字段均为小写。但最新版的支付后台生成签名使用的 timeStamp 字段名需大写其中的 S 字符
  384. nonceStr: wxData.nonceStr, // 支付签名随机串,不长于 32 位
  385. package: wxData.package, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=\*\*\*)
  386. signType: wxData.signType, // 微信支付V3的传入 RSA ,微信支付V2的传入格式与V2统一下单的签名格式保持一致
  387. paySign: wxData.paySign, // 支付签名
  388. success: function(res) {
  389. // 支付成功后的回调函数
  390. that.$router.replace({
  391. name: "payResult",
  392. query: {
  393. outTradeNo: that.outTradeNo,
  394. price: that.price,
  395. rechargeUrl: data.rechargeUrl,
  396. iccid: that.params.iccid,
  397. isAdmin: that.$route.query.isAdmin || false,
  398. serialNo: that.params.imei,
  399. issue: that.packageIssue
  400. }
  401. });
  402. console.log("微信支付成功::", res);
  403. },
  404. fail: err => {
  405. console.log("支付出错了::", err);
  406. that.$dialog.confirm({
  407. title: "温馨提示",
  408. message: "出错了,请您重新进入",
  409. showCancelButton: false
  410. });
  411. },
  412. cancel: function(err) {
  413. // 用户取消支付
  414. that.$dialog.confirm({
  415. title: "温馨提示",
  416. message: "您取消了支付",
  417. showCancelButton: false
  418. });
  419. console.log("用户取消了支付::", err);
  420. }
  421. }); */
  422. this.onWxPay(wxData);
  423. })
  424. .catch(error => {
  425. console.log("error", error);
  426. })
  427. .finally(() => {
  428. this.$toast.clear();
  429. });
  430. },
  431. onWxPay(data) {
  432. let that = this;
  433. function onBridgeReady() {
  434. WeixinJSBridge.invoke(
  435. "getBrandWCPayRequest",
  436. {
  437. appId: AppId, //公众号ID,由商户传入
  438. timeStamp: data.timeStamp, //时间戳,自1970年以来的秒数
  439. nonceStr: data.nonceStr, //随机串
  440. package: data.package,
  441. signType: data.signType, //微信签名方式:
  442. paySign: data.paySign //微信签名
  443. },
  444. function(res) {
  445. if (res.err_msg == "get_brand_wcpay_request:ok") {
  446. // 使用以上方式判断前端返回,微信团队郑重提示:
  447. //res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。
  448. that.$router.replace({
  449. name: "payResult",
  450. query: {
  451. outTradeNo: that.outTradeNo,
  452. price: that.price,
  453. rechargeUrl: data.rechargeUrl,
  454. iccid: that.params.iccid,
  455. isAdmin: that.$route.query.isAdmin || false,
  456. serialNo: that.params.imei,
  457. issue: that.packageIssue
  458. }
  459. });
  460. } else {
  461. that.$dialog.confirm({
  462. message: "您取消了支付",
  463. showCancelButton: false
  464. });
  465. }
  466. }
  467. );
  468. }
  469. if (typeof WeixinJSBridge == "undefined") {
  470. if (document.addEventListener) {
  471. document.addEventListener(
  472. "WeixinJSBridgeReady",
  473. onBridgeReady,
  474. false
  475. );
  476. } else if (document.attachEvent) {
  477. document.attachEvent("WeixinJSBridgeReady", onBridgeReady);
  478. document.attachEvent(
  479. "onWeixinJSBridgeReady",
  480. onBridgeReady
  481. );
  482. }
  483. } else {
  484. onBridgeReady();
  485. }
  486. },
  487. // 跳转到支付宝花呗外部链接
  488. aliPay(data) {
  489. console.log("选择了支付宝::", data);
  490. this.$toast.loading({
  491. message: "加载中"
  492. });
  493. let orderData = data;
  494. let reqBody = {
  495. openId: this.openId, //openId
  496. imei: this.params.imei, //imei
  497. iccid: this.params.iccid,
  498. productId: this.payProductId, //套餐id
  499. packageName: /* data.productModel + ',' + */data.packagesName, //套餐名字
  500. packagePayType: Number(this.payType), //支付类型
  501. packageIssue: this.packageIssue, //分期
  502. packagePrice: process.env.NODE_ENV === "production" ? data.packagesPrice * 100 : 1 //总金额单位为分,测试环境写死
  503. };
  504. this.$toast.clear();
  505. APICore.payLiveBaseDevice(reqBody)
  506. .then(res => {
  507. if (res.data.code === 104 || res.data.code === 106) {
  508. this.getAuth();
  509. setTimeout(() => {
  510. this.aliPay(orderData);
  511. }, 1000);
  512. }
  513. let that = this;
  514. let alipayData = res.data.data.xmlStrMap;
  515. that.outTradeNo = alipayData.outTradeNo;
  516. let alipayForm = decodeURI(alipayData.payXmlStr);
  517. that.$store.commit("isFromWx", true);
  518. let alipayUserId = process.env.NODE_ENV === "production" ? 69 : 18;
  519. this.$router.replace({
  520. name: "payResult",
  521. query: {
  522. rechargeUrl:
  523. data.rechargeUrl ||
  524. `https://id.ssjlai.com/frontend/#/alipay`,
  525. outTradeNo: that.outTradeNo,
  526. price: that.price,
  527. alipayForm: alipayForm,
  528. iccid: that.params.iccid,
  529. isAdmin: that.$route.query.isAdmin || false,
  530. serialNo: that.params.imei,
  531. alipayUserId: alipayUserId,
  532. productId: this.payProductId
  533. }
  534. });
  535. })
  536. .catch(error => {
  537. console.log("error", error);
  538. this.$dialog.confirm({
  539. message: `${error.message}`,
  540. showCancelButton: false
  541. })
  542. })
  543. .finally(() => {
  544. this.$toast.clear();
  545. });
  546. },
  547. // 支付类型切换
  548. onRaidoChange(value) {
  549. console.log("选择的支付类型是", value);
  550. this.payType = value;
  551. }
  552. }
  553. };
  554. </script>
  555. <style lang="scss">
  556. .van-nav-bar__title {
  557. max-width: 80% !important;
  558. font-size: 16px;
  559. }
  560. </style>
  561. <style lang="scss" scoped>
  562. .package-list-container {
  563. background-color: white;
  564. height: 100vh;
  565. .topup-container {
  566. position: relative;
  567. /* margin: 20px; */
  568. display: flex;
  569. justify-content: space-between;
  570. align-items: center;
  571. flex-direction: column;
  572. background-color: white;
  573. overflow: scroll;
  574. height: calc(100vh - 88px);
  575. .main {
  576. display: flex;
  577. justify-content: center;
  578. align-items: center;
  579. flex-direction: column;
  580. .tips {
  581. padding: 10px;
  582. }
  583. .noData_container {
  584. margin: 100px auto 0;
  585. height: 120px;
  586. /* background: url(../../../assets/img/news-noData.png) center no-repeat; */
  587. background-size: 165px 120px;
  588. display: flex;
  589. justify-content: center;
  590. align-items: flex-end;
  591. font-size: 16px;
  592. color: #999;
  593. p {
  594. font-size: 16px;
  595. }
  596. /* @include colorAndFont(#999, 28); */
  597. }
  598. p {
  599. padding: 10px;
  600. font-size: 16px;
  601. }
  602. .cancel-button {
  603. width: 30vw;
  604. border-radius: 5px;
  605. background-color: #2599ff;
  606. color: #fff;
  607. min-height: 40px;
  608. display: flex;
  609. justify-content: center;
  610. align-items: center;
  611. font-size: 16px;
  612. }
  613. .package-order-container {
  614. position: relative;
  615. margin: 10px 0;
  616. /* padding: 0 20px; */
  617. z-index: 999;
  618. box-shadow: rgba(14, 30, 37, 0.12) 0 3px 5px 0,
  619. rgba(14, 30, 37, 0.32) 0 2px 16px 0;
  620. .recom {
  621. position: absolute;
  622. top: -7px;
  623. left: -26px;
  624. border-style: solid;
  625. border-width: 0 40px 40px;
  626. border-color: transparent transparent red;
  627. transform: rotate(-45deg);
  628. text-align: center;
  629. z-index: 9999;
  630. p {
  631. padding: 0;
  632. color: white;
  633. font-size: 14px;
  634. }
  635. .shape {
  636. position: absolute;
  637. top: -1px;
  638. left: -21px;
  639. border-style: solid;
  640. border-width: 0 21px 21px;
  641. border-color: transparent transparent white;
  642. }
  643. .square {
  644. height: 15px;
  645. width: 35px;
  646. position: absolute;
  647. top: 21px;
  648. left: -20px;
  649. background: red;
  650. font-size: 14px;
  651. }
  652. }
  653. .order-content {
  654. padding: 15px 10px;
  655. .title {
  656. display: flex;
  657. justify-content: flex-start;
  658. p {
  659. font-size: 16px;
  660. font-weight: bold;
  661. }
  662. }
  663. .details {
  664. display: flex;
  665. justify-content: flex-start;
  666. align-items: center;
  667. p {
  668. height: 40px;
  669. @include center();
  670. font-size: 14px;
  671. padding: 5px 0 5px 10px;
  672. }
  673. .total {
  674. font-size: 16px;
  675. padding: 0;
  676. }
  677. .orange {
  678. color: orange;
  679. }
  680. .large {
  681. font-size: 26px;
  682. margin: 0 2px;
  683. }
  684. .price {
  685. font-size: 16px;
  686. }
  687. /* .buy-btn {
  688. height: 30px;
  689. width: 100px;
  690. display: flex;
  691. justify-content: center;
  692. align-items: center;
  693. background: orange;
  694. border-radius: 45px;
  695. p {
  696. font-size: 16px;
  697. padding: 0;
  698. color: red;
  699. }
  700. } */
  701. }
  702. .remark {
  703. display: flex;
  704. justify-content: flex-start;
  705. p {
  706. font-size: 14px;
  707. padding: 5px 10px;
  708. /* font-weight: bold; */
  709. }
  710. }
  711. .package-buy {
  712. @include center();
  713. padding: 5px 8px;
  714. @include center();
  715. .buy-btn {
  716. height: 40px;
  717. width: 200px;
  718. padding: 0 5px;
  719. display: flex;
  720. justify-content: center;
  721. align-items: center;
  722. background: orange;
  723. border-radius: 20px;
  724. p {
  725. font-size: 16px;
  726. padding: 0;
  727. color: white;
  728. }
  729. }
  730. }
  731. .radios-con {
  732. /* padding: 20px 10px; */
  733. /* @include center(); */
  734. /* align-items: center; */
  735. padding: 10px 0 10px 10px;
  736. font-size: 14px;
  737. /* box-shadow: rgba(14, 30, 37, 0.12) 0 3px 5px 0,
  738. rgba(14, 30, 37, 0.32) 0 2px 16px 0; */
  739. img {
  740. height: 20px;
  741. width: 20px;
  742. margin: 2px;
  743. }
  744. .pay-type {
  745. text-align: left;
  746. p {
  747. font-size: 14px;
  748. padding: 0 0 10px 0;
  749. }
  750. }
  751. .radio-con {
  752. @include center();
  753. }
  754. .van-cell-text {
  755. display: flex;
  756. justify-content: flex-start;
  757. align-items: center;
  758. span {
  759. font-size: 14px;
  760. padding: 0 5px;
  761. }
  762. }
  763. }
  764. }
  765. .content {
  766. font-size: 14px;
  767. }
  768. }
  769. }
  770. }
  771. .gray-line {
  772. height: 10px;
  773. width: 100%;
  774. background: #f2f4f5;
  775. }
  776. .order-description {
  777. height: 60px;
  778. display: flex;
  779. justify-content: flex-start;
  780. align-items: flex-start;
  781. flex-direction: column;
  782. padding: 5px 0 10px 10px;
  783. h5 {
  784. font-size: 14px;
  785. padding: 10px 0 0 0;
  786. }
  787. }
  788. .pay-radios {
  789. position: relative;
  790. top: 0;
  791. width: 100%;
  792. /* background-color: red; */
  793. /* padding: 0 15px; */
  794. .radios-con {
  795. padding: 20px 10px;
  796. /* @include center(); */
  797. align-items: center;
  798. font-size: 18px;
  799. box-shadow: rgba(14, 30, 37, 0.12) 0 3px 5px 0,
  800. rgba(14, 30, 37, 0.32) 0 2px 16px 0;
  801. img {
  802. height: 35px;
  803. width: auto;
  804. }
  805. .van-cell-text {
  806. display: flex;
  807. justify-content: flex-start;
  808. align-items: center;
  809. span {
  810. padding: 0 5px;
  811. }
  812. }
  813. }
  814. }
  815. }
  816. </style>