form.vue 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668
  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.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. saveOrder,
  195. carrierForOutsource,
  196. submitOrder,
  197. exportOutsource,
  198. printOutsource,
  199. submitDetails,
  200. submitDetailsOnFirst,
  201. getLotByProductionPlanSub
  202. } from "@/api/business/outsourcedOrder";
  203. import DialogFurnaceNoInfo from "./DialogFurnaceNoInfo";
  204. import dialogSuppliers from "./DialogSuppliers";
  205. import dialogProducts from "./DialogProducts";
  206. import dialogProcesses from "./DialogProcesses";
  207. import dialogOutsourcedRecords from "./DialogOutsourcedRecords"
  208. // import FormDetailsRecycling from "./detailsRecyclingForm";
  209. const { proxy } = getCurrentInstance();
  210. /** 父组件传参 */
  211. const props = defineProps({
  212. getList: {
  213. type: Function,
  214. default: () => { },
  215. },
  216. deliveryMethod: {
  217. type: Array,
  218. default: [],
  219. },
  220. settlementType: {
  221. type: Array,
  222. default: [],
  223. },
  224. packagingMethod: {
  225. type: Array,
  226. default: [],
  227. },
  228. });
  229. const { getList, deliveryMethod, packagingMethod, settlementType } =
  230. toRefs(props);
  231. /** 字典数组区 */
  232. /** 表单抽屉 页变量 */
  233. const loading = ref(false);
  234. const multiple = ref(true);
  235. const visible = ref(false);
  236. const editStatus = ref(true);
  237. const hasReturnReceiptDetailFlag = ref(true);
  238. const totalCarriersNum = ref(0);
  239. const detailInfo = ref({});
  240. const loadingCarrier = ref(false);
  241. const carriers = ref([]);
  242. const webHost = import.meta.env.VITE_APP_BASE_API;
  243. const form = ref({});
  244. const selections = ref([])
  245. // const formatDetails = ref([])
  246. const currentDetail = ref({});
  247. const dialogFurnaceNoInfoRef = ref(null)
  248. const rules = {
  249. supplierName: [
  250. { required: true, message: "外协商名称不能为空", trigger: "change" },
  251. ],
  252. };
  253. /*********************** 方法区 ****************************/
  254. /** 导出按钮操作 */
  255. function handleExport() {
  256. exportOutsource({ id: form.value.id });
  257. }
  258. /** 打印按钮操作 */
  259. function handlePrint() {
  260. printOutsource({ id: form.value.id });
  261. }
  262. /** 打开抽屉 */
  263. function open(row) {
  264. reset();
  265. totalCarriersNum.value = 0
  266. visible.value = true;
  267. if (row) {
  268. console.log(row)
  269. detailInfo.value = row
  270. form.value.id = row.id;
  271. getForm();
  272. } else {
  273. editStatus.value = true;
  274. hasReturnReceiptDetailFlag.value = true
  275. }
  276. }
  277. /** 查询表单信息 */
  278. function getForm() {
  279. loading.value = true;
  280. getOrder(form.value.id).then((response) => {
  281. form.value = response.data;
  282. //如果发出单明细里收回单,主表除了备注之外不能编辑
  283. form.value.details.forEach((item) => {
  284. item.hasReturnReceiptDetailFlag = true
  285. if (item.returnReceiptDetailList && item.returnReceiptDetailList.length > 0) {
  286. hasReturnReceiptDetailFlag.value = false
  287. }
  288. if (item.returnReceiptDetailList && item.returnReceiptDetailList.length > 0 && item.returnReceiptDetailList[0].status == 1) {
  289. item.hasReturnReceiptDetailFlag = false
  290. }
  291. });
  292. form.value.details.forEach((item) => {
  293. item.editStatus = false;
  294. totalCarriersNum.value += item.carrierNum == null ? 0 : item.carrierNum;
  295. });
  296. editStatus.value = form.value.isSubmit == 1;
  297. if (!detailInfo.value.flag) {
  298. editStatus.value = false
  299. console.log(editStatus.value)
  300. }
  301. console.log(hasReturnReceiptDetailFlag.value)
  302. loading.value = false;
  303. });
  304. }
  305. //改变带箱方式
  306. function handleChangePackagingMethod() {
  307. totalCarriersNum.value = 0
  308. if (!editStatus) {
  309. if (form.value.packagingMethod == 1 && form.value.details.length > 0) {
  310. form.value.details.forEach(item => { item.newCarriers = []; item.carrierIds = []; item.carriers = carriers.value })
  311. } if (form.value.packagingMethod == 0 && form.value.details.length > 0) {
  312. form.value.details.forEach(item => {
  313. item.carriers = carriers.value;
  314. item.newCarriers = [];
  315. item.carrierIds = [];
  316. item.newCarriers.push(...item.originalCarrierList.map(v => ({ id: v.carrierId, code: v.carrierCode })));
  317. item.carriers.push(...item.originalCarrierList.map((v) => ({ value: v.carrierId, label: v.carrierCode })));
  318. item.carrierIds = item.originalCarrierList.map(info => { return info.carrierId })
  319. })
  320. }
  321. } else {
  322. form.value.details.forEach(item => {
  323. console.log(item.editStatus)
  324. if (item.editStatus) {
  325. item.newCarriers = []; item.carrierIds = []; item.carriers = carriers.value
  326. }
  327. })
  328. }
  329. console.log(form.value.details)
  330. for (let i = 0; i < form.value.details.length; i++) {
  331. console.log(form.value.details)
  332. totalCarriersNum.value += form.value.details[i].carrierNum == null ? 0 : form.value.details[i].carrierNum
  333. }
  334. }
  335. //改变送货方式
  336. function handleChangeDeliveryMethod() {
  337. if (form.value.deliveryMethod == 1) {
  338. form.value.freightAmount = form.value.freightPrice * totalCarriersNum.value;
  339. } else {
  340. form.value.freightAmount = 0.0;
  341. }
  342. }
  343. //打开历史记录弹窗
  344. function handleViewRecords() {
  345. proxy.$refs.dialogOutsourcedRecordsRef.open(form.value.id);
  346. }
  347. function selectText(value, data) {
  348. if (value) {
  349. return data.filter((item) => item.value == value)[0].label;
  350. }
  351. }
  352. /** 取消按钮 */
  353. function cancel() {
  354. visible.value = false;
  355. // reset();
  356. }
  357. const handleDelete = (index) => {
  358. totalCarriersNum.value -= (form.value.details[index].carrierNum == null ? 0 : form.value.details[index].carrierNum);
  359. if (form.value.deliveryMethod == 1) {
  360. form.value.freightAmount = form.value.freightPrice * totalCarriersNum.value;
  361. } else {
  362. form.value.freightAmount = 0.0;
  363. }
  364. form.value.details.splice(index, 1);
  365. };
  366. /** 表单重置 */
  367. function reset() {
  368. // console.log(proxy.parseTime(new Date(), "{y}-{m}-{d}"))
  369. form.value = {
  370. id: null,
  371. tenantId: null,
  372. formCode: null,
  373. formDate: proxy.parseTime(new Date(), "{y}-{m}-{d}"),
  374. supplierId: "0",
  375. supplierName: "",
  376. deliveryMethod: "0",
  377. freightPrice: 0.0,
  378. freightAmount: 0.0,
  379. packagingMethod: "0",
  380. remark: null,
  381. details: [],
  382. isSubmit: 0,
  383. isFirstProcess: 1
  384. };
  385. proxy.resetForm("formRef");
  386. }
  387. /** 保存 */
  388. function saveFrom() {
  389. if (!form.value.details || form.value.details.length == 0) {
  390. proxy.$modal.msgError("请添加产品明细");
  391. return;
  392. }
  393. proxy.$refs["formRef"].validate((valid) => {
  394. for (const item of form.value.details) {
  395. if (!item.processNames) {
  396. proxy.$modal.msgError("请选择" + item.lotCode + "批次的工序");
  397. return;
  398. }
  399. }
  400. if (form.value.packagingMethod == 1) {
  401. console.log("form.value.details", form.value.details);
  402. for (const item of form.value.details) {
  403. if (item.newCarriers.length == 0) {
  404. proxy.$modal.msgError("请选择" + item.lotCode + "批次的新箱号");
  405. return;
  406. }
  407. }
  408. }
  409. if (valid) {
  410. saveOrder(form.value).then((response) => {
  411. if (response.code == 200) {
  412. proxy.$modal.msgSuccess("保存成功");
  413. visible.value = false;
  414. getList.value();
  415. }
  416. });
  417. }
  418. });
  419. }
  420. /** 保存并提交 */
  421. function submitFrom() {
  422. console.log("from", form.value);
  423. proxy.$modal
  424. .confirm("是否确定提交,提交后不可修改,删除")
  425. .then(function () {
  426. return;
  427. })
  428. .then(() => {
  429. if (!form.value.details || form.value.details.length == 0) {
  430. proxy.$modal.msgError("请添加产品明细");
  431. return;
  432. }
  433. proxy.$refs["formRef"].validate((valid) => {
  434. for (const item of form.value.details) {
  435. if (!item.processNames) {
  436. proxy.$modal.msgError("请选择" + item.lotCode + "批次的工序");
  437. return;
  438. }
  439. }
  440. if (form.value.packagingMethod == 1) {
  441. console.log("form.value.details", form.value.details);
  442. for (const item of form.value.details) {
  443. if (item.newCarriers.length == 0) {
  444. proxy.$modal.msgError("请选择" + item.lotCode + "批次的新箱号");
  445. return;
  446. }
  447. }
  448. }
  449. if (valid) {
  450. console.log(form.value);
  451. submitOrder(form.value).then((response) => {
  452. proxy.$modal.msgSuccess("提交成功");
  453. visible.value = false;
  454. getList.value();
  455. });
  456. }
  457. });
  458. })
  459. .catch(() => { });
  460. }
  461. //5.29保存
  462. function handleSubmit() {
  463. if (form.value.isSubmit == 0) {
  464. proxy.$modal
  465. .confirm("是否确定保存,保存后外协商不可编辑!")
  466. .then(function () {
  467. return;
  468. })
  469. .then(() => {
  470. if (!form.value.details || form.value.details.length == 0) {
  471. proxy.$modal.msgError("请添加产品明细");
  472. return;
  473. }
  474. proxy.$refs["formRef"].validate((valid) => {
  475. for (const item of form.value.details) {
  476. if (!item.processNames) {
  477. proxy.$modal.msgError("请选择" + item.lotCode + "批次的工序");
  478. return;
  479. }
  480. }
  481. // 判断是否有批次没有炉号
  482. const unfurnace = form.value.details.find(v => v.furnaceNoInfo == null)
  483. if (unfurnace != null) {
  484. proxy.$modal.msgError("请选择" + unfurnace.lotCode + "批次的炉号")
  485. }
  486. if (valid) {
  487. console.log(form.value)
  488. submitDetailsOnFirst(form.value).then((response) => {
  489. proxy.$modal.msgSuccess("提交成功");
  490. visible.value = false;
  491. getList.value();
  492. });
  493. }
  494. });
  495. })
  496. } else {
  497. if (!form.value.details || form.value.details.length == 0) {
  498. proxy.$modal.msgError("请添加产品明细");
  499. return;
  500. }
  501. proxy.$refs["formRef"].validate((valid) => {
  502. for (const item of form.value.details) {
  503. if (!item.processNames) {
  504. proxy.$modal.msgError("请选择" + item.lotCode + "批次的工序");
  505. return;
  506. }
  507. }
  508. if (form.value.packagingMethod == 1) {
  509. console.log("form.value.details", form.value.details);
  510. for (const item of form.value.details) {
  511. if (item.newCarriers.length == 0) {
  512. proxy.$modal.msgError("请选择" + item.lotCode + "批次的新箱号");
  513. return;
  514. }
  515. }
  516. }
  517. if (valid) {
  518. console.log(form.value)
  519. submitDetailsOnFirst(form.value).then((response) => {
  520. proxy.$modal.msgSuccess("提交成功");
  521. visible.value = false;
  522. getList.value();
  523. });
  524. }
  525. });
  526. }
  527. }
  528. /***************************** 外协商对话框相关 *****************************/
  529. // 打开外协商选择对话框
  530. const handleShowDialogSuppliers = () => {
  531. proxy.$refs.dialogSuppliersRef.open();
  532. };
  533. // 外协商选择带回
  534. const handleSingleSelectedSupplier = (data) => {
  535. console.log(data);
  536. form.value.supplierId = data.id;
  537. form.value.lossLimit = data.lossLimit;
  538. form.value.supplierName = data.name;
  539. form.value.deliveryMethod = data.deliveryMethod;
  540. form.value.freightPrice = data.freightPrice;
  541. form.value.settlementType = data.settlementType;
  542. if (form.value.deliveryMethod == 1) {
  543. form.value.freightAmount = form.value.freightPrice * totalCarriersNum.value;
  544. } else {
  545. form.value.freightAmount = 0.0;
  546. }
  547. };
  548. /***************************** 外协收回明细相关 *****************************/
  549. //打开收回明细表单
  550. function handleDetailsRecycling() {
  551. proxy.$refs.formDetailsRecyclingRef.open(row);
  552. }
  553. function handleSingleSelectedRecycling() { }
  554. /***************************** 产品对话框相关 *****************************/
  555. // 打开产品选择对话框
  556. const handleShowDialogProducts = () => {
  557. // const dayworkIds = form.value.details.map((item) => item.dayworkId);
  558. // console.log(dayworkIds);
  559. proxy.$refs.dialogProductsRef.open();
  560. };
  561. // 产品选择带回
  562. const handleMultipleSelectedProducts = (selection) => {
  563. // 获取所有批次信息
  564. const requestData = {
  565. planDetails: selection,
  566. supplierId: form.value.supplierId,
  567. supplierName: form.value.supplierName,
  568. masterId: form.value.id
  569. }
  570. getLotByProductionPlanSub(requestData).then(res => {
  571. // console.log(res)
  572. if (res.code === 200) {
  573. form.value.details.push(...res.data.filter(e => form.value.details.findIndex(t => t.lotId === e.lotId) < 0).map(e => ({ ...e, hasReturnReceiptDetailFlag: true })))
  574. }
  575. })
  576. };
  577. /***************************** 外协工序对话框相关 *****************************/
  578. // 打开外协工序选择对话框
  579. const handleShowDialogProcesses = (row) => {
  580. currentDetail.value = row;
  581. proxy.$refs.dialogProcessesRef.open(row);
  582. };
  583. // 工序选择带回
  584. const handleMultipleSelectedProcesses = (selection) => {
  585. currentDetail.value.processes = []
  586. console.log(selection);
  587. const processNames = selection.sort((a, b) => a.processStepNumber - b.processStepNumber).map((item) => item.processAlias);
  588. // 使用join方法将数组转换为以逗号分隔的字符串
  589. let commaSeparatedString = processNames.join(",");
  590. currentDetail.value.processes = [];
  591. currentDetail.value.processNames = commaSeparatedString;
  592. selection.forEach((item) => {
  593. const newProcess = {
  594. processId: item.processId,
  595. processCode: item.processCode,
  596. processAlias: item.processAlias,
  597. processStepNumber: item.processStepNumber,
  598. technologicalProcessDetailId: item.id,
  599. };
  600. currentDetail.value.processes.push(newProcess);
  601. });
  602. };
  603. function handleSelectionChange(selection) {
  604. selections.value = selection
  605. }
  606. // 选择炉号
  607. const handleChoiceFurnaceNoInfo = (row) => {
  608. // 判断选择的产品是不是同一个
  609. const changeFurnaceNoInfo = row ? [row] : selections.value;
  610. let checkSame = true
  611. changeFurnaceNoInfo.forEach(l => {
  612. checkSame = checkSame && l.productId == changeFurnaceNoInfo[0].productId
  613. })
  614. console.log(checkSame)
  615. if (!checkSame) {
  616. proxy.$modal.msgError('请选择相同计划单批量选择炉号')
  617. return
  618. }
  619. if (changeFurnaceNoInfo.length === 0) {
  620. proxy.$modal.msgError('请选择需要变更炉号的计划单')
  621. return
  622. }
  623. dialogFurnaceNoInfoRef.value.open({ details: changeFurnaceNoInfo, queryParams: { ...changeFurnaceNoInfo[0] } })
  624. }
  625. const handleSingleSelectFurnaceNoInfo = (details, info) => {
  626. details.forEach(l => {
  627. l.furnaceNoInfo = info
  628. })
  629. }
  630. function handleCarrierNumChange() {
  631. let sumNum = 0
  632. form.value.details.forEach(v => {
  633. sumNum += (v.carrierNum == null ? 0 : v.carrierNum)
  634. })
  635. totalCarriersNum.value = sumNum
  636. }
  637. /** 暴露给父组件的方法 */
  638. defineExpose({
  639. open,
  640. });
  641. </script>