ProductProfit.vue
10.5 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
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
<!-- <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';
import axios from 'axios';
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 ids = ref();
const [register, { closeModal }] = useModalInner(async (data) => {
res.value = data.data;
customerCode.value = data.customerCode[0][0];
const extractedValues = ref<string[]>(data.projectNo.map((item) => item[0]));
projectNo.value = extractedValues.value;
ids.value = data.data;
console.log(data.projectNo, '5656projectNo');
console.log(Input2.value, 565656);
filteredItems.value = data.filteredItems;
});
async function handleOk() {
axios
.post(
'/basic-api/order/erp/calculate_profit/inner_profit_ratio_export',
{
customerCode: customerCode.value,
projectNo: projectNo.value,
ids: ids.value,
projectStartTime: projectStartTime.value,
projectEndTime: projectEndTime.value,
productionDepartmentPredictPrice: productionDepartmentPredictPrice.value,
productionActualPrice: productionActualPrice.value,
},
{
responseType: 'blob', // 设置响应类型为 'blob'
},
)
.then((response) => {
// 创建一个 Blob 对象来保存二进制数据
const blob = new Blob([response.data], { type: 'application/octet-stream' });
const getFormattedDate = (): string => {
const date = new Date();
const year = date.getFullYear();
const month = String(date.getMonth() + 1).padStart(2, '0');
const day = String(date.getDate()).padStart(2, '0');
const hours = String(date.getHours()).padStart(2, '0');
const minutes = String(date.getMinutes()).padStart(2, '0');
const seconds = String(date.getSeconds()).padStart(2, '0');
return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`;
};
const date = getFormattedDate();
// 创建一个链接元素用于下载
const link = document.createElement('a');
link.href = window.URL.createObjectURL(blob);
link.download = `内部生产净利润分析${date}.pdf`; // 你可以为文件命名
document.body.appendChild(link);
link.click(); // 自动点击链接,触发下载
console.log(link, 5656);
document.body.removeChild(link); // 下载完成后移除链接
})
.catch((error) => {
console.error(error);
});
closeModal();
}
function handleShow(visible: boolean) {
if (visible) {
projectStartTime.value = null;
projectEndTime.value = null;
productionDepartmentPredictPrice.value = null;
productionActualPrice.value = null;
projectNo.value = null;
ids.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,
ids: ids.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>