qukaidi 3 سال پیش
والد
کامیت
34e7590c05
1فایلهای تغییر یافته به همراه217 افزوده شده و 0 حذف شده
  1. 217 0
      src/views/statisticAnalysis/taskStatistics/index.vue

+ 217 - 0
src/views/statisticAnalysis/taskStatistics/index.vue

@@ -0,0 +1,217 @@
+<template>
+  <div>
+    <basic-container class="page-crad">
+      <avue-crud ref="crud" :option="option" :data="dataList" :page.sync="page" :search.sync="search"
+        :cell-style="cellStyle" @search-change="searchChange" @current-change="currentChange" @size-change="sizeChange"
+        @refresh-change="refreshChange" @on-load="onLoad" :table-loading="loading" @saveColumn="saveColumn"
+        @resetColumn="resetColumn" @search-criteria-switch="searchCriteriaSwitch">
+        <!-- <template slot="menuLeft">
+          <el-button type="info" size="small" @click="outExport">导出
+          </el-button>
+        </template> -->
+        <template slot="businesDateSearch">
+          <el-date-picker v-model="search.businesDate" type="daterange" start-placeholder="开始日期" end-placeholder="结束日期"
+            format="yyyy-MM-dd" value-format="yyyy-MM-dd HH:mm:ss" :default-time="['00:00:00', '23:59:59']">
+          </el-date-picker>
+        </template>
+      </avue-crud>
+    </basic-container>
+  </div>
+</template>
+
+<script>
+import { getToken } from "@/util/auth";
+import { getList } from "@/api/statisticAnalysis/taskStatistics"
+
+export default {
+  name: "index",
+  data() {
+    return {
+      form: {},
+      search: {},
+      dataList: [],
+      loading: false,
+      detailData: {},
+      page: {
+        pageSize: 20,
+        currentPage: 1,
+        total: 0,
+        pageSizes: [10, 20, 30, 40, 50, 100, 200, 300, 400, 500]
+      },
+      option: {},
+      optionBack: {
+        searchShow: true,
+        searchMenuPosition: "right",
+        searchSpan: 8,
+        searchMenuSpan: 24,
+        border: true,
+        index: true,
+        addBtn: false,
+        viewBtn: false,
+        editBtn: false,
+        delBtn: false,
+        searchIcon: true,
+        menu: false,
+        column: [
+          {
+            label: "承做人",
+            prop: "userName",
+            overHidden: true,
+            search: true
+          },
+          {
+            label: "日期",
+            prop: "beginTime",
+            type: "datetime",
+            format: 'yyyy-MM-dd',
+            valueFormat: 'yyyy-MM-dd HH:mm:ss',
+            searchRange: true,
+            searchDefaultTime: ['00:00:00', '23:59:59'],
+            overHidden: true,
+            search: true,
+          },
+          {
+            label: "客户名称",
+            prop: "cornName",
+            overHidden: true,
+          },
+          {
+            label: "任务名称",
+            prop: "pname",
+            overHidden: true,
+          },
+          {
+            label: "状态",
+            prop: "taskStatus",
+            search: true,
+            type: "select",
+            overHidden: true,
+            dicData: [{
+              label: '暂存',
+              value: 10,
+            }, {
+              label: '进行中',
+              value: 20,
+            }, {
+              label: '完成',
+              value: 30,
+            }]
+          }
+        ]
+      }
+    };
+  },
+  async created() {
+    this.option = await this.getColumnData(this.getColumnName(183), this.optionBack);
+  },
+  methods: {
+    cellStyle() {
+      return "padding:0;height:40px;";
+    },
+    searchCriteriaSwitch(type) {
+      if (type) {
+        this.option.height = this.option.height - 46;
+      } else {
+        this.option.height = this.option.height + 46;
+      }
+      this.$refs.crud.getTableHeight();
+    },
+    //点击搜索按钮触发
+    searchChange(params, done) {
+      this.page.currentPage = 1;
+      this.onLoad(this.page, params);
+      done();
+    },
+    refreshChange() {
+      this.onLoad(this.page, this.search);
+    },
+    currentChange(val) {
+      this.page.currentPage = val;
+    },
+    sizeChange(val) {
+      this.page.currentPage = 1;
+      this.page.pageSize = val;
+    },
+    onLoad(page, params = {}) {
+      let data = this.deepClone(Object.assign({}, params, this.search));
+      if (data.beginTime) {
+        data.beginTimeStart = data.beginTime[0]
+        data.beginTimeEnd = data.beginTime[1]
+        delete data.beginTime
+      }
+      data.branch = "N"
+      this.loading = true;
+      getList(
+        page.currentPage,
+        page.pageSize,
+        Object.assign(data)
+      ).then(res => {
+        if (res.data.data.records) {
+          res.data.data.records.forEach(e => {
+            e.itemLoading = true;
+          });
+        }
+        this.dataList = res.data.data.records ? res.data.data.records : [];
+        this.page.total = res.data.data.total;
+        if (this.page.total) {
+          this.option.height = window.innerHeight - 210;
+        }
+      }).finally(() => {
+        this.loading = false;
+      });
+    },
+
+    //列保存触发
+    async saveColumn() {
+      const inSave = await this.saveColumnData(this.getColumnName(183), this.option);
+      if (inSave) {
+        this.$message.success("保存成功");
+        //关闭窗口
+        this.$refs.crud.$refs.dialogColumn.columnBox = false;
+      }
+    },
+    async resetColumn() {
+      this.option = this.optionBack;
+      const inSave = await this.delColumnData(this.getColumnName(183), this.optionBack);
+      if (inSave) {
+        this.$message.success("重置成功");
+        this.$refs.crud.$refs.dialogColumn.columnBox = false;
+      }
+    },
+    editOpen(row) {
+    },
+    outExport() {
+      let queryParams = this.search
+
+      if (queryParams.arrivalTime) {
+        queryParams.beginCreateTime = queryParams.careteTime[0]
+        queryParams.endCreateTime = queryParams.careteTime[1]
+        delete queryParams.careteTime
+      }
+      console.log(queryParams)
+      // const routeData = this.$router.resolve({
+      //   path: '/api/blade-land/order/acct-export',      //跳转目标窗口的地址
+      //   query: {
+      //     ...queryParams    //括号内是要传递给新窗口的参数
+      //   }
+      // })
+      // window.open(routeData.href.slice(1, routeData.href.length - 1) + '&' + `${this.website.tokenHeader}=${getToken()}`);
+      // window.open(`/api/blade-land/order/acct-export?${this.website.tokenHeader}=${getToken()}&cname=${this.search.cname}`);
+    }
+  }
+};
+</script>
+
+<style scoped>
+.page-crad ::v-deep .basic-container__card {
+  height: 94.2vh;
+}
+
+::v-deep .el-table__expanded-cell[class*="cell"] {
+  padding: 0px;
+}
+
+.itemTable ::v-deep .el-table {
+  width: 100%;
+}
+</style>