123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543 |
- <template>
- <div class="station scroll-y">
- <div class="station-head">
- <div class="station-head-title">运单基本信息</div>
- <div class="station-head-content flex">
- <div v-for="item in dataInfo" :key="item.id">{{item.name}}:{{item.value}}</div>
- </div>
- </div>
- <div class="station-status flex">
- <div class="station-status-info flex-wrap">
- <div class="manageTitle">运单跟踪信息</div>
- <div class="status">正常</div>
- </div>
- <div class="station-status-search flex-wrap">
- <TBtnGroup @columnSet="columnSet" :groupSet="groupSet" />
- <Search @clear="clear" @search="search" />
- </div>
- </div>
- <div class="station-list flex-wrap">
- <div class="station-list-left">
- <div class="title flex-wrap">
- <div class="title-list">航班号CA1001</div>
- <div class="title-list">出港: 深圳机场</div>
- <div class="title-list">日期:2022/09/10</div>
- </div>
- <Steps :datas="datas" />
- </div>
- <div class="station-list-right">
- <div class="title flex-wrap">
- <div class="title-list">出港: 深圳机场</div>
- <div class="title-list">日期:2022/09/10</div>
- </div>
- <Steps :datas="datas1" />
- </div>
- </div>
- <div class="station-list flex-wrap">
- <div class="station-list-left">
- <div class="title flex-wrap">
- <div class="title-list">航班号CA1001</div>
- <div class="title-list">出港: 深圳机场</div>
- <div class="title-list">日期:2022/09/10</div>
- </div>
- <Steps :datas="datas" />
- </div>
- <div class="station-list-right">
- <div class="title flex-wrap">
- <div class="title-list">出港: 深圳机场</div>
- <div class="title-list">日期:2022/09/10</div>
- </div>
- <Steps :datas="datas1" />
- </div>
- </div>
- <div class="station-table">
- <Table height="calc(100vh - 700px)" :tableHeader="state.waybillTableHeader" :tableData="tableData" @cell-click="cellClickHandler" />
- </div>
- <tableColumnSet :dialogVisible="state.dialogVisible" :columnList="state.waybillTableHeader" @setColumn="setColumn" @closeDialog="closeDialog"></tableColumnSet>
- </div>
- </template>
- <script setup lang="ts">
- import { reactive } from "vue";
- import Search from "@/components/search/index.vue";
- import Steps from "@/components/steps/index.vue";
- import Table from "@/components/tableTemp/index.vue";
- import TBtnGroup from "@/components/TBtnGroup/index.vue";
- import tableColumnSet from "@/components/tableColumnSet/index.vue";
- import { ElMessage } from "element-plus";
- const dataInfo = [
- {
- id: 1,
- name: "运单",
- value: "FA56888829",
- },
- {
- id: 2,
- name: "货代公司",
- value: "深圳市联运通货有限公司",
- },
- {
- id: 3,
- name: "品名",
- value: "电路板、手机外壳",
- },
- {
- id: 4,
- name: "特货信息",
- value: "特",
- },
- {
- id: 5,
- name: "始发机场",
- value: "SZX",
- },
- {
- id: 6,
- name: "目的机场",
- value: "CTU",
- },
- {
- id: 7,
- name: "货物数量",
- value: "7件",
- },
- {
- id: 8,
- name: "货物总重",
- value: "82KG",
- },
- ];
- const datas = [
- {
- id: 1,
- name: "收货核单",
- flag: true,
- labelWidth: 100,
- children: ["A32", "534件", "通过", "10:25"],
- },
- {
- id: 2,
- name: "安检",
- flag: true,
- children: ["A32", "534件", "通过", "10:25"],
- },
- {
- id: 3,
- name: "安检",
- flag: true,
- children: ["A32", "534件", "通过", "10:25"],
- },
- {
- id: 4,
- name: "安检",
- flag: true,
- children: ["A32", "534件", "通过", "10:25"],
- },
- {
- id: 5,
- name: "安检",
- flag: true,
- children: ["A32", "534件", "通过", "10:25"],
- },
- {
- id: 6,
- name: "安检",
- flag: false,
- children: ["A32", "534件", "通过", "10:25"],
- },
- {
- id: 7,
- name: "安检安检",
- flag: false,
- labelWidth: 100,
- children: ["A32", "534件", "通过", "10:25"],
- },
- ];
- const datas1 = [
- {
- id: 1,
- name: "收货核单",
- flag: true,
- labelWidth: 100,
- children: ["A32", "534件", "通过", "10:25"],
- },
- {
- id: 2,
- name: "安检",
- flag: true,
- children: ["A32", "534件", "通过", "10:25"],
- },
- {
- id: 3,
- name: "安检",
- flag: true,
- children: ["A32", "534件", "通过", "10:25"],
- },
- {
- id: 4,
- name: "安检",
- flag: false,
- children: ["A32", "534件", "通过", "10:25"],
- },
- ];
- const groupSet = {
- isUtc: false,
- isRefresh: false,
- isDownLoad: true,
- isColumnSet: true,
- };
- const tableHeader = [
- { label: "航班号", key: "fightNo" },
- { label: "集装器编号", key: "containerNo" },
- { label: "货物编码", key: "goodsNo" },
- { label: "拉下", key: "dwon1" },
- { label: "退运", key: "return" },
- {
- label: "收货核单",
- key: "receipt",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- },
- {
- label: "安检",
- key: "securityCheck",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- },
- {
- label: "理货",
- key: "tally",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- },
- {
- label: "拉下",
- key: "dwon2",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- },
- {
- label: "待运区",
- key: "waitingArea",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- },
- {
- label: "货站交接",
- key: "goodSstation1",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- },
- {
- label: "机下交接",
- key: "offBoard1",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- },
- {
- label: "装机",
- key: "installEquipment",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- },
- {
- label: "卸机",
- key: "unloading",
- lableClass: "scoreColumn2",
- columnClassName: "scoreColumn2",
- },
- {
- label: "机下交接",
- key: "offBoard2",
- lableClass: "scoreColumn2",
- columnClassName: "scoreColumn2",
- },
- {
- label: "货站交接",
- key: "goodSstation2",
- lableClass: "scoreColumn2",
- columnClassName: "scoreColumn2",
- },
- {
- label: "提取",
- key: "extract",
- lableClass: "scoreColumn2",
- columnClassName: "scoreColumn2",
- },
- ];
- const tableData = [
- {
- id: 1,
- fightNo: "CA1001",
- containerNo: "DOU2424U2",
- goodsNo: "56888829",
- dwon1: "Y",
- return: "Y",
- receipt: "A203-未通过-15:40",
- securityCheck: "A203-未通过-15:40",
- tally: "A203-未通过-15:40",
- dwon2: "A203-未通过-15:40",
- waitingArea: "A203-未通过-15:40",
- goodSstation1: "A203-未通过-15:40",
- offBoard1: "A203-未通过-15:40",
- installEquipment: "A203-未通过-15:40",
- unloading: "A203-未通过-15:40",
- offBoard2: "A203-未通过-15:40",
- goodSstation2: "A203-未通过-15:40",
- extract: "A203-未通过-15:40",
- },
- {
- id: 2,
- fightNo: "CA1001",
- containerNo: "DOU2424U2",
- goodsNo: "56888829",
- dwon1: "Y",
- return: "Y",
- receipt: "A203-未通过-15:40",
- securityCheck: "A203-未通过-15:40",
- tally: "A203-未通过-15:40",
- dwon2: "A203-未通过-15:40",
- waitingArea: "A203-未通过-15:40",
- goodSstation1: "A203-未通过-15:40",
- offBoard1: "A203-未通过-15:40",
- installEquipment: "A203-未通过-15:40",
- unloading: "A203-未通过-15:40",
- offBoard2: "A203-未通过-15:40",
- goodSstation2: "A203-未通过-15:40",
- extract: "A203-未通过-15:40",
- },
- {
- id: 3,
- fightNo: "CA1001",
- containerNo: "DOU2424U2",
- goodsNo: "56888829",
- dwon1: "Y",
- return: "Y",
- receipt: "A203-未通过-15:40",
- securityCheck: "A203-未通过-15:40",
- tally: "A203-未通过-15:40",
- dwon2: "A203-未通过-15:40",
- waitingArea: "A203-未通过-15:40",
- goodSstation1: "A203-未通过-15:40",
- offBoard1: "A203-未通过-15:40",
- installEquipment: "A203-未通过-15:40",
- unloading: "A203-未通过-15:40",
- offBoard2: "A203-未通过-15:40",
- goodSstation2: "A203-未通过-15:40",
- extract: "A203-未通过-15:40",
- },
- {
- id: 4,
- fightNo: "CA1001",
- containerNo: "DOU2424U2",
- goodsNo: "56888829",
- dwon1: "Y",
- return: "Y",
- receipt: "A203-未通过-15:40",
- securityCheck: "A203-未通过-15:40",
- tally: "A203-未通过-15:40",
- dwon2: "A203-未通过-15:40",
- waitingArea: "A203-未通过-15:40",
- goodSstation1: "A203-未通过-15:40",
- offBoard1: "A203-未通过-15:40",
- installEquipment: "A203-未通过-15:40",
- unloading: "A203-未通过-15:40",
- offBoard2: "A203-未通过-15:40",
- goodSstation2: "A203-未通过-15:40",
- extract: "A203-未通过-15:40",
- },
- ];
- const state = reactive({
- dialogVisible: false,
- waybillTableHeader: [
- { label: "航班号", key: "fightNo", isShow: true },
- { label: "集装器编号", key: "containerNo", isShow: true },
- { label: "货物编码", key: "goodsNo", isShow: true },
- { label: "拉下", key: "dwon1", isShow: true },
- { label: "退运", key: "return", isShow: true },
- {
- label: "收货核单",
- key: "receipt",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- isShow: true,
- },
- {
- label: "安检",
- key: "securityCheck",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- isShow: true,
- },
- {
- label: "理货",
- key: "tally",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- isShow: true,
- },
- {
- label: "拉下",
- key: "dwon2",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- isShow: true,
- },
- {
- label: "待运区",
- key: "waitingArea",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- isShow: true,
- },
- {
- label: "货站交接",
- key: "goodSstation1",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- isShow: true,
- },
- {
- label: "机下交接",
- key: "offBoard1",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- isShow: true,
- },
- {
- label: "装机",
- key: "installEquipment",
- lableClass: "scoreColumn",
- columnClassName: "scoreColumn",
- isShow: true,
- },
- {
- label: "卸机",
- key: "unloading",
- lableClass: "scoreColumn2",
- columnClassName: "scoreColumn2",
- isShow: true,
- },
- {
- label: "机下交接",
- key: "offBoard2",
- lableClass: "scoreColumn2",
- columnClassName: "scoreColumn2",
- isShow: true,
- },
- {
- label: "货站交接",
- key: "goodSstation2",
- lableClass: "scoreColumn2",
- columnClassName: "scoreColumn2",
- isShow: true,
- },
- {
- label: "提取",
- key: "extract",
- lableClass: "scoreColumn2",
- columnClassName: "scoreColumn2",
- isShow: true,
- },
- ],
- });
- const search = (val) => {
- ElMessage.success(`搜索成功:${val}`);
- };
- const clear = () => {
- ElMessage.success(`清除`);
- };
- const setColumn = (data) => {
- state.waybillTableHeader = data;
- state.dialogVisible = false;
- };
- const closeDialog = (data) => {
- state.dialogVisible = false;
- };
- //点击列设置按钮
- const columnSet = (data) => {
- state.dialogVisible = true;
- };
- const router = useRouter()
- const route = useRoute()
- const cellClickHandler = (row, column, cell, event) => {
- switch(column.property) {
- case 'goodsNo':
- router.push({
- path: `${route.path.split('/').slice(0, -1).join('/')}/goods`,
- query: {
- goodsNo: row.goodsNo
- },
- })
- break
- default:
- break
- }
- }
- </script>
- <style lang="scss" scoped>
- .station {
- &-head {
- height: 144px;
- background: #410425;
- padding: 24px 30px;
- color: #ffffff;
- &-title {
- font-size: 18px;
- font-family: Microsoft YaHei;
- font-weight: bold;
- margin-bottom: 40px;
- }
- }
- &-status {
- margin: 24px 0;
- line-height: 32px;
- .status {
- font-size: 16px;
- font-family: Microsoft YaHei;
- font-weight: bold;
- color: #519f6b;
- }
- }
- &-list {
- margin-bottom: 8px;
- &:last-child {
- margin-bottom: 0;
- }
- .title {
- font-size: 16px;
- font-family: Microsoft YaHei;
- font-weight: bold;
- color: #101116;
- margin-bottom: 10px;
- &-list {
- margin-right: 50px;
- }
- }
- &-left {
- background: #ffffff;
- padding: 24px 24px 12px 24px;
- width: 1090px;
- margin-right: 8px;
- }
- &-right {
- flex: 1;
- background: #ffffff;
- padding: 24px 24px 12px 24px;
- }
- }
- :deep &-table {
- margin-top: 16px;
- .scoreColumn {
- background: #eef3d6 !important;
- }
- .scoreColumn2 {
- background: #d6e6f3 !important;
- }
- }
- }
- </style>
|