zhaoke 1 рік тому
батько
коміт
430a326dbe

+ 8 - 0
public/config.js

@@ -117,6 +117,10 @@ var NEW_DATACONTENT_ID = [
   52222,
   52223,
   52224,
+  52225,
+  52226,
+  52227,
+  52228,
   51063
 ]
 
@@ -440,6 +444,10 @@ var DATACONTENT_ID = {
   dataGnArrival: 52222, //数据异常统计-航班统计-国内进港
   dataGjDeparture: 52223, //数据异常统计-航班统计-国际离港
   dataGjArrival: 52224, //数据异常统计-航班统计-国际进港
+  waybillGnDeparture: 52225, //数据异常统计-运单统计-国内离港
+  waybillGnArrival: 52226, //数据异常统计-运单统计-国内进港
+  waybillGjDeparture: 52227, //数据异常统计-运单统计-国际离港
+  waybillGjArrival: 52228, //数据异常统计-运单统计-国际进港
 }
 
 var SERVICE_ID = {

+ 30 - 14
src/views/statisticalanalysis/components/echart/tableforms.vue

@@ -372,30 +372,32 @@
       </template>
       <template v-if="tableList.length && action == 17">
         <el-table :data="tableList" style="width: 100%" :row-style="rowStyle" :header-row-style="rowStyle" :style="dataTableContentStyle" height="calc(100vh - 236px)" max-height="calc(100vh - 236px)" :stripe="tableProps.stripe" :row-key="tableProps.rowKey" :highlight-current-row="tableProps.highlightCurrentRow" :header-cell-class-name="tableProps.headerCellClassName" :tooltip-effect="tableProps.tooltipEffect" :summary-method="totalOutPrice" :show-summary="tableProps.showSummary" :header-cell-style="{ background: '#F9FAFC' }">
-          <el-table-column prop="date" label="总航班数" class-name="elChgTbeClmn" :show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align">
+          <el-table-column prop="flight_date" label="日期" :show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align">
+          </el-table-column>
+          <el-table-column prop="allstock" label="总运单数" class-name="elChgTbeClmn" :show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align">
             <template #header>
               <div class="elHeadCon">
                 <div class="headerCon1">总运单数</div>
                 <div class="headerCon2">问题类型</div>
-                <div class="headerLine"></div>
+                <div style="transform: rotate(-53deg);" class="headerLine"></div>
               </div>
             </template>
           </el-table-column>
-          <el-table-column prop="name" label="数据缺失" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align">
-            <el-table-column prop="province" label="航班数" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
-            <el-table-column prop="city" label="占比" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
+          <el-table-column label="数据缺失" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align">
+            <el-table-column prop="havenot_allnode_stock" label="航班数" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
+            <el-table-column prop="havenot_allnode_lv" label="占比(%)" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
           </el-table-column>
-          <el-table-column prop="name" label="流程节点缺失" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align">
-            <el-table-column prop="province" label="航班数" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
-            <el-table-column prop="city" label="占比" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
+          <el-table-column label="流程节点缺失" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align">
+            <el-table-column prop="have_part_stock" label="航班数" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
+            <el-table-column prop="have_part_lv" label="占比(%)" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
           </el-table-column>
-          <el-table-column prop="name" label="时间倒置" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align">
-            <el-table-column prop="province" label="航班数" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
-            <el-table-column prop="city" label="占比" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
+          <el-table-column label="时间倒置" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align">
+            <el-table-column prop="time_inversion_stock" label="航班数" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
+            <el-table-column prop="time_inversion_lv" label="占比(%)" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
           </el-table-column>
-          <el-table-column prop="name" label="时间相同" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align">
-            <el-table-column prop="province" label="航班数" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
-            <el-table-column prop="city" label="占比" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
+          <el-table-column label="时间相同" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align">
+            <el-table-column prop="time_equal_stock" label="航班数" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
+            <el-table-column prop="time_equal_lv" label="占比(%)" show-overflow-tooltip="tableColumnProperty.showOverflowTooltip" :align="tableColumnProperty.align"></el-table-column>
           </el-table-column>
         </el-table>
       </template>
@@ -724,6 +726,20 @@ export default {
           sums[5] = ((allhaveNum / allflightNum) * 100).toFixed(2) + '%'
           sums[7] = ((allinversionNum / allflightNum) * 100).toFixed(2) + '%'
           sums[9] = ((allequalNum / allflightNum) * 100).toFixed(2) + '%'
+        } else if (this.action === 17) {
+          let [allflightNum, allhavenotNum, allhaveNum, allinversionNum, allequalNum] = [null, null, null, null, null]
+          this.tableData.forEach(item => {
+            const { allstock, havenot_allnode_stock, have_part_stock, time_inversion_stock, time_equal_stock } = item
+            allflightNum += allstock
+            allhavenotNum += havenot_allnode_stock,
+              allhaveNum += have_part_stock,
+              allinversionNum += time_inversion_stock,
+              allequalNum += time_equal_stock
+          })
+          sums[3] = ((allhavenotNum / allflightNum) * 100).toFixed(2) + '%'
+          sums[5] = ((allhaveNum / allflightNum) * 100).toFixed(2) + '%'
+          sums[7] = ((allinversionNum / allflightNum) * 100).toFixed(2) + '%'
+          sums[9] = ((allequalNum / allflightNum) * 100).toFixed(2) + '%'
         }
       });
       return sums;

