chenrui  2 years ago
parent
commit
806288b894

+ 1 - 0
public/config.js

@@ -8,6 +8,7 @@
  */
 var PLATFROM_CONFIG = {};
 PLATFROM_CONFIG.baseUrl = "http://106.14.243.117:9111"; // http请求地址
+// PLATFROM_CONFIG.baseUrl = "http://10.211.66.25:8074"; // http请求地址
 PLATFROM_CONFIG.appSecret = "9inu7zpllz1folzsljm498dcpi0lsog1"; //appSecret
 PLATFROM_CONFIG.appId = "q7kdjmmaf0kerwpf"; //appid
 // PLATFROM_CONFIG.baseURLCA = "http://106.14.243.117:9114";

+ 4 - 9
src/views/BasicsData/views/airlineCompany/airlineCompanyInfo.vue

@@ -255,13 +255,7 @@ export default {
   components: { Search, Dialog },
   data() {
     return {
-      arr: [
-        {
-          names: "",
-          Name: "名称",
-          FullName: "测试",
-        },
-      ], //内容数据
+      arr: [], //内容数据
       flag: false, //删除弹框开关
       addFlag: false, //新增机场信息弹框开关
       EditFlag: false,
@@ -334,6 +328,7 @@ export default {
         name: item.Name,
       };
     },
+    //编辑-航司信息(存储信息)
     airEdit(item) {
       this.EditForm.ID = item.ID;
       this.EditForm.Name = item.Name;
@@ -370,6 +365,7 @@ export default {
         }
       }
     },
+    //清空内容
     closeForm() {
       this.$refs.ruleForm.resetFields();
     },
@@ -442,8 +438,8 @@ export default {
         });
         if (res.code === "0") {
           this.$message.success(res.message ?? "成功");
-          this.getAirlines();
           this.flag = false;
+          this.getAirlines();
         } else {
           this.$message.error(res.message ?? "失败");
         }
