AgvStationModal.vue 5.95 KB
<template>
  <j-modal
    :title="title"
    :width="900"
    :visible="visible"
    :confirmLoading="confirmLoading"
    switchFullscreen
    @ok="handleOk"
    @cancel="handleCancel"
    cancelText="关闭">
    <!-- 查询区域 -->
    <div class="col-sm-8" id="stationBind">
      <div class="radio radio-info radio-inline">
        <input type="radio" id="task1" name="task" value="1" data-info="1号站台" checked="checked" class="radio_select">
        <label for="task1">1号站台</label>
      </div>
    </div>
    <!-- 查询区域-END -->



    <!-- table区域-begin -->
    <div>
      <!--      <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">-->
      <!--        <i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择 <a style="font-weight: 600">{{ selectedRowKeys.length }}</a> 项-->
      <!--        <a style="margin-left: 24px" @click="onClearSelected">清空</a>-->
      <!--      </div>-->


    </div>

  </j-modal>
</template>

<script>

import '@/assets/less/TableExpand.less'
import {mixinDevice} from '@/utils/mixin'
import {JeecgListMixin} from '@/mixins/JeecgListMixin'
import {filterMultiDictText} from '@/components/dict/JDictSelectUtil'
import {callReceiptBox, executeAgv, queryIdTree} from '@/api/api'
import {completeAgv, cancelAgv} from '@/api/api'
import pick from "lodash.pick";

export default {
  name: 'AgvStationModal',
  mixins: [JeecgListMixin, mixinDevice],
  components: {

  },
  data() {
    return {
      title: "操作",
      // width: 500,
      portList: [],
      querySource: {},
      queryParam: {
        taskHeaderId: "",
      },
      visible: false,
      model: {},

      activeKey: '1',
      confirmLoading: false,

      description: 'AGV任务管理页面',
      firstLoad:0,
      isorter: {
        column: 'status',
        order: 'asc',
      },

      url: {
        list: "/task/agvTaskMenu/getStation",

      },
      dictOptions: {},
      superFieldList: [],
    }
  },
  created() {
    this.getSuperFieldList();
  },
  mounted() {
    if(this.firstLoad == 0) {
      this.firstLoad = 1;
      return;
    }
    //页面没加载完,此时methods里的方法找不到,使用定时器模拟点击
    let timeSearch=setInterval(()=>{
      let eleSearch= document.getElementById("search");
      if (eleSearch!=null){
        //调用成功,清除定时器
        clearInterval(timeSearch)
        eleSearch.click();
      }
    },200)
  },
  computed: {
    importExcelUrl: function () {
      return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`;
    },
  },
  methods: {
    getStatusColor(status) {
      const colors = {
        '生成任务': 'green',
        '下发任务': 'blue',
        '开始执行': 'orange',
        '取货完成': 'purple',
        '任务完成': 'grey',
        default: 'blue'
      };
      return colors[status] || colors.default;
    },
    edit (record) {

      this.queryParam = {taskHeaderId:record.taskHeaderId}
      this.model = Object.assign({}, record);
      this.model.dictId = this.dictId;
      this.model.status = this.status;
      this.visible = true;

      // 当其它模块调用该模块时,调用此方法加载字典数据
      this.loadData();
      // this.visible=true
      // this.model.containerCode = record[0].containerCode;
      // this.inventoryHeaderList = record;
      // this.getList();


    },
    close() {
      this.$emit('close');
      this.visible = false;
    },
    initDictConfig() {
    },
    executeAgvTask(record) {
      this.loading = true;
      this.model = Object.assign({}, record);
      executeAgv(this.model.id).then((res) => {
        this.loading = false;
        if (res.success) {
          this.$message.success(res.message);
        } else {
          this.$message.error(res.message);
        }
        this.searchQuery();
      });
    },
    completeAgvTask(record) {
      this.loading = true;
      this.model = Object.assign({}, record);
      completeAgv(this.model.id).then((res) => {
        this.loading = false;
        if (res.success) {
          this.$message.success(res.message);
        } else {
          this.$message.error(res.message);
        }
        this.searchQuery();
      });
    },
    cancelAgvTask(record) {
      this.loading = true;
      this.model = Object.assign({}, record);
      cancelAgv(this.model.id).then((res) => {
        this.loading = false;
        if (res.success) {
          this.$message.success(res.message);
        } else {
          this.$message.error(res.message);
        }
        this.searchQuery();
      });
    },
    getSuperFieldList() {
      let fieldList = [];
      fieldList.push({type: 'string', value: 'warehouseCode', text: '仓库编码', dictCode: ''})
      fieldList.push({type: 'string', value: 'zoneCode', text: '库区', dictCode: ''})
      fieldList.push({type: 'int', value: 'taskType', text: '任务类型', dictCode: 'agv_task_type'})
      fieldList.push({type: 'string', value: 'containerCode', text: '容器编码', dictCode: ''})
      fieldList.push({type: 'string', value: 'carno', text: '小车编码', dictCode: ''})
      fieldList.push({type: 'int', value: 'priority', text: '优先级', dictCode: ''})
      fieldList.push({type: 'int', value: 'status', text: '状态', dictCode: 'agv_task_status'})
      fieldList.push({type: 'string', value: 'fromPort', text: '起始点位', dictCode: ''})
      fieldList.push({type: 'string', value: 'toPort', text: '目标点位', dictCode: ''})
      fieldList.push({type: 'string', value: 'createBy', text: '创建人', dictCode: ''})
      fieldList.push({type: 'datetime', value: 'createTime', text: '创建日期'})
      fieldList.push({type: 'string', value: 'updateBy', text: '更新人', dictCode: ''})
      fieldList.push({type: 'datetime', value: 'updateTime', text: '更新日期'})
      this.superFieldList = fieldList
    },
    handleOk() {
      this.close()

    },
    handleCancel() {
      this.close()
    },
  }
}
</script>
<style scoped>
@import '~@assets/less/common.less';
</style>