ProductProfit.vue
8.42 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
<!-- <template>
<BasicModal
v-bind="$attrs"
@register="register"
title="生产对账单"
width="60%"
:bodyStyle="{ height: '500px' }"
@ok="handleOk"
>
</BasicModal>
</template> -->
<template>
<BasicModal
v-bind="$attrs"
@register="register"
title="内部生产净利润分析表"
width="60%"
:bodyStyle="{ height: '360px' }"
@visible-change="handleShow"
@ok="handleOk"
okText="导出"
>
<template #appendFooter>
<a-button style="background-color: #1890ff; color: white" @click="handleCalculate"
>计算</a-button
>
</template>
<table
style="
width: 100%;
border-collapse: collapse;
text-align: center;
border: 1px solid black;
font-size: 16px;
"
>
<thead>
<!-- <tr>
<th colspan="4" style="border: 1px solid black">净利润分析表</th>
</tr> -->
</thead>
<tbody>
<tr>
<td style="border: 1px solid black; width: 20%">项目号</td>
<td style="border: 1px solid black; width: 20%">{{ projectNo }}</td>
<td style="border: 1px solid black; width: 20%">开始时间</td>
<td style="border: 1px solid black; width: 20%">结束时间</td>
<td style="border: 1px solid black; width: 20%">生产持续时间</td>
</tr>
<tr>
<td style="border: 1px solid black; width: 20%"></td>
<td style="border: 1px solid black; width: 20%">项目开发时间</td>
<td style="border: 1px solid black; width: 20%">
<input type="date" v-model="projectStartTime" style="width: 100%" />
</td>
<td style="border: 1px solid black; width: 20%">
<input type="date" v-model="projectEndTime" style="width: 100%" />
</td>
<td style="border: 1px solid black; width: 20%">{{ projectDays }}</td>
</tr>
<tr>
<td style="border: 1px solid black; width: 20%">客户编码</td>
<td style="border: 1px solid black; width: 20%">{{ customerCode }}</td>
<td style="border: 1px solid black; width: 20%">明细</td>
<td style="border: 1px solid black; width: 20%">金额</td>
<td style="border: 1px solid black; width: 20%">订单数量</td>
</tr>
<tr>
<td style="border: 1px solid black; width: 40%" colspan="2">生产科总价合计</td>
<td style="border: 1px solid black; width: 20%">{{ productionDepartmentTotalPrice }}</td>
<td style="border: 1px solid black; width: 20%">{{ sumMoney }}</td>
<td style="border: 1px solid black; width: 20%">{{ sumCount }}</td>
</tr>
<tr>
<td style="border: 1px solid black; width: 40%" colspan="2">生产科预算金额</td>
<td style="border: 1px solid black; width: 20%"
><a-input v-model:value="productionDepartmentPredictPrice" placeholder="请输入"
/></td>
<td style="border: 1px solid black; width: 20%">预算占比</td>
<td style="border: 1px solid black; width: 20%">预算占比与实际占比差</td>
</tr>
<tr>
<td style="border: 1px solid black; width: 40%" colspan="2">实际发生费用</td>
<td style="border: 1px solid black; width: 20%"
><a-input v-model:value="productionActualPrice" placeholder="请输入"
/></td>
<td style="border: 1px solid black; width: 20%">{{ predictRatio }}</td>
<td style="border: 1px solid black; width: 20%">{{ predictRatioDeduct }}</td>
</tr>
<tr>
<td style="border: 1px solid black; width: 40%" colspan="2">内部生产毛利润</td>
<td style="border: 1px solid black; width: 20%">{{ grossProfit }}</td>
<td style="border: 1px solid black; width: 20%"></td>
<td style="border: 1px solid black; width: 20%"></td>
</tr>
<tr>
<td style="border: 1px solid black; width: 40%" colspan="2">内部生产固定成本</td>
<td style="border: 1px solid black; width: 20%">{{ innerProduceFixProfit }}</td>
<td style="border: 1px solid black; width: 20%"></td>
<td style="border: 1px solid black; width: 20%"></td>
</tr>
<tr>
<td style="border: 1px solid black; width: 40%" colspan="2">内部生产提交</td>
<td style="border: 1px solid black; width: 20%">{{ innerProduceTotalPrice }}</td>
<td style="border: 1px solid black; width: 20%"></td>
<td style="border: 1px solid black; width: 20%"></td>
</tr>
<tr>
<td style="border: 1px solid black; width: 40%" colspan="2">内部生产净利润</td>
<td style="border: 1px solid black; width: 20%">{{ innerProduceTotalProfit }}</td>
<td style="border: 1px solid black; width: 20%"></td>
<td style="border: 1px solid black; width: 20%"></td>
</tr>
</tbody>
</table>
</BasicModal>
</template>
<script lang="ts" setup>
import { BasicModal, useModalInner } from '@/components/Modal';
import { computed, ref } from 'vue';
import { payDate, checkCreate } from '@/api/project/invoice';
import type { Dayjs } from 'dayjs';
import { calculateInnerProfitRatio, exportInnerProfitRatio } from '@/api/project/order';
const Input1 = ref('');
const Input2 = ref();
const res = ref();
const customerCode = ref(); // 客户编码
const grossProfit = ref(); // 内部生产毛利润
const innerProduceFixProfit = ref(); // 内部生产固定成本
const innerProduceTotalPrice = ref(); // 内部生产提成
const innerProduceTotalProfit = ref(); // 内部生产净利润
const predictRatio = ref(); // 预算占比
const predictRatioDeduct = ref(); // 预算占比差
const productionActualPrice = ref(); // 实际发生费用
const productionDepartmentPredictPrice = ref(); // 生产科预算金额
const productionDepartmentTotalPrice = ref(); // 生产科总价合计
const projectDays = ref(); // 生产持续时间
const sumCount = ref(0);
const sumMoney = ref(0);
const projectEndTime = ref(); // 项目开发结束时间
const projectNo = ref(); // 项目号
const projectStartTime = ref(); // 项目开发开始时间
const filteredItems = ref();
const [register, { closeModal }] = useModalInner(async (data) => {
res.value = data.data;
customerCode.value = data.customerCode[0][0];
projectNo.value = data.projectNo[0][0];
console.log(Input2.value, 565656);
filteredItems.value = data.filteredItems;
});
async function handleOk() {
closeModal();
}
function handleShow(visible: boolean) {
if (visible) {
projectStartTime.value = null;
projectEndTime.value = null;
productionDepartmentPredictPrice.value = null;
productionActualPrice.value = null;
}
}
function formatDateTime(dateTime: string): string {
return dateTime.split('T')[0];
}
async function handleCalculate() {
projectStartTime.value = formatDateTime(projectStartTime.value);
projectEndTime.value = formatDateTime(projectEndTime.value);
const res = await calculateInnerProfitRatio({
customerCode: customerCode.value,
projectNo: projectNo.value,
projectStartTime: projectStartTime.value,
projectEndTime: projectEndTime.value,
productionDepartmentPredictPrice: productionDepartmentPredictPrice.value,
productionActualPrice: productionActualPrice.value,
});
console.log(res, '5656resproductprofit');
grossProfit.value = res.grossProfit;
innerProduceFixProfit.value = res.innerProduceFixProfit;
innerProduceTotalPrice.value = res.innerProduceTotalPrice;
innerProduceTotalProfit.value = res.innerProduceTotalProfit;
predictRatio.value = res.predictRatio;
productionActualPrice.value = res.productionActualPrice;
productionDepartmentPredictPrice.value = res.productionDepartmentPredictPrice;
productionDepartmentTotalPrice.value = res.productionDepartmentTotalPrice;
projectDays.value = res.projectDays;
predictRatioDeduct.value = 1 - predictRatio.value;
console.log(filteredItems.value, '5656filteredItems');
filteredItems.value.forEach((item) => {
sumMoney.value += item.profitAnalysisInfo.productionDepartmentTotalPrice;
sumCount.value += item.orderCount;
});
console.log(sumMoney.value, '5656filteredItems', sumCount.value);
}
</script>
<style scoped>
.divAll {
display: flex;
justify-content: center;
align-items: center;
}
</style>