tripg-payment

A Vue.js swanui

Usage no npm install needed!

<script type="module">
  import tripgPayment from 'https://cdn.skypack.dev/tripg-payment';
</script>

README

swan-tripgui

A Vue.js project

Build Setup

# install dependencies
npm install

# serve with hot reload at localhost:8080
npm run dev

# build for production with minification
npm run build

For detailed explanation on how things work, consult the docs for vue-loader.

更换组件 npm uninstall tripg-invoices

发票组件

注: 各个项目引入后 全局css样式表中mint-ui.css中修改mint-toast层级
    .mint-toast{
      z-index: 99999 !important;
    } 
如果收银台页面左上角返回按钮不显示,请在当前页调整样式问题
其他样式冲突==>自行调试 

依赖安装后 在main.js中 添加

import invoices from 'swan-tripgui'
Vue.use(invoices)
import invmask from 'swan-tripgui'
Vue.use(invmask)

支付组件
import payment from 'swan-tripgui'
Vue.use(payment)


在index.html页面中引入支付包
 if(window.Vue){
   document.write('<script src="https://www.tripglobal.cn/tripg.php?_t='+Math.ceil(Math.random() * 999)+'"><\/script>');
 }else{
   document.write('<script src="https://www.tripglobal.cn/tripgvue.php?_t='+Math.ceil(Math.random() * 999)+'"><\/script>');
 }

在需要引入发票组件的页面加入

支付内容展示页面
<payment 
    :payParams="payParams" 
    :payUserInfo='payUserInfo' 
    :payOrderStatus="payOrderStatus"  
    @cancelOrder="cancelOrderBtn"  
    @successOrder="successOrder"></payment>

发票内容展示页面
<invoices  
  ref="invoices"
  :invoicesObj.sync = "invoicesObj"
  :checkinvoicesIndex.sync = "checkinvoicesIndex"
  :checkinvoicesflag.sync = 'checkinvoicesflag'
  :ajaxObj = "ajaxObj"
  :travelType='isYg'
  ></invoices>
  

发票弹框展示页面
 <invmask 
  ref="inmask"
  :invoicesObj.sync = "invoicesObj"
  :checkinvoicesIndex.sync = "checkinvoicesIndex"
  :checkinvoicesflag.sync = 'checkinvoicesflag'
  :ajaxObj = "ajaxObj"
  ></invmask>
  
  
data里加入
  userInfo:{},//开局发票人员信息(登陆信息)
  ajaxObj:null, //发票请求ajax参数
  invoicesObj:{},//发票信息
  checkinvoicesIndex:null,//点击发票内容组件的项
  checkinvoicesflag:null, 
  isYg:null,  //true or false 因公因私 传Boolean类型
data里加入支付组件所需
    payUserInfo:{},   //个人信息字符串
    payParams:{
        orderid: "",   //订单号
        callBackUrls: encodeURI(window.location.href),   //回调地址
        travelType:1,  //因公因私  1因公  2因私
        testPay:false,  //测试环境  true or false
        payId:'14',   //产品线id 机票11 酒店12 租车13 火车票14 国际机票28 具体与产品线一致
        exceed:false   //酒店超标支付
    },
    payOrderStatus:'20190524093020',   //20190524093020 保险订单创建时间

created() {
    this.userInfo = JSON.parse(localStorage.getItem('userInfo'))
    this.ajaxObj = {
      userInfo: this.userInfo,
      product_id: '11' //产品线id 机票11 酒店12 租车13 火车票14 国际机票28 具体与产品线一致
    }
  },
methods:{
    <!-- 按需调用 -->
    cancelOrderBtn(){
        <!-- 取消订单返回事件 -->
    },
    successOrder(item){
        <!-- 授信支付成功返回事件 -->
        console.log(item,'订单号')
    }
    }

(提交发票。提交发票走原tripg发票的逻辑)

在计算属性 computed中获取
this.$refs.invoices.$data.popVisible;//该值是判断发票开关是否打开(下单时判断)

下单按钮事件中添加

// 验证发票信息是否完整

if (this.$refs.invoices.checkInvoice() == false) {
  return;
}

下单成功后添加

this.allinvoiceInfo = []; //所有发票信息
["下单成功后返回的订单号"].forEach(v => {
  //这里是给李发的值,具体添加什么李发提供 businessinfo,
  //下面是机票线的,其它线修改一下。
  v.businessinfo = {
    product_id: v.product_id, //产品线ID
    order_no: v.tradeCode, //订单号
    ...this.paramsObj[0], //其它航班信息等
    money: v.pay_money //价格
  };
  this.allinvoiceInfo.push(v);
});

//下单后记录综合订单号。
this.mainOrderCode = order_info.Result.mainOrderCode;

最后一步提交,添加在订单成功后,跳路由之前。

await this.$refs.invoices.invoiceInfo_post(
  allinvoiceInfo,
  mainOrderCode
);