ReconciliationList.vue 5.7 KB
<template>
  <a-card :bordered="false">
    <!-- 查询区域 -->
    <div class="table-page-search-wrapper">
      <a-form layout="inline" @keyup.enter.native="searchQuery">
        <a-row :gutter="24">
          <a-col :md="6" :sm="8">
            <a-form-item label="订单编号">
              <j-input placeholder="请输入订单编号" v-model="queryParam.orderNum"></j-input>
            </a-form-item>
          </a-col>
          <a-col :md="6" :sm="8">
            <a-form-item label="状态">
              <a-select style="width: 100%" v-model="queryParam.reconciliationStatus" placeholder="请选择状态">
                <a-select-option v-for="item in auditList" :key="item.value" :value="item.value">{{item.label}}</a-select-option>
              </a-select>
            </a-form-item>
          </a-col>
          <a-col :md="6" :sm="8">
            <a-form-item label="提交开始时间">
              <a-date-picker placeholder="提交开始时间" valueFormat="YYYY-MM-DD" v-model="queryParam.createTime_begin"></a-date-picker>
            </a-form-item>
          </a-col>
          <a-col :md="6" :sm="8">
            <a-form-item label="提交结束时间">
              <a-date-picker placeholder="提交结束时间" valueFormat="YYYY-MM-DD" v-model="queryParam.createTime_end"></a-date-picker>
            </a-form-item>
          </a-col>
          <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
            <a-col :md="6" :sm="24">
              <a-button type="primary" @click="searchQuery">查询</a-button>
              <a-button style="margin-left: 8px" @click="searchReset">重置</a-button>
            </a-col>
          </span>
        </a-row>
      </a-form>
    </div>

    <!-- table区域-begin -->
    <div>
      <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
        <!-- <i class="anticon anticon-info-circle ant-alert-icon"></i>已选择&nbsp;<a style="font-weight: 600">{{
        selectedRowKeys.length }}</a>&nbsp;&nbsp;
        <a style="margin-left: 24px" v-if="selectedRowKeys.length > 0" @click="onClearSelected">清空</a> -->
        以下账单,展示 <span style="color:red">{{showDay}}</span> 天前的账单金额
      </div>

      <a-table
        ref="table"
        size="middle"
        :scroll="{x:true}"
        bordered rowKey="id"
        :columns="columns"
        :dataSource="dataSource"
        :pagination="ipagination"
        :loading="loading"
        class="j-table-force-nowrap"
        @change="handleTableChange"
      >
        <span slot="orderSource">小程序</span>
        <span slot="action" slot-scope="text, record">
          <a href="javascript:;" @click="propertyDetails(record.id)">详情</a>
          <template v-if="record.isShow === '1' && record.reconciliationStatus === 1 || record.reconciliationStatus === 4">
            <a-divider type="vertical" />
            <a href="javascript:;" @click="handleEdit(record, '申请对账')">申请对账</a>
          </template>
        </span>
      </a-table>

    </div>
    <!-- table区域-end -->
    <property-adv-modal ref="modalForm" @ok="modalFormOk"></property-adv-modal>
  </a-card>
</template>

<script>
import { getRuleDayDetailApi } from '@/api/api'
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
import { filterDictTextByStatic, FENLICENTRAL_AUDIT_STATUS, PAY_WAY } from '@/assets/static.js'
import PropertyAdvModal from './modules/PropertyAdvModal'

const columns = [
  {
    title: '结算单号',
    dataIndex: 'balanceNum',
    key: 'balanceNum',
    align: 'center',
  },
  {
    title: '订单编号',
    dataIndex: 'orderNum',
    key: 'orderNum',
    align: 'center',
  },
  {
    title: '提交时间',
    dataIndex: 'createTime',
    key: 'createTime',
    align: 'center',
  },
  {
    title: '用户账号',
    dataIndex: 'buyerName',
    key: 'buyerName',
    align: 'center',
  },
  {
    title: '订单金额',
    dataIndex: 'totalMoney',
    key: 'totalMoney',
    align: 'center',
  },
  {
    title: '分利金额',
    dataIndex: 'shareMoney',
    key: 'shareMoney',
    align: 'center',
  },
  {
    title: '支付方式',
    dataIndex: 'payWay',
    key: 'payWay',
    align: 'center',
    customRender: function (text) {
      return filterDictTextByStatic(PAY_WAY, text)
    }
  },
  {
    title: '订单来源',
    dataIndex: 'orderSource',
    key: 'orderSource',
    align: 'center',
    scopedSlots: { customRender: 'orderSource' },
  },
  {
    title: '订单状态',
    dataIndex: 'reconciliationStatus',
    key: 'reconciliationStatus',
    align: 'center',
    customRender: function (text) {
      return filterDictTextByStatic(FENLICENTRAL_AUDIT_STATUS, text)
    }
  },
  {
    title: '备注',
    dataIndex: 'remarks',
    key: 'remarks',
    align: 'center',
  },
  {
    title: '所属平台',
    dataIndex: 'propertyName',
    key: 'propertyName',
    align: 'center',
  },
  {
    title: '操作',
    dataIndex: 'action',
    scopedSlots: { customRender: 'action' },
    align: 'center',
    fixed: 'right',
    width: 150
  },
]

export default {
  name: 'PermissionListAsync',
  mixins: [JeecgListMixin],
  components: {
    PropertyAdvModal,
  },
  data() {
    return {
      showDay: 7,
      auditList: FENLICENTRAL_AUDIT_STATUS,
      columns: columns,
      url: {
        list: '/property-central/partners/shareBenefit/list?platformType=central'
      }
    }
  },
  methods: {
    propertyDetails(id) {
      this.$router.push({
        path: '/benefitsAudit/ReconciliationDetails?id=' + id
      })
    }
  },
  created() {
    getRuleDayDetailApi({id: 1}).then(res=> {
      this.showDay = res.result.days
    })
  }
}
</script>
<style scoped>
@import '~@assets/less/common.less';
</style>