index.vue 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290
  1. <template>
  2. <div id="container" style="margin-bottom: 100px;display: flex;justify-content: center;">
  3. <div style="width:80%;">
  4. <el-form :model="form" ref="form" :rules="rules" label-position="top">
  5. <!-- 基本资料-->
  6. <div class="moduleStyle">
  7. <div class="titleBox">
  8. <span class="redBlock">&nbsp;</span>
  9. <span>基础资料</span>
  10. </div>
  11. <div class="basicData">
  12. <div class="mainModules">
  13. <el-form-item label="起运港口" prop="fLoadportid">
  14. <el-select
  15. v-model="form.fLoadportid"
  16. filterable
  17. remote
  18. @change="estimatedTime"
  19. style="width: 80%;"
  20. class="elSelect"
  21. placeholder="请输入模糊查找起运港口"
  22. :disabled="noEditing"
  23. >
  24. <el-scrollbar>
  25. <el-option
  26. v-for="(dict, index) in fMblnoOptions"
  27. :key="dict.fId"
  28. :label="dict.fName"
  29. :value="dict.fId"
  30. ></el-option>
  31. </el-scrollbar>
  32. </el-select>
  33. </el-form-item>
  34. <!-- </el-input>-->
  35. </div>
  36. <div class="mainModules">
  37. <!-- <span>目的港口</span>-->
  38. <!-- <el-input style="width:80%;margin-left:20px;top: 4px" v-model="form.fDestportid"/>-->
  39. <el-form-item label="目的港口" prop="fDestportid">
  40. <el-select
  41. v-model="form.fDestportid"
  42. filterable
  43. remote
  44. @change="estimatedTime"
  45. style="width: 80%;"
  46. :disabled="noEditing"
  47. class="elSelect"
  48. placeholder="请输入模糊查找目的港口"
  49. >
  50. <el-scrollbar>
  51. <el-option
  52. v-for="(dict, index) in fMblnoOptions"
  53. :key="dict.fId"
  54. :label="dict.fName"
  55. :value="dict.fId"
  56. ></el-option>
  57. </el-scrollbar>
  58. </el-select>
  59. </el-form-item>
  60. </div>
  61. <div class="mainModules">
  62. <!-- <span>预计装货时间</span>-->
  63. <!-- <el-input style="width:80%;margin-left:20px;top: 4px" v-model="form.fBsdate"/>-->
  64. <el-form-item label="预计装货时间" prop="fBsdate">
  65. <el-date-picker
  66. v-model="form.fBsdate"
  67. style="width:80%;"
  68. :disabled="noEditing"
  69. type="date"
  70. value-format="yyyy-MM-dd"
  71. placeholder="选择日期">
  72. </el-date-picker>
  73. </el-form-item>
  74. </div>
  75. <div class="mainModules">
  76. <el-form-item label="运输条款" prop="fServiceitems">
  77. <el-select style="width:80%;"
  78. placeholder="请选择"
  79. :disabled="noEditing"
  80. v-model="form.fServiceitems">
  81. <el-option
  82. v-for="(dict, index) in transport"
  83. :key="dict.dictValue"
  84. :label="dict.dictLabel"
  85. :value="dict.dictValue"
  86. ></el-option>
  87. </el-select>
  88. </el-form-item>
  89. </div>
  90. <div class="mainModules">
  91. <!-- <span>付款方式</span>-->
  92. <el-form-item label="付款方式" prop="fPaymode">
  93. <el-select style="width:80%;" placeholder="请选择" :disabled="noEditing"
  94. v-model="form.fPaymode">
  95. <el-option
  96. v-for="(dict, index) in paymentMethod"
  97. :key="dict.dictValue"
  98. :label="dict.dictLabel"
  99. :value="dict.dictValue"
  100. ></el-option>
  101. </el-select>
  102. </el-form-item>
  103. <!-- <el-input style="width:80%;margin-left:20px;top: 4px" v-model="form.fBillingway"></el-input>-->
  104. </div>
  105. <div class="mainModules">
  106. <el-form-item label="受票方" prop="fInvoceobj">
  107. <el-select style="width:80%;" placeholder="请选择" :disabled="noEditing"
  108. v-model="form.fInvoceobj">
  109. <el-option
  110. v-for="(dict, index) in drawee"
  111. :key="dict.dictValue"
  112. :label="dict.dictLabel"
  113. :value="dict.dictValue"
  114. ></el-option>
  115. </el-select>
  116. </el-form-item>
  117. <!-- <el-input style="width:80%;margin-left:20px;top: 4px" v-model="form.fInvoceobj"/>-->
  118. </div>
  119. <div class="mainModules">
  120. <el-form-item label="航线" prop="fLaneid">
  121. <el-select style="width:80%;" placeholder="请选择" :disabled="noEditing"
  122. v-model="form.fLaneid">
  123. <el-option
  124. v-for="(dict, index) in rouTe"
  125. :key="dict.fId"
  126. :label="dict.fName"
  127. :value="dict.fId"
  128. ></el-option>
  129. </el-select>
  130. </el-form-item>
  131. </div>
  132. <div class="mainModules">
  133. <el-form-item label="箱内签收单" prop="fSign">
  134. <!-- <el-input style="width:80%;" v-model="form.fSign"/>-->
  135. <el-select style="width:80%;" placeholder="请选择" :disabled="noEditing"
  136. v-model="form.fSign">
  137. <el-option
  138. v-for="(dict, index) in cEsign"
  139. :key="dict.dictValue"
  140. :label="dict.dictLabel"
  141. :value="dict.dictValue"
  142. ></el-option>
  143. </el-select>
  144. </el-form-item>
  145. </div>
  146. <div class="mainModules">
  147. <el-form-item label="订舱人扣货" prop="fDetentioncargo">
  148. <!-- <el-input style="width:80%;" v-model="form.fDetentioncargo"/>-->
  149. <el-select style="width:80%;" placeholder="请选择" :disabled="noEditing"
  150. v-model="form.fDetentioncargo">
  151. <el-option
  152. v-for="(dict, index) in etentioncargo"
  153. :key="dict.dictValue"
  154. :label="dict.dictLabel"
  155. :value="dict.dictValue"
  156. ></el-option>
  157. </el-select>
  158. </el-form-item>
  159. </div>
  160. <div style="width: 70%;">
  161. <el-form-item label="备注" prop="remarks" style="width: 80%;float: left;text-align: left">
  162. <el-input style="width:80%;float: left" placeholder="如有特殊需求,请再此说明" :disabled="noEditing" v-model="form.remarks"/>
  163. <el-button type="text" style="display: inline; color: red" :disabled="noEditing">附件上传<i
  164. class="el-icon-upload el-icon--right"></i></el-button>
  165. </el-form-item>
  166. </div>
  167. <!-- <div class="mainModules"></div>-->
  168. </div>
  169. </div>
  170. <!-- 预计时间-->
  171. <div class="moduleStyle">
  172. <div class="titleBox">
  173. <span class="redBlock">&nbsp;</span>
  174. <span>预计时间</span>
  175. <el-button type="primary" size="mini" style="float: right;margin-right: 20px" @click="dialogVisible = true"
  176. :disabled="!form.fLoadportid || !form.fDestportid || noEditing">查看船期
  177. </el-button>
  178. </div>
  179. <span style="color:red;display: block;margin:0 auto;margin-bottom: -20px;">{{estimaTe.pidName}}&nbsp;&nbsp;&nbsp;{{estimaTe.fNo}}</span>
  180. <!-- 步骤条-->
  181. <div style="width: 100%;" v-if="!estimaTe">
  182. <div style="width: 80%;margin: 0 auto;padding-bottom: 10px">
  183. <img src="@/assets/noShipping.png" alt="" style="width: 100px;">
  184. <p style="color: #9EA3AA;">抱歉,没有符合条件的船期!</p>
  185. </div>
  186. </div>
  187. <div class="stepBarIcon" v-if="estimaTe">
  188. <div class="iconShip">
  189. <img src="@/assets/ship.png" style="height: 100%;" alt="">
  190. <img src="@/assets/ship.png" style="height: 100%;" alt="">
  191. </div>
  192. <div class="stepBarLine">
  193. <div v-for="item in 5"></div>
  194. </div>
  195. <!-- 文本地点-->
  196. <div class="stepBarText">
  197. <div>
  198. <p>{{ estimaTe.portofloadidName }}</p>
  199. <div>
  200. <p>预计开航</p>
  201. <p>{{ estimaTe.fEtd }}</p>
  202. </div>
  203. </div>
  204. <div v-if="!estimaTe.portoftransshipmentName">
  205. <p>{{ estimaTe.portoftransshipmentName }}</p>
  206. <!-- <div>
  207. <p>预计抵港</p>
  208. <p>2022-03-24</p>
  209. <p>预计开航</p>
  210. <p>2022-03-24</p>
  211. </div> -->
  212. </div>
  213. <div>
  214. <p>{{ estimaTe.portofdischargeidName }}</p>
  215. <div>
  216. <p>预计抵港</p>
  217. <p>{{ estimaTe.fEta }}</p>
  218. </div>
  219. </div>
  220. </div>
  221. </div>
  222. </div>
  223. <!-- 收发货人信息-->
  224. <div class="feeBox" style="">
  225. <!-- 发货信息-->
  226. <div class="titleBox_receive" style="margin-right: 4px;">
  227. <div>
  228. <span class="redBlock">&nbsp;</span>
  229. <span>发货信息</span>
  230. </div>
  231. <div class="receiveInfo">
  232. <el-form-item label="发货人全称" prop="fShippername">
  233. <el-input v-model="form.fShippername" :disabled="noEditing"/>
  234. </el-form-item>
  235. <el-form-item label="发货人联系人">
  236. <el-input v-model="form.fShipperattn" :disabled="noEditing"/>
  237. </el-form-item>
  238. <el-form-item label="发货人电话">
  239. <el-input v-model="form.fShippertel" :disabled="noEditing"/>
  240. </el-form-item>
  241. </div>
  242. </div>
  243. <!-- 收货信息-->
  244. <div class="titleBox_receive" style="padding-right: 10px">
  245. <div>
  246. <span class="redBlock">&nbsp;</span>
  247. <span>收货信息</span>
  248. </div>
  249. <div class="receiveInfo">
  250. <el-form-item label="收货人全称" prop="fConsigneername">
  251. <el-input v-model="form.fConsigneername" :disabled="noEditing"/>
  252. </el-form-item>
  253. <el-form-item label="收货人联系人">
  254. <el-input v-model="form.fConsigneeattn" :disabled="noEditing"/>
  255. </el-form-item>
  256. <el-form-item label="收货人电话">
  257. <el-input v-model="form.fConsigneetel" :disabled="noEditing"/>
  258. </el-form-item>
  259. </div>
  260. </div>
  261. </div>
  262. <el-form :model="list" ref="list" :rules="rulEs" label-position="top">
  263. <!-- 货物信息-->
  264. <!-- 基本资料-->
  265. <div class="moduleStyle">
  266. <div class="titleBox">
  267. <span class="redBlock">&nbsp;</span>
  268. <span>货物信息</span>
  269. </div>
  270. <div style="display:flex;justify-content:space-around;flex-wrap: wrap;margin: 10px 20px">
  271. <div class="mainModules">
  272. <el-form-item label="货物名称" prop="fGoodsid">
  273. <el-select
  274. v-model="list.fGoodsid"
  275. filterable
  276. remote
  277. @change="select"
  278. style="width: 80%;"
  279. class="elSelect"
  280. placeholder="请输入模糊查找货物名称"
  281. :disabled="noEditing"
  282. >
  283. <el-scrollbar>
  284. <el-option
  285. v-for="(dict, index) in goods"
  286. :key="dict.fId"
  287. :label="dict.fName"
  288. :value="dict.fId"
  289. ></el-option>
  290. </el-scrollbar>
  291. </el-select>
  292. </el-form-item>
  293. </div>
  294. <div class="mainModules">
  295. <el-form-item label="货类">
  296. <el-input style="width:80%;" v-model="typeGoods" :disabled="noEditing"/>
  297. </el-form-item>
  298. </div>
  299. <div class="mainModules">
  300. <el-form-item label="包装类型" prop="fPackageid">
  301. <el-select style="width:80%;" placeholder="请选择"
  302. v-model="list.fPackageid" :disabled="noEditing">
  303. <el-option
  304. v-for="(dict, index) in packing"
  305. :key="dict.dictValue"
  306. :label="dict.dictLabel"
  307. :value="dict.dictValue"
  308. ></el-option>
  309. </el-select>
  310. </el-form-item>
  311. </div>
  312. <div class="mainModules">
  313. <el-form-item label="箱型" prop="fCntrid">
  314. <el-select style="width:80%;" placeholder="请选择"
  315. v-model="list.fCntrid" @change="seleEt" :disabled="noEditing">
  316. <el-option
  317. v-for="(dict, index) in container"
  318. :key="dict.fId"
  319. :label="dict.fNo"
  320. :value="dict.fId"
  321. ></el-option>
  322. </el-select>
  323. </el-form-item>
  324. </div>
  325. <div class="mainModules">
  326. <el-form-item label="箱量" prop="fCntrcount">
  327. <el-input style="width:80%;" :disabled="noEditing" v-model.number="list.fCntrcount" placeholder="请输入箱量" :maxlength="3" @input="calculation" oninput='this.value=this.value.replace(/[^\d.]/g,"")'/>
  328. </el-form-item>
  329. </div>
  330. <div class="mainModules">
  331. <el-form-item label="单箱重量(吨)" prop="fCntrweight">
  332. <el-input style="width:80%;" :disabled="noEditing" v-model="list.fCntrweight" @input="cntrWeight"/>
  333. </el-form-item>
  334. </div>
  335. <div class="mainModules">
  336. <el-form-item label="箱态" prop="fCntrstatus">
  337. <el-select style="width:80%;" placeholder="请选择"
  338. v-model="list.fCntrstatus" :disabled="noEditing">
  339. <el-option
  340. v-for="(dict, index) in fStatus"
  341. :key="dict.dictValue"
  342. :label="dict.dictLabel"
  343. :value="dict.dictValue"
  344. ></el-option>
  345. </el-select>
  346. </el-form-item>
  347. </div>
  348. <div class="mainModules">
  349. <el-form-item label="自备货柜" prop="fSoc">
  350. <el-select style="width:80%;" placeholder="请选择"
  351. v-model="list.fSoc" :disabled="noEditing">
  352. <el-option label="是" value="0"></el-option>
  353. <el-option label="否" value="1"></el-option>
  354. </el-select>
  355. </el-form-item>
  356. </div>
  357. <div class="mainModules" v-if="whether === true">
  358. <el-form-item label="设置温度(℃)">
  359. <el-input style="width:80%;" :disabled="noEditing" v-model="list.fTemperature" @input="temperature" oninput='this.value=this.value.replace(/[^\-?\d.]/g,"")'/>
  360. </el-form-item>
  361. </div>
  362. <div class="mainModules" v-if="whether === true">
  363. <el-form-item label="风门开度(%)">
  364. <el-input style="width:80%;" :disabled="noEditing" v-model.number="list.fDraught" @input="throttleOpening" oninput='this.value=this.value.replace(/[^\d.]/g,"")'/>
  365. </el-form-item>
  366. </div>
  367. <div class="mainModules" v-if="whether === true">
  368. <el-form-item label="湿度设置(%)">
  369. <el-input style="width:80%;" :disabled="noEditing" v-model="list.fHumidity" @input="throttleOpening" oninput='this.value=this.value.replace(/[^\d.]/g,"")'/>
  370. </el-form-item>
  371. </div>
  372. <div class="mainModules" v-if="whether === true">
  373. <el-form-item label="预冷要求">
  374. <el-select style="width:80%;" v-model="list.fPrecooling" :disabled="noEditing" placeholder="请选择">
  375. <el-option label="是" value="1"></el-option>
  376. <el-option label="否" value="2"></el-option>
  377. </el-select>
  378. </el-form-item>
  379. </div>
  380. <div class="mainModules">
  381. <el-form-item label="危险化学品" prop="fIfdanger">
  382. <el-select style="width:80%;" placeholder="请选择"
  383. v-model="list.fIfdanger" :disabled="noEditing">
  384. <el-option
  385. v-for="(dict, index) in dangerous"
  386. :key="dict.dictValue"
  387. :label="dict.dictLabel"
  388. :value="dict.dictValue"
  389. ></el-option>
  390. </el-select>
  391. <el-button type="text" style="display: inline; color: red" :disabled="noEditing">
  392. <i class="el-icon-upload el-icon--right"></i>
  393. </el-button>
  394. </el-form-item>
  395. </div>
  396. <div style="width: 72%;height: 100px;text-align: left;">
  397. <el-form-item label="备注" prop="remarks">
  398. <el-input style="width:80%;" placeholder="如有特殊需求,请再此说明" v-model="list.remarks" :disabled="noEditing"/>
  399. </el-form-item>
  400. </div>
  401. </div>
  402. </div>
  403. </el-form>
  404. <!-- 费用信息-->
  405. <div class="moduleStyle">
  406. <div class="titleBox">
  407. <span class="redBlock">&nbsp;</span>
  408. <span>费用信息</span>
  409. </div>
  410. <div class="basicData" style="display:flex;justify-content: flex-start">
  411. <div class="mainModules">
  412. <el-form-item label="是否办理保险" prop="fInsurance">
  413. <el-select style="width:80%;" placeholder="请选择"
  414. v-model="form.fInsurance" :disabled="noEditing">
  415. <el-option
  416. v-for="(dict, index) in insurance"
  417. :key="dict.dictValue"
  418. :label="dict.dictLabel"
  419. :value="dict.dictValue"
  420. ></el-option>
  421. </el-select>
  422. </el-form-item>
  423. </div>
  424. <div class="mainModules">
  425. <el-form-item label="保险货值(万元)" prop="fInsuranceamt">
  426. <el-input style="width:80%;" v-model="form.fInsuranceamt" :disabled="list.fInsurance == '2' ||noEditing"/>
  427. </el-form-item>
  428. </div>
  429. </div>
  430. </div>
  431. </el-form>
  432. <!-- 箱信息-->
  433. <div class="moduleStyle" v-if="boxInformation">
  434. <div class="titleBox">
  435. <span class="redBlock">&nbsp;</span>
  436. <span>箱信息</span>
  437. <el-button type="primary" size="mini" style="float: right;margin-right: 20px" @click="newlyAdded" :disabled="noEditing">新行
  438. </el-button>
  439. </div>
  440. <div class="basicData" style="display:flex;justify-content: flex-start">
  441. <el-table
  442. :data="tableData"
  443. style="width: 100%">
  444. <el-table-column
  445. prop="fCntrno"
  446. align="center"
  447. width="155"
  448. label="箱号">
  449. <template slot-scope="scope">
  450. <el-input v-model="scope.row.fCntrno" placeholder="请输入箱号" :disabled="noEditing"></el-input>
  451. </template>
  452. </el-table-column>
  453. <el-table-column
  454. prop="fSealno"
  455. align="center"
  456. width="135"
  457. label="铅封号">
  458. <template slot-scope="scope">
  459. <el-input v-model="scope.row.fSealno" placeholder="请输入铅封号" :disabled="noEditing"></el-input>
  460. </template>
  461. </el-table-column>
  462. <el-table-column
  463. prop="fCntrweight"
  464. align="center"
  465. width="80"
  466. label="单箱(吨)">
  467. <template slot-scope="scope">
  468. <el-input v-model="scope.row.fCntrweight" placeholder="请输入" :disabled="noEditing"></el-input>
  469. </template>
  470. </el-table-column>
  471. <el-table-column
  472. prop="fGoodsid"
  473. align="center"
  474. width="110"
  475. label="货名">
  476. <template slot-scope="scope">
  477. <!-- <el-input v-model="scope.row.fGoodsid" placeholder="请输入货名"></el-input>-->
  478. <el-select
  479. v-model="scope.row.fGoodsid"
  480. :disabled="noEditing"
  481. filterable
  482. remote
  483. @change="select"
  484. class="elSelect"
  485. placeholder="请输入"
  486. >
  487. <el-scrollbar>
  488. <el-option
  489. v-for="(dict, index) in goods"
  490. :key="dict.fId"
  491. :label="dict.fName"
  492. :value="dict.fId"
  493. ></el-option>
  494. </el-scrollbar>
  495. </el-select>
  496. </template>
  497. </el-table-column>
  498. <el-table-column
  499. prop="fPackageid"
  500. align="center"
  501. width="100"
  502. label="包装类型">
  503. <template slot-scope="scope">
  504. <!-- <el-input v-model="scope.row.fGoodsid" placeholder="请输入货名"></el-input>-->
  505. <el-select slot="prepend" placeholder="请选" v-model="scope.row.fPackageid" :disabled="noEditing">
  506. <el-option
  507. v-for="(dict, index) in packing"
  508. :key="dict.dictValue"
  509. :label="dict.dictLabel"
  510. :value="dict.dictValue"
  511. ></el-option>
  512. </el-select>
  513. </template>
  514. </el-table-column>
  515. <el-table-column
  516. prop="fCntrid"
  517. align="center"
  518. width="105"
  519. label="箱型">
  520. <template slot-scope="scope">
  521. <!-- <el-input v-model="scope.row.fGoodsid" placeholder="请输入货名"></el-input>-->
  522. <el-select slot="prepend" placeholder="请选择" v-model="scope.row.fCntrid" :disabled="noEditing">
  523. <el-option
  524. v-for="(dict, index) in container"
  525. :key="dict.fId"
  526. :label="dict.fNo"
  527. :value="dict.fId"
  528. ></el-option>
  529. </el-select>
  530. </template>
  531. </el-table-column>
  532. <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
  533. <template slot-scope="scope">
  534. <el-button
  535. size="mini"
  536. type="text"
  537. icon="el-icon-delete"
  538. :disabled="noEditing"
  539. @click.native.prevent="deleteRow(scope.$index, tableData)"
  540. >删除
  541. </el-button>
  542. </template>
  543. </el-table-column>
  544. </el-table>
  545. </div>
  546. </div>
  547. </div>
  548. <!-- 右基本资料-->
  549. <div class="costCalculation">
  550. <div class="costModuleStyle" style="">
  551. <div class="titleBox">
  552. <span class="redBlock">&nbsp;</span>
  553. <span>费用计算</span>
  554. </div>
  555. <div class="mainBox">
  556. <p>
  557. <span>箱型</span>
  558. <span v-if="boxType">{{boxType}}</span>
  559. <span v-else>---</span>
  560. </p>
  561. <p>
  562. <span>箱量</span>
  563. <span>¥{{cntrcount}}</span>
  564. </p>
  565. </div>
  566. <div class="mainBox" style="border-bottom: 1px solid #E8E8E8">
  567. <p>
  568. <span>海运服务费</span>
  569. <span>¥0</span>
  570. </p>
  571. <p>
  572. <span>代理进口杂费合计</span>
  573. <span>¥0</span>
  574. </p>
  575. <p>
  576. <span>代理出口杂费合计</span>
  577. <span>¥0</span>
  578. </p>
  579. <p>
  580. <span>THC代收</span>
  581. <span>¥0</span>
  582. </p>
  583. <p>
  584. <span>燃油附加费</span>
  585. <span>¥0</span>
  586. </p>
  587. </div>
  588. <div class="mainBox" style="border-bottom: none">
  589. <p>
  590. <span>保险费</span>
  591. <span>¥{{ form.fInsuranceamt }}</span>
  592. </p>
  593. </div>
  594. </div>
  595. <div class="confirmOrder" @click="confirmOrder" v-if="boxStatus">
  596. 确认下单
  597. </div>
  598. <div class="confirmOrder" @click="submit" v-else v-show="!noEditing">
  599. 提交箱信息
  600. </div>
  601. </div>
  602. <el-dialog
  603. title="请选择船期"
  604. :visible.sync="dialogVisible"
  605. :close-on-press-escape="false"
  606. :close-on-click-modal="false"
  607. width="80%"
  608. style="text-align: left"
  609. :before-close="handleClose">
  610. <el-table
  611. :data="estimated"
  612. style="width: 100%"
  613. :header-cell-style="{textAlign: 'center'}"
  614. :cell-style="{ textAlign: 'center' }">
  615. <el-table-column
  616. prop="fEta"
  617. label="预计开航">
  618. </el-table-column>
  619. <el-table-column
  620. prop="fEtd"
  621. label="预计抵港">
  622. </el-table-column>
  623. <el-table-column
  624. prop="fCutoffdate"
  625. label="截港日期">
  626. </el-table-column>
  627. <el-table-column
  628. prop="pidName"
  629. label="船名航次">
  630. <template slot-scope="scope">
  631. {{scope.row.pidName}}&nbsp;&nbsp;&nbsp;{{scope.row.fNo}}
  632. </template>
  633. </el-table-column>
  634. <el-table-column
  635. prop="twenty"
  636. label="20GP">
  637. </el-table-column>
  638. <el-table-column
  639. prop="fortyHc"
  640. label="40HC">
  641. </el-table-column>
  642. <el-table-column
  643. prop="fortyRh"
  644. label="40RH">
  645. </el-table-column>
  646. <el-table-column
  647. label="操作">
  648. <template slot-scope="scope">
  649. <el-button type="primary" @click="booking(scope.row)">订舱</el-button>
  650. </template>
  651. </el-table-column>
  652. </el-table>
  653. </el-dialog>
  654. </div>
  655. </template>
  656. <script>
  657. import { request } from '../../request/request';
  658. export default {
  659. name: 'contractPlacing',
  660. data() {
  661. return {
  662. boxType:'',
  663. cntrcount:0,
  664. noEditing:false,
  665. rules: {
  666. fLoadportid: [{ required: true, message: " ", trigger: "blur" }],
  667. fDestportid: [{ required: true, message: " ", trigger: "blur" }],
  668. fBsdate: [{ required: true, message: " ", trigger: "blur" }],
  669. fServiceitems: [{ required: true, message: " ", trigger: "blur" }],
  670. fPaymode: [{ required: true, message: " ", trigger: "blur" }],
  671. fInvoceobj: [{ required: true, message: " ", trigger: "blur" }],
  672. fLaneid: [{ required: true, message: " ", trigger: "blur" }],
  673. fSign: [{ required: true, message: " ", trigger: "blur" }],
  674. fDetentioncargo: [{ required: true, message: " ", trigger: "blur" }],
  675. fShippername: [{ required: true, message: " ", trigger: "blur" }],
  676. fShipperattn: [{ required: true, message: " ", trigger: "blur" }],
  677. fShippertel: [{ required: true, message: " ", trigger: "blur" }],
  678. fConsigneername: [{ required: true, message: " ", trigger: "blur" }],
  679. fConsigneeattn: [{ required: true, message: " ", trigger: "blur" }],
  680. fConsigneetel: [{ required: true, message: " ", trigger: "blur" }],
  681. fInsurance: [{ required: true, message: " ", trigger: "blur" }],
  682. fInsuranceamt: [{ required: true, message: " ", trigger: "blur" }],
  683. },
  684. rulEs:{
  685. fGoodsid: [{ required: true, message: " ", trigger: "blur" }],
  686. fPackageid: [{ required: true, message: " ", trigger: "blur" }],
  687. fCntrid: [{ required: true, message: " ", trigger: "blur" }],
  688. fCntrcount: [{ required: true, message: " ", trigger: "blur" }],
  689. fCntrweight: [{ required: true, message: " ", trigger: "blur" }],
  690. fCntrstatus: [{ required: true, message: " ", trigger: "blur" }],
  691. fSoc: [{ required: true, message: " ", trigger: "blur" }],
  692. fIfdanger: [{ required: true, message: " ", trigger: "blur" }],
  693. },
  694. fMblnoOptions: [],
  695. paymentMethod: [],
  696. estimated: [],
  697. goods: [],
  698. dialogVisible: false,
  699. transport: [],
  700. insurance: [],
  701. drawee: [],
  702. packing: [],
  703. rouTe: [],
  704. boxInformation: false,
  705. tableData: [],
  706. container: [],
  707. form: {
  708. fInsuranceamt:0,
  709. fInsurance:'1'
  710. },
  711. etentioncargo:[],
  712. estimaTe: '',
  713. list: {},
  714. typeGoods: '',
  715. whether: false,
  716. dangerous: [],
  717. boxStatus: true,
  718. fStatus:[],
  719. cEsign:[]
  720. };
  721. },
  722. created() {
  723. this.dictionary('f_paymode');
  724. this.dictionary('f_invoceobj');
  725. this.dictionary('f_insurance');
  726. this.dictionary('f_serviceitems');
  727. this.dictionary('f_packageid');
  728. this.dictionary('f_ifdanger');
  729. this.dictionary('f_updateEF');
  730. this.dictionary('f_sign');
  731. this.dictionary('f_detentioncargo');
  732. this.handleQuery();
  733. this.queryGoods();
  734. this.queryContainer();
  735. this.routeGood();
  736. if (this.$route.query.data) {
  737. this.detailsInquiry(this.$route.query.data);
  738. this.boxInformation = true;
  739. this.boxStatus = false;
  740. }else if (this.$route.query.res){
  741. let data = JSON.parse(this.$route.query.res)
  742. this.form.fLoadportid = data.fPortofloadid
  743. this.form.fDestportid = data.fDistinationid
  744. this.$set(this.form, "fBsdate", data.fEtd);
  745. this.estimatedTime()
  746. }
  747. },
  748. methods: {
  749. cntrWeight(res){
  750. if (res < 40 && res > 0){
  751. return
  752. }else if( res == '' || res == null){
  753. return;
  754. } else {
  755. this.list.fCntrweight = ''
  756. this.$message({
  757. showClose: true,
  758. message: '单箱重量应在0-40吨之间',
  759. type: 'error',
  760. offset:90
  761. });
  762. }
  763. },
  764. temperature(res){
  765. console.log(res);
  766. if (res < 20 && res > -30){
  767. }else if(res == '-'){
  768. }else {
  769. this.list.fTemperature = ''
  770. this.$message({
  771. showClose: true,
  772. message: '冷藏箱温度为-30℃至20℃之间的整数',
  773. type: 'error',
  774. offset:90
  775. });
  776. }
  777. },
  778. throttleOpening(res){
  779. if (res <= 100){
  780. }else {
  781. this.list.fDraught = ''
  782. this.$message({
  783. showClose: true,
  784. message: '不能大于100%或小于0%',
  785. type: 'error',
  786. offset:90
  787. });
  788. }
  789. },
  790. newlyAdded() {
  791. console.log(this.tableData);
  792. this.tableData.push({
  793. fCntrno: '',
  794. fSealno: '',
  795. fCntrweight: '',
  796. fGoodsid: '',
  797. fPackageid:'',
  798. fCntrid:''
  799. });
  800. },
  801. deleteRow(index, rows) {
  802. rows.splice(index, 1);
  803. },
  804. detailsInquiry(fId) {
  805. request({
  806. url: '/khwarehouse/warehousebills/webVersionOrder',
  807. method: 'post',
  808. data: {
  809. fId: fId
  810. }
  811. })
  812. .then(res => {
  813. console.log(res.data.rows[0]);
  814. this.form = res.data.rows[0];
  815. if (this.form.fBillstatus >= 11){
  816. this.noEditing = true
  817. }
  818. this.form.fPaymode = this.form.fPaymode +''
  819. this.form.fSign = this.form.fSign +''
  820. this.form.fDetentioncargo = this.form.fDetentioncargo +''
  821. this.estimaTe = res.data.rows[0].tVoyageL;
  822. this.list = res.data.rows[0].tWarehousebillsCntrList[0];
  823. this.typeGoods = res.data.rows[0].tWarehousebillsCntrList[0].typeidName;
  824. if (res.data.rows[0].tWarehousebillsCntritemsList){
  825. this.tableData = res.data.rows[0].tWarehousebillsCntritemsList
  826. }
  827. })
  828. .catch(err => {
  829. console.log(err);
  830. });
  831. },
  832. routeGood() {
  833. request({
  834. url: '/shipping/address/selectAirLineName',
  835. method: 'get',
  836. })
  837. .then(res => {
  838. console.log(res);
  839. this.rouTe = res.data.rows;
  840. })
  841. .catch(err => {
  842. console.log(err);
  843. });
  844. },
  845. booking(res) {
  846. if (res) {
  847. this.estimaTe = res;
  848. this.form.fVoyid = this.estimaTe.fId;
  849. this.form.fVslid = this.estimaTe.fPid;
  850. this.dialogVisible = false
  851. }
  852. },
  853. submit() {
  854. let formData = new window.FormData();
  855. formData.append('tWarehousebills', JSON.stringify({ fId:this.form.fId }));
  856. formData.append('tWarehousebillsCntritems', JSON.stringify(this.tableData));
  857. request({
  858. url: '/khwarehouse/warehousebills/submitMakingMessage',
  859. method: 'post',
  860. data: formData
  861. }).then(res => {
  862. // console.log(res);
  863. if (res.data.code === 500){
  864. // console.log(res.data.msg);
  865. // this.$message.error(res.data.msg);
  866. }else {
  867. this.goods = res.data.data;
  868. this.$router.push({
  869. path: '/',
  870. });
  871. }
  872. }).catch(err => {
  873. // console.log(err);
  874. this.$message.error(err);
  875. });
  876. },
  877. queryGoods() {
  878. request({
  879. url: '/khwarehouse/warehousebills/getGoodName',
  880. method: 'post',
  881. })
  882. .then(res => {
  883. console.log(res);
  884. this.goods = res.data.data;
  885. })
  886. .catch(err => {
  887. this.$message.error('未知错误');
  888. });
  889. },
  890. calculation(){
  891. for (let item in this.container){
  892. if (this.container[item].fId == this.list.fCntrid){
  893. request({
  894. url: '/shipping/items/containerPrice/',
  895. method: 'post',
  896. data:{
  897. cntridName:this.container[item].fNo,
  898. fPortofloadid:this.form.fLoadportid,
  899. fDistinationid:this.form.fDestportid,
  900. fEtd:this.form.fBsdate
  901. }
  902. }).then(res => {
  903. console.log(res);
  904. let number = Number(res.data.data[0]) * Number(this.list.fCntrcount)
  905. if (number){
  906. this.cntrcount = number
  907. }else {
  908. this.cntrcount = 0
  909. }
  910. }).catch(err => {
  911. console.log(err);
  912. });
  913. }
  914. }
  915. },
  916. queryContainer() {
  917. request({
  918. url: '/shipping/cntr/selectRcntrName',
  919. method: 'get',
  920. }).then(res => {
  921. // console.log(res);
  922. this.container = res.data.rows;
  923. })
  924. .catch(err => {
  925. console.log(err);
  926. });
  927. },
  928. handleQuery() {
  929. request({
  930. url: '/shipping/address/selectPortName',
  931. method: 'get',
  932. params: {
  933. fName: this.form.fLoadportid
  934. }
  935. })
  936. .then(res => {
  937. // console.log(res);
  938. this.fMblnoOptions = res.data.rows;
  939. // console.log(this.fMblnoOptions);
  940. })
  941. .catch(err => {
  942. console.log(err);
  943. });
  944. },
  945. estimatedTime() {
  946. // console.log(this.form.fLoadportid, this.form.fDestportid);
  947. if (this.form.fLoadportid && this.form.fDestportid) {
  948. request({
  949. url: 'shipping/voyage/selectMessage',
  950. method: 'post',
  951. data: {
  952. fPortofloadid: this.form.fLoadportid,
  953. fDistinationid: this.form.fDestportid
  954. }
  955. }).then(res => {
  956. let data = res.data.rows;
  957. if (data.length !== 0) {
  958. this.estimated = data;
  959. this.estimaTe = data[0];
  960. this.form.fVoyid = this.estimaTe.fId;
  961. this.form.fVslid = this.estimaTe.fPid;
  962. }
  963. }).catch(err => {
  964. console.log(err);
  965. });
  966. }
  967. },
  968. dictionary(dictType) {
  969. request({
  970. url: '/system/dict/data/type/' + dictType,
  971. method: 'get',
  972. })
  973. .then(res => {
  974. // console.log(res);
  975. switch (dictType) {
  976. case 'f_paymode':
  977. this.paymentMethod = res.data.data;
  978. break;
  979. case 'f_invoceobj':
  980. this.drawee = res.data.data;
  981. break;
  982. case 'f_insurance':
  983. this.insurance = res.data.data;
  984. break;
  985. case 'f_serviceitems':
  986. this.transport = res.data.data;
  987. break;
  988. case 'f_packageid':
  989. this.packing = res.data.data;
  990. break;
  991. case 'f_ifdanger':
  992. this.dangerous = res.data.data;
  993. break;
  994. case 'f_updateEF':
  995. this.fStatus = res.data.data;
  996. break;
  997. case 'f_sign':
  998. this.cEsign = res.data.data;
  999. break;
  1000. case 'f_detentioncargo':
  1001. this.etentioncargo = res.data.data;
  1002. break;
  1003. default:
  1004. break;
  1005. }
  1006. })
  1007. .catch(err => {
  1008. console.log(err);
  1009. });
  1010. },
  1011. confirmOrder() {
  1012. this.$refs["form"].validate((valid) => {
  1013. if (valid) {
  1014. console.log(valid);
  1015. this.$refs["list"].validate((valid) => {
  1016. if (valid) {
  1017. let formData = new window.FormData();
  1018. formData.append('tWarehousebills', JSON.stringify(this.form));
  1019. formData.append('tWarehousebillsCntr', JSON.stringify([this.list]));
  1020. request({
  1021. url: '/khwarehouse/warehousebills/submitPlantMessage',
  1022. method: 'post',
  1023. data: formData
  1024. })
  1025. .then(res => {
  1026. if (res.data.code === 200){
  1027. this.$message.success(res.data.msg);
  1028. this.$router.push({
  1029. path: '/',
  1030. });
  1031. }
  1032. console.log(res);
  1033. })
  1034. .catch(err => {
  1035. console.log(err);
  1036. });
  1037. } else {
  1038. console.log('error submit!!');
  1039. return false;
  1040. }
  1041. });
  1042. } else {
  1043. console.log('error submit!!');
  1044. return false;
  1045. }
  1046. });
  1047. },
  1048. handleClose() {
  1049. this.dialogVisible = false
  1050. },
  1051. select(id) {
  1052. for (let item in this.goods) {
  1053. if (this.goods[item].fId === id) {
  1054. this.typeGoods = this.goods[item].typeName;
  1055. }
  1056. }
  1057. },
  1058. seleEt(id) {
  1059. console.log(id);
  1060. // boxType
  1061. console.log(this.container);
  1062. for (let item in this.container) {
  1063. if (this.container[item].fId === id) {
  1064. this.boxType = this.container[item].fNo
  1065. this.calculation()
  1066. if (this.container[item].fType === 2){
  1067. this.whether = true;
  1068. return
  1069. }else {
  1070. this.whether = false;
  1071. return
  1072. }
  1073. }
  1074. }
  1075. }
  1076. }
  1077. };
  1078. </script>
  1079. <style scoped lang="scss">
  1080. .el-select{
  1081. > > > .el-input__inner {
  1082. border: none;
  1083. border-bottom: 1px solid #ccc;
  1084. border-radius: 0;
  1085. }
  1086. }
  1087. .el-input {
  1088. /deep/ .el-input__inner {
  1089. border: none;
  1090. border-bottom: 1px solid #ccc;
  1091. border-radius: 0;
  1092. }
  1093. }
  1094. .mainModules > > > .el-input__inner {
  1095. border: none;
  1096. border-bottom: 1px solid #ccc;
  1097. border-radius: 0;
  1098. }
  1099. .moduleStyle {
  1100. background: #FFFFFF;
  1101. box-shadow: 0px 4px 13px 0px rgba(200, 200, 200, 0.33);
  1102. width: 75%;
  1103. margin-bottom: 10px;
  1104. }
  1105. .titleBox {
  1106. padding-left: 30px;
  1107. width: 100%;
  1108. text-align: left;
  1109. padding: 10px;
  1110. font-size: 20px
  1111. }
  1112. .feeBox {
  1113. display: flex;
  1114. justify-content: space-between;
  1115. width: 75%;
  1116. margin-bottom: 10px;
  1117. }
  1118. .titleBox_receive {
  1119. padding-left: 30px;
  1120. width: 50%;
  1121. text-align: left;
  1122. padding: 12px;
  1123. font-size: 20px;
  1124. background: #FFFFFF;
  1125. box-shadow: 0px 4px 13px 0px rgba(200, 200, 200, 0.44);
  1126. }
  1127. .redBlock {
  1128. display: inline-block;
  1129. background-color: red;
  1130. width: 5px;
  1131. margin-right: 10px
  1132. }
  1133. .basicData {
  1134. display: flex;
  1135. justify-content: space-around;
  1136. flex-wrap: wrap;
  1137. margin: 10px 20px
  1138. }
  1139. .mainModules {
  1140. width: 24%;
  1141. height: 100px;
  1142. text-align: left;
  1143. }
  1144. .mainModules > span {
  1145. margin-left: 20px;
  1146. color: #A3A7AD;
  1147. }
  1148. .stepBarIcon {
  1149. margin: 10px;
  1150. padding: 20px 0 40px 0;
  1151. display: flex;
  1152. flex-direction: column;
  1153. align-items: center
  1154. }
  1155. .iconShip {
  1156. width: 35%;
  1157. display: flex;
  1158. justify-content: space-between
  1159. }
  1160. .iconShip {
  1161. img {
  1162. width: 20px
  1163. }
  1164. }
  1165. .stepBarLine {
  1166. width: 80%;
  1167. display: flex;
  1168. align-items: center;
  1169. }
  1170. .stepBarLine {
  1171. div:nth-child(odd) {
  1172. background-color: red;
  1173. width: 8px;
  1174. height: 8px;
  1175. border-radius: 50%;
  1176. display: inline-block
  1177. }
  1178. div:nth-child(even) {
  1179. width: 50%;
  1180. height: 2px;
  1181. background-color: red;
  1182. display: inline-block;
  1183. }
  1184. }
  1185. .stepBarText {
  1186. display: flex;
  1187. justify-content: space-between;
  1188. width: 90%;
  1189. div {
  1190. div {
  1191. color: #848484;
  1192. display: flex;
  1193. flex-direction: column;
  1194. align-items: center;
  1195. p:nth-child(odd) {
  1196. width: 70px;
  1197. margin: 0
  1198. }
  1199. p:nth-child(even) {
  1200. margin: 0
  1201. }
  1202. }
  1203. }
  1204. }
  1205. .receiveInfo {
  1206. margin: 30px auto;
  1207. }
  1208. .el-form-item>>>.el-form-item__label{
  1209. padding: 0px;
  1210. }
  1211. .costCalculation {
  1212. width: 25%;
  1213. position: fixed;
  1214. right: 4%;
  1215. .costModuleStyle {
  1216. background: #FFFFFF;
  1217. box-shadow: 0px 4px 13px 0px rgba(200, 200, 200, 0.44);
  1218. }
  1219. .titleBox {
  1220. .redBlock {
  1221. display: inline-block;
  1222. background-color: red;
  1223. width: 5px;
  1224. margin-right: 10px
  1225. }
  1226. }
  1227. .mainBox {
  1228. padding: 10px;
  1229. margin: 0 20px 0 20px;
  1230. border-bottom: 1px dashed #E8E8E8;
  1231. color: #71757A;
  1232. p {
  1233. display: flex;
  1234. justify-content: space-between;
  1235. span:nth-child(even) {
  1236. color: #000;
  1237. }
  1238. }
  1239. }
  1240. }
  1241. .confirmOrder {
  1242. background: red;
  1243. height: 70px;
  1244. margin-top: 20px;
  1245. text-align: center;
  1246. line-height: 70px;
  1247. color: white;
  1248. font-size: 20px;
  1249. }
  1250. .confirmOrder:hover {
  1251. cursor: pointer;
  1252. }
  1253. </style>
  1254. <style>
  1255. .el-form-item.is-error .el-input__inner, .el-form-item.is-error .el-input__inner:focus, .el-form-item.is-error .el-textarea__inner, .el-form-item.is-error .el-textarea__inner:focus, .el-message-box__input input.invalid, .el-message-box__input input.invalid:focus {
  1256. border-color: #F56C6C;
  1257. }
  1258. </style>