AddOrUpdate.vue 57 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687
  1. <template>
  2. <el-dialog
  3. :title="title"
  4. :visible.sync="showDialog"
  5. width="80%"
  6. @close="handleClose"
  7. :close-on-click-modal="false"
  8. >
  9. <span>
  10. <el-form ref="form" :model="form" :rules="rules" label-width="80px">
  11. <el-row>
  12. <el-col :span="6">
  13. <el-form-item label="客户名称" prop="corpId">
  14. <el-select
  15. v-model="form.corpId"
  16. placeholder="请输入客户名称"
  17. :clearable="true"
  18. filterable
  19. :disabled="disabled"
  20. size="mini"
  21. style="width: 180px"
  22. >
  23. <el-option
  24. v-for="(dict, index) in fMblnoOptions"
  25. :key="index.fId"
  26. :label="dict.fName"
  27. :value="dict.fId"
  28. />
  29. </el-select>
  30. </el-form-item>
  31. </el-col>
  32. <el-col :span="6">
  33. <el-form-item label="业务类型" prop="billType">
  34. <el-select
  35. v-model="form.billType"
  36. placeholder="请选择业务类型"
  37. :disabled="disabled"
  38. size="mini"
  39. style="width: 180px"
  40. >
  41. <el-option
  42. v-for="(dict, index) in billTypeList"
  43. :key="index.dictValue"
  44. :label="dict.dictLabel"
  45. :value="dict.dictValue"
  46. />
  47. </el-select>
  48. </el-form-item>
  49. </el-col>
  50. <el-col :span="6">
  51. <el-form-item label="运输方式" prop="transType">
  52. <el-select
  53. v-model="form.transType"
  54. placeholder="请选择运输方式"
  55. :disabled="disabled"
  56. size="mini"
  57. style="width: 180px"
  58. >
  59. <el-option
  60. v-for="(dict, index) in transTypeList"
  61. :key="index.dictValue"
  62. :label="dict.dictLabel"
  63. :value="dict.dictValue"
  64. />
  65. </el-select>
  66. </el-form-item>
  67. </el-col>
  68. <el-col :span="6">
  69. <el-form-item label="运输性质" prop="transProp">
  70. <el-select
  71. v-model="form.transProp"
  72. placeholder="请选择运输方式"
  73. :disabled="disabled"
  74. size="mini"
  75. style="width: 180px"
  76. >
  77. <el-option
  78. v-for="(dict, index) in transPropList"
  79. :key="index.dictValue"
  80. :label="dict.dictLabel"
  81. :value="dict.dictValue"
  82. />
  83. </el-select>
  84. </el-form-item>
  85. </el-col>
  86. </el-row>
  87. <el-row>
  88. <el-col :span="6">
  89. <el-form-item label="提单号" prop="mblno">
  90. <el-input
  91. v-model="form.mblno"
  92. placeholder="请输入提单号"
  93. :disabled="disabled"
  94. size="mini"
  95. style="width: 180px"
  96. @input="mbinput(form.mblno)"
  97. />
  98. </el-form-item>
  99. </el-col>
  100. <el-col :span="6">
  101. <el-form-item label="货品名称" prop="goodsId">
  102. <el-select
  103. v-model="form.goodsId"
  104. placeholder="请输入货品名称"
  105. :disabled="disabled"
  106. clearable
  107. filterable
  108. size="mini"
  109. style="width: 180px"
  110. >
  111. <el-option
  112. v-for="(dict, index) in goodsOptions"
  113. :key="index.fId"
  114. :label="dict.fName"
  115. :value="dict.fId"
  116. />
  117. </el-select>
  118. </el-form-item>
  119. </el-col>
  120. <el-col :span="6">
  121. <el-form-item label="计划件数" prop="qtyPlan">
  122. <el-input
  123. v-model="form.qtyPlan"
  124. placeholder="请输入计划件数"
  125. :disabled="disabled"
  126. v-input-limit="2"
  127. size="mini"
  128. style="width: 180px"
  129. />
  130. </el-form-item>
  131. </el-col>
  132. <el-col :span="6">
  133. <el-form-item label="重量(吨)" prop="weightPlan">
  134. <el-input
  135. v-model="form.weightPlan"
  136. placeholder="请输入计划重量"
  137. :disabled="disabled"
  138. v-input-limit="2"
  139. size="mini"
  140. style="width: 180px"
  141. />
  142. </el-form-item>
  143. </el-col>
  144. </el-row>
  145. <el-row>
  146. <el-col :span="6">
  147. <el-form-item label="船名" prop="ysl">
  148. <el-input
  149. v-model="form.ysl"
  150. placeholder="请输入船名"
  151. :disabled="disabled"
  152. size="mini"
  153. style="width: 180px"
  154. />
  155. </el-form-item>
  156. </el-col>
  157. <el-col :span="6">
  158. <el-form-item label="航次" prop="voy">
  159. <el-input
  160. v-model="form.voy"
  161. placeholder="请输入航次"
  162. :disabled="disabled"
  163. size="mini"
  164. style="width: 180px"
  165. />
  166. </el-form-item>
  167. </el-col>
  168. <el-col :span="6">
  169. <el-form-item label="起运港" prop="polId">
  170. <el-input
  171. v-model="form.polId"
  172. placeholder="请输入起运港"
  173. :disabled="disabled"
  174. size="mini"
  175. style="width: 180px"
  176. />
  177. </el-form-item>
  178. </el-col>
  179. <el-col :span="6">
  180. <el-form-item label="目的港" prop="podId">
  181. <el-input
  182. v-model="form.podId"
  183. placeholder="请输入目的港"
  184. :disabled="disabled"
  185. size="mini"
  186. style="width: 180px"
  187. />
  188. </el-form-item>
  189. </el-col>
  190. </el-row>
  191. <el-row>
  192. <el-col :span="6">
  193. <el-form-item
  194. v-if="form.transType != 3"
  195. label="提箱地点"
  196. prop="loadAddr"
  197. >
  198. <el-input
  199. v-model="form.loadAddr"
  200. placeholder="请输入提箱地点"
  201. :disabled="disabled"
  202. size="mini"
  203. style="width: 180px"
  204. />
  205. </el-form-item>
  206. <el-form-item v-else label="装货地点" prop="loadAddr">
  207. <el-input
  208. v-model="form.loadAddr"
  209. placeholder="请输入装货地点"
  210. :disabled="disabled"
  211. size="mini"
  212. />
  213. </el-form-item>
  214. </el-col>
  215. <el-col :span="6">
  216. <el-form-item label="计划时间" prop="loadDate">
  217. <el-date-picker
  218. clearable
  219. size="mini"
  220. style="width: 180px"
  221. v-model="form.loadDate"
  222. type="datetime"
  223. placeholder="选择计划装车时间"
  224. :disabled="disabled"
  225. >
  226. </el-date-picker>
  227. </el-form-item>
  228. </el-col>
  229. <el-col :span="6">
  230. <el-form-item label="联系人" prop="loadAttn">
  231. <el-input
  232. v-model="form.loadAttn"
  233. placeholder="请输入装车联系人"
  234. :disabled="disabled"
  235. size="mini"
  236. style="width: 180px"
  237. />
  238. </el-form-item>
  239. </el-col>
  240. <el-col :span="6">
  241. <el-form-item label="联系电话" prop="loadAttntel">
  242. <el-input
  243. v-model="form.loadAttntel"
  244. placeholder="请输入装车联系电话"
  245. :disabled="disabled"
  246. v-input-limit="0"
  247. size="mini"
  248. style="width: 180px"
  249. />
  250. </el-form-item>
  251. </el-col>
  252. </el-row>
  253. <el-row v-if="form.transType != 3">
  254. <el-col :span="6">
  255. <el-form-item
  256. v-if="form.billType == 1"
  257. label="卸货地点"
  258. prop="mdLoadAddr"
  259. >
  260. <el-input
  261. v-model="form.mdLoadAddr"
  262. placeholder="请输入装卸货地点"
  263. :disabled="disabled"
  264. size="mini"
  265. style="width: 180px"
  266. />
  267. </el-form-item>
  268. <el-form-item
  269. v-if="form.billType == 2"
  270. label="装货地点"
  271. prop="mdLoadAddr"
  272. >
  273. <el-input
  274. v-model="form.mdLoadAddr"
  275. placeholder="请输入装货地点"
  276. :disabled="disabled"
  277. size="mini"
  278. style="width: 180px"
  279. />
  280. </el-form-item>
  281. </el-col>
  282. <el-col :span="6" v-if="form.billType == 1 || form.billType == 2">
  283. <el-form-item label="计划时间" prop="mdLoadDate">
  284. <el-date-picker
  285. clearable
  286. size="mini"
  287. style="width: 180px"
  288. v-model="form.mdLoadDate"
  289. type="datetime"
  290. placeholder="选择计划装卸货时间"
  291. :disabled="disabled"
  292. >
  293. </el-date-picker>
  294. </el-form-item>
  295. </el-col>
  296. <el-col :span="6" v-if="form.billType == 1 || form.billType == 2">
  297. <el-form-item label="联系人" prop="mdLoadAttn">
  298. <el-input
  299. v-model="form.mdLoadAttn"
  300. placeholder="请输入装卸货联系人"
  301. :disabled="disabled"
  302. size="mini"
  303. style="width: 180px"
  304. />
  305. </el-form-item>
  306. </el-col>
  307. <el-col :span="6" v-if="form.billType == 1 || form.billType == 2">
  308. <el-form-item label="联系电话" prop="mdLoadAttnTel">
  309. <el-input
  310. v-model="form.mdLoadAttnTel"
  311. placeholder="请输入装卸货联系电话"
  312. :disabled="disabled"
  313. v-input-limit="0"
  314. size="mini"
  315. style="width: 180px"
  316. />
  317. </el-form-item>
  318. </el-col>
  319. </el-row>
  320. <el-row>
  321. <el-col v-if="form.transType != 3" :span="6">
  322. <el-form-item label="卸箱地点" prop="unLoadAddr">
  323. <el-input
  324. v-model="form.unLoadAddr"
  325. placeholder="请输入卸箱地点"
  326. :disabled="disabled"
  327. size="mini"
  328. style="width: 180px"
  329. />
  330. </el-form-item>
  331. </el-col>
  332. <el-col v-else :span="6">
  333. <el-form-item label="卸货地点" prop="unLoadAddr">
  334. <el-input
  335. v-model="form.unLoadAddr"
  336. placeholder="请输入卸箱地点"
  337. :disabled="disabled"
  338. size="mini"
  339. style="width: 180px"
  340. />
  341. </el-form-item>
  342. </el-col>
  343. <el-col :span="6">
  344. <el-form-item label="计划时间" prop="unLoadDate">
  345. <el-date-picker
  346. clearable
  347. size="mini"
  348. style="width: 180px"
  349. v-model="form.unLoadDate"
  350. type="datetime"
  351. placeholder="选择计划卸车时间"
  352. :disabled="disabled"
  353. >
  354. </el-date-picker>
  355. </el-form-item>
  356. </el-col>
  357. <el-col :span="6">
  358. <el-form-item label="联系人" prop="unLoadAttn">
  359. <el-input
  360. v-model="form.unLoadAttn"
  361. placeholder="请输入卸车联系人"
  362. :disabled="disabled"
  363. size="mini"
  364. style="width: 180px"
  365. />
  366. </el-form-item>
  367. </el-col>
  368. <el-col :span="6">
  369. <el-form-item label="联系电话" prop="unLoadAttnTel">
  370. <el-input
  371. v-model="form.unLoadAttnTel"
  372. placeholder="请输入卸车联系电话"
  373. :disabled="disabled"
  374. v-input-limit="0"
  375. size="mini"
  376. style="width: 180px"
  377. />
  378. </el-form-item>
  379. </el-col>
  380. </el-row>
  381. <el-row>
  382. <el-col>
  383. <el-form-item label="线路描述" prop="routeDesc">
  384. <el-input
  385. type="textarea"
  386. :rows="2"
  387. v-model="form.routeDesc"
  388. placeholder="请输入线路描述"
  389. :disabled="disabled"
  390. size="mini"
  391. />
  392. </el-form-item>
  393. </el-col>
  394. </el-row>
  395. <el-row>
  396. <el-col>
  397. <el-form-item label="备注" prop="remarks">
  398. <el-input
  399. type="textarea"
  400. :rows="2"
  401. v-model="form.remarks"
  402. placeholder="请输入备注"
  403. :disabled="disabled"
  404. size="mini"
  405. />
  406. </el-form-item>
  407. </el-col>
  408. </el-row>
  409. <!-- <div style="display: flex; justify-content: flex-end; margin: 10px 0">
  410. <el-button type="danger" @click="submitAllowChanges"
  411. >申请修改</el-button
  412. >
  413. </div> -->
  414. <el-collapse v-model="collapses2">
  415. <el-collapse-item name="1">
  416. <template slot="title">
  417. <i class="header-icon el-icon-circle-plus" style="font-size: 16px"
  418. ><span
  419. style="font-size: 16px; font-weight: bolder; margin-left: 5px"
  420. >计划货量</span
  421. >
  422. </i>
  423. </template>
  424. <div>
  425. <div
  426. style="
  427. display: flex;
  428. justify-content: space-between;
  429. margin: 10px 0;
  430. "
  431. >
  432. <div>
  433. <el-button
  434. type="primary"
  435. icon="el-icon-plus"
  436. size="mini"
  437. @click="addRow(planList)"
  438. :disabled="disabled"
  439. >添加</el-button
  440. >
  441. </div>
  442. <div v-if="form.transType == 3">
  443. <el-form-item label="损耗单位" prop="goodsLossType">
  444. <el-select
  445. v-model="form.goodsLossType"
  446. placeholder="请选择损耗单位"
  447. >
  448. <el-option
  449. v-for="(dict, index) in goodsLossTypeList"
  450. :key="index.dictValue"
  451. :label="dict.dictLabel"
  452. :value="dict.dictValue"
  453. />
  454. </el-select>
  455. </el-form-item>
  456. </div>
  457. <div v-if="form.transType == 3">
  458. <el-form-item label="耗损标准" prop="goodsLossStd">
  459. <el-input
  460. v-model="form.goodsLossStd"
  461. placeholder="请输入耗损标准"
  462. v-input-limit="2"
  463. />
  464. </el-form-item>
  465. </div>
  466. </div>
  467. <el-table :data="planList">
  468. <el-table-column label="箱型" align="center" prop="cntrId">
  469. <template slot-scope="scope">
  470. <el-select
  471. v-model="scope.row.cntrId"
  472. placeholder="请选择箱型"
  473. :disabled="disabled"
  474. @visible-change="noMorecntrId(planList)"
  475. >
  476. <el-option
  477. v-for="(dict, index) in cntrIdList"
  478. :key="index.dictValue"
  479. :label="dict.dictLabel"
  480. :value="dict.dictValue"
  481. :disabled="dict.noOption"
  482. />
  483. </el-select>
  484. </template>
  485. </el-table-column>
  486. <el-table-column
  487. label="计价方式"
  488. align="center"
  489. prop="priceType"
  490. >
  491. <template slot-scope="scope">
  492. <el-select
  493. v-model="scope.row.priceType"
  494. placeholder="请输入计价方式"
  495. :disabled="disabled"
  496. >
  497. <el-option
  498. v-for="(dict, index) in priceTypeList"
  499. :key="index.dictValue"
  500. :label="dict.dictLabel"
  501. :value="dict.dictValue"
  502. />
  503. </el-select>
  504. </template>
  505. </el-table-column>
  506. <el-table-column label="应收运价" align="center" prop="priceDr">
  507. <template slot-scope="scope">
  508. <el-input
  509. v-model="scope.row.priceDr"
  510. placeholder="应收运价"
  511. :disabled="disabled"
  512. v-input-limit="2"
  513. />
  514. </template>
  515. </el-table-column>
  516. <el-table-column label="应付运价" align="center" prop="priceCr">
  517. <template slot-scope="scope">
  518. <el-input
  519. v-model="scope.row.priceCr"
  520. placeholder="应付运价"
  521. :disabled="disabled"
  522. v-input-limit="2"
  523. />
  524. </template>
  525. </el-table-column>
  526. <el-table-column label="计划货量" align="center" prop="cntrQty">
  527. <template slot-scope="scope">
  528. <el-input
  529. v-model="scope.row.cntrQty"
  530. placeholder="计划货量"
  531. :disabled="disabled"
  532. v-input-limit="2"
  533. />
  534. </template>
  535. </el-table-column>
  536. <el-table-column
  537. label="已调度货量"
  538. align="center"
  539. prop="cntrPlanQty"
  540. >
  541. <template slot-scope="scope">
  542. <el-input
  543. v-model="scope.row.cntrPlanQty"
  544. placeholder="已调度货量"
  545. :disabled="true"
  546. />
  547. </template>
  548. </el-table-column>
  549. <el-table-column
  550. label="已派车货量"
  551. align="center"
  552. prop="planQty"
  553. >
  554. <template slot-scope="scope">
  555. <el-input
  556. v-model="scope.row.planQty"
  557. placeholder="已派车货量"
  558. :disabled="true"
  559. />
  560. </template>
  561. </el-table-column>
  562. <el-table-column label="备注" align="center" prop="remarks">
  563. <template slot-scope="scope">
  564. <el-input
  565. v-model="scope.row.remarks"
  566. placeholder="备注"
  567. :disabled="disabled"
  568. />
  569. </template>
  570. </el-table-column>
  571. <el-table-column
  572. label="操作"
  573. align="center"
  574. class-name="small-padding fixed-width"
  575. width="100"
  576. >
  577. <template slot-scope="scope">
  578. <el-button
  579. size="mini"
  580. type="text"
  581. icon="el-icon-delete"
  582. @click.native.prevent="
  583. deleteplansRow(scope.$index, planList, scope.row)
  584. "
  585. :disabled="disabled"
  586. >删除</el-button
  587. >
  588. </template>
  589. </el-table-column>
  590. </el-table>
  591. </div>
  592. </el-collapse-item>
  593. <el-collapse-item name="2" v-if="userType == '00'">
  594. <template slot="title">
  595. <i class="header-icon el-icon-circle-plus" style="font-size: 16px"
  596. ><span
  597. style="font-size: 16px; font-weight: bolder; margin-left: 5px"
  598. >调度安排</span
  599. >
  600. </i>
  601. </template>
  602. <div>
  603. <div
  604. style="
  605. display: flex;
  606. justify-content: space-between;
  607. margin: 10px 0;
  608. "
  609. >
  610. <div>
  611. <el-button
  612. type="primary"
  613. icon="el-icon-plus"
  614. size="mini"
  615. @click="addschedulingRow(schedulingList)"
  616. :disabled="disabled"
  617. >添加</el-button
  618. >
  619. </div>
  620. </div>
  621. <el-table :data="schedulingList">
  622. <el-table-column label="箱型" align="center" prop="cntrId">
  623. <template slot-scope="scope">
  624. <el-select
  625. v-model="scope.row.cntrId"
  626. placeholder="请选择箱型"
  627. :disabled="disabled || scope.row.billStatus == 6"
  628. @change="checkPid(scope.row)"
  629. >
  630. <el-option
  631. v-for="(dict, index) in cntrId2List"
  632. :key="index.dictValue"
  633. :label="dict.dictLabel"
  634. :value="dict.dictValue"
  635. />
  636. </el-select>
  637. </template>
  638. </el-table-column>
  639. <el-table-column
  640. label="车队名称"
  641. align="center"
  642. prop="carcorPid"
  643. >
  644. <template slot-scope="scope">
  645. <el-input
  646. v-model="scope.row.carcorPid"
  647. placeholder="车队名称"
  648. :disabled="disabled || scope.row.billStatus == 6"
  649. />
  650. </template>
  651. </el-table-column>
  652. <el-table-column
  653. label="调度安排货量"
  654. align="center"
  655. prop="cntrQty"
  656. :disabled="disabled"
  657. >
  658. <template slot-scope="scope">
  659. <el-input
  660. v-model="scope.row.cntrQty"
  661. placeholder="调度安排货量"
  662. v-input-limit="2"
  663. :disabled="disabled || scope.row.billStatus == 6"
  664. />
  665. </template>
  666. </el-table-column>
  667. <el-table-column
  668. label="已派车货量"
  669. align="center"
  670. prop="carQty"
  671. >
  672. <template slot-scope="scope">
  673. <el-input
  674. v-model="scope.row.carQty"
  675. placeholder="已派车货量"
  676. :disabled="true"
  677. />
  678. </template>
  679. </el-table-column>
  680. <el-table-column label="备注" align="center" prop="remarks">
  681. <template slot-scope="scope">
  682. <el-input
  683. v-model="scope.row.remarks"
  684. placeholder="备注"
  685. :disabled="disabled || scope.row.billStatus == 6"
  686. />
  687. </template>
  688. </el-table-column>
  689. <el-table-column
  690. label="操作"
  691. align="center"
  692. class-name="small-padding fixed-width"
  693. width="150"
  694. >
  695. <template slot-scope="scope">
  696. <el-button
  697. size="mini"
  698. type="text"
  699. icon="el-icon-delete"
  700. @click.native.prevent="
  701. delplansRow(scope.$index, schedulingList, scope.row)
  702. "
  703. :disabled="disabled || scope.row.billStatus == 6"
  704. >删除</el-button
  705. >
  706. <el-button
  707. size="mini"
  708. type="text"
  709. icon="el-icon-document-checked"
  710. @click.native.prevent="addplansRow(scope.row)"
  711. :disabled="disabled || scope.row.billStatus == 6"
  712. >提交</el-button
  713. >
  714. <el-button
  715. size="mini"
  716. type="text"
  717. icon="el-icon-document-delete"
  718. @click.native.prevent="
  719. revokeplansRow(scope.$index, schedulingList, scope.row)
  720. "
  721. :disabled="true"
  722. >撤销</el-button
  723. >
  724. </template>
  725. </el-table-column>
  726. </el-table>
  727. </div>
  728. </el-collapse-item>
  729. <el-collapse-item name="3" v-if="userType == '00'">
  730. <template slot="title">
  731. <i class="header-icon el-icon-circle-plus" style="font-size: 16px"
  732. ><span
  733. style="font-size: 16px; font-weight: bolder; margin-left: 5px"
  734. >收款信息</span
  735. >
  736. </i>
  737. </template>
  738. <div>
  739. <div
  740. style="
  741. display: flex;
  742. justify-content: space-between;
  743. margin: 10px 0;
  744. "
  745. >
  746. <div>
  747. <el-button
  748. type="primary"
  749. icon="el-icon-plus"
  750. size="mini"
  751. @click="addDListRow(DList)"
  752. :disabled="disabled"
  753. >添加</el-button
  754. >
  755. </div>
  756. </div>
  757. <el-table :data="DList">
  758. <el-table-column label="结算单位" align="center" prop="fCorpid">
  759. <template slot-scope="scope">
  760. <el-select
  761. v-model="scope.row.fCorpid"
  762. placeholder="结算单位"
  763. :clearable="true"
  764. filterable
  765. :disabled="disabled"
  766. >
  767. <el-option
  768. v-for="(dict, index) in fMblnoOptions"
  769. :key="index.fId"
  770. :label="dict.fName"
  771. :value="dict.fId"
  772. />
  773. </el-select>
  774. </template>
  775. </el-table-column>
  776. <el-table-column label="费用名称" align="center" prop="fFeeid">
  777. <template slot-scope="scope">
  778. <el-select
  779. v-model="scope.row.fFeeid"
  780. placeholder="费用名称"
  781. clearable
  782. filterable
  783. :disabled="disabled"
  784. >
  785. <el-option
  786. v-for="(dict, index) in fWbuOptions"
  787. :key="index.fId"
  788. :label="dict.fName"
  789. :value="dict.fId"
  790. />
  791. </el-select>
  792. </template>
  793. </el-table-column>
  794. <el-table-column
  795. label="计费单位"
  796. align="center"
  797. prop="fFeeunitid"
  798. >
  799. <template slot-scope="scope">
  800. <el-select
  801. v-model="scope.row.fFeeunitid"
  802. placeholder="计费单位"
  803. :disabled="disabled"
  804. >
  805. <el-option
  806. v-for="(dict, index) in ffeeunitidList"
  807. :key="index.dictValue"
  808. :label="dict.dictLabel"
  809. :value="dict.dictValue"
  810. />
  811. </el-select>
  812. </template>
  813. </el-table-column>
  814. <el-table-column label="计费数量" align="center" prop="fQty">
  815. <template slot-scope="scope">
  816. <el-input
  817. v-model="scope.row.fQty"
  818. placeholder="计费数量"
  819. v-input-limit="0"
  820. :disabled="disabled"
  821. />
  822. </template>
  823. </el-table-column>
  824. <el-table-column label="单价" align="center" prop="fUnitprice">
  825. <template slot-scope="scope">
  826. <el-input
  827. v-model="scope.row.fUnitprice"
  828. placeholder="单价"
  829. v-input-limit="2"
  830. :disabled="disabled"
  831. />
  832. </template>
  833. </el-table-column>
  834. <el-table-column label="币种" align="center" prop="fCurrency">
  835. <template slot-scope="scope">
  836. <el-input
  837. v-model="scope.row.fCurrency"
  838. placeholder="RMB"
  839. :disabled="true"
  840. />
  841. </template>
  842. </el-table-column>
  843. <el-table-column label="税率" align="center" prop="fTaxrate">
  844. <template slot-scope="scope">
  845. <el-input
  846. v-model="scope.row.fTaxrate"
  847. placeholder="税率"
  848. v-input-limit="2"
  849. :disabled="disabled"
  850. />
  851. </template>
  852. </el-table-column>
  853. <el-table-column label="金额" align="center" prop="fAmount">
  854. <template slot-scope="scope">
  855. <el-input
  856. v-model="scope.row.fAmount"
  857. placeholder="金额"
  858. v-input-limit="2"
  859. :disabled="disabled"
  860. />
  861. </template>
  862. </el-table-column>
  863. <el-table-column label="汇率" align="center" prop="fExrate">
  864. <template slot-scope="scope">
  865. <el-input
  866. v-model="scope.row.fExrate"
  867. placeholder="汇率"
  868. v-input-limit="2"
  869. :disabled="disabled"
  870. />
  871. </template>
  872. </el-table-column>
  873. <el-table-column label="备注" align="center" prop="remarks">
  874. <template slot-scope="scope">
  875. <el-input
  876. v-model="scope.row.remarks"
  877. placeholder="备注"
  878. :disabled="disabled"
  879. />
  880. </template>
  881. </el-table-column>
  882. <el-table-column
  883. label="操作"
  884. align="center"
  885. class-name="small-padding fixed-width"
  886. width="100"
  887. >
  888. <template slot-scope="scope">
  889. <el-button
  890. size="mini"
  891. type="text"
  892. icon="el-icon-delete"
  893. @click.native.prevent="deleteRow(scope.$index, DList)"
  894. :disabled="disabled"
  895. >删除</el-button
  896. >
  897. </template>
  898. </el-table-column>
  899. </el-table>
  900. </div>
  901. </el-collapse-item>
  902. <el-collapse-item name="4" v-if="userType == '00'">
  903. <template slot="title">
  904. <i class="header-icon el-icon-circle-plus" style="font-size: 16px"
  905. ><span
  906. style="font-size: 16px; font-weight: bolder; margin-left: 5px"
  907. >付款信息</span
  908. >
  909. </i>
  910. </template>
  911. <div>
  912. <div
  913. style="
  914. display: flex;
  915. justify-content: space-between;
  916. margin: 10px 0;
  917. "
  918. >
  919. <div>
  920. <el-button
  921. type="primary"
  922. icon="el-icon-plus"
  923. size="mini"
  924. @click="addDListRow(CList)"
  925. :disabled="disabled"
  926. >添加</el-button
  927. >
  928. </div>
  929. </div>
  930. <el-table :data="CList">
  931. <el-table-column label="结算单位" align="center" prop="fCorpid">
  932. <template slot-scope="scope">
  933. <el-select
  934. v-model="scope.row.fCorpid"
  935. placeholder="结算单位"
  936. :clearable="true"
  937. filterable
  938. :disabled="disabled"
  939. >
  940. <el-option
  941. v-for="(dict, index) in fMblnoOptions"
  942. :key="index.fId"
  943. :label="dict.fName"
  944. :value="dict.fId"
  945. />
  946. </el-select>
  947. </template>
  948. </el-table-column>
  949. <el-table-column label="费用名称" align="center" prop="fFeeid">
  950. <template slot-scope="scope">
  951. <el-select
  952. v-model="scope.row.fFeeid"
  953. placeholder="费用名称"
  954. clearable
  955. filterable
  956. :disabled="disabled"
  957. >
  958. <el-option
  959. v-for="(dict, index) in fWbuOptions"
  960. :key="index.fId"
  961. :label="dict.fName"
  962. :value="dict.fId"
  963. />
  964. </el-select>
  965. </template>
  966. </el-table-column>
  967. <el-table-column
  968. label="计费单位"
  969. align="center"
  970. prop="fFeeunitid"
  971. >
  972. <template slot-scope="scope">
  973. <el-select
  974. v-model="scope.row.fFeeunitid"
  975. placeholder="计费单位"
  976. :disabled="disabled"
  977. >
  978. <el-option
  979. v-for="(dict, index) in ffeeunitidList"
  980. :key="index.dictValue"
  981. :label="dict.dictLabel"
  982. :value="dict.dictValue"
  983. />
  984. </el-select>
  985. </template>
  986. </el-table-column>
  987. <el-table-column label="计费数量" align="center" prop="fQty">
  988. <template slot-scope="scope">
  989. <el-input
  990. v-model="scope.row.fQty"
  991. placeholder="计费数量"
  992. v-input-limit="0"
  993. :disabled="disabled"
  994. />
  995. </template>
  996. </el-table-column>
  997. <el-table-column label="单价" align="center" prop="fUnitprice">
  998. <template slot-scope="scope">
  999. <el-input
  1000. v-model="scope.row.fUnitprice"
  1001. placeholder="单价"
  1002. v-input-limit="2"
  1003. :disabled="disabled"
  1004. />
  1005. </template>
  1006. </el-table-column>
  1007. <el-table-column label="币种" align="center" prop="fCurrency">
  1008. <template slot-scope="scope">
  1009. <el-input
  1010. v-model="scope.row.fCurrency"
  1011. placeholder="RMB"
  1012. :disabled="true"
  1013. />
  1014. </template>
  1015. </el-table-column>
  1016. <el-table-column label="税率" align="center" prop="fTaxrate">
  1017. <template slot-scope="scope">
  1018. <el-input
  1019. v-model="scope.row.fTaxrate"
  1020. placeholder="税率"
  1021. v-input-limit="2"
  1022. :disabled="disabled"
  1023. />
  1024. </template>
  1025. </el-table-column>
  1026. <el-table-column label="金额" align="center" prop="fAmount">
  1027. <template slot-scope="scope">
  1028. <el-input
  1029. v-model="scope.row.fAmount"
  1030. placeholder="金额"
  1031. v-input-limit="2"
  1032. :disabled="disabled"
  1033. />
  1034. </template>
  1035. </el-table-column>
  1036. <el-table-column label="汇率" align="center" prop="fExrate">
  1037. <template slot-scope="scope">
  1038. <el-input
  1039. v-model="scope.row.fExrate"
  1040. placeholder="汇率"
  1041. v-input-limit="2"
  1042. :disabled="disabled"
  1043. />
  1044. </template>
  1045. </el-table-column>
  1046. <el-table-column label="备注" align="center" prop="remarks">
  1047. <template slot-scope="scope">
  1048. <el-input
  1049. v-model="scope.row.remarks"
  1050. placeholder="备注"
  1051. :disabled="disabled"
  1052. />
  1053. </template>
  1054. </el-table-column>
  1055. <el-table-column
  1056. label="操作"
  1057. align="center"
  1058. class-name="small-padding fixed-width"
  1059. width="100"
  1060. >
  1061. <template slot-scope="scope">
  1062. <el-button
  1063. size="mini"
  1064. type="text"
  1065. icon="el-icon-delete"
  1066. @click.native.prevent="deleteRow(scope.$index, DList)"
  1067. :disabled="disabled"
  1068. >删除</el-button
  1069. >
  1070. </template>
  1071. </el-table-column>
  1072. </el-table>
  1073. </div>
  1074. </el-collapse-item>
  1075. <el-collapse-item name="5">
  1076. <template slot="title">
  1077. <i class="header-icon el-icon-circle-plus" style="font-size: 16px"
  1078. ><span
  1079. style="font-size: 16px; font-weight: bolder; margin-left: 5px"
  1080. >附件上传</span
  1081. >
  1082. </i>
  1083. </template>
  1084. <div>
  1085. <div
  1086. style="
  1087. display: flex;
  1088. justify-content: space-between;
  1089. margin: 10px 0;
  1090. "
  1091. >
  1092. <div>
  1093. <el-button
  1094. type="primary"
  1095. icon="el-icon-plus"
  1096. size="mini"
  1097. @click="addRelevt"
  1098. :disabled="disabled"
  1099. >添加</el-button
  1100. >
  1101. </div>
  1102. </div>
  1103. <el-table
  1104. :data="relevantAttachments"
  1105. tooltip-effect="dark"
  1106. border
  1107. stripe
  1108. style="width: 100%"
  1109. height="150"
  1110. >
  1111. <el-table-column label="序号" type="index" width="80">
  1112. </el-table-column>
  1113. <el-table-column
  1114. prop="attachName"
  1115. header-align="center"
  1116. align="center"
  1117. label="附件名称"
  1118. >
  1119. <template slot-scope="scope">
  1120. <el-input
  1121. v-model="scope.row.attachName"
  1122. placeholder="附件名称"
  1123. show-word-limit
  1124. />
  1125. </template>
  1126. </el-table-column>
  1127. <el-table-column
  1128. prop="opuserID "
  1129. header-align="center"
  1130. align="center"
  1131. label="上传人"
  1132. >
  1133. <template slot-scope="scope">
  1134. <el-input
  1135. v-model="scope.row.opuserID"
  1136. placeholder="上传人"
  1137. show-word-limit
  1138. />
  1139. </template>
  1140. </el-table-column>
  1141. <el-table-column
  1142. prop="opdata"
  1143. header-align="center"
  1144. align="center"
  1145. label="上传时间"
  1146. >
  1147. <template slot-scope="scope">
  1148. <el-date-picker
  1149. v-model="scope.row.opdata"
  1150. type="datetime"
  1151. disabled
  1152. placeholder="上传时间"
  1153. format="yyyy-MM-dd HH:mm"
  1154. value-format="timestamp"
  1155. ></el-date-picker>
  1156. </template>
  1157. </el-table-column>
  1158. <el-table-column
  1159. prop="attachUrl"
  1160. header-align="center"
  1161. align="center"
  1162. label="上传附件"
  1163. >
  1164. <template slot-scope="scope">
  1165. <uploadFile
  1166. @input="showFile"
  1167. v-model="scope.row.attachUrl"
  1168. />
  1169. </template>
  1170. </el-table-column>
  1171. <el-table-column
  1172. header-align="center"
  1173. align="center"
  1174. label="操作"
  1175. width="130PX"
  1176. >
  1177. <template slot-scope="scope">
  1178. <el-button
  1179. size="mini"
  1180. type="text"
  1181. icon="el-icon-delete"
  1182. @click.native.prevent="
  1183. deleteRow(scope.$index, relevantAttachments)
  1184. "
  1185. :disabled="disabled"
  1186. >删除</el-button
  1187. >
  1188. </template>
  1189. </el-table-column>
  1190. </el-table>
  1191. </div>
  1192. </el-collapse-item>
  1193. </el-collapse>
  1194. </el-form>
  1195. </span>
  1196. <span slot="footer" class="dialog-footer">
  1197. <el-button type="primary" @click="submitForm" :disabled="disabled"
  1198. >提 交</el-button
  1199. >
  1200. <!-- <el-button type="success" @click="submitFix">修改</el-button> -->
  1201. <el-button type="success" @click="submitAllowChanges">修 改</el-button>
  1202. <el-button type="info" @click="submitSave" :disabled="disabled"
  1203. >保 存</el-button
  1204. >
  1205. <el-button
  1206. type="warning"
  1207. @click="submitRetreat"
  1208. :disabled="this.form.billStatus != 40"
  1209. >撤 回</el-button
  1210. >
  1211. <el-button @click="showDialog = false">取 消</el-button>
  1212. </span>
  1213. </el-dialog>
  1214. </template>
  1215. <script>
  1216. import {
  1217. addFtmsorderbills,
  1218. RetreatFtmsorderbills,
  1219. allowChangesFtmsorderbills,
  1220. updateFtmsorderbills,
  1221. planChangeFtmsorderbills,
  1222. } from "@/api/fleet/ftmsorderbills";
  1223. import {
  1224. singleaddFtmsorderbillsplans,
  1225. revokeFtmsorderbillsplans,
  1226. removeFtmsorderbillsplans,
  1227. } from "@/api/fleet/ftmsorderbillsplans";
  1228. import { listGoods } from "@/api/basicdata/goods";
  1229. import { listCorps } from "@/api/basicdata/corps";
  1230. import { listFees } from "@/api/basicdata/fees";
  1231. import UploadFile from "@/components/Uploadfile";
  1232. import Cookies from "js-cookie";
  1233. export default {
  1234. name: "plans",
  1235. props: {
  1236. addOrUpdateVisible: {
  1237. type: Boolean,
  1238. default: false,
  1239. },
  1240. title: {
  1241. type: String,
  1242. required: "",
  1243. },
  1244. form: Object,
  1245. disabled: {
  1246. type: Boolean,
  1247. default: false,
  1248. },
  1249. planList: {
  1250. type: Array,
  1251. default: [],
  1252. },
  1253. DList: {
  1254. type: Array,
  1255. default: [],
  1256. },
  1257. CList: {
  1258. type: Array,
  1259. default: [],
  1260. },
  1261. schedulingList: {
  1262. type: Array,
  1263. default: [],
  1264. },
  1265. collapses: {
  1266. type: Array,
  1267. default: [],
  1268. },
  1269. },
  1270. components: {
  1271. UploadFile,
  1272. },
  1273. data() {
  1274. return {
  1275. dcList: [
  1276. {
  1277. value: "D",
  1278. label: "收款",
  1279. },
  1280. {
  1281. value: "C",
  1282. label: "付款",
  1283. },
  1284. ],
  1285. currencyList: [
  1286. {
  1287. value: "RMB",
  1288. label: "RMB",
  1289. },
  1290. ],
  1291. // 控制弹出框显示隐藏
  1292. showDialog: false,
  1293. // 表单校验
  1294. rules: {
  1295. corpId: [
  1296. { required: true, message: "请输入客户名称", trigger: "blur" },
  1297. ],
  1298. billType: [
  1299. { required: true, message: "请选择业务类型", trigger: "blur" },
  1300. ],
  1301. transType: [
  1302. { required: true, message: "请选择运输方式", trigger: "blur" },
  1303. ],
  1304. loadAddr: [
  1305. { required: true, message: "请输入提箱地点", trigger: "blur" },
  1306. ],
  1307. loadAttntel: [
  1308. {
  1309. pattern: /^((0\d{2,3}-\d{7,8})|(1[3584]\d{9}))$/,
  1310. message: "请正确输入手机号",
  1311. trigger: "blur",
  1312. },
  1313. ],
  1314. mdLoadAttnTel: [
  1315. {
  1316. pattern: /^((0\d{2,3}-\d{7,8})|(1[3584]\d{9}))$/,
  1317. message: "请正确输入手机号",
  1318. trigger: "blur",
  1319. },
  1320. ],
  1321. unLoadAttnTel: [
  1322. {
  1323. pattern: /^((0\d{2,3}-\d{7,8})|(1[3584]\d{9}))$/,
  1324. message: "请正确输入手机号",
  1325. trigger: "blur",
  1326. },
  1327. ],
  1328. },
  1329. billTypeList: [],
  1330. transTypeList: [],
  1331. transPropList: [],
  1332. goodsLossTypeList: [],
  1333. relevantAttachments: [],
  1334. cntrIdList: [],
  1335. priceTypeList: [],
  1336. userType: null,
  1337. username: null,
  1338. fMblnoOptions: [],
  1339. cntrId2List: [],
  1340. goodsOptions: [],
  1341. fWbuOptions: [],
  1342. ffeeunitidList: [],
  1343. collapses2: [],
  1344. };
  1345. },
  1346. created() {
  1347. this.getDicts("data_billType").then((response) => {
  1348. this.billTypeList = response.data;
  1349. });
  1350. this.getDicts("data_transType").then((response) => {
  1351. this.transTypeList = response.data;
  1352. });
  1353. this.getDicts("data_transProp").then((response) => {
  1354. this.transPropList = response.data;
  1355. });
  1356. this.getDicts("data_goodsLossType").then((response) => {
  1357. this.goodsLossTypeList = response.data;
  1358. });
  1359. this.getDicts("data_cntrId").then((response) => {
  1360. response.data.map((e) => (e.noOption = false));
  1361. this.cntrIdList = response.data;
  1362. });
  1363. this.getDicts("data_priceType").then((response) => {
  1364. this.priceTypeList = response.data;
  1365. });
  1366. this.getDicts("data_ffeeunitid").then((response) => {
  1367. this.ffeeunitidList = response.data;
  1368. });
  1369. listCorps().then((response) => {
  1370. this.fMblnoOptions = response.rows;
  1371. });
  1372. listGoods().then((response) => {
  1373. this.goodsOptions = response.rows;
  1374. });
  1375. listFees().then((response) => {
  1376. this.fWbuOptions = response.rows;
  1377. });
  1378. this.userType = Cookies.get("userType");
  1379. this.username = Cookies.get("userName");
  1380. },
  1381. methods: {
  1382. //选中时赋值pid
  1383. checkPid(row) {
  1384. let arr = this.planList;
  1385. let arr2 = arr.filter((e) => e.cntrId == row.cntrId);
  1386. row["pid"] = arr2[0].id;
  1387. },
  1388. noMorecntrId(e) {
  1389. this.cntrIdList.forEach((item) => (item.noOption = false));
  1390. let arrIds = e.map((item) => item.cntrId);
  1391. this.cntrIdList
  1392. .filter((item) => arrIds.indexOf(item.dictValue) > -1)
  1393. .forEach((item) => (item.noOption = true));
  1394. },
  1395. showSure(val) {
  1396. let pidList = val.filter((e) => e.pid != null);
  1397. let arr1 = pidList;
  1398. let arr1Ids = arr1.map((item) => item.cntrId);
  1399. arr1Ids = [...new Set(arr1Ids)];
  1400. let arr2 = this.cntrIdList;
  1401. this.cntrId2List = arr2.filter(
  1402. (item) => arr1Ids.indexOf(item.dictValue) > -1
  1403. );
  1404. },
  1405. // 新增附件上传
  1406. addRelevt() {
  1407. this.relevantAttachments.push({
  1408. attachUrl: null,
  1409. attachName: null,
  1410. opuserID: this.username,
  1411. opdata: Date.parse(new Date()),
  1412. });
  1413. },
  1414. // 添加行
  1415. addRow(tableData, event) {
  1416. var obj = {};
  1417. tableData.push(obj);
  1418. },
  1419. addDListRow(tableData, event) {
  1420. var obj = { fcorpid: this.form.corpId, fcurrency: "RMB" };
  1421. tableData.push(obj);
  1422. },
  1423. //删除行
  1424. deleteRow(index, rows) {
  1425. rows.splice(index, 1);
  1426. },
  1427. deleteplansRow(index, rows, row) {
  1428. let arr = this.schedulingList;
  1429. let arr2 = arr.filter((e) => e.cntrId == row.cntrId && e.cntrId != null);
  1430. if (arr2.length != 0) {
  1431. this.msgSuccess("调度安排已插入此箱型数据,不能删除");
  1432. } else {
  1433. this.cntrIdList
  1434. .filter((item) => item.dictValue == row.cntrId)
  1435. .forEach((item) => (item.noOption = false));
  1436. rows.splice(index, 1);
  1437. }
  1438. },
  1439. // 上传成功返回数据
  1440. showFile(row) {
  1441. for (let list in this.relevantAttachments) {
  1442. this.$set(this.relevantAttachments[list], "attachUrl", row.url);
  1443. this.$set(this.relevantAttachments[list], "attachName", row.fileName);
  1444. }
  1445. },
  1446. // 弹出框关闭后触发
  1447. handleClose() {
  1448. // 子组件调用父组件方法,并传递参数
  1449. this.$emit("changeShow", "false");
  1450. this.cntrIdList.forEach((item) => (item.noOption = false));
  1451. },
  1452. /** 提交按钮 */
  1453. submitForm() {
  1454. this.$refs["form"].validate((valid) => {
  1455. if (valid) {
  1456. let arr = this.schedulingList.filter((e) => e.billStatus == 6);
  1457. if (this.schedulingList.length == arr.length) {
  1458. this.form["billStatus"] = "6";
  1459. this.DList.map((e) => {
  1460. return (e.fDc = "D");
  1461. });
  1462. this.CList.map((e) => {
  1463. return (e.fDc = "C");
  1464. });
  1465. if (this.planList) {
  1466. let arr2 = [];
  1467. this.planList.map((e) => {
  1468. let arr = this.cntrIdList.filter(
  1469. (item) => item.dictValue == e.cntrId
  1470. );
  1471. arr.map((a) => {
  1472. arr2.push(a.dictLabel + "*" + e.cntrQty);
  1473. });
  1474. });
  1475. this.cntrDesc = [...new Set(arr2)].join(",");
  1476. }
  1477. this.form["cntrDesc"] = this.cntrDesc;
  1478. let formData = new window.FormData();
  1479. formData.append("tmsorder", JSON.stringify(this.form));
  1480. formData.append(
  1481. "attachs",
  1482. JSON.stringify(this.relevantAttachments)
  1483. );
  1484. formData.append("scntrs", JSON.stringify(this.planList));
  1485. formData.append(
  1486. "fees",
  1487. JSON.stringify(this.DList.concat(this.CList))
  1488. );
  1489. formData.append("plans", JSON.stringify(this.schedulingList));
  1490. if (this.form.billStatus != 50) {
  1491. addFtmsorderbills(formData).then((response) => {
  1492. this.msgSuccess("新增成功");
  1493. this.$parent.getList();
  1494. this.showDialog = false;
  1495. });
  1496. } else {
  1497. planChangeFtmsorderbills(formData).then((response) => {
  1498. this.msgSuccess("修改成功");
  1499. this.$parent.getList();
  1500. this.showDialog = false;
  1501. });
  1502. }
  1503. } else {
  1504. this.msgSuccess("调度安排中有未提交的数据");
  1505. }
  1506. }
  1507. });
  1508. },
  1509. //保存
  1510. submitSave() {
  1511. this.form["billStatus"] = "2";
  1512. this.DList.map((e) => {
  1513. return (e.fDc = "D");
  1514. });
  1515. this.CList.map((e) => {
  1516. return (e.fDc = "C");
  1517. });
  1518. let formData = new window.FormData();
  1519. formData.append("tmsorder", JSON.stringify(this.form));
  1520. formData.append("attachs", JSON.stringify(this.relevantAttachments));
  1521. formData.append("scntrs", JSON.stringify(this.planList));
  1522. formData.append("fees", JSON.stringify(this.DList.concat(this.CList)));
  1523. formData.append("plans", JSON.stringify(this.schedulingList));
  1524. addFtmsorderbills(formData).then((response) => {
  1525. if (response.code == 200) {
  1526. this.msgSuccess("保存成功");
  1527. this.$parent.getList();
  1528. this.$parent.getSave(response);
  1529. console.log(response);
  1530. } else {
  1531. this.msgSuccess("保存失败");
  1532. }
  1533. });
  1534. },
  1535. //撤回
  1536. submitRetreat() {
  1537. if (this.form.billStatus <= 3) {
  1538. const data = { id: this.form.id };
  1539. RetreatFtmsorderbills(data).then((response) => {
  1540. if (response.code == 200) {
  1541. this.msgSuccess("撤回成功");
  1542. this.$parent.getList();
  1543. this.$emit("fixDisabled", "false");
  1544. }
  1545. });
  1546. } else {
  1547. this.msgSuccess("单据已进行业务调度不允许修改");
  1548. }
  1549. },
  1550. //修改
  1551. submitAllowChanges() {
  1552. this.$emit("fixDisabled", "false");
  1553. this.msgSuccess("允许修改");
  1554. // if (this.form.billStatus == 20 || this.form.billStatus == 50) {
  1555. // this.$emit("fixDisabled", "false");
  1556. // this.msgSuccess("允许修改");
  1557. // } else if (this.form.billStatus == 30) {
  1558. // this.msgSuccess("单据已撤销不允许修改");
  1559. // } else if (this.form.billStatus > 50) {
  1560. // this.msgSuccess("单据已进行业务调度不允许修改");
  1561. // } else {
  1562. // this.$confirm("该单据已经提交,是否进行变更操作?", "提示", {
  1563. // confirmButtonText: "确定",
  1564. // cancelButtonText: "取消",
  1565. // type: "warning",
  1566. // })
  1567. // .then(() => {
  1568. // const data = { id: this.form.id, billType: 1000 };
  1569. // allowChangesFtmsorderbills(data).then((response) => {
  1570. // if (response.code == 200) {
  1571. // this.$emit("fixDisabled", "false");
  1572. // this.msgSuccess("允许修改");
  1573. // this.$set(this.form, "billStatus", 50);
  1574. // } else {
  1575. // this.msgSuccess("不允许修改");
  1576. // }
  1577. // });
  1578. // })
  1579. // .catch(() => {
  1580. // this.$message({
  1581. // type: "info",
  1582. // message: "已取消",
  1583. // });
  1584. // });
  1585. // }
  1586. },
  1587. //调度安排新增
  1588. addschedulingRow(tableData, event) {
  1589. const pidList = this.planList.filter((e) => e.pid != null);
  1590. if (
  1591. this.planList.length == 0 ||
  1592. Object.keys(this.planList[0]).length == 0
  1593. ) {
  1594. this.msgSuccess("至少添加一条计划货量");
  1595. } else if (pidList.length != this.planList.length) {
  1596. this.$confirm("计划货量存在未保存数据,是否保存?", "提示", {
  1597. confirmButtonText: "确定",
  1598. cancelButtonText: "取消",
  1599. type: "warning",
  1600. })
  1601. .then(() => {
  1602. this.submitSave();
  1603. })
  1604. .catch(() => {
  1605. this.$message({
  1606. type: "info",
  1607. message: "已取消保存",
  1608. });
  1609. });
  1610. } else {
  1611. var obj = {};
  1612. tableData.push(obj);
  1613. this.showSure(this.planList);
  1614. }
  1615. },
  1616. //单条订单调度提交
  1617. addplansRow(row) {
  1618. console.log(row);
  1619. if (row.billStatus != 6) {
  1620. let formData = new window.FormData();
  1621. formData.append("tmsorder", JSON.stringify(this.form));
  1622. formData.append("plans", JSON.stringify(row));
  1623. singleaddFtmsorderbillsplans(formData).then((response) => {
  1624. this.msgSuccess("成功提交");
  1625. if (response.code == 200) {
  1626. this.$set(row, "id", response.data.id);
  1627. this.$set(row, "billStatus", response.data.billStatus);
  1628. }
  1629. });
  1630. } else {
  1631. this.msgSuccess("请勿重复提交");
  1632. }
  1633. },
  1634. delplansRow(index, rows, row) {
  1635. if (row.billStatus != 6 && row.id != null) {
  1636. removeFtmsorderbillsplans(row).then((response) => {
  1637. if (response.code == 200) {
  1638. rows.splice(index, 1);
  1639. this.msgSuccess("成功删除");
  1640. }
  1641. });
  1642. } else {
  1643. rows.splice(index, 1);
  1644. }
  1645. },
  1646. revokeplansRow(index, rows, row) {
  1647. if (row.billStatus == 6) {
  1648. revokeFtmsorderbillsplans(row).then((response) => {
  1649. if (response.code == 200) {
  1650. this.msgSuccess("成功撤回");
  1651. this.$set(row, "billStatus", response.data.billStatus);
  1652. }
  1653. });
  1654. } else {
  1655. this.msgSuccess("此条数据没有提交,不能申请撤回");
  1656. }
  1657. },
  1658. mbinput(val) {
  1659. this.form.mblno = val.toUpperCase();
  1660. },
  1661. },
  1662. watch: {
  1663. // 监听 addOrUpdateVisible 改变
  1664. addOrUpdateVisible(oldVal, newVal) {
  1665. this.showDialog = this.addOrUpdateVisible;
  1666. },
  1667. planList(val) {
  1668. this.showSure(val);
  1669. },
  1670. collapses() {
  1671. this.collapses2 = this.collapses;
  1672. },
  1673. },
  1674. };
  1675. </script>