|
@@ -0,0 +1,242 @@
|
|
|
+<template>
|
|
|
+ <cl-crud ref="Crud" class="orderList">
|
|
|
+ <cl-row>
|
|
|
+ <cl-filter-group :items="items" :data="filterParam" :reset-btn="true" />
|
|
|
+ <cl-export-btn :columns="Table?.columns" />
|
|
|
+ </cl-row>
|
|
|
+
|
|
|
+ <cl-row>
|
|
|
+ <el-checkbox v-model="showSummary" label="统计数据" size="small" />
|
|
|
+ <el-tag v-if="showSummary" class="ml-2" effect="light">成功总金额: {{ summary.num1 }}</el-tag>
|
|
|
+ <el-tag v-if="showSummary" class="ml-2" effect="light">成功订单手续费: {{ summary.num2 }}</el-tag>
|
|
|
+ <el-tag v-if="showSummary" class="ml-2" effect="light">成功订单数: {{ summary.num3 }}</el-tag>
|
|
|
+ <el-tag v-if="showSummary" class="ml-2" effect="light">成功率: {{ summary.num4.toFixed(2) }}%</el-tag>
|
|
|
+ </cl-row>
|
|
|
+
|
|
|
+ <cl-row>
|
|
|
+ <!-- 数据表格 -->
|
|
|
+ <cl-table ref="Table" :contextMenu="[]">
|
|
|
+ </cl-table>
|
|
|
+ </cl-row>
|
|
|
+
|
|
|
+ <cl-row>
|
|
|
+ <cl-flex1 />
|
|
|
+ <!-- 分页控件 -->
|
|
|
+ <cl-pagination />
|
|
|
+ </cl-row>
|
|
|
+ </cl-crud>
|
|
|
+</template>
|
|
|
+
|
|
|
+<script lang="ts" name="pay-order" setup>
|
|
|
+import { useCrud, useTable, useUpsert } from "@cool-vue/crud";
|
|
|
+import { ref } from "vue";
|
|
|
+import { useCool } from "/@/cool";
|
|
|
+import dayjs from "dayjs";
|
|
|
+
|
|
|
+const { service } = useCool();
|
|
|
+
|
|
|
+const showSummary = ref(false);
|
|
|
+
|
|
|
+const filterParam = ref({
|
|
|
+ createTime: [
|
|
|
+ dayjs().format("YYYY-MM-DD ") + "00:00:00",
|
|
|
+ dayjs().format("YYYY-MM-DD ") + "23:59:59"
|
|
|
+ ]
|
|
|
+});
|
|
|
+
|
|
|
+const summary = ref({
|
|
|
+ num1: 0,
|
|
|
+ num2: 0,
|
|
|
+ num3: 0,
|
|
|
+ num4: 0
|
|
|
+});
|
|
|
+
|
|
|
+const items = ref<ClForm.Item[]>([
|
|
|
+ {
|
|
|
+ label: "订单号",
|
|
|
+ prop: "orderNo",
|
|
|
+ component: {
|
|
|
+ name: "el-input"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: "商户订单号",
|
|
|
+ prop: "outOrderNo",
|
|
|
+ component: {
|
|
|
+ name: "el-input"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: "商户号",
|
|
|
+ prop: "mchId",
|
|
|
+ component: {
|
|
|
+ name: "el-input"
|
|
|
+ },
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: "支付方式",
|
|
|
+ prop: "payType",
|
|
|
+ component: {
|
|
|
+ name: "el-input"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: "支付状态",
|
|
|
+ prop: "status",
|
|
|
+ component: {
|
|
|
+ name: "el-select",
|
|
|
+ props: {
|
|
|
+ clearable: true
|
|
|
+ },
|
|
|
+ options: [
|
|
|
+ {
|
|
|
+ label: "待支付",
|
|
|
+ value: 0
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: "支付成功",
|
|
|
+ value: 1
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: "下单失败",
|
|
|
+ value: 2
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: "日期范围",
|
|
|
+ prop: "createTime",
|
|
|
+ component: {
|
|
|
+ name: "el-date-picker",
|
|
|
+ props: {
|
|
|
+ style: { width: "360px" },
|
|
|
+ type: "datetimerange",
|
|
|
+ unlinkPanels: true,
|
|
|
+ valueFormat: "YYYY-MM-DD HH:mm:ss",
|
|
|
+ shortcuts: [
|
|
|
+ {
|
|
|
+ text: '今天',
|
|
|
+ value: () => {
|
|
|
+ return [dayjs().startOf('day'), dayjs().endOf('day')]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ text: '昨天',
|
|
|
+ value: () => {
|
|
|
+ return [dayjs().subtract(1, 'day').startOf('day'), dayjs().subtract(1, 'day').endOf('day')]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ text: '近三天',
|
|
|
+ value: () => {
|
|
|
+ return [dayjs().subtract(2, 'day').startOf('day'), dayjs().endOf('day')]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ text: '近七天',
|
|
|
+ value: () => {
|
|
|
+ return [dayjs().subtract(6, 'day').startOf('day'), dayjs().endOf('day')]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ text: '近一个月',
|
|
|
+ value: () => {
|
|
|
+ return [dayjs().startOf('month'), dayjs().endOf('month')]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ ],
|
|
|
+ onChange() { }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+]);
|
|
|
+
|
|
|
+// cl-table
|
|
|
+const Table = useTable({
|
|
|
+ autoHeight: false,
|
|
|
+ columns: [
|
|
|
+ { type: 'index', label: '#' },
|
|
|
+ { prop: "orderNo", label: "订单号", showOverflowTooltip: true },
|
|
|
+ { prop: "outOrderNo", label: "商户订单号", showOverflowTooltip: true },
|
|
|
+ { prop: "mchId", label: "商户号" },
|
|
|
+ {
|
|
|
+ prop: "amount",
|
|
|
+ label: "金额",
|
|
|
+ formatter(row) {
|
|
|
+ return (+row.amount).toFixed(2);
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ prop: "charge",
|
|
|
+ label: "手续费",
|
|
|
+ formatter(row) {
|
|
|
+ return (+row.charge).toFixed(2);
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ prop: "currency",
|
|
|
+ label: "货币"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ prop: "status",
|
|
|
+ label: "订单状态",
|
|
|
+ dict: [
|
|
|
+ { label: "待支付", value: 0, color: "#909399" },
|
|
|
+ { label: "支付成功", value: 1, color: "#67C23A" },
|
|
|
+ { label: "下单失败", value: 2, color: "#F56C6C" }
|
|
|
+ ],
|
|
|
+ },
|
|
|
+ { prop: "payType", label: "支付方式", showOverflowTooltip: true },
|
|
|
+ { prop: "createTime", label: "创建时间" },
|
|
|
+ ]
|
|
|
+});
|
|
|
+
|
|
|
+// cl-crud
|
|
|
+const Crud = useCrud(
|
|
|
+ {
|
|
|
+ service: service.dj.agentOrder,
|
|
|
+ async onRefresh(params, { next, render }) {
|
|
|
+ const { list, pagination } = await next({
|
|
|
+ order: "createTime",
|
|
|
+ sort: "desc",
|
|
|
+ ...params
|
|
|
+ });
|
|
|
+ if (showSummary.value) {
|
|
|
+ const { num1, num2, num3, num4 } = (
|
|
|
+ await service.dj.agentOrder.summary(params)
|
|
|
+ )[0];
|
|
|
+ summary.value.num1 = +num1;
|
|
|
+ summary.value.num2 = +num2;
|
|
|
+ summary.value.num3 = +num3;
|
|
|
+ summary.value.num4 = +num4 > 0 ? (+num3 / +num4) * 100 : 0;
|
|
|
+ }
|
|
|
+ render(list, pagination);
|
|
|
+ }
|
|
|
+ },
|
|
|
+ (app) => {
|
|
|
+ app.refresh(filterParam.value);
|
|
|
+ }
|
|
|
+);
|
|
|
+</script>
|
|
|
+
|
|
|
+<style lang="scss">
|
|
|
+.orderList {
|
|
|
+ .el-descriptions {
|
|
|
+ .el-descriptions__label {
|
|
|
+ width: 120px !important;
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+.desc .el-descriptions__label {
|
|
|
+ min-width: 115px;
|
|
|
+}
|
|
|
+
|
|
|
+.tooltip {
|
|
|
+ max-width: 100px !important;
|
|
|
+ overflow: hidden;
|
|
|
+ text-overflow: ellipsis;
|
|
|
+ white-space: nowrap;
|
|
|
+}
|
|
|
+</style>
|