index.vue 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698
  1. <template>
  2. <div class="app-container">
  3. <el-menu
  4. :default-active="activeIndex"
  5. class="el-menu-demo"
  6. mode="horizontal"
  7. @select="handleSelect"
  8. text-color="#000"
  9. active-text-color="#ffd04b">
  10. <el-menu-item index="0">全部</el-menu-item>
  11. <el-menu-item index="1">待审核</el-menu-item>
  12. <el-menu-item index="2">订舱审核通过</el-menu-item>
  13. <el-menu-item index="3">待配船</el-menu-item>
  14. <el-menu-item index="4">配船审核通过</el-menu-item>
  15. <el-menu-item index="5">已撤销</el-menu-item>
  16. <el-menu-item index="6">已驳回</el-menu-item>
  17. <el-menu-item index="7">运单变更</el-menu-item>
  18. </el-menu>
  19. <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px" style="margin-top:20px">
  20. <el-row>
  21. <el-form-item label="订舱号" prop="fBillno">
  22. <el-input size="small" width="240px" clearable v-model="queryParams.fBillno"/>
  23. </el-form-item>
  24. <el-form-item label="运输条款" prop="fServiceitems">
  25. <el-select size="small" width="240px" clearable v-model="queryParams.fServiceitems">
  26. <el-option
  27. v-for="item in serviceitems"
  28. :key="item.dictValue"
  29. :label="item.dictLabel"
  30. :value="item.dictValue"/>
  31. </el-select>
  32. </el-form-item>
  33. <el-form-item label="收货人" prop="fConsigneername">
  34. <el-input size="small" width="240px" clearable v-model="queryParams.fConsigneername"/>
  35. </el-form-item>
  36. <el-form-item label="箱型" prop="fCntrid">
  37. <el-select size="small" v-model="queryParams.fCntrid" clearable :remote-method="cntrRemoteMethod">
  38. <el-option
  39. v-for="(dict, index) in container"
  40. :key="dict.fId"
  41. :label="dict.fNo"
  42. :value="dict.fId"
  43. ></el-option>
  44. </el-select>
  45. </el-form-item>
  46. <el-form-item label="箱量" prop="fCntrcount">
  47. <el-input size="small" width="240px" clearable v-model="queryParams.fCntrcount"/>
  48. </el-form-item>
  49. <el-form-item label="装货时间" prop="cLoadDate">
  50. <el-date-picker
  51. v-model="queryParams.cLoadDate"
  52. type="daterange"
  53. range-separator="至"
  54. value-format="yyyy-MM-dd"
  55. start-placeholder="开始日期"
  56. end-placeholder="结束日期">
  57. </el-date-picker>
  58. </el-form-item>
  59. </el-row>
  60. </el-form>
  61. <el-row :gutter="10" class="mb8">
  62. <div style="float: left">
  63. <el-button type="cyan" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
  64. <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
  65. </div>
  66. <div class="tabSetting">
  67. <right-toolbar
  68. :showSearch.sync="showSearch"
  69. @queryTable="getList"
  70. ></right-toolbar>
  71. <div style="margin: 0 12px">
  72. <el-button
  73. icon="el-icon-setting"
  74. size="mini"
  75. circle
  76. @click="showSetting = !showSetting"
  77. ></el-button>
  78. </div>
  79. </div>
  80. </el-row>
  81. <el-dialog title="提示" :visible.sync="showSetting" width="700px" v-dialogDrag>
  82. <template slot="title">
  83. <div class="avue-crud__dialog__header">
  84. <span class="el-dialog__title">
  85. <span style="display:inline-block;width:3px;height:20px;margin-right:5px; float: left;margin-top:2px"></span>
  86. </span>
  87. </div>
  88. </template>
  89. <div>配置排序列数据(拖动调整顺序)</div>
  90. <div style="margin-left: 17px">
  91. <el-checkbox
  92. v-model="allCheck"
  93. label="全选"
  94. @change="allChecked"
  95. ></el-checkbox>
  96. </div>
  97. <div style="padding: 4px; display: flex; justify-content: center">
  98. <draggable
  99. v-model="setRowList"
  100. group="site"
  101. animation="300"
  102. @start="onStart"
  103. @end="onEnd"
  104. handle=".indraggable"
  105. >
  106. <transition-group>
  107. <div
  108. v-for="item in setRowList"
  109. :key="item.surface"
  110. class="listStyle"
  111. >
  112. <div style="width: 500px" class="indraggable">
  113. <div class="progress" :style="{ width: item.width + 'px' }">
  114. <el-checkbox
  115. :label="item.name"
  116. v-model="item.checked"
  117. :true-label="0"
  118. :false-label="1"
  119. >{{ item.name }}
  120. </el-checkbox>
  121. </div>
  122. </div>
  123. <el-input-number
  124. v-model.number="item.width"
  125. controls-position="right"
  126. :min="1"
  127. :max="500"
  128. size="mini"
  129. ></el-input-number>
  130. </div>
  131. </transition-group>
  132. </draggable>
  133. </div>
  134. <span slot="footer" class="dialog-footer">
  135. <el-button @click="showSetting = false">取 消</el-button>
  136. <el-button @click="delRow" type="danger">重 置</el-button>
  137. <el-button type="primary" @click="save()">确 定</el-button>
  138. </span>
  139. </el-dialog>
  140. <el-table v-loading="loading" :data="corpsList" @selection-change="handleSelectionChange">
  141. <el-table-column type="selection" width="55" align="center" />
  142. <el-table-column label="行号" align="center" type="index" fixed/>
  143. <el-table-column
  144. v-for="(item, index) in getRowList"
  145. :key="index"
  146. :label="item.name"
  147. :width="item.width"
  148. :prop="item.label"
  149. align="center"
  150. :fixed="item.fixed"
  151. :show-overflow-tooltip="true"
  152. sortable
  153. >
  154. <template slot-scope="scope">
  155. <span v-if="item.label == 'fBillno'">{{scope.row.fBillno}}</span>
  156. <span v-if="item.label == 'fServiceitems'">{{scope.row.fServiceitems}}</span>
  157. <span v-if="item.label == 'fConsigneername'">{{scope.row.fConsigneername}}</span>
  158. <span v-if="item.label == 'fName'">{{scope.row.fName}}</span>
  159. <span v-if="item.label == 'fNo'">{{scope.row.fNo}}</span>
  160. <span v-if="item.label == 'fCntrcount'">{{scope.row.fCntrcount}}</span>
  161. <span v-if="item.label == 'fBsdate'">{{scope.row.fBsdate}}</span>
  162. <span v-if="item.label == 'fBillstatus'">{{scope.row.fBillstatus}}</span>
  163. <span v-if="item.label == 'vslName'">{{scope.row.vslName}}</span>
  164. <span v-if="item.label == 'voyNo'">{{scope.row.voyNo}}</span>
  165. <span v-if="item.label == 'fMblno'">{{scope.row.fMblno}}</span>
  166. <span v-if="item.label == 'corpName'">{{scope.row.corpName}}</span>
  167. <span v-if="item.label == 'goodsName'">{{scope.row.goodsName}}</span>
  168. <span v-if="item.label == 'createBy'">{{scope.row.createBy}}</span>
  169. <span v-if="item.label == 'createTime'">{{ (scope.row.createTime).slice(0,10) }}</span>
  170. <span v-if="item.label == 'loadportName'">{{scope.row.loadportName}}</span>
  171. <span v-if="item.label == 'moneyStatus'">{{scope.row.moneyStatus}}</span>
  172. </template>
  173. </el-table-column>
  174. <!-- <el-table-column label="订舱号" align="center" prop="fBillno"/>-->
  175. <!-- <el-table-column label="运输条款" align="center" prop="fServiceitems" />-->
  176. <!-- <el-table-column label="收货人" align="center" prop="fConsigneername"/>-->
  177. <!-- <el-table-column label="航线" align="center" prop="fName"/>-->
  178. <!-- <el-table-column label="箱型" align="center" prop="fNo"/>-->
  179. <!-- <el-table-column label="箱量" align="center" prop="fCntrcount"/>-->
  180. <!-- <el-table-column label="装货时间" align="center" prop="fBsdate"/>-->
  181. <el-table-column label="操作" fixed="right" align="center" class-name="small-padding fixed-width" min-width="160px">
  182. <template slot-scope="scope">
  183. <el-button
  184. size="mini"
  185. type="text"
  186. icon="el-icon-edit"
  187. @click="handleUpdate(scope.row)"
  188. v-hasPermi="['warehouse:warehousebills:webVersionOrderDetails']"
  189. >查看</el-button>
  190. <!-- <el-button-->
  191. <!-- size="mini"-->
  192. <!-- type="text"-->
  193. <!-- icon="el-icon-delete"-->
  194. <!-- @click="handleDelete(scope.row)"-->
  195. <!-- >移除</el-button>-->
  196. </template>
  197. </el-table-column>
  198. <!-- <el-table-column-->
  199. <!-- class-name="small-padding fixed-width"-->
  200. <!-- v-for="(item,index) in boxDistributionName"-->
  201. <!-- :key="item.index"-->
  202. <!-- :label="item"-->
  203. <!-- :value="item.index"-->
  204. <!-- :prop="item"-->
  205. <!-- >-->
  206. <!-- </el-table-column>-->
  207. </el-table>
  208. <pagination
  209. v-show="total>0"
  210. :total="total"
  211. :page.sync="queryParams.pageNum"
  212. :limit.sync="queryParams.pageSize"
  213. @pagination="getList"
  214. />
  215. </div>
  216. </template>
  217. <script>
  218. import { listCorps, getcntrName, delCorps, changeCorpsStatus,exportCorps } from "@/api/kaihe/domesticTrade/myOrder";
  219. import Cookies from 'js-cookie'
  220. import { addSet, resetModule, select } from '@/api/system/set'
  221. import Vue from 'vue'
  222. import draggable from "vuedraggable";
  223. Vue.directive('dialogDrag', {
  224. bind(el, binding, vnode, oldVnode) {
  225. const dialogHeaderEl = el.querySelector('.el-dialog__header')
  226. const dragDom = el.querySelector('.el-dialog')
  227. const enlarge = el.querySelector('.enlarge')
  228. dialogHeaderEl.style.cursor = 'move'
  229. // 获取原有属性 ie dom元素.currentStyle 火狐谷歌 window.getComputedStyle(dom元素, null);
  230. const sty = dragDom.currentStyle || window.getComputedStyle(dragDom, null)
  231. if(enlarge){
  232. enlarge.onclick = (e) => {
  233. dragDom.style.top = '0px'
  234. dragDom.style.left = '0px'
  235. }
  236. }
  237. dialogHeaderEl.onmousedown = (e) => {
  238. // 鼠标按下,计算当前元素距离可视区的距离
  239. const disX = e.clientX - dialogHeaderEl.offsetLeft
  240. const disY = e.clientY - dialogHeaderEl.offsetTop
  241. // 获取到的值带px 正则匹配替换
  242. let styL, styT
  243. // 注意在ie中 第一次获取到的值为组件自带50% 移动之后赋值为px
  244. if (sty.left.includes('%')) {
  245. styL = +document.body.clientWidth * (+sty.left.replace(/\%/g, '') / 100)
  246. styT = +document.body.clientHeight * (+sty.top.replace(/\%/g, '') / 100)
  247. } else {
  248. styL = +sty.left.replace(/\px/g, '')
  249. styT = +sty.top.replace(/\px/g, '')
  250. }
  251. document.onmousemove = function(e) {
  252. // 通过事件委托,计算移动的距离
  253. const l = e.clientX - disX
  254. const t = e.clientY - disY
  255. // 移动当前元素
  256. if ((t + styT) >= 0){
  257. dragDom.style.top = `${t + styT}px`
  258. }
  259. dragDom.style.left = `${l + styL}px`
  260. // 将此时的位置传出去
  261. // binding.value({x:e.pageX,y:e.pageY})
  262. }
  263. document.onmouseup = function(e) {
  264. document.onmousemove = null
  265. document.onmouseup = null
  266. }
  267. }
  268. }
  269. })
  270. export default {
  271. name: "myOrder",
  272. components: {
  273. draggable,
  274. },
  275. data() {
  276. return {
  277. activeIndex: '0',
  278. setRowList: [],
  279. getRowList: [],
  280. tableDate: [
  281. {
  282. surface: "1",
  283. label: "fBillno",
  284. name: "订舱号",
  285. fixed:"left",
  286. checked: 0,
  287. width: 120,
  288. },
  289. {
  290. surface: "2",
  291. label: "fServiceitems",
  292. name: "运输条款",
  293. fixed:"left",
  294. checked: 0,
  295. width: 120,
  296. },
  297. {
  298. surface: "3",
  299. label: "fConsigneername",
  300. name: "收货人",
  301. fixed:"left",
  302. checked: 0,
  303. width: 120,
  304. },
  305. {
  306. surface: "4",
  307. label: "fName",
  308. name: "航线",
  309. fixed:"left",
  310. checked: 0,
  311. width: 120,
  312. },
  313. {
  314. surface: "5",
  315. label: "fNo",
  316. name: "箱型",
  317. fixed:"left",
  318. checked: 0,
  319. width: 120,
  320. },
  321. {
  322. surface: "6",
  323. label: "fCntrcount",
  324. name: "箱量",
  325. fixed:"left",
  326. checked: 0,
  327. width: 120,
  328. },
  329. {
  330. surface: "7",
  331. label: "fBsdate",
  332. name: "装货时间",
  333. checked: 0,
  334. width: 120,
  335. },
  336. {
  337. surface: "8",
  338. label: "fBillstatus",
  339. name: "状态",
  340. checked: 0,
  341. width: 120,
  342. },
  343. {
  344. surface: "9",
  345. label: "vslName",
  346. name: "船名",
  347. checked: 0,
  348. width: 120,
  349. },
  350. {
  351. surface: "10",
  352. label: "voyNo",
  353. name: "航次",
  354. checked: 0,
  355. width: 120,
  356. },
  357. {
  358. surface: "11",
  359. label: "fMblno",
  360. name: "提单号",
  361. checked: 0,
  362. width: 120,
  363. },
  364. {
  365. surface: "12",
  366. label: "corpName",
  367. name: "订舱单位",
  368. checked: 0,
  369. width: 120,
  370. },
  371. {
  372. surface: "13",
  373. label: "goodsName",
  374. name: "货名",
  375. checked: 0,
  376. width: 120,
  377. },
  378. {
  379. surface: "14",
  380. label: "createBy",
  381. name: "订舱人",
  382. checked: 0,
  383. width: 120,
  384. },
  385. {
  386. surface: "15",
  387. label: "createTime",
  388. name: "订舱时间",
  389. checked: 0,
  390. width: 120,
  391. },
  392. {
  393. surface: "16",
  394. label: "loadportName",
  395. name: "起运港",
  396. checked: 0,
  397. width: 120,
  398. },
  399. {
  400. surface: "17",
  401. label: "destportName",
  402. name: "目的港",
  403. checked: 0,
  404. width: 120,
  405. },
  406. {
  407. surface: "18",
  408. label: "moneyStatus",
  409. name: "费用状态",
  410. checked: 0,
  411. width: 120,
  412. }
  413. ],
  414. //自定义列宽
  415. allCheck: false,
  416. showSetting:false,
  417. serviceitems:[],
  418. container:[],
  419. // 遮罩层
  420. loading: true,
  421. // 选中数组
  422. ids: [],
  423. // 非单个禁用
  424. single: true,
  425. // 非多个禁用
  426. multiple: true,
  427. // 显示搜索条件
  428. showSearch: true,
  429. // 总条数
  430. total: 0,
  431. // 客户详情表格数据
  432. corpsList: [],
  433. // 查询参数
  434. queryParams: {
  435. pageNum: 1,
  436. pageSize: 10,
  437. },
  438. };
  439. },
  440. created() {
  441. this.setRowList = this.tableDate;
  442. this.getRowList = this.tableDate;
  443. this.getList();
  444. this.cntrRemoteMethod()
  445. this.getDicts("f_serviceitems").then((response) => {
  446. if (response.data) {
  447. this.serviceitems = response.data;
  448. }
  449. });
  450. this.getRow()
  451. },
  452. activated() {
  453. this.getList()
  454. },
  455. methods: {
  456. handleSelect(key, keyPath) {
  457. if(key === '0'){
  458. this.queryParams = {
  459. pageNum: 1,
  460. pageSize: 10,
  461. }
  462. }else if(key === '1'){
  463. this.queryParams.fBillstatus = 4
  464. }else if(key === '2'){
  465. this.queryParams.fBillstatus = 6
  466. }else if(key === '3'){
  467. this.queryParams.fBillstatus = 9
  468. }else if(key === '4'){
  469. this.queryParams.fBillstatus = 11
  470. }else if(key === '7'){
  471. this.queryParams.fBillstatus = 12
  472. }
  473. listCorps(this.queryParams).then(response => {
  474. console.log(response)
  475. this.corpsList = response.rows;
  476. this.total = response.total;
  477. this.loading = false;
  478. });
  479. },
  480. //重置列表
  481. delRow() {
  482. this.data = {
  483. tableName: "我的订单",
  484. userId: Cookies.get("userName"),
  485. };
  486. resetModule(this.data).then((res) => {
  487. if (res.code == 200) {
  488. this.showSetting = false;
  489. this.setRowList = this.tableDate;
  490. this.getRowList = this.tableDate;
  491. }
  492. });
  493. },
  494. //列设置全选
  495. allChecked() {
  496. if (this.allCheck == true) {
  497. this.setRowList.map((e) => {
  498. return (e.checked = 0);
  499. });
  500. } else {
  501. this.setRowList.map((e) => {
  502. return (e.checked = 1);
  503. });
  504. }
  505. },
  506. //查询列数据
  507. getRow() {
  508. let that = this;
  509. this.data = {
  510. tableName: "我的订单",
  511. userId: Cookies.get("userName"),
  512. };
  513. select(this.data).then((res) => {
  514. if (res.data.length != 0) {
  515. this.getRowList = res.data.filter((e) => e.checked == 0);
  516. this.setRowList = res.data;
  517. this.setRowList = this.setRowList.reduce((res, item) => {
  518. res.push({
  519. surface: item.surface,
  520. label: item.label,
  521. name: item.name,
  522. checked: item.checked,
  523. width: item.width,
  524. fixed: item.fixed
  525. });
  526. return res;
  527. }, []);
  528. }
  529. });
  530. },
  531. //保存列设置
  532. save() {
  533. this.showSetting = false;
  534. this.data = {
  535. tableName: "我的订单",
  536. userId: Cookies.get("userName"),
  537. sysTableSetList: this.setRowList,
  538. };
  539. addSet(this.data).then((res) => {
  540. this.getRowList = this.setRowList.filter((e) => e.checked == 0);
  541. });
  542. },
  543. //开始拖拽事件
  544. onStart() {
  545. this.drag = true;
  546. },
  547. //拖拽结束事件
  548. onEnd() {
  549. this.drag = false;
  550. },
  551. //箱型下拉查询
  552. cntrRemoteMethod() {
  553. let queryParams = { pageNum: 1,};
  554. getcntrName(queryParams).then(response=>{
  555. console.log(response)
  556. this.container = response.rows
  557. })
  558. },
  559. /** 删除按钮操作 */
  560. handleDelete(row) {
  561. const fIds = row.fId || this.ids;
  562. this.$confirm('是否确认删除客户详情编号为"' + fIds + '"的数据项?', "警告", {
  563. confirmButtonText: "确定",
  564. cancelButtonText: "取消",
  565. type: "warning"
  566. }).then(function() {
  567. return delCorps(fIds);
  568. }).then(() => {
  569. this.getList();
  570. this.msgSuccess("删除成功");
  571. })
  572. },
  573. //查看跳转
  574. handleUpdate(row){
  575. console.log(row.fId)
  576. let res = {}
  577. res = {
  578. fId:row.fId
  579. }
  580. this.$router.push({
  581. path: "/domesticTrade/orderInformation",
  582. query: { data: JSON.stringify(res) },
  583. });
  584. },
  585. //模糊查询地点
  586. addressMethod(){
  587. let queryParams = { pageNum: 1,};
  588. getaddress(queryParams).then(response=>{
  589. this.addressOptions = response.rows
  590. })
  591. },
  592. /** 查询客户详情列表 */
  593. getList() {
  594. console.log(this.queryParams)
  595. listCorps(this.queryParams).then(response => {
  596. console.log(response)
  597. this.corpsList = response.rows;
  598. this.total = response.total;
  599. this.loading = false;
  600. });
  601. },
  602. // 从表重置
  603. contList() {
  604. this.contactList = []
  605. },
  606. // 状态修改
  607. handleStatusChange(row) {
  608. let text = row.fStatus === "0" ? "启用" : "停用";
  609. this.$confirm('确认要"' + text + '""' + row.fName + '"吗?', "警告", {
  610. confirmButtonText: "确定",
  611. cancelButtonText: "取消",
  612. type: "warning"
  613. }).then(function() {
  614. return changeCorpsStatus(row.fId, row.fStatus);
  615. }).then(() => {
  616. this.msgSuccess(text + "成功");
  617. }).catch(function() {
  618. row.fStatus = row.fStatus === "0" ? "1" : "0";
  619. });
  620. },
  621. /** 搜索按钮操作 */
  622. handleQuery() {
  623. this.queryParams.pageNum = 1;
  624. this.getList();
  625. },
  626. /** 重置按钮操作 */
  627. resetQuery() {
  628. this.queryParams = {
  629. fBillno:null,
  630. fServiceitems:null,
  631. fConsigneername:null,
  632. fCntrid:null,
  633. fCntrcount:null,
  634. cLoadDate:null,
  635. }
  636. this.resetForm("queryForm");
  637. this.handleQuery();
  638. },
  639. // 多选框选中数据
  640. handleSelectionChange(selection) {
  641. this.ids = selection.map(item => item.fId)
  642. this.single = selection.length!==1
  643. this.multiple = !selection.length
  644. },
  645. }
  646. };
  647. </script>
  648. <style lang="scss" scoped>
  649. .tabSetting {
  650. display: flex;
  651. justify-content: flex-end;
  652. }
  653. .listStyle {
  654. display: flex;
  655. border-top: 1px solid #dcdfe6;
  656. border-left: 1px solid #dcdfe6;
  657. border-right: 1px solid #dcdfe6;
  658. }
  659. .listStyle:last-child {
  660. border-bottom: 1px solid #dcdfe6;
  661. }
  662. .progress {
  663. display: flex;
  664. align-items: center;
  665. padding: 2px;
  666. background-color: rgba(0, 0, 0, 0.05);
  667. height: 100%;
  668. }
  669. </style>
  670. <style lang="scss">
  671. .el-table {
  672. .el-table__body-wrapper {
  673. z-index: 2;
  674. }
  675. }
  676. </style>