You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
395 lines
17 KiB
395 lines
17 KiB
<template>
|
|
<div class="app-container">
|
|
<!--工具栏-->
|
|
<div class="head-container">
|
|
<div v-if="crud.props.searchToggle">
|
|
<el-form
|
|
:inline="true"
|
|
class="demo-form-inline"
|
|
label-position="right"
|
|
label-width="80px"
|
|
label-suffix=":"
|
|
>
|
|
<el-form-item label="任务号">
|
|
<label slot="label">任 务 号:</label>
|
|
<el-input
|
|
v-model="query.task_code"
|
|
clearable
|
|
style="width: 180px"
|
|
placeholder="任务号"
|
|
@keyup.enter.native="crud.toQuery"
|
|
/>
|
|
</el-form-item>
|
|
<el-form-item label="载具号">
|
|
<label slot="label">载 具 号:</label>
|
|
<el-input
|
|
v-model="query.vehicle_code"
|
|
clearable
|
|
style="width: 180px"
|
|
placeholder="载具号"
|
|
@keyup.enter.native="crud.toQuery"
|
|
/>
|
|
</el-form-item>
|
|
<el-form-item label="点位编码">
|
|
<el-input
|
|
v-model="query.point_code"
|
|
clearable
|
|
style="width: 180px"
|
|
placeholder="起点"
|
|
@keyup.enter.native="crud.toQuery"
|
|
/>
|
|
</el-form-item>
|
|
<el-form-item label="创建时间">
|
|
<el-date-picker
|
|
v-model="query.createTime"
|
|
type="datetimerange"
|
|
value-format="yyyy-MM-dd HH:mm:ss"
|
|
range-separator="至"
|
|
start-placeholder="开始日期"
|
|
end-placeholder="结束日期"
|
|
@change="crud.toQuery"
|
|
/>
|
|
</el-form-item>
|
|
<el-form-item label="任务状态">
|
|
<el-select
|
|
v-model="query.task_status"
|
|
multiple
|
|
style="width: 360px"
|
|
placeholder="任务状态"
|
|
class="filter-item"
|
|
clearable
|
|
@change="handTaskStatus"
|
|
>
|
|
<el-option
|
|
v-for="item in taskStatusList"
|
|
:key="item.code"
|
|
:label="item.name"
|
|
:value="item.code"
|
|
/>
|
|
</el-select>
|
|
</el-form-item>
|
|
<rrOperation />
|
|
</el-form>
|
|
</div>
|
|
<!--如果想在工具栏加入更多按钮,可以使用插槽方式, slot = 'left' or 'right'-->
|
|
<crudOperation :permission="permission" />
|
|
<!--表单组件-->
|
|
<el-dialog :close-on-click-modal="false" :before-close="crud.cancelCU" :visible.sync="crud.status.cu > 0" :title="crud.status.title" width="800px">
|
|
<el-form ref="form" style="border: 1px solid #cfe0df;margin-top: 10px;padding-top: 10px;" :inline="true" :model="form" :rules="rules" size="mini" label-width="115px" label-suffix=":">
|
|
<el-form-item label="任务编码">
|
|
<el-input v-model="form.task_code" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="任务分类">
|
|
<el-input v-model="form.task_class_id" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="任务状态">
|
|
<el-input v-model="form.task_status" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="配置编码">
|
|
<el-input v-model="form.config_code" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="点位1">
|
|
<el-input v-model="form.point_code1" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="点位2">
|
|
<el-input v-model="form.point_code2" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="点位3">
|
|
<el-input v-model="form.point_code3" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="点位4">
|
|
<el-input v-model="form.point_code4" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="载具类型">
|
|
<el-input v-model="form.vehicle_type" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="载具数量">
|
|
<el-input v-model="form.vehicle_qty" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="载具编码">
|
|
<el-input v-model="form.vehicle_code" style="width: 240px;" />
|
|
</el-form-item>
|
|
<!-- <el-form-item label="优先级">-->
|
|
<!-- <el-input v-model="form.priority" style="width: 240px;" />-->
|
|
<!-- </el-form-item>-->
|
|
<el-form-item v-if="false" label="处理类">
|
|
<el-input v-model="form.handle_class" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="处理状态">
|
|
<el-input v-model="form.handle_status" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="车号">
|
|
<el-input v-model="form.car_no" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="任务组标识">
|
|
<el-input v-model="form.task_group_id" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="任务组顺序号">
|
|
<el-input v-model="form.task_group_seq" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="任务完成类型">
|
|
<el-input v-model="form.finished_type" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="生成方式">
|
|
<el-input v-model="form.create_mode" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="链路标识">
|
|
<el-input v-model="form.acs_trace_id" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item v-if="false" label="生成任务的请求参数">
|
|
<el-input v-model="form.request_param" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="下发任务的请求参数">
|
|
<el-input v-model="form.response_param" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="车间编码">
|
|
<el-input v-model="form.workshop_code" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="额外组盘信息">
|
|
<el-input v-model="form.ext_group_data" style="width: 240px;" />
|
|
</el-form-item>
|
|
<el-form-item label="备注">
|
|
<el-input v-model="form.remark" style="width: 240px;" />
|
|
</el-form-item>
|
|
</el-form>
|
|
<div slot="footer" class="dialog-footer">
|
|
<el-button type="text" @click="crud.cancelCU">取消</el-button>
|
|
<el-button :loading="crud.cu === 2" type="primary" @click="crud.submitCU">确认</el-button>
|
|
</div>
|
|
</el-dialog>
|
|
<!--表格渲染-->
|
|
<el-table ref="table" v-loading="crud.loading" :data="crud.data" size="mini" style="width: 100%;" @selection-change="crud.selectionChangeHandler">
|
|
<el-table-column type="selection" width="55" />
|
|
<el-table-column prop="task_id" label="任务ID" :min-width="flexWidth('task_id',crud.data,'任务编码')" />
|
|
<el-table-column prop="task_code" label="任务编码" :min-width="flexWidth('task_code',crud.data,'任务编码')" />
|
|
<el-table-column prop="vehicle_code" label="载具编码1" :min-width="flexWidth('vehicle_code',crud.data,'载具编码1')">
|
|
<template slot-scope="scope">
|
|
{{ scope.row.vehicle_code ? scope.row.vehicle_code : '-' }}
|
|
</template>
|
|
</el-table-column>
|
|
<!-- <el-table-column prop="vehicle_code2" label="载具编码2" :min-width="flexWidth('vehicle_code2',crud.data,'载具编码2')">
|
|
<template slot-scope="scope">
|
|
{{ scope.row.vehicle_code2 ? scope.row.vehicle_code2 : '-' }}
|
|
</template>
|
|
</el-table-column> -->
|
|
<!-- <el-table-column prop="task_class_id" label="任务分类" :min-width="flexWidth('task_class_id',crud.data,'任务分类')" />-->
|
|
<el-table-column prop="task_status" label="任务状态" :min-width="flexWidth('task_status',crud.data,'任务状态')">
|
|
<template slot-scope="scope">
|
|
{{ getStatusName(scope.row.task_status) }}
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column prop="remark" label="提示信息" :min-width="flexWidth('remark',crud.data,'提示信息')" />
|
|
<el-table-column prop="config_code" label="配置编码" :min-width="flexWidth('config_code',crud.data,'配置编码')" />
|
|
<el-table-column prop="point_code1" label="点位1" :min-width="flexWidth('point_code1',crud.data,'点位1')" />
|
|
<el-table-column prop="point_code2" label="点位2" :min-width="flexWidth('point_code2',crud.data,'点位2')" />
|
|
<!-- <el-table-column prop="request_param" label="请求参数" :min-width="flexWidth('request_param',crud.data,'请求参数')" /> -->
|
|
<el-table-column prop="request_param" label="请求参数" :min-width="150">
|
|
<template slot-scope="scope">
|
|
<div class="truncate" :title="scope.row.request_param" placement="top">
|
|
{{ scope.row.request_param }}
|
|
</div>
|
|
</template>
|
|
</el-table-column>
|
|
<!-- <el-table-column prop="start_wait_point" label="取货等待点" :min-width="flexWidth('start_wait_point',crud.data,'取货等待点')" />-->
|
|
<el-table-column v-if="false" prop="next_wait_point" label="放货等待点" :min-width="flexWidth('next_wait_point',crud.data,'放货等待点')" />
|
|
<el-table-column v-if="false" prop="vehicle_type" label="载具类型" :min-width="flexWidth('vehicle_type',crud.data,'载具类型', 20)">
|
|
<template slot-scope="scope">
|
|
{{ dict.label.vehicle_type[scope.row.vehicle_type] }}
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column prop="vehicle_qty" label="载具数量" :min-width="flexWidth('vehicle_qty',crud.data,'载具数量')" />
|
|
<el-table-column v-if="false" prop="priority" label="优先级" :min-width="flexWidth('priority',crud.data,'优先级')" />
|
|
<el-table-column v-if="false" prop="handle_class" label="处理类" :min-width="flexWidth('handle_class',crud.data,'处理类')" />
|
|
<el-table-column v-if="false" prop="handle_status" label="处理状态" :min-width="flexWidth('handle_status',crud.data,'处理状态')" />
|
|
<el-table-column prop="car_no" label="车号" :min-width="flexWidth('car_no',crud.data,'车号')" />
|
|
<el-table-column v-if="false" prop="task_group_id" label="任务组标识" :min-width="flexWidth('task_group_id',crud.data,'任务组标识')" />
|
|
<el-table-column v-if="false" prop="task_group_seq" label="任务组顺序号" :min-width="flexWidth('task_group_seq',crud.data,'任务组顺序号')" />
|
|
<el-table-column v-if="false" prop="finished_type" label="任务完成类型" :min-width="flexWidth('finished_type',crud.data,'任务完成类型')">
|
|
<template slot-scope="scope">
|
|
{{ dict.label.finished_type[scope.row.finished_type]?dict.label.finished_type[scope.row.finished_type]:'未完成' }}
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column prop="create_mode" label="生成方式" :min-width="flexWidth('create_mode',crud.data,'生成方式')">
|
|
<template slot-scope="scope">
|
|
{{ dict.label.create_mode[scope.row.create_mode] }}
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column v-if="false" prop="request_param" label="生成任务的请求参数" :min-width="100" show-overflow-tooltip />
|
|
<el-table-column v-if="false" prop="workshop_code" label="车间编码" :min-width="flexWidth('workshop_code',crud.data,'车间编码')" />
|
|
<el-table-column prop="create_name" label="创建人" :min-width="flexWidth('create_name',crud.data,'创建人')" />
|
|
<el-table-column prop="create_time" label="创建时间" :min-width="flexWidth('create_time',crud.data,'创建时间')" />
|
|
<el-table-column prop="update_name" label="修改人" :min-width="flexWidth('update_name',crud.data,'修改人')" />
|
|
<el-table-column prop="update_time" label="修改时间" :min-width="flexWidth('update_time',crud.data,'修改时间')" />
|
|
<el-table-column v-permission="[]" label="操作" width="160px" align="center" fixed="right">
|
|
<template slot-scope="scope">
|
|
<el-button
|
|
type="text"
|
|
icon="el-icon-close"
|
|
:disabled="scope.row.task_status==='5' || scope.row.task_status==='6'"
|
|
@click="doOperate(scope.row, 'b')"
|
|
>取消</el-button>
|
|
<el-button
|
|
type="text"
|
|
icon="el-icon-success"
|
|
:disabled="scope.row.task_status==='5' || scope.row.task_status==='6'"
|
|
@click="doOperate(scope.row, 'a')"
|
|
>完成</el-button>
|
|
<!-- <el-button
|
|
type="text"
|
|
icon="el-icon-error"
|
|
:disabled="scope.row.task_status==='5' || scope.row.task_status==='6'"
|
|
@click="doOperate(scope.row, 's')"
|
|
>任务调度</el-button> -->
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
<!--分页组件-->
|
|
<pagination />
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import crudSchBaseTask from './schBaseTask'
|
|
import CRUD, { crud, form, header, presenter } from '@crud/crud'
|
|
import rrOperation from '@crud/RR.operation'
|
|
import crudOperation from '@crud/CRUD.operation'
|
|
import pagination from '@crud/Pagination'
|
|
|
|
const defaultForm = {
|
|
task_id: null,
|
|
task_code: null,
|
|
task_class_id: null,
|
|
task_status: null,
|
|
config_code: null,
|
|
point_code1: null,
|
|
point_code2: null,
|
|
point_code3: null,
|
|
point_code4: null,
|
|
start_wait_point: null,
|
|
next_wait_point: null,
|
|
vehicle_type: null,
|
|
vehicle_qty: null,
|
|
vehicle_code: null,
|
|
vehicle_code2: null,
|
|
priority: null,
|
|
handle_class: null,
|
|
handle_status: null,
|
|
car_no: null,
|
|
task_group_id: null,
|
|
task_group_seq: null,
|
|
finished_type: null,
|
|
create_mode: null,
|
|
acs_trace_id: null,
|
|
request_param: null,
|
|
response_param: null,
|
|
workshop_code: null,
|
|
ext_group_data: null,
|
|
remark: null,
|
|
is_delete: false
|
|
}
|
|
export default {
|
|
name: 'Task',
|
|
dicts: ['vehicle_type', 'create_mode', 'finished_type'],
|
|
components: { pagination, crudOperation, rrOperation },
|
|
mixins: [presenter(), header(), form(defaultForm), crud()],
|
|
cruds() {
|
|
return CRUD({
|
|
title: '任务管理',
|
|
url: 'api/schBaseTask',
|
|
idField: 'task_id',
|
|
sort: 'task_code,desc',
|
|
optShow: {
|
|
add: false,
|
|
edit: false,
|
|
del: false,
|
|
download: false,
|
|
reset: true
|
|
},
|
|
crudMethod: { ...crudSchBaseTask }
|
|
})
|
|
},
|
|
data() {
|
|
return {
|
|
permission: {
|
|
},
|
|
rules: {
|
|
},
|
|
taskStatusList: []
|
|
}
|
|
},
|
|
created() {
|
|
this.getTaskStatusList()
|
|
},
|
|
methods: {
|
|
// 钩子:在获取表格数据之前执行,false 则代表不获取数据
|
|
[CRUD.HOOK.beforeRefresh]() {
|
|
return true
|
|
},
|
|
hand(value) {
|
|
this.crud.toQuery()
|
|
},
|
|
handTaskStatus(value) {
|
|
this.crud.query.more_task_status = null
|
|
if (value) {
|
|
this.crud.query.more_task_status = value.toString()
|
|
}
|
|
this.crud.toQuery()
|
|
},
|
|
getTaskStatusList() {
|
|
crudSchBaseTask.getTaskStatusList().then(res => {
|
|
this.taskStatusList = res.content
|
|
})
|
|
},
|
|
getStatusName(code) {
|
|
const status = this.taskStatusList.find(item => item.code === code)
|
|
return status ? status.name : '-'
|
|
},
|
|
doOperate(row, command) {
|
|
let method_name = ''
|
|
switch (command) {
|
|
case 'a':// 完成
|
|
method_name = 'forceFinish'
|
|
break
|
|
case 'b':// 取消
|
|
method_name = 'cancel'
|
|
break
|
|
case 'c':// 下发
|
|
method_name = 'immediateNotifyAcs'
|
|
break
|
|
case 'd':// 详情
|
|
method_name = 'view'
|
|
break
|
|
case 's':// 详情
|
|
method_name = 'view'
|
|
break
|
|
}
|
|
if (method_name === 'view') {
|
|
// this.view(row)
|
|
return
|
|
}
|
|
const data = {
|
|
task_code: row.task_code,
|
|
method_name: method_name,
|
|
config_code: row.config_code
|
|
}
|
|
crudSchBaseTask.operation(data).then(res => {
|
|
this.crud.toQuery()
|
|
this.crud.notify('操作成功', CRUD.NOTIFICATION_TYPE.SUCCESS)
|
|
}).catch(err => {
|
|
console.log(err.response.data.message)
|
|
})
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
.truncate {
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
max-width: 100%; /* 或者设置为具体的宽度 */
|
|
cursor: pointer; /* 可选:鼠标悬停时变为手形 */
|
|
}
|
|
</style>
|
|
|