+ 46 - 143
src/views/statisticalanalysis/dataException/views/waybill.vue

@@ -16,6 +16,7 @@ import Tableformbrs from "../../components/echart/tableforms.vue";
 import StatisticsHeader from "../../components/echart/statisticsHeader.vue";
 import { export_json_to_excel } from "@/utils/Export2Excel";
 import { Query } from "@/api/webApi";
+import _ from 'lodash'
 export default {
   name: "ChartsBar",
   data () {
@@ -41,7 +42,7 @@ export default {
         tyol: "",
       },
       formData: {
-        airport: "",
+        flighttype: "",
         dateTime: "",
       },
       titleTop: "运单统计",
@@ -74,33 +75,25 @@ export default {
           clearable: true,
           options: [
             {
-              value: "国内离港",
+              value: DATACONTENT_ID.waybillGnDeparture,
               label: "国内出港",
             },
             {
-              value: "国际离港",
+              value: DATACONTENT_ID.waybillGjDeparture,
               label: "国际出港",
             },
             {
-              value: "国内进港",
+              value: DATACONTENT_ID.waybillGnArrival,
               label: "国内进港",
             },
             {
-              value: "国际进港",
+              value: DATACONTENT_ID.waybillGjArrival,
               label: "国际进港",
             },
-            {
-              value: "国内进港-全部",
-              label: "国内进港-全部",
-            },
-            {
-              value: "国内离港-全部",
-              label: "国内离港-全部",
-            },
           ],
         },
         {
-          prop: "kht",
+          prop: "flighttype",
           inputType: "select",
           placeholder: "客货类型",
           requiredWarning: "请先选择客货类型",
@@ -114,36 +107,16 @@ export default {
               value: "货机",
               label: "货机",
             },
-            {
-              value: "其它",
-              label: "其它",
-            },
             {
               value: "全部",
               label: "全部",
             },
           ],
         },
-        {
-          prop: "td",
-          inputType: "select",
-          placeholder: "统计维度",
-          requiredWarning: "请先选择统计时间维度",
-          clearable: true,
-          options: [
-            {
-              value: "月",
-              label: "月",
-            },
-            {
-              value: "年",
-              label: "年",
-            },
-          ],
-        },
         {
           prop: "dateTime",
           inputType: "datePicker",
+          requiredWarning: "请先选择日期",
           clearable: true,
           width: "240px",
           options: [],
@@ -152,56 +125,6 @@ export default {
     };
   },
   mounted () {
-    this.tableList = [{
-      date: '2016-05-03',
-      name: '王小虎',
-      province: '上海',
-      city: '普陀区',
-      address: '上海市普陀区金沙江路 1518 弄',
-      zip: 200333
-    }, {
-      date: '2016-05-02',
-      name: '王小虎',
-      province: '上海',
-      city: '普陀区',
-      address: '上海市普陀区金沙江路 1518 弄',
-      zip: 200333
-    }, {
-      date: '2016-05-04',
-      name: '王小虎',
-      province: '上海',
-      city: '普陀区',
-      address: '上海市普陀区金沙江路 1518 弄',
-      zip: 200333
-    }, {
-      date: '2016-05-01',
-      name: '王小虎',
-      province: '上海',
-      city: '普陀区',
-      address: '上海市普陀区金沙江路 1518 弄',
-      zip: 200333
-    }, {
-      date: '2016-05-08',
-      name: '王小虎',
-      province: '上海',
-      city: '普陀区',
-      address: '上海市普陀区金沙江路 1518 弄',
-      zip: 200333
-    }, {
-      date: '2016-05-06',
-      name: '王小虎',
-      province: '上海',
-      city: '普陀区',
-      address: '上海市普陀区金沙江路 1518 弄',
-      zip: 200333
-    }, {
-      date: '2016-05-07',
-      name: '王小虎',
-      province: '上海',
-      city: '普陀区',
-      address: '上海市普陀区金沙江路 1518 弄',
-      zip: 200333
-    }]
     // this.getQuery([]);
   },
   watch: {
@@ -219,79 +142,59 @@ export default {
       this.tableData.data2 = [];
       let option = [
         {
-          fttp: data.fttp,
-          kht: data.kht,
-          td: data.td,
+          flighttype: data.flighttype,
           fd1: data.dateTime[0],
-          fd2: data.dateTime[1],
+          fd2: data.dateTime[1]
         },
       ];
-      this.getQuery(option, null);
+      this.getQuery(data.fttp, option, null);
       this.listname =
-        "航班量统计" +
-        data.fttp +
-        data.kht +
-        data.td +
-        data.dateTime[0] +
-        "--" +
-        data.dateTime[1];
+        "航班统计" +
+        data.flighttype +
+        data.fd;
       this.listHeader = ["序号", "时间", "航班(班)", "环比(%)"];
     },
     //获取表格数据
-    async getQuery (data, dat) {
+    async getQuery (id, data, dat) {
       try {
         const { code, returnData } = await Query({
-          id: this.listqueryTemplateID,
+          id: Number(id),
           dataContent: data,
         });
         if (code == 0) {
           this.tableData.time = [];
           this.tableData.data1 = [];
           this.tableData.data2 = [];
-          this.tableList = JSON.parse(JSON.stringify(returnData.listValues));
-          this.tableListcop = JSON.parse(JSON.stringify(returnData.listValues));
-          this.tableList.forEach((item, index) => {
-            item.indexs = index + 1;
-          });
-          for (let i = 0; i < 10; i++) {
-            if (!this.tableList[i]) {
-              this.tableList.push({});
-            }
-          }
-          this.tableListcop.forEach((item, index) => {
-            item.indexs = index + 1;
-          });
-          let objar = {
-            indexs: "合计",
-            flightNum: returnData.listValues[0].totalFlightNum,
-          };
-          this.tableListcop.push(objar);
-          returnData.listValues.forEach((element) => {
-            this.tableData.data2.push(
-              element.flightNum ? element.flightNum : 0
-            );
-            this.tableData.time.push(element.dat);
-            this.tableData.kg = "单位:班";
-            this.tableData.data1 = [];
-          });
-          this.tableData.data1.push(0);
-          for (let index = 0; index < this.tableData.data2.length; index++) {
-            if (index > 0) {
-              const element =
-                (this.tableData.data2[index] -
-                  this.tableData.data2[index - 1]) /
-                this.tableData.data2[index - 1];
-              this.tableData.data1.push(
-                element.toFixed(2) ? element.toFixed(2) : 0
-              );
-              this.tableData.data1.forEach((element) => {
-                element = Number(element);
-                if (typeof element !== "number") {
-                  element = 0;
-                }
-              });
-            }
-          }
+          this.tableList = _.cloneDeep(returnData);
+          this.tableListcop = _.cloneDeep(returnData);
+          // returnData.listValues.forEach((element) => {
+          //   this.tableData.data2.push(
+          //     element.flightNum ? element.flightNum : 0
+          //   );
+          //   this.tableData.time.push(element.dat);
+          //   this.tableData.kg = "单位:班";
+          //   this.tableData.data1 = [];
+          // });
+          // this.tableData.data1.push(0);
+          // for (let index = 0; index < this.tableData.data2.length; index++) {
+          //   if (index > 0) {
+          //     const element =
+          //       (this.tableData.data2[index] -
+          //         this.tableData.data2[index - 1]) /
+          //       this.tableData.data2[index - 1];
+          //     this.tableData.data1.push(
+          //       element.toFixed(2) ? element.toFixed(2) : 0
+          //     );
+          //     this.tableData.data1.forEach((element) => {
+          //       element = Number(element);
+          //       if (typeof element !== "number") {
+          //         element = 0;
+          //       }
+          //     });
+          //   }
+          // }
+        } else {
+          console.log(code)
         }
       } catch (error) {
         this.page--;