form.vue 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669
  1. <!-- 首序外协 -->
  2. <template>
  3. <el-drawer title="首序外协信息" :with-header="false" v-model="visible" direction="rtl" size="100%">
  4. <div class="form-container column-container">
  5. <div class="form-btns-container">
  6. <span class="title-label">
  7. <el-icon>
  8. <Document />
  9. </el-icon>
  10. <span>外协单信息</span>
  11. </span>
  12. <el-button v-show="editStatus && form.isSubmit == 1" type="primary" icon="Download" @click="handleExport"
  13. v-hasPermi="['business:outsource:export']">导出</el-button>
  14. <el-button v-show="editStatus && form.isSubmit == 1" type="warning" icon="Download" @click="handlePrint"
  15. v-hasPermi="['business:outsource:export']">
  16. 打印
  17. </el-button>
  18. <el-button v-if="editStatus" type="primary" icon="Finished" @click="handleSubmit">保存</el-button>
  19. <el-button v-if="editStatus && form.isSubmit == 1" type="info" icon="Calendar"
  20. @click="handleViewRecords">历史记录</el-button>
  21. <div class="close-btn" @click="cancel">
  22. <i class="fa fa-times" aria-hidden="true" />
  23. <!-- <span>关闭</span> -->
  24. </div>
  25. </div>
  26. <el-form ref="formRef" class="master-container" :model="form" v-loading="loading" :rules="rules"
  27. label-width="120px">
  28. <el-row :gutter="20">
  29. <el-col :span="6">
  30. <el-form-item label="单据号" prop="formCode">
  31. <el-input v-if="editStatus" v-model="form.formCode" disabled placeholder="系统自动生成" />
  32. <span v-else>{{ form.formCode }}</span>
  33. </el-form-item>
  34. </el-col>
  35. <el-col :span="6">
  36. <el-form-item label="表单日期" prop="formDate">
  37. <el-date-picker v-if="editStatus && hasReturnReceiptDetailFlag" clearable v-model="form.formDate"
  38. type="date" value-format="YYYY-MM-DD" placeholder="请选择表单日期" style="width: 100%">
  39. </el-date-picker>
  40. <span v-else>{{ parseTime(form.formDate, "{y}-{m}-{d}") }}</span>
  41. </el-form-item>
  42. </el-col>
  43. <el-col :span="6">
  44. <el-form-item label="外协商名称" prop="supplierName">
  45. <el-input v-if="editStatus && form.isSubmit == 0 && hasReturnReceiptDetailFlag"
  46. v-model="form.supplierName" readonly placeholder="请输入外协商名称">
  47. <template #append>
  48. <el-button icon="Search" @click="handleShowDialogSuppliers" />
  49. </template>
  50. </el-input>
  51. <span v-else>{{ form.supplierName }}</span>
  52. </el-form-item>
  53. </el-col>
  54. <el-col :span="6" v-if="false">
  55. <el-form-item label="运费单价" prop="freightPrice">
  56. <el-input-number v-if="editStatus && hasReturnReceiptDetailFlag" v-model="form.freightPrice" :min="0"
  57. :precision="2" controls-position="right" />
  58. <span v-else>{{ form.freightPrice }}</span>
  59. </el-form-item>
  60. </el-col>
  61. <el-col :span="6" v-if="false">
  62. <el-form-item label="运费总价" prop="freightAmount">
  63. <el-input-number v-if="editStatus && hasReturnReceiptDetailFlag" v-model="form.freightAmount" :min="0"
  64. :precision="2" controls-position="right" />
  65. <span v-else>{{ form.freightAmount }}</span>
  66. </el-form-item>
  67. </el-col>
  68. <el-col :span="6">
  69. <el-form-item label="送货方式" prop="deliveryMethod">
  70. <el-select v-if="editStatus && hasReturnReceiptDetailFlag" v-model="form.deliveryMethod" placeholder="请选择"
  71. @change="handleChangeDeliveryMethod">
  72. <el-option v-for=" dict in deliveryMethod " :key="dict.value" :label="dict.label"
  73. :value="dict.value" />
  74. </el-select>
  75. <span v-else>{{ selectText(form.deliveryMethod, deliveryMethod) }}</span>
  76. </el-form-item>
  77. </el-col>
  78. <el-col :span="6">
  79. <el-form-item label="带箱方式" prop="packagingMethod">
  80. <el-select v-if="editStatus && hasReturnReceiptDetailFlag" v-model="form.packagingMethod"
  81. placeholder="请选择" @change="handleChangePackagingMethod">
  82. <el-option v-for=" dict in packagingMethod " :key="dict.value" :label="dict.label"
  83. :value="dict.value" />
  84. </el-select>
  85. <span v-else>{{ selectText(form.packagingMethod, packagingMethod) }}</span>
  86. </el-form-item>
  87. </el-col>
  88. <el-col :span="6">
  89. <el-form-item label="结算方式" prop="settlementType">
  90. <el-select v-if="editStatus && hasReturnReceiptDetailFlag" v-model="form.settlementType"
  91. placeholder="请选择">
  92. <el-option v-for=" dict in settlementType " :key="dict.value" :label="dict.label"
  93. :value="dict.value" />
  94. </el-select>
  95. <span v-else>{{ selectText(form.settlementType, settlementType) }}</span>
  96. </el-form-item>
  97. </el-col>
  98. <el-col :span="6">
  99. <el-form-item label="备注" prop="remark">
  100. <el-input v-if="editStatus" v-model.trim="form.remark" placeholder="请输入备注" />
  101. <span v-else>{{ form.remark }}</span>
  102. </el-form-item>
  103. </el-col>
  104. <el-col :span="6">
  105. <el-form-item label="总箱数" prop="remark">
  106. <span>{{ totalCarriersNum }}</span>
  107. </el-form-item>
  108. </el-col>
  109. </el-row>
  110. </el-form>
  111. <!-- 渲染数据区 -->
  112. <div class="form-details-btns-container">
  113. <el-button v-show="editStatus" type="primary" icon="Plus" @click="handleShowDialogProducts"
  114. v-hasPermi="['business:outsource:add']">
  115. 添加外协产品明细
  116. </el-button>
  117. <el-button v-show="editStatus" type="primary" icon="Plus" @click="handleChoiceFurnaceNoInfo()">
  118. 批量选择炉号
  119. </el-button>
  120. </div>
  121. <div class="el-table-container">
  122. <div class="el-table-inner-container">
  123. <el-table v-loading="loading" :data="form.details" size="small" border height="100%"
  124. @selection-change="handleSelectionChange">
  125. <el-table-column type="selection" align="center" width="48" />
  126. <el-table-column label="行号" type="index" align="center" width="48" />
  127. <el-table-column label="批次号" align="center" prop="lotCode" width="104" />
  128. <el-table-column label="产品描述" align="center" prop="productDescription" width="320" />
  129. <el-table-column label="产品数" align="center" width="160" prop="productNum">
  130. </el-table-column>
  131. <el-table-column label="箱数" align="center" prop="carrierNum" width="100">
  132. <template #default="scope">
  133. <el-input-number v-if="editStatus && scope.row.hasReturnReceiptDetailFlag" :min="0"
  134. v-model="scope.row.carrierNum" :controls="false" placeholder="箱数" @blur="handleCarrierNumChange" />
  135. <span v-else>{{ scope.row.carrierNum }}</span>
  136. </template>
  137. </el-table-column>
  138. <el-table-column label="炉号" align="center" prop="" width="150">
  139. <template #default="scope">
  140. <el-button link type="primary" icon="Refresh" v-if="editStatus"
  141. @click="handleChoiceFurnaceNoInfo(scope.row)">
  142. {{ scope.row.furnaceNoInfo != null ? scope.row.furnaceNoInfo.furnaceNumber : '选择炉号' }}
  143. </el-button>
  144. <span v-else>{{ scope.row.furnaceNoInfo.furnaceNumber }}</span>
  145. </template>
  146. </el-table-column>
  147. <el-table-column label="外协工序" align="center" prop="processNames" width="320">
  148. <template #default="scope">
  149. <el-input v-if="editStatus && scope.row.hasReturnReceiptDetailFlag" v-model="scope.row.processNames"
  150. readonly placeholder="请选择工序">
  151. <template #append>
  152. <el-button icon="Search" @click="handleShowDialogProcesses(scope.row)" />
  153. </template>
  154. </el-input>
  155. <span v-else>{{ scope.row.processNames }}</span>
  156. </template>
  157. </el-table-column>
  158. <el-table-column label="备注" align="center" prop="remark">
  159. <template #default="scope">
  160. <el-input v-if="editStatus && scope.row.hasReturnReceiptDetailFlag" v-model="scope.row.remark"
  161. placeholder="备注" />
  162. <span v-else>{{ scope.row.remark }}</span>
  163. </template>
  164. </el-table-column>
  165. <el-table-column v-if="editStatus" label="操作" align="center" class-name="small-padding fixed-width"
  166. width="64">
  167. <template #default="scope">
  168. <el-button circle type="danger" v-if="scope.row.hasReturnReceiptDetailFlag" icon="Delete"
  169. @click="handleDelete(scope.$index)" v-hasPermi="['business:outsource:remove']" />
  170. </template>
  171. </el-table-column>
  172. </el-table>
  173. </div>
  174. </div>
  175. </div>
  176. <!-- 外协商选择 -->
  177. <dialog-suppliers ref="dialogSuppliersRef" :single-selected="handleSingleSelectedSupplier" />
  178. <!-- 投产单选择 -->
  179. <dialog-products ref="dialogProductsRef" :supplier-id="form.supplierId"
  180. :multiple-selected="handleMultipleSelectedProducts" />
  181. <!-- 工序选择 -->
  182. <dialog-processes ref="dialogProcessesRef" :multiple-selected="handleMultipleSelectedProcesses" />
  183. <!-- 新箱号选择 -->
  184. <DialogFurnaceNoInfo ref="dialogFurnaceNoInfoRef" :singleSelected="handleSingleSelectFurnaceNoInfo" />
  185. <!-- 历史记录弹窗 -->
  186. <dialog-outsourced-records ref="dialogOutsourcedRecordsRef" />
  187. <!-- 收回明细带回 -->
  188. <!-- <form-details-recycling ref="formDetailsRecyclingRef" :singleSelected="handleSingleSelectedRecycling"/> -->
  189. </el-drawer>
  190. </template>
  191. <script setup>
  192. import {
  193. getOrder,
  194. getFirstOrder,
  195. saveOrder,
  196. carrierForOutsource,
  197. submitOrder,
  198. exportOutsource,
  199. printOutsource,
  200. submitDetails,
  201. submitDetailsOnFirst,
  202. getLotByProductionPlanSub
  203. } from "@/api/business/outsourcedOrder";
  204. import DialogFurnaceNoInfo from "./DialogFurnaceNoInfo";
  205. import dialogSuppliers from "./DialogSuppliers";
  206. import dialogProducts from "./DialogProducts";
  207. import dialogProcesses from "./DialogProcesses";
  208. import dialogOutsourcedRecords from "./DialogOutsourcedRecords"
  209. // import FormDetailsRecycling from "./detailsRecyclingForm";
  210. const { proxy } = getCurrentInstance();
  211. /** 父组件传参 */
  212. const props = defineProps({
  213. getList: {
  214. type: Function,
  215. default: () => { },
  216. },
  217. deliveryMethod: {
  218. type: Array,
  219. default: [],
  220. },
  221. settlementType: {
  222. type: Array,
  223. default: [],
  224. },
  225. packagingMethod: {
  226. type: Array,
  227. default: [],
  228. },
  229. });
  230. const { getList, deliveryMethod, packagingMethod, settlementType } =
  231. toRefs(props);
  232. /** 字典数组区 */
  233. /** 表单抽屉 页变量 */
  234. const loading = ref(false);
  235. const multiple = ref(true);
  236. const visible = ref(false);
  237. const editStatus = ref(true);
  238. const hasReturnReceiptDetailFlag = ref(true);
  239. const totalCarriersNum = ref(0);
  240. const detailInfo = ref({});
  241. const loadingCarrier = ref(false);
  242. const carriers = ref([]);
  243. const webHost = import.meta.env.VITE_APP_BASE_API;
  244. const form = ref({});
  245. const selections = ref([])
  246. // const formatDetails = ref([])
  247. const currentDetail = ref({});
  248. const dialogFurnaceNoInfoRef = ref(null)
  249. const rules = {
  250. supplierName: [
  251. { required: true, message: "外协商名称不能为空", trigger: "change" },
  252. ],
  253. };
  254. /*********************** 方法区 ****************************/
  255. /** 导出按钮操作 */
  256. function handleExport() {
  257. exportOutsource({ id: form.value.id });
  258. }
  259. /** 打印按钮操作 */
  260. function handlePrint() {
  261. printOutsource({ id: form.value.id });
  262. }
  263. /** 打开抽屉 */
  264. function open(row) {
  265. reset();
  266. totalCarriersNum.value = 0
  267. visible.value = true;
  268. if (row) {
  269. console.log(row)
  270. detailInfo.value = row
  271. form.value.id = row.id;
  272. getForm();
  273. } else {
  274. editStatus.value = true;
  275. hasReturnReceiptDetailFlag.value = true
  276. }
  277. }
  278. /** 查询表单信息 */
  279. function getForm() {
  280. loading.value = true;
  281. getFirstOrder(form.value.id).then((response) => {
  282. form.value = response.data;
  283. //如果发出单明细里收回单,主表除了备注之外不能编辑
  284. form.value.details.forEach((item) => {
  285. item.hasReturnReceiptDetailFlag = true
  286. if (item.returnReceiptDetailList && item.returnReceiptDetailList.length > 0) {
  287. hasReturnReceiptDetailFlag.value = false
  288. }
  289. if (item.returnReceiptDetailList && item.returnReceiptDetailList.length > 0 && item.returnReceiptDetailList[0].status == 1) {
  290. item.hasReturnReceiptDetailFlag = false
  291. }
  292. });
  293. form.value.details.forEach((item) => {
  294. item.editStatus = false;
  295. totalCarriersNum.value += item.carrierNum == null ? 0 : item.carrierNum;
  296. });
  297. editStatus.value = form.value.isSubmit == 1;
  298. if (!detailInfo.value.flag) {
  299. editStatus.value = false
  300. console.log(editStatus.value)
  301. }
  302. console.log(hasReturnReceiptDetailFlag.value)
  303. loading.value = false;
  304. });
  305. }
  306. //改变带箱方式
  307. function handleChangePackagingMethod() {
  308. totalCarriersNum.value = 0
  309. if (!editStatus) {
  310. if (form.value.packagingMethod == 1 && form.value.details.length > 0) {
  311. form.value.details.forEach(item => { item.newCarriers = []; item.carrierIds = []; item.carriers = carriers.value })
  312. } if (form.value.packagingMethod == 0 && form.value.details.length > 0) {
  313. form.value.details.forEach(item => {
  314. item.carriers = carriers.value;
  315. item.newCarriers = [];
  316. item.carrierIds = [];
  317. item.newCarriers.push(...item.originalCarrierList.map(v => ({ id: v.carrierId, code: v.carrierCode })));
  318. item.carriers.push(...item.originalCarrierList.map((v) => ({ value: v.carrierId, label: v.carrierCode })));
  319. item.carrierIds = item.originalCarrierList.map(info => { return info.carrierId })
  320. })
  321. }
  322. } else {
  323. form.value.details.forEach(item => {
  324. console.log(item.editStatus)
  325. if (item.editStatus) {
  326. item.newCarriers = []; item.carrierIds = []; item.carriers = carriers.value
  327. }
  328. })
  329. }
  330. console.log(form.value.details)
  331. for (let i = 0; i < form.value.details.length; i++) {
  332. console.log(form.value.details)
  333. totalCarriersNum.value += form.value.details[i].carrierNum == null ? 0 : form.value.details[i].carrierNum
  334. }
  335. }
  336. //改变送货方式
  337. function handleChangeDeliveryMethod() {
  338. if (form.value.deliveryMethod == 1) {
  339. form.value.freightAmount = form.value.freightPrice * totalCarriersNum.value;
  340. } else {
  341. form.value.freightAmount = 0.0;
  342. }
  343. }
  344. //打开历史记录弹窗
  345. function handleViewRecords() {
  346. proxy.$refs.dialogOutsourcedRecordsRef.open(form.value.id);
  347. }
  348. function selectText(value, data) {
  349. if (value) {
  350. return data.filter((item) => item.value == value)[0].label;
  351. }
  352. }
  353. /** 取消按钮 */
  354. function cancel() {
  355. visible.value = false;
  356. // reset();
  357. }
  358. const handleDelete = (index) => {
  359. totalCarriersNum.value -= (form.value.details[index].carrierNum == null ? 0 : form.value.details[index].carrierNum);
  360. if (form.value.deliveryMethod == 1) {
  361. form.value.freightAmount = form.value.freightPrice * totalCarriersNum.value;
  362. } else {
  363. form.value.freightAmount = 0.0;
  364. }
  365. form.value.details.splice(index, 1);
  366. };
  367. /** 表单重置 */
  368. function reset() {
  369. // console.log(proxy.parseTime(new Date(), "{y}-{m}-{d}"))
  370. form.value = {
  371. id: null,
  372. tenantId: null,
  373. formCode: null,
  374. formDate: proxy.parseTime(new Date(), "{y}-{m}-{d}"),
  375. supplierId: "0",
  376. supplierName: "",
  377. deliveryMethod: "0",
  378. freightPrice: 0.0,
  379. freightAmount: 0.0,
  380. packagingMethod: "0",
  381. remark: null,
  382. details: [],
  383. isSubmit: 0,
  384. isFirstProcess: 1
  385. };
  386. proxy.resetForm("formRef");
  387. }
  388. /** 保存 */
  389. function saveFrom() {
  390. if (!form.value.details || form.value.details.length == 0) {
  391. proxy.$modal.msgError("请添加产品明细");
  392. return;
  393. }
  394. proxy.$refs["formRef"].validate((valid) => {
  395. for (const item of form.value.details) {
  396. if (!item.processNames) {
  397. proxy.$modal.msgError("请选择" + item.lotCode + "批次的工序");
  398. return;
  399. }
  400. }
  401. if (form.value.packagingMethod == 1) {
  402. console.log("form.value.details", form.value.details);
  403. for (const item of form.value.details) {
  404. if (item.newCarriers.length == 0) {
  405. proxy.$modal.msgError("请选择" + item.lotCode + "批次的新箱号");
  406. return;
  407. }
  408. }
  409. }
  410. if (valid) {
  411. saveOrder(form.value).then((response) => {
  412. if (response.code == 200) {
  413. proxy.$modal.msgSuccess("保存成功");
  414. visible.value = false;
  415. getList.value();
  416. }
  417. });
  418. }
  419. });
  420. }
  421. /** 保存并提交 */
  422. function submitFrom() {
  423. console.log("from", form.value);
  424. proxy.$modal
  425. .confirm("是否确定提交,提交后不可修改,删除")
  426. .then(function () {
  427. return;
  428. })
  429. .then(() => {
  430. if (!form.value.details || form.value.details.length == 0) {
  431. proxy.$modal.msgError("请添加产品明细");
  432. return;
  433. }
  434. proxy.$refs["formRef"].validate((valid) => {
  435. for (const item of form.value.details) {
  436. if (!item.processNames) {
  437. proxy.$modal.msgError("请选择" + item.lotCode + "批次的工序");
  438. return;
  439. }
  440. }
  441. if (form.value.packagingMethod == 1) {
  442. console.log("form.value.details", form.value.details);
  443. for (const item of form.value.details) {
  444. if (item.newCarriers.length == 0) {
  445. proxy.$modal.msgError("请选择" + item.lotCode + "批次的新箱号");
  446. return;
  447. }
  448. }
  449. }
  450. if (valid) {
  451. console.log(form.value);
  452. submitOrder(form.value).then((response) => {
  453. proxy.$modal.msgSuccess("提交成功");
  454. visible.value = false;
  455. getList.value();
  456. });
  457. }
  458. });
  459. })
  460. .catch(() => { });
  461. }
  462. //5.29保存
  463. function handleSubmit() {
  464. if (form.value.isSubmit == 0) {
  465. proxy.$modal
  466. .confirm("是否确定保存,保存后外协商不可编辑!")
  467. .then(function () {
  468. return;
  469. })
  470. .then(() => {
  471. if (!form.value.details || form.value.details.length == 0) {
  472. proxy.$modal.msgError("请添加产品明细");
  473. return;
  474. }
  475. proxy.$refs["formRef"].validate((valid) => {
  476. for (const item of form.value.details) {
  477. if (!item.processNames) {
  478. proxy.$modal.msgError("请选择" + item.lotCode + "批次的工序");
  479. return;
  480. }
  481. }
  482. // 判断是否有批次没有炉号
  483. const unfurnace = form.value.details.find(v => v.furnaceNoInfo == null)
  484. if (unfurnace != null) {
  485. proxy.$modal.msgError("请选择" + unfurnace.lotCode + "批次的炉号")
  486. }
  487. if (valid) {
  488. console.log(form.value)
  489. submitDetailsOnFirst(form.value).then((response) => {
  490. proxy.$modal.msgSuccess("提交成功");
  491. visible.value = false;
  492. getList.value();
  493. });
  494. }
  495. });
  496. })
  497. } else {
  498. if (!form.value.details || form.value.details.length == 0) {
  499. proxy.$modal.msgError("请添加产品明细");
  500. return;
  501. }
  502. proxy.$refs["formRef"].validate((valid) => {
  503. for (const item of form.value.details) {
  504. if (!item.processNames) {
  505. proxy.$modal.msgError("请选择" + item.lotCode + "批次的工序");
  506. return;
  507. }
  508. }
  509. if (form.value.packagingMethod == 1) {
  510. console.log("form.value.details", form.value.details);
  511. for (const item of form.value.details) {
  512. if (item.newCarriers.length == 0) {
  513. proxy.$modal.msgError("请选择" + item.lotCode + "批次的新箱号");
  514. return;
  515. }
  516. }
  517. }
  518. if (valid) {
  519. console.log(form.value)
  520. submitDetailsOnFirst(form.value).then((response) => {
  521. proxy.$modal.msgSuccess("提交成功");
  522. visible.value = false;
  523. getList.value();
  524. });
  525. }
  526. });
  527. }
  528. }
  529. /***************************** 外协商对话框相关 *****************************/
  530. // 打开外协商选择对话框
  531. const handleShowDialogSuppliers = () => {
  532. proxy.$refs.dialogSuppliersRef.open();
  533. };
  534. // 外协商选择带回
  535. const handleSingleSelectedSupplier = (data) => {
  536. console.log(data);
  537. form.value.supplierId = data.id;
  538. form.value.lossLimit = data.lossLimit;
  539. form.value.supplierName = data.name;
  540. form.value.deliveryMethod = data.deliveryMethod;
  541. form.value.freightPrice = data.freightPrice;
  542. form.value.settlementType = data.settlementType;
  543. if (form.value.deliveryMethod == 1) {
  544. form.value.freightAmount = form.value.freightPrice * totalCarriersNum.value;
  545. } else {
  546. form.value.freightAmount = 0.0;
  547. }
  548. };
  549. /***************************** 外协收回明细相关 *****************************/
  550. //打开收回明细表单
  551. function handleDetailsRecycling() {
  552. proxy.$refs.formDetailsRecyclingRef.open(row);
  553. }
  554. function handleSingleSelectedRecycling() { }
  555. /***************************** 产品对话框相关 *****************************/
  556. // 打开产品选择对话框
  557. const handleShowDialogProducts = () => {
  558. // const dayworkIds = form.value.details.map((item) => item.dayworkId);
  559. // console.log(dayworkIds);
  560. proxy.$refs.dialogProductsRef.open();
  561. };
  562. // 产品选择带回
  563. const handleMultipleSelectedProducts = (selection) => {
  564. // 获取所有批次信息
  565. const requestData = {
  566. planDetails: selection,
  567. supplierId: form.value.supplierId,
  568. supplierName: form.value.supplierName,
  569. masterId: form.value.id
  570. }
  571. getLotByProductionPlanSub(requestData).then(res => {
  572. // console.log(res)
  573. if (res.code === 200) {
  574. form.value.details.push(...res.data.filter(e => form.value.details.findIndex(t => t.lotId === e.lotId) < 0).map(e => ({ ...e, hasReturnReceiptDetailFlag: true })))
  575. }
  576. })
  577. };
  578. /***************************** 外协工序对话框相关 *****************************/
  579. // 打开外协工序选择对话框
  580. const handleShowDialogProcesses = (row) => {
  581. currentDetail.value = row;
  582. proxy.$refs.dialogProcessesRef.open(row);
  583. };
  584. // 工序选择带回
  585. const handleMultipleSelectedProcesses = (selection) => {
  586. currentDetail.value.processes = []
  587. console.log(selection);
  588. const processNames = selection.sort((a, b) => a.processStepNumber - b.processStepNumber).map((item) => item.processAlias);
  589. // 使用join方法将数组转换为以逗号分隔的字符串
  590. let commaSeparatedString = processNames.join(",");
  591. currentDetail.value.processes = [];
  592. currentDetail.value.processNames = commaSeparatedString;
  593. selection.forEach((item) => {
  594. const newProcess = {
  595. processId: item.processId,
  596. processCode: item.processCode,
  597. processAlias: item.processAlias,
  598. processStepNumber: item.processStepNumber,
  599. technologicalProcessDetailId: item.id,
  600. };
  601. currentDetail.value.processes.push(newProcess);
  602. });
  603. };
  604. function handleSelectionChange(selection) {
  605. selections.value = selection
  606. }
  607. // 选择炉号
  608. const handleChoiceFurnaceNoInfo = (row) => {
  609. // 判断选择的产品是不是同一个
  610. const changeFurnaceNoInfo = row ? [row] : selections.value;
  611. let checkSame = true
  612. changeFurnaceNoInfo.forEach(l => {
  613. checkSame = checkSame && l.productId == changeFurnaceNoInfo[0].productId
  614. })
  615. console.log(checkSame)
  616. if (!checkSame) {
  617. proxy.$modal.msgError('请选择相同计划单批量选择炉号')
  618. return
  619. }
  620. if (changeFurnaceNoInfo.length === 0) {
  621. proxy.$modal.msgError('请选择需要变更炉号的计划单')
  622. return
  623. }
  624. dialogFurnaceNoInfoRef.value.open({ details: changeFurnaceNoInfo, queryParams: { ...changeFurnaceNoInfo[0] } })
  625. }
  626. const handleSingleSelectFurnaceNoInfo = (details, info) => {
  627. details.forEach(l => {
  628. l.furnaceNoInfo = info
  629. })
  630. }
  631. function handleCarrierNumChange() {
  632. let sumNum = 0
  633. form.value.details.forEach(v => {
  634. sumNum += (v.carrierNum == null ? 0 : v.carrierNum)
  635. })
  636. totalCarriersNum.value = sumNum
  637. }
  638. /** 暴露给父组件的方法 */
  639. defineExpose({
  640. open,
  641. });
  642. </script>