|
@@ -13,7 +13,7 @@
|
|
|
</div>
|
|
|
|
|
|
<el-row style="margin-top:10px" v-if="!isEmpty">
|
|
|
- <el-table border size="mini" :data="tableData" :cell-class-name="setCellClassName">
|
|
|
+ <el-table border size="mini" :data="tableData" :header-cell-class-name="setHeaderClassName" :cell-class-name="setCellClassName">
|
|
|
<el-table-column fixed="left" label="业务公司" prop="companyName" align="center" width="70px">
|
|
|
<template slot-scope="scope">
|
|
|
<div v-if="scope.row.companyName.indexOf('普润') === -1">{{mapCompany[scope.row.companyName] || scope.row.companyName}}</div>
|
|
@@ -38,63 +38,57 @@
|
|
|
<el-table-column label="当月营业收入(净)" align="center" min-width="450px">
|
|
|
<template slot-scope="scope">
|
|
|
<div style="display:flex;flex-direction: column;">
|
|
|
- <p style="text-align: center;">{{ unit2TenThousand(scope.row.msale_total, isTenThound) }}</p>
|
|
|
+ <p :style="`text-align: center;${getCurrentValueStyle(scope.row.msale_total,scope.row.total_tips)}`" >
|
|
|
+ {{ unit2TenThousand(scope.row.msale_total, isTenThound) }}
|
|
|
+ </p>
|
|
|
+
|
|
|
<div class="table-size">
|
|
|
<p>直营/自营: {{ unit2TenThousand(scope.row.info[0][0].monthinfo.msale_total, isTenThound) }}</p>
|
|
|
<p>渠道: {{ unit2TenThousand(scope.row.info[0][1].monthinfo.msale_total, isTenThound) }}</p>
|
|
|
<p>供应商端: {{ unit2TenThousand(scope.row.info[0][2].monthinfo.msale_total, isTenThound) }}</p>
|
|
|
</div>
|
|
|
</div>
|
|
|
-
|
|
|
- <!-- <el-table border size="mini" :data="scope.row.info">
|
|
|
- <el-table-column align="center" label="直营/自营">
|
|
|
- <template slot-scope="scope">
|
|
|
- {{unit2TenThousand(scope.row[0].monthinfo.msale_total, isTenThound)}}
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
-
|
|
|
- <el-table-column align="center" label="渠道">
|
|
|
- <template slot-scope="scope">
|
|
|
- {{ unit2TenThousand(scope.row[1].monthinfo.msale_total,isTenThound)}}
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- <el-table-column align="center" label="供应商端">
|
|
|
- <template slot-scope="scope">
|
|
|
- {{ unit2TenThousand(scope.row[2].monthinfo.msale_total,isTenThound)}}
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- </el-table> -->
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
|
|
|
<el-table-column label="当月营收完成%" align="center" min-width="120px">
|
|
|
<template slot-scope="scope">
|
|
|
- {{ scope.row.completion_rate + "%" }}
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- <el-table-column label="当月毛利完成%" align="center" min-width="120px">
|
|
|
- <template slot-scope="scope">
|
|
|
- {{ scope.row.gross_completion_rate + '%' }}
|
|
|
+ <div :style="`${getCurrentRateStyle(scope.row.completion_rate)}`">{{ scope.row.completion_rate + "%" }}</div>
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
|
|
|
|
|
|
<template v-if="costField">
|
|
|
- <el-table-column label="当月毛利指标" align="center" width="120px">
|
|
|
+ <el-table-column label="当月毛利目标" align="center" width="120px">
|
|
|
<template slot-scope="scope">
|
|
|
{{ unit2TenThousand(scope.row.cost_tips, isTenThound) }}
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
+
|
|
|
<el-table-column label="当月毛利完成" align="center" width="120px">
|
|
|
<template slot-scope="scope">
|
|
|
- {{ unit2TenThousand(scope.row.gross_completion, isTenThound) }}
|
|
|
+ <div :style="`${getCurrentValueStyle(scope.row.gross_completion, scope.row.cost_tips)}`">
|
|
|
+ {{ unit2TenThousand(scope.row.gross_completion, isTenThound) }}
|
|
|
+ </div>
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
+
|
|
|
<el-table-column label="当月实际毛利率" align="center" width="120px">
|
|
|
<template slot-scope="scope">
|
|
|
- {{ unit2TenThousand(scope.row.gross_sale_completion_rate) + "%" }}
|
|
|
+ <!-- <div :style="`${getCurrentRateStyle(scope.row.gross_sale_completion_rate)}`"> -->
|
|
|
+ {{ unit2TenThousand(scope.row.gross_sale_completion_rate) + "%" }}
|
|
|
+ <!-- </div> -->
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
+
|
|
|
+ <el-table-column label="当月毛利完成%" align="center" min-width="120px">
|
|
|
+ <template slot-scope="scope">
|
|
|
+ <div :style="getCurrentRateStyle(scope.row.gross_completion_rate)">
|
|
|
+ {{ scope.row.gross_completion_rate + '%' }}
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+
|
|
|
<el-table-column label="当月成本合计" align="center" width="450px">
|
|
|
<template slot-scope="scope">
|
|
|
<div style="display:flex;flex-direction: column;">
|
|
@@ -108,29 +102,6 @@
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
</template>
|
|
|
-
|
|
|
- <!--
|
|
|
- <el-table-column label="当月成本合计" align="center" width="120px">
|
|
|
- <template slot-scope="scope">
|
|
|
- {{unit2TenThousand(scope.row.mcost_total,isTenThound)}}
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
-
|
|
|
- <el-table-column label="直营/自营成本" align="center" width="120px">
|
|
|
- <template slot-scope="scope">
|
|
|
- {{ unit2TenThousand(scope.row.info[0][0].monthinfo.mcost_total,isTenThound)}}
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- <el-table-column label="渠道成本" align="center" width="120px">
|
|
|
- <template slot-scope="scope">
|
|
|
- {{ unit2TenThousand(scope.row.info[0][1].monthinfo.mcost_total,isTenThound)}}
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- <el-table-column label="供应商端成本" align="center" width="120px">
|
|
|
- <template slot-scope="scope">
|
|
|
- {{ unit2TenThousand(scope.row.info[0][2].monthinfo.mcost_total,isTenThound)}}
|
|
|
- </template>
|
|
|
- </el-table-column> -->
|
|
|
</el-table>
|
|
|
</el-row>
|
|
|
|
|
@@ -145,6 +116,7 @@
|
|
|
import asyncRequest from "@/api/newResults";
|
|
|
import { addition, unit2TenThousand, subtraction, multiplication, division } from "../newReport/src/_utils";
|
|
|
import { mapCompany } from "./mapCompany";
|
|
|
+import dayjs from "dayjs"
|
|
|
|
|
|
export default {
|
|
|
props: ['companies', 'costField'],
|
|
@@ -158,13 +130,6 @@ export default {
|
|
|
cp_companies: [],
|
|
|
isEmpty: false,
|
|
|
mapCompany
|
|
|
- // companies:[
|
|
|
- // { value:"",label: "所有公司"},
|
|
|
- // { value:"GS2302231125079621",label: "北京百辰荣达国际科贸有限公司"},
|
|
|
- // { value:"GS2302231323386950",label: "北京泓源广诚国际商贸有限公司"},
|
|
|
- // { value:"GS2203161855277894 ",label: "北京万宇恒通国际科贸有限公司"},
|
|
|
- // { value:"GS2302231124114965",label: "普润&锦兴&知事"}
|
|
|
- // ]
|
|
|
}
|
|
|
},
|
|
|
mounted() {
|
|
@@ -188,6 +153,20 @@ export default {
|
|
|
},
|
|
|
methods: {
|
|
|
unit2TenThousand,
|
|
|
+ getCurrentRateStyle(current){
|
|
|
+ const days = dayjs().daysInMonth();
|
|
|
+ const oneDay = Number(division(100,days)).toFixed(2);
|
|
|
+ const currentDay = dayjs().date();
|
|
|
+ const currentTotalTip = Number( multiplication(currentDay,oneDay)).toFixed(2);
|
|
|
+ return Number(currentTotalTip) > Number(current) ? 'color:red' : ''
|
|
|
+ },
|
|
|
+ getCurrentValueStyle(current,total){
|
|
|
+ const days = dayjs().daysInMonth();
|
|
|
+ const oneDay = Number(division(total,days)).toFixed(2);
|
|
|
+ const currentDay = dayjs().date();
|
|
|
+ const currentTotalTip = Number( multiplication(currentDay,oneDay)).toFixed(2);
|
|
|
+ return Number(currentTotalTip) > Number(current) ? 'color: red' : '';
|
|
|
+ },
|
|
|
addDataToCompany(c1, c2) {
|
|
|
// Number(addition(c1.total_tips,c2.total_tips)).toFixed(2)
|
|
|
|
|
@@ -215,7 +194,14 @@ export default {
|
|
|
},
|
|
|
setCellClassName({ column }) {
|
|
|
const { label } = column;
|
|
|
- return label === "当月营业收入(净)" || label === '当月成本合计' ? "pure__cell" : "";
|
|
|
+ if(label === "当月营业收入(净)" || label === '当月成本合计') return "pure__cell";
|
|
|
+ if(label === "当月营收目标") return "bg__yellow"
|
|
|
+ if(label === "当月毛利目标") return "bg__red"
|
|
|
+ },
|
|
|
+ setHeaderClassName({ column }){
|
|
|
+ const { label } = column;
|
|
|
+ if(label === "当月营收目标") return "bg__yellow"
|
|
|
+ if(label === "当月毛利目标") return "bg__red"
|
|
|
},
|
|
|
transformTime() {
|
|
|
let time = new Date();
|
|
@@ -244,8 +230,6 @@ export default {
|
|
|
res.data[prIndex] = this.addDataToCompany(jxResult.data[0], res.data[prIndex]);
|
|
|
}
|
|
|
|
|
|
- console.log(res.data[prIndex])
|
|
|
-
|
|
|
// const isBeforeDate = this.getDiffDay() < 0 && this.companyNo === "GS2302231323386950"
|
|
|
|
|
|
if (res.code === 0 && res.data && res.data.length > 0) {
|
|
@@ -302,7 +286,6 @@ export default {
|
|
|
|
|
|
|
|
|
prev_sale_total = Number(addition(prev_sale_total, sale_total)).toFixed(2);
|
|
|
-
|
|
|
prev_msale_total = Number(addition(prev_msale_total, msale_total)).toFixed(2);
|
|
|
prev_cost_total = Number(addition(prev_cost_total, cost_total)).toFixed(2);
|
|
|
prev_mcost_total = Number(addition(prev_mcost_total, mcost_total)).toFixed(2);
|
|
@@ -314,22 +297,19 @@ export default {
|
|
|
}
|
|
|
})
|
|
|
|
|
|
-
|
|
|
const gross_completion = Number(subtraction(prev_msale_total, prev_mcost_total)).toFixed(2) //当月毛利完成 = 月营收 - 月成本
|
|
|
-
|
|
|
this.tableData = [
|
|
|
...this.tableData,
|
|
|
{
|
|
|
companyName, // 公司名称
|
|
|
cost_tips, // 当月成本指标
|
|
|
total_tips, // 当月营收目标
|
|
|
- info: [{ ...item }], // 直营.. 渠道 销售
|
|
|
+ info: [{ ...item }], // 直营..渠道 销售
|
|
|
sale_total: prev_sale_total, // 当日营业收入
|
|
|
cost_total: prev_cost_total, // 当日成本总额
|
|
|
msale_total: prev_msale_total, // 当月营业收入
|
|
|
mcost_total: prev_mcost_total,// 当月成本总额
|
|
|
gross_completion, //当月毛利完成 = 月营收 - 月成本
|
|
|
-
|
|
|
completion_rate: multiplication(division(prev_msale_total, total_tips), 100).toFixed(2), // 当月应收完成率
|
|
|
gross_completion_rate: Number(cost_tips) === 0 ? 0 : multiplication(division(gross_completion, cost_tips) || 0, 100).toFixed(2), // 当月毛利完成率
|
|
|
gross_sale_completion_rate: Number(multiplication(division(gross_completion, prev_msale_total) || 0, 100)).toFixed(2), // 本月毛利率 = 当月毛利完成 / 当月营业收入
|