index.vue 12.9 KB
<template>
<div class="app-container">
  <el-tabs v-model="activeName" type="card">
    <el-tab-pane label="主表" name="first">
      
        <el-form :model="queryHeaderParams" ref="queryHeaderForm" :inline="true" v-show="showHeaderSearch" label-width="100px">
      <el-form-item label="任务id" prop="id">
        <el-input
          v-model="queryHeaderParams.id"
          placeholder="请输入任务id"
          clearable
          style="width: 240px;"
          size="small"
          @keyup.enter.native="headerQuery
          "
        />
      </el-form-item>
      <el-form-item label="容器编号" prop="containerCode">
        <el-input
          v-model="queryHeaderParams.containerCode"
          placeholder="请输入容器编号"
          clearable
          style="width: 240px;"
          size="small"
          @keyup.enter.native="headerQuery
          "
        />
      </el-form-item>
      <el-form-item label="源库位编号" prop="fromLocation">
        <el-input
          v-model="queryHeaderParams.fromLocation"
          placeholder="请输入源库位编号"
          clearable
          style="width: 240px;"
          size="small"
          @keyup.enter.native="headerQuery
          "
        />
      </el-form-item>
      <el-form-item label="目的库位编号" prop="toLocation">
        <el-input
          v-model="queryHeaderParams.toLocation"
          placeholder="请输入目的库位编号"
          clearable
          style="width: 240px;"
          size="small"
          @keyup.enter.native="headerQuery
          "
        />
      </el-form-item>
      <el-form-item label="创建时间">
        <el-date-picker
          v-model="headerDateRange"
          size="small"
          style="width: 240px"
          value-format="yyyy-MM-dd"
          type="daterange"
          range-separator="-"
          start-placeholder="开始日期"
          end-placeholder="结束日期"
        ></el-date-picker>
      </el-form-item>
      <el-form-item>
        <el-button type="cyan" icon="el-icon-search" size="mini" @click="headerQuery">搜索</el-button>
        <el-button icon="el-icon-refresh" size="mini" @click="resetHeaderQuery">重置</el-button>
      </el-form-item>
    </el-form>

    <el-row :gutter="10" class="mb8">
     
      <el-col :span="1.5">
        <el-button
          type="primary"
          icon="el-icon-printer"
          size="mini"
          @click="print"
         
        >打印</el-button>
      </el-col>
      <el-col :span="1.5">
            <el-button type="success" icon="el-icon-s-promotion" size="mini" :disabled="multiple" @click="execute">批量执行</el-button>
          </el-col>
          <el-col :span="1.5">
            <el-button type="danger" icon="el-icon-close" size="mini" :disabled="multiple" @click="remove">批量取消</el-button>
          </el-col>
      <right-toolbar :showSearch.sync="showHeaderSearch" @queryTable="getHeaderList"></right-toolbar>
    </el-row>

    <el-table v-loading="" :data="headerList" @selection-change="headerSelectionChange">
         <el-table-column type="selection" width="55" align="center" />
         <el-table-column label="操作" align="center" width="200" class-name="small-padding fixed-width">
            <template slot-scope="scope">
              <el-button size="mini" type="text" icon="el-icon-my-detail" @click="detail(scope.row)">明细</el-button>
              <el-button size="mini" type="text" icon="el-icon-s-promotion" @click="execute(scope.row)">执行</el-button>
              <el-button size="mini" type="text" icon="el-icon-close" @click="remove(scope.row)">取消</el-button>
              <el-button size="mini" type="text" icon="el-icon-check" @click="complete(scope.row)">完成</el-button>
            </template>
          </el-table-column>
     
      <el-table-column label="任务id" align="center" prop="id" sortable min-width="100" />
      <el-table-column label="任务类型" align="center" prop="taskType" min-width="100">
      <template slot-scope="scope">
              <el-button
                size="mini"
                :type="scope.row.taskType | taskTypeFilter"
                round
                >{{ taskTypeFormat(scope.row, scope.column) }}</el-button
              >
            </template>
          </el-table-column>
      <el-table-column label="源库位号" align="center" prop="fromLocation" :show-overflow-tooltip="true" />
      <el-table-column label="目的库位号" align="center" prop="toLocation" min-width="100" />
      <el-table-column label="容器号" align="center" prop="containerCode" sortable min-width="100" />
      <el-table-column label="重量" align="center" prop="weight" />
      <el-table-column label="站台" align="center" prop="stationCode" />
      <el-table-column label="异常原因" align="center" prop="exceptionCode" sortable min-width="100" />
      <el-table-column label="开始拣货时间" align="center" prop="startPickDateTime" width="180" sortable>
        <template slot-scope="scope">
          <span>{{ parseTime(scope.row.startPickDateTime) }}</span>
        </template>
      </el-table-column>
      <el-table-column label="截止拣货时间" align="center" prop="endPickDateTime" width="180" sortable>
        <template slot-scope="scope">
          <span>{{ parseTime(scope.row.endPickDateTime) }}</span>
        </template>
      </el-table-column>
      <el-table-column label="生成时间" align="center" prop="created" width="180" sortable>
        <template slot-scope="scope">
          <span>{{ parseTime(scope.row.created) }}</span>
        </template>
      </el-table-column>
      <el-table-column label="任务下达人" align="center" prop="createdBy" min-width="100" :show-overflow-tooltip="true" />
      <el-table-column label="修改时间" align="center" prop="lastUpdated" width="180" sortable>
        <template slot-scope="scope">
          <span>{{ parseTime(scope.row.lastUpdated) }}</span>
        </template>
      </el-table-column> 
       <el-table-column label="更新用户" align="center" prop="lastUpdatedBy" :show-overflow-tooltip="true" />   
    </el-table>

    <pagination
      v-show="headerTotal>0"
      :total="headerTotal"
      :page.sync="queryHeaderParams.pageNum"
      :limit.sync="queryHeaderParams.pageSize"
      @pagination="getHeaderList"
    />
    </el-tab-pane>
    <el-tab-pane label="明细" name="second" v-if="queryDetailParams.id !== undefined">
   <el-row :gutter="10" class="mb8">
     
      <el-col :span="1.5">
        <el-button type="warning" icon="el-icon-download" size="mini" @click="handleExport">导出</el-button>
      </el-col>
      <right-toolbar :showSearch.sync="showDetailSearch" @queryTable="getDetailList"></right-toolbar>
    </el-row>


    <el-table v-loading="detailLoading" :data="detailList">
      <el-table-column type="selection" width="55" align="center" />
      <el-table-column label="明细ID" align="center" prop="id" min-width="55" />
      <el-table-column label="任务头ID" align="center" prop="taskId" sortable min-width="100" />
      <el-table-column label="单据编码" align="center" prop="billCode" />
      <el-table-column label="单据明细ID" align="center" prop="billDetailId" sortable min-width="120" />
      <el-table-column label="物料编码" align="center" prop="materialCode" />
      <el-table-column label="物料名称" align="center" prop="materialName" />
      <el-table-column label="项目号" align="center" prop="projectNo" />
      <el-table-column label="容器编码" align="center" prop="containerCode" sortable min-width="100" />
      <el-table-column label="源库位" align="center" prop="fromLocation" sortable min-width="100" />
      <el-table-column label="目的库位" align="center" prop="toLocation" sortable min-width="100" /> 
      <el-table-column label="数量" align="center" prop="qty" />
      <el-table-column label="子任务状态" align="center" prop="status" min-width="100">
       <template slot-scope="scope">
              <el-button
                size="mini"
                type="info"
                round
                >{{ taskStatusFormat(scope.row, scope.column) }}</el-button
              >
            </template>
          </el-table-column>
      <el-table-column label="更新用户" align="center" prop="lastUpdatedBy" />          
    </el-table>
    <pagination
      v-show="detailTotal>0"
      :total="detailTotal"
      :page.sync="queryDetailParams.pageNum"
      :limit.sync="queryDetailParams.pageSize"
      @pagination="getDetailList"
    />
    </el-tab-pane>
   
  </el-tabs>
  
  
  </div>