@@ -460,7 +456,6 @@ export default {
   .log {
     width: 26px;
     height: 26px;
-    background: #eb2f3b;
     border-radius: 50%;
     margin-right: 15px;
     background: url("../../../../assets/index/ic_close_hint.png") no-repeat;

+ 453 - 311
src/views/baggageManagement/components/arrival/index.vue

@@ -1,14 +1,14 @@
 <!--
  * @Author: zk
  * @Date: 2022-01-17 10:39:22
- * @LastEditTime: 2022-05-07 16:59:57
+ * @LastEditTime: 2022-05-07 16:55:50
  * @LastEditors: your name
- * @Description: 港01
+ * @Description: 港01
 -->
 <template>
-  <div class="arrival-one">
+  <div class="departure-one">
     <!--功能区-表单-->
-    <div class="arrival-form">
+    <div class="departure-form">
       <el-form
         ref="form"
         :inline="true"
@@ -17,9 +17,9 @@
         class="form"
       >
         <el-form-item prop="currentAirport">
-          <el-cascader
+          <!-- <el-cascader
             v-model="formData.currentAirport"
-            style="width:144px;"
+            style="width:144px;margin-left:10px"
             placeholder="全部机场"
             size="small"
             :options="currentAirportList"
@@ -28,68 +28,26 @@
             clearable
             filterable
             @change="setCurrentAirport"
-          />
-        </el-form-item>
-        <el-form-item prop="relatedAirport">
-          <el-cascader
-            v-model="formData.relatedAirport"
-            style="width:136px;"
-            size="small"
-            :options="relatedAirportList"
-            :props="relatedAirportProps"
-            placeholder="全部起飞站"
-            collapse-tags
-            clearable
-            filterable
-            @change="onSubmit"
-          />
-        </el-form-item>
-        <el-form-item prop="inboundCarrier">
-          <el-cascader
-            v-model="formData.inboundCarrier"
-            style="width:164px;"
-            size="small"
-            :options="carrierList"
-            :props="carrierProps"
-            placeholder="全部航司"
-            collapse-tags
-            clearable
-            filterable
-            @change="onSubmit"
-          />
-        </el-form-item>
-        <el-form-item prop="craftType">
-          <el-cascader
-            v-model="formData.craftType"
-            style="width:120px;"
-            size="small"
-            :options="craftTypeList"
-            :props="craftTypeProps"
-            placeholder="全部机型"
-            collapse-tags
-            clearable
-            filterable
-            @change="onSubmit"
-          />
-        </el-form-item>
-        <el-form-item prop="flightAttr">
-          <el-cascader
-            v-model="formData.flightAttr"
-            style="width:120px;"
+          /> -->
+          <el-select
+            v-model="formData.currentAirport"
             size="small"
-            :options="flightAttrList"
-            :props="flightAttrProps"
-            placeholder="国际/国内"
-            collapse-tags
-            clearable
-            filterable
-            @change="onSubmit"
-          />
+            @change="airPortChange"
+            placeholder="请选择机场"
+          >
+            <el-option
+              v-for="(item, index) in AirportList"
+              :key="index"
+              :label="item.PlanDepartureApt"
+              :value="item.PlanDepartureApt"
+            >
+            </el-option>
+          </el-select>
         </el-form-item>
         <el-form-item prop="startDate">
           <el-date-picker
             v-model="formData.startDate"
-            style="width:216px;"
+            style="width: 216px"
             size="small"
             type="date"
             value-format="yyyy-MM-dd"
@@ -100,7 +58,7 @@
         <el-form-item prop="endDate">
           <el-date-picker
             v-model="formData.endDate"
-            style="width:216px;"
+            style="width: 216px"
             size="small"
             type="date"
             value-format="yyyy-MM-dd"
@@ -108,71 +66,93 @@
             @change="setEndDate"
           />
         </el-form-item>
-        <el-form-item prop="search">
-          <el-input
-            v-model="formData.search"
-            style="width:240px;margin-left:105px;"
-            size="small"
-            placeholder="请输入内容"
-            prefix-icon="el-icon-search"
-            clearable
-            @clear="inputClear"
-          />
-        </el-form-item>
         <el-form-item>
-          <el-button
-            size="small"
-            type="primary"
-            @click="onSubmit"
-          >搜索</el-button>
-        </el-form-item>
-        <el-form-item v-is="['i_showTransit']">
-          <el-switch
-            v-model="formData.switch"
-            style="margin-left:40px;"
-            active-text="显示中转"
-          />
-        </el-form-item>
-        <el-form-item v-is="['i_timeIcon']">
-          <el-dropdown>
-            <img
-              class="checkTime msgImg"
-              src="../../../../assets/departure/ic_time.png"
+          <div class="box-item">
+            <p>预计装载总数:</p>
+            <li
+              :class="{ 'number-item': !isNaN(item), 'mark-item': isNaN(item) }"
+              v-for="(item, index) in orderNum"
+              :key="index"
             >
-            <el-dropdown-menu
-              slot="dropdown"
-              class="time-zone"
-            >
-              <el-dropdown-item>国内Local/国际UTC</el-dropdown-item>
-              <el-dropdown-item>Local</el-dropdown-item>
-              <el-dropdown-item>UTC</el-dropdown-item>
-            </el-dropdown-menu>
-          </el-dropdown>
-        </el-form-item>
-        <!-- <el-form-item v-is="['i_columnSettings']"> -->
-        <el-form-item>
-          <img
-            class="msgImg"
-            src="../../../../assets/departure/ic_setting.png"
-            @click="show"
-          >
+              <span v-if="!isNaN(item)">
+                <i ref="numberItem">0123456789</i>
+              </span>
+              <span class="comma" v-else>{{ item }}</span>
+            </li>
+          </div>
         </el-form-item>
+        <div style="float: right">
+          <el-form-item prop="search">
+            <el-input
+              v-model="formData.search"
+              style="width: 240px; margin-left: 105px"
+              size="small"
+              placeholder="请输入内容"
+              prefix-icon="el-icon-search"
+              clearable
+              @clear="inputClear"
+              @keyup.enter="onSubmit"
+            />
+          </el-form-item>
+          <el-form-item>
+            <el-button size="small" type="primary" @click="onSubmit"
+              >搜索</el-button
+            >
+          </el-form-item>
+          <el-form-item>
+            <el-switch
+              v-model="formData.switch"
+              style="margin-left: 40px"
+              active-text="显示中转"
+            />
+          </el-form-item>
+          <el-form-item v-is="['i_timeIcon']">
+            <el-dropdown>
+              <img
+                class="checkTime msgImg"
+                src="../../../../assets/departure/ic_time.png"
+              />
+              <el-dropdown-menu slot="dropdown" class="time-zone">
+                <el-dropdown-item>国内Local/国际UTC</el-dropdown-item>
+                <el-dropdown-item>Local</el-dropdown-item>
+                <el-dropdown-item>UTC</el-dropdown-item>
+              </el-dropdown-menu>
+            </el-dropdown>
+          </el-form-item>
+          <el-form-item>
+            <img
+              class="msgImg"
+              src="../../../../assets/departure/ic_setting.png"
+              @click="show"
+            />
+          </el-form-item>
+          <el-form-item>
+            <el-button
+              class="btn-square setBtn"
+              type="primary"
+              icon="el-icon-s-tools"
+              size="mini"
+              @click="show"
+            />
+          </el-form-item>
+        </div>
       </el-form>
     </div>
     <!--表格-->
     <div
       v-loading="loading"
-      class="arrival-table"
+      class="departure-table"
       element-loading-text="拼命加载中"
       element-loading-spinner="el-icon-loading"
       element-loading-background="rgba(0, 0, 0, 0.8)"
     >
       <el-table
         ref="table"
-        :row-class-name="tableRowClassName"
         :data="tableData"
         class="table"
         :height="computedTableHeight"
+        :header-cell-class-name="tableCellClassName"
+        :row-class-name="tableRowClassName"
         show-summary
         :summary-method="summaryMethod"
         border
@@ -180,27 +160,20 @@
         @row-click="rowClick"
       >
         <el-table-column
-          v-for="(item,index) in tableColsCopy"
+          v-for="(item, index) in tableColsCopy"
           :key="index"
           :prop="item.statCode"
           :label="item.statName"
-        >
-          <el-table-column
-            v-for="(p,i) in item.children"
-            :key="i"
-            :prop="p.statCode"
-            :label="p.statName"
-            :width="item.width"
-            :formatter="tableFormat"
-          />
-        </el-table-column>
+          :width="item.width"
+          :filters="flightBaggageTableFilters[item.statCode]"
+          :filter-method="
+            flightBaggageTableFilters[item.statCode] && filterHandler
+          "
+        />
       </el-table>
     </div>
     <!--列设置-->
-    <Dialog
-      :flag="dialogFlag"
-      class="dialog-check-cols"
-    >
+    <Dialog :flag="dialogFlag" class="dialog-check-cols">
       <div class="col-dialog">
         <div class="title">列设置</div>
         <div class="content">
@@ -212,23 +185,17 @@
             :default-expand-all="true"
             :props="{
               label: 'statName',
-              children: 'children'
+              children: 'children',
             }"
             :default-checked-keys="checkedKeysTemp"
             @check="handleCheck"
           />
         </div>
         <div class="foot right t30">
-          <el-button
-            size="medium"
-            class="r24"
-            type="primary"
-            @click="onCheck"
-          >确定</el-button>
-          <el-button
-            size="medium"
-            @click="hide"
-          >取消</el-button>
+          <el-button size="medium" class="r24" type="primary" @click="onCheck"
+            >确定</el-button
+          >
+          <el-button size="medium" @click="hide">取消</el-button>
         </div>
       </div>
     </Dialog>
@@ -236,207 +203,290 @@
 </template>
 
 <script>
-import Dialog from '@/layout/components/Dialog'
-import terminalMixin from '../../mixins/terminal'
-import formMixin from '../../mixins/form'
-import tableColsMixin from '../../mixins/tableCols'
+import Dialog from "@/layout/components/Dialog";
+import terminalMixin from "../../mixins/terminal";
+import formMixin from "../../mixins/form";
+import tableColsMixin from "../../mixins/tableCols";
+import { getQuery } from "@/api/flight";
 
 export default {
-  name: 'ArrivalTerminalView',
+  name: "DepartureTerminalView",
   components: { Dialog },
   mixins: [terminalMixin, formMixin, tableColsMixin],
   data() {
     return {
+      orderNum: ["0", "0", "0", "0"], // 默认总数
       // 初始表头
       tableCols: [
         {
-          statCode: 'flightInfo',
-          statName: '航班信息',
-          children: [
-            {
-              statCode: 'FlightNO',
-              statName: '航班号',
-              width: 91
-            },
-            {
-              statCode: 'FlightDate',
-              statName: '执飞日期',
-              width: 105
-            },
-            {
-              statCode: 'PlanLandingTime',
-              statName: '到港时间',
-              width: 115
-            },
-            {
-              statCode: 'PlanDepartureApt',
-              statName: '起飞航站',
-              width: 71
-            },
-            {
-              statCode: 'LandingBuild',
-              statName: '到达航站楼',
-              width: 65
-            },
-            {
-              statCode: 'Carousel',
-              statName: '行李转盘',
-              width: 68
-            },
-            {
-              statCode: 'StandForLanding',
-              statName: '停机位',
-              width: 68
-            }
-          ]
+          statCode: "FlightNO",
+          statName: "航班号",
+          width: 80,
         },
         {
-          statCode: 'depatureInfo',
-          statName: '始飞站行李信息',
-          children: [
-            {
-              statCode: 'checkin',
-              statName: '值机',
-              width: 72
-            },
-            {
-              statCode: 'expect_load',
-              statName: '预计装载',
-              width: 101
-            },
-            {
-              statCode: 'loadflight',
-              statName: '已装载',
-              width: 65
-            }
-          ]
+          statCode: "FlightDate",
+          statName: "执飞日期",
+          width: 105,
         },
         {
-          statCode: 'arriveInfo',
-          statName: '到达行李信息',
-          children: [
-            {
-              statCode: 'reach',
-              statName: '到达',
-              width: 88
-            },
-            {
-              statCode: 'did_not_arrive',
-              statName: '未到达',
-              width: 76
-            },
-            {
-              statCode: 'special',
-              statName: '特殊',
-              width: 88
-            },
-            {
-              statCode: 'claim',
-              statName: '理赔',
-              width: 83
-            }
-          ]
+          statCode: "asarrivalTime",
+          statName: "到港时间",
+          width: 150,
         },
         {
-          statCode: 'uninstallInfo',
-          statName: '卸载状态',
-          children: [
-            {
-              statCode: 'uninstalled',
-              statName: '已卸载',
-              width: 83
-            },
-            {
-              statCode: 'to_be_uninstalled',
-              statName: '待卸载',
-              width: 80
-            }
-          ]
+          statCode: "departureTerminal",
+          statName: "起飞航站",
         },
         {
-          statCode: 'stopBaggage',
-          statName: '终止行李',
-          children: [
-            {
-              statCode: 'terminateArrive',
-              statName: '到达',
-              width: 79
-            },
-            {
-              statCode: 'terminatedNotArrived',
-              statName: '未到达',
-              width: 82
-            }
-          ]
+          statCode: "arrivalTerminal",
+          statName: "到达航站楼",
         },
         {
-          statCode: 'TransferBaggage',
-          statName: '转运行李',
-          children: [
-            {
-              statCode: 'delivered',
-              statName: '已交运',
-              width: 89
-            },
-            {
-              statCode: 'not_shipped',
-              statName: '未交运',
-              width: 89
-            }
-          ]
+          statCode: "luggageCarousel",
+          statName: "行李转盘",
         },
         {
-          statCode: 'disBaggage',
-          statName: '行李分布',
-          children: [
-            {
-              statCode: 'container',
-              statName: '容器',
-              width: 97
-            },
-            {
-              statCode: 'bulk',
-              statName: '散装',
-              width: 101
-            }
-          ]
-        }
-      ]
-    }
+          statCode: "parkingSpace",
+          statName: "停机位",
+        },
+        {
+          statCode: "checkIns",
+          statName: "值机数",
+        },
+        {
+          statCode: "projectedLoad",
+          statName: "预计装载",
+        },
+        {
+          statCode: "loadedQuantity",
+          statName: "已装载",
+        },
+        {
+          statCode: "numberOfDestinationArrivals",
+          statName: "到达",
+        },
+        {
+          statCode: "endPointNotReached",
+          statName: "未到达",
+        },
+        {
+          statCode: "specialQuantity",
+          statName: "特殊",
+        },
+        {
+          statCode: "numberOfClaims",
+          statName: "理赔",
+        },
+        {
+          statCode: "uninstalled",
+          statName: "已卸载",
+        },
+        {
+          statCode: "numberToBeUninstalled",
+          statName: "待卸载",
+        },
+        {
+          statCode: "terminateArrivalQuantity",
+          statName: "到达",
+        },
+        {
+          statCode: "terminateUnreachedQuantity",
+          statName: "未到达",
+        },
+        {
+          statCode: "quantityShipped",
+          statName: "已交运",
+        },
+        {
+          statCode: "undeliveredQuantity",
+          statName: "未交运",
+        },
+        {
+          statCode: "numberOfContainers",
+          statName: "容器",
+        },
+        {
+          statCode: "numberOfBulk",
+          statName: "散装",
+        },
+      ],
+      AirportList: [],
+      flightBaggageTableFilters: {
+        FlightNO: [],
+        FlightDate: [],
+        PlanDepartureTime: [],
+        TargetAirport: [],
+        BordingGate: [],
+        StandForDepartrue: [],
+        DepartureBuild: [],
+      },
+      loopEvent: null,
+      leaveCount: 0,
+      baggageCount: 0,
+    };
+  },
+  created() {
+    this.getAirPortData();
   },
   methods: {
+    airPortChange() {
+      this.getTableData();
+    },
+    //选择机场
+    async getAirPortData() {
+      try {
+        const res = await getQuery({
+          id: 67,
+          dataContent: [],
+        });
+        if (res.code == 0) {
+          this.AirportList = res.returnData;
+          this.formData.currentAirport = "PEK";
+          this.getTableData();
+        } else {
+          this.$message.error(res.message);
+        }
+      } catch (error) {
+        console.log("出错了", error);
+      }
+    },
     tableRowClassName({ row, rowIndex }) {
-      if (rowIndex < 2) {
-        return 'bgl-hui'
+      if (row.hasTakenOff == 0) {
+        if (rowIndex == this.leaveCount - 1) {
+          return "bgl-hui redBorder";
+        } else {
+          return "bgl-hui";
+        }
       }
     },
-    // 获取表单下拉框数据
-    getFormData(params) {
-      this.relatedAirportQuery({
-        ...params,
-        type: 'IN'
-      })
-      this.inboundCarrierQuery(params)
-      this.craftTypeQuery(params)
-      this.flightAttrQuery(params)
+    tableCellClassName({ row, column }) {
+      if (
+        column.property === "transfer_all" ||
+        column.property === "departureAnomaly" ||
+        column.property === "riskWarning"
+      ) {
+        return "bgl-huang";
+      }
     },
+    // 获取表单下拉框数据
+    // getFormData(params) {
+    //   this.relatedAirportQuery({
+    //     ...params,
+    //     type: 'OUT'
+    //   })
+    //   this.outgoingAirlineQuery(params)
+    //   this.craftTypeQuery(params)
+    //   this.flightAttrQuery(params)
+    // },
     // 获取表格数据
-    getTableData(params) {
-      this.integratedQuery({
-        ...params,
-        type: 'IN'
-      })
+    async getTableData() {
+      let arr = [
+        this.formData.currentAirport,
+        this.formData.startDate,
+        this.formData.endDate,
+      ];
+      try {
+        const res = await getQuery({
+          id: 38,
+          dataContent: [...arr, ...arr, ...arr],
+        });
+        if (res.code == 0) {
+          this.initTableData(res.returnData);
+        } else {
+          console.log(res.message);
+        }
+      } catch (error) {
+        clearInterval(this.loopEvent);
+        console.log("出错了", error);
+      }
     },
     initTableData(tableData) {
-      this.tableData = this._.sortBy(tableData, ['FlightDate', 'PlanLandingTime'])
-    }
-  }
-}
+      this.leaveCount = 0;
+      this.baggageCount = 0;
+      tableData.forEach((item) => {
+        if (item.hasTakenOff == 0) {
+          this.leaveCount++;
+        }
+        // item["waitfanj"] = item["noCheckInNumber"] - item["unLoad"];
+        this.baggageCount = this.baggageCount + item.preLoad;
+      });
+      // this.tableData = this._.sortBy(tableData, [
+      //   "FlightDate",
+      //   "PlanDepartureTime",
+      // ]);
+      this.setTableFilters();
+      this.toOrderNum(this.baggageCount);
+      // setInterval(() => {
+      //   this.baggageCount = this.baggageCount+1;
+      //    // 这里输入数字即可调用
+      // }, 2000);
+    },
+    // 表格添加过滤条件
+    setTableFilters() {
+      this.tableData.forEach((item) => {
+        Object.keys(this.flightBaggageTableFilters).forEach((key) => {
+          if (
+            (item[key] ?? "") !== "" &&
+            this.flightBaggageTableFilters[key].every(
+              (obj) => obj.value !== item[key]
+            )
+          ) {
+            this.flightBaggageTableFilters[key].push({
+              text: item[key],
+              value: item[key],
+            });
+          }
+          this.flightBaggageTableFilters[key] = this._.sortBy(
+            this.flightBaggageTableFilters[key],
+            ["value"]
+          );
+        });
+      });
+    },
+    filterHandler(value, row, column) {
+      const property = column["property"];
+      return row[property] === value;
+    },
+    setNumberTransform() {
+      const numberItems = this.$refs.numberItem; // 拿到数字的ref,计算元素数量
+      const numberArr = this.orderNum.filter((item) => !isNaN(item));
+      // 结合CSS 对数字字符进行滚动,显示订单数量
+      for (let index = 0; index < numberItems.length; index++) {
+        const elem = numberItems[index];
+        elem.style.transform = `translate(-50%, -${numberArr[index] * 10}%)`;
+      }
+    },
+
+    toOrderNum(num) {
+      num = num.toString();
+      if (num.length < 4) {
+        num = "0" + num; // 如未满八位数,添加"0"补位
+        this.toOrderNum(num); // 递归添加"0"补位
+      } else if (num.length === 4) {
+        this.orderNum = num.split(""); // 将其便变成数据,渲染至滚动数组
+      } else {
+        // 订单总量数字超过八位显示异常
+        this.$message.warning("总量数字过大");
+      }
+      this.setNumberTransform();
+    },
+  },
+  mounted() {
+    let that = this;
+    this.loopEvent = setInterval(function () {
+      that.getTableData();
+    }, 3000);
+  },
+  beforeDestroy() {
+    clearInterval(this.loopEvent);
+  },
+};
 </script>
 
 <style lang="scss" scoped>