</template>
<script>
import {
  listTaskHeader,
  cancelTaskHeader,
  completeTaskByWMS,
  taskExecute,
  taskDetail,
} from "@/api/task/taskHeader";

  export default {
    name:"MoveTask",
   
    data() {
      return {
       show: false,
       headerIds: [],
     
      
       multiple:true,
       headerLoading: true,
       detailLoading: true,
       headerTotal: 0,
       detailTotal: 0,
      headerList: null,
      detailList:null,
      activeName: 'first',
      
      headerDateRange: [],
      
      showHeaderSearch: true,
      showDetailSearch: true,
      taskTypeOptions:[],
      taskStatusOptions:[],
      queryHeaderParams: {
        pageNum: 1,
        pageSize: 10,
        id: undefined,
        internalTaskType: 600,
        containerCode: undefined,
        fromLocation: undefined,
        toLocation: undefined,  
      },
      queryDetailParams: {
        pageNum: 1,
        pageSize: 10,
        id: undefined
        
       
      },
      };
    },
      created() {
    this.getHeaderList();
 
    this.getDicts("taskType").then((response) => {
      this.taskTypeOptions = response.data;
    });
    this.getDicts("taskStatus").then((response) => {
      this.taskStatusOptions = response.data;
    });
  },
    methods: {
     
    getHeaderList() {
      this.headerLoading = true;
      listTaskHeader(this.addDateRange(this.queryHeaderParams, this.headerDateRange)).then(
        (response) => {
          this.headerList = response.rows;
          this.headerTotal = response.total;
          this.headerLoading = false;
        }
      );
    },
    // 任务类型字典翻译
    taskTypeFormat(row, column) {
      return this.selectDictLabel(this.taskTypeOptions, row.taskType);
    },
      // 任务状态字典翻译
    taskStatusFormat(row, column) {
      return this.selectDictLabel(this.taskStatusOptions, row.status);
    },
     headerQuery() {
      this.queryHeaderParams.pageNum = 1;
      this.getHeaderList();
    },
    headerAdd() {
      this.show=true
    },
    resetHeaderQuery() {
      this.headerDateRange = [];
      this.resetForm("queryHeaderForm");
      this.headerQuery();
    },
    /** 打印按钮操作 */
   print() {

   },
    headerSelectionChange(selection) {
      this.headerIds = selection.map((item) => item.id);
      this.multiple = !selection.length;
    },

 // 主表明细按钮操作
    detail(row) {
      console.log(row);
      this.queryDetailParams.id = row.id;
      this.activeName = "second";
      this.getDetailList();
    },
    /** 执行按钮操作 */
    execute(row) {
      console.log(row);
      const ids = row.id || this.headerIds.toString();
      this.$confirm('是否确认执行任务id为"' + ids + '"的数据项?', "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(function () {
          return taskExecute(ids);
        })
        .then(() => {
          this.getHeaderList();
          this.msgSuccess("执行任务成功");
        });
    },
    /** 取消按钮操作 */
    remove(row) {
      const ids = row.id || this.headerIds.toString();
      this.$confirm('是否确认取消任务id为"' + ids + '"的数据项?', "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(function () {
          return cancelTaskHeader(ids);
        })
        .then(() => {
          this.getDetailList();
          this.msgSuccess("取消任务成功");
        });
    },
    /** 完成按钮操作 */
    complete(row) {
      const ids = row.id || this.headerIds.toString();
      this.$confirm('是否确认完成任务id为"' + ids + '"的数据项?', "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(function () {
          return completeTaskByWMS(ids);
        })
        .then(() => {
          this.getDetailList();
          this.msgSuccess("完成任务成功");
        });
    },
    /** 查询上架任务明细列表 */
    getDetailList() {
      this.detailLoading = true;
      taskDetail(this.queryDetailParams).then((response) => {
        console.log(response);
        this.detailList = response.rows;
        this.detailTotal = response.total;
        this.detailLoading = false;
      });
    },
     /** 导出按钮操作 */
    handleExport() {

    }
    }
  };
</script>
<style lang="scss">

  
</style>