-.arrival-form {
+.departure-form {
   padding-top: 11px;
+  padding-left: 5px;
   ::v-deep .form {
     .el-form-item {
       margin-bottom: 0px;
@@ -446,7 +496,7 @@ export default {
       optgroup,
       select,
       textarea {
-        font-family: Helvetica, 'Microsoft YaHei';
+        font-family: Helvetica, "Microsoft YaHei";
         font-size: 14px;
       }
       .el-switch__label {
@@ -455,6 +505,16 @@ export default {
       .el-form-item__error {
         z-index: 10;
       }
+      .el-button {
+        &.btn-square {
+          width: 30px;
+          height: 30px;
+          display: flex;
+          align-items: center;
+          justify-content: center;
+          margin-top: 5px;
+        }
+      }
     }
     .checkTime {
       margin: 0 16px;
@@ -465,16 +525,98 @@ export default {
       top: 6px;
     }
   }
+  .box-item {
+    position: relative;
+    height: 32px;
+    font-size: 18px;
+    line-height: 32px;
+    text-align: center;
+    list-style: none;
+    color: #2d7cff;
+    writing-mode: vertical-lr;
+    text-orientation: upright;
+    /*文字禁止编辑*/
+    -moz-user-select: none; /*火狐*/
+    -webkit-user-select: none; /*webkit浏览器*/
+    -ms-user-select: none; /*IE10*/
+    -khtml-user-select: none; /*早期浏览器*/
+    user-select: none;
+    /* overflow: hidden; */
+    p {
+      line-height: 32px;
+      writing-mode: horizontal-tb !important;
+      text-orientation: none !important;
+      /*文字禁止编辑*/
+      -moz-user-select: none; /*火狐*/
+      -webkit-user-select: none; /*webkit浏览器*/
+      -ms-user-select: none; /*IE10*/
+      -khtml-user-select: none; /*早期浏览器*/
+      user-select: none;
+      margin-top: 5px;
+    }
+  }
+  /* 默认逗号设置 */
+  .mark-item {
+    width: 10px;
+    height: 32px;
+    margin-right: 5px;
+    line-height: 10px;
+    font-size: 18px;
+    position: relative;
+    & > span {
+      position: absolute;
+      width: 100%;
+      bottom: 0;
+      writing-mode: vertical-rl;
+      text-orientation: upright;
+    }
+  }
+  /*滚动数字设置*/
+  .number-item {
+    width: 41px;
+    height: 42px;
+    /* 背景图片 */
+    background: url(/images/text-bg-blue.png) no-repeat center center;
+    background-size: 100% 100%;
+    // background: #ccc;
+    list-style: none;
+    margin-right: 5px;
+    // background:rgba(250,250,250,1);
+    border-radius: 4px;
+    border: 3px solid rgb(221, 221, 221);
+    & > span {
+      position: relative;
+      display: inline-block;
+      margin-right: 10px;
+      width: 100%;
+      height: 100%;
+      writing-mode: vertical-rl;
+      text-orientation: upright;
+      overflow: hidden;
+      & > i {
+        font-style: normal;
+        position: absolute;
+        top: 11px;
+        left: 50%;
+        transform: translate(-50%, -1%);
+        transition: transform 1s ease-in-out;
+        letter-spacing: 10px;
+      }
+    }
+  }
+  .number-item:last-child {
+    margin-right: 0;
+  }
 }
-.arrival-table {
-  width: calc(100vw - 60px);
+.departure-table {
+  width: 100%;
   ::v-deep .table {
     width: 100%;
     .cell {
       padding: 0;
       text-align: center;
-      font-family: Helvetica, 'Microsoft YaHei';
       font-size: 14px;
+      font-family: Helvetica, "Microsoft YaHei";
       letter-spacing: 0;
     }
     .el-table__header-wrapper {
@@ -496,10 +638,10 @@ export default {
         td {
           background: #d2d6df;
         }
-        &:nth-child(5) {
+        &.redBorder {
           position: relative;
           &::after {
-            content: '';
+            content: "";
             position: absolute;
             left: 0;
             bottom: 0;

+ 1 - 0
vue.config.js

@@ -41,6 +41,7 @@ module.exports = {
         // 此处的写法,目的是为了 将 /api 替换成 https://www.baidu.com/
         // target: 'http://ca.midsk.cn:8080',
         target: 'http://106.14.243.117:9111',
+        // target: '10.211.66.25:8074',
         // target: 'http://192.168.3.67:8092',
         // target: 'http://10.9.247.105:8092',
         // target: 'http://127.0.0.1:4523/mock/528199',