<template>
|
<div class="Taskmanagement">
|
<div class="content">
|
<div class="serch">
|
<div class="time_box">
|
<div class="time">创建日期</div>
|
<el-date-picker
|
v-model="queryForm.selectTime"
|
prefix-icon="none"
|
clear-icon="none"
|
style="
|
font-size: 0.75rem !important;
|
border: 0.06rem solid rgba(222, 222, 222, 1);
|
border-radius: 0 0.25rem 0.25rem 0;
|
box-shadow: none;
|
width: 19rem;
|
height: 2rem;
|
border-left: 0;
|
"
|
format="YYYY-MM-DD HH:mm:ss"
|
type="datetimerange"
|
range-separator="~"
|
start-placeholder="起始日期"
|
end-placeholder="截止日期"
|
size="small"
|
/>
|
</div>
|
<div class="serch_box">
|
<div class="serchb">全局搜索</div>
|
<input
|
v-model="queryForm.selectName"
|
placeholder="请输入关键词搜索"
|
style="border-left: 0.06rem solid #e2e2e2"
|
/>
|
</div>
|
<el-button type="primary" size="small" style="margin-left: 0.98rem"
|
>查询</el-button
|
>
|
<el-button size="small">重置</el-button>
|
</div>
|
<div class="btns">
|
<div style="display: flex; align-items: center">
|
<el-button
|
type="primary"
|
size="small"
|
@click="dialogVisible1 = true"
|
style="
|
width: 5.5rem;
|
height: 2rem;
|
font-size: 0.88rem;
|
display: flex;
|
align-items: center;
|
"
|
><el-icon style="margin-right: 0.2rem"><Plus /></el-icon
|
>新建</el-button
|
>
|
<el-button
|
type="primary"
|
size="small"
|
@click="table = true"
|
style="
|
width: 6rem;
|
height: 2rem;
|
font-size: 0.88rem;
|
display: flex;
|
align-items: center;
|
"
|
><el-icon style="margin-right: 0.2rem"><Plus /></el-icon
|
>手动获取</el-button
|
>
|
<el-button
|
@click="dialogVisible = true"
|
size="small"
|
style="width: 5.5rem; height: 2rem; font-size: 0.88rem"
|
>批量导入</el-button
|
>
|
<el-button
|
size="small"
|
style="width: 5.5rem; height: 2rem; font-size: 0.88rem"
|
>批量导出</el-button
|
>
|
<el-button
|
size="small"
|
style="width: 5.5rem; height: 2rem; font-size: 0.88rem"
|
>批量删除</el-button
|
>
|
</div>
|
<el-button
|
size="small"
|
style="
|
width: 6.56rem;
|
height: 2rem;
|
font-size: 0.88rem;
|
background: #2200de;
|
color: #fff;
|
"
|
@click="router.push('/Tasktemplates')"
|
>任务模板</el-button
|
>
|
</div>
|
<div style="margin-top: 1rem; height: 100%">
|
<el-table
|
:data="tableData"
|
style="width: 100%"
|
:header-cell-style="{
|
background: 'rgba(250,250,250,1)',
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
border: 'none',
|
}"
|
:row-style="{
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
}"
|
>
|
<el-table-column type="selection" align="center" />
|
<el-table-column prop="address" label="车型" align="center" />
|
<el-table-column prop="date" label="车组" align="center" />
|
<el-table-column prop="name" label="股道" align="center" />
|
<el-table-column prop="address" label="车厢号位置" align="center" />
|
<el-table-column prop="address" label="转向架位置" align="center" />
|
<el-table-column prop="address" label="检修班组" align="center" />
|
<el-table-column prop="address" label="任务状态" align="center" />
|
<el-table-column prop="address" label="检修日期" align="center" />
|
<el-table-column prop="address" label="创建日期" align="center" />
|
<el-table-column prop="address" label="操作" align="center">
|
<template #default="">
|
<el-button size="small" type="text" @click="Send"
|
>派任务</el-button
|
>
|
<el-button size="small" type="text" @click="delt">编辑</el-button>
|
</template>
|
</el-table-column>
|
</el-table>
|
</div>
|
<div
|
style="
|
display: flex;
|
justify-content: right;
|
align-self: flex-end;
|
margin-bottom: 1.19rem;
|
margin-right: 1.25rem;
|
"
|
>
|
<el-pagination
|
size="small"
|
background
|
layout="prev, pager, next"
|
:total="1"
|
/>
|
</div>
|
</div>
|
<!-- 任务信息弹出框 -->
|
<el-dialog
|
v-model="dialogVisible1"
|
title=""
|
width="60%"
|
:before-close="handleClose"
|
style="margin-top: 15.625rem"
|
>
|
<template #title>
|
<div
|
style="
|
height: 3.63rem;
|
display: flex;
|
border-bottom: 1px solid #e6e6e6;
|
"
|
>
|
<span
|
style="color: rgb(16, 16, 16); font-size: 1rem; font-weight: bold"
|
>任务信息</span
|
>
|
</div>
|
</template>
|
<el-form :model="form" label-width="auto" label-position="top">
|
<el-row :gutter="20">
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>车型</span
|
>
|
</div>
|
</template>
|
<el-input size="small" v-model="form.name" placeholder="请输入" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>车组</span
|
>
|
</div>
|
</template>
|
<el-input size="small" v-model="form.name" placeholder="请输入" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>股道</span
|
>
|
</div>
|
</template>
|
<el-input size="small" v-model="form.name" placeholder="请输入" />
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row :gutter="20">
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>车厢号位置</span
|
>
|
</div>
|
</template>
|
<el-input size="small" v-model="form.name" placeholder="请输入" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>转向架位置</span
|
>
|
</div>
|
</template>
|
<el-input size="small" v-model="form.name" placeholder="请输入" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>检修班组</span
|
>
|
</div>
|
</template>
|
<el-input size="small" v-model="form.name" placeholder="请输入" />
|
</el-form-item>
|
</el-col>
|
</el-row>
|
</el-form>
|
<template #footer>
|
<div class="dialog-footer" style="text-align: center">
|
<el-button
|
size="small"
|
type="primary"
|
@click="dialogVisible1 = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>
|
确认
|
</el-button>
|
<el-button
|
size="small"
|
@click="dialogVisible1 = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>取消</el-button
|
>
|
</div>
|
</template>
|
</el-dialog>
|
|
<!-- 派任务弹出框 -->
|
<el-dialog
|
v-model="SenddialogVisible"
|
title=""
|
width="60%"
|
:before-close="handleClose"
|
top="2%"
|
>
|
<template #title>
|
<div
|
style="
|
height: 3.63rem;
|
display: flex;
|
border-bottom: 1px solid #e6e6e6;
|
"
|
>
|
<span
|
style="color: rgb(16, 16, 16); font-size: 1rem; font-weight: bold"
|
>派任务</span
|
>
|
</div>
|
</template>
|
<el-form :model="form" label-width="auto" label-position="top">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span style="font-size: 0.88rem; color: black; font-weight: bold"
|
>任务模板</span
|
>
|
</div>
|
</template>
|
<el-select v-model="value" placeholder="请选择" size="small">
|
<el-option
|
v-for="item in options"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
<el-row :gutter="20">
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>任务名称</span
|
>
|
</div>
|
</template>
|
<el-input size="small" v-model="form.name" placeholder="请输入" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>技术员</span
|
>
|
</div>
|
</template>
|
<el-input size="small" v-model="form.name" placeholder="请输入" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>检修工长</span
|
>
|
</div>
|
</template>
|
<el-input size="small" v-model="form.name" placeholder="请输入" />
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row>
|
<span
|
style="
|
color: rgb(16, 16, 16);
|
font-size: 1rem;
|
font-weight: bold;
|
margin-bottom: 1.25rem;
|
"
|
>质检组</span
|
>
|
</el-row>
|
<el-row :gutter="20">
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>电气质检</span
|
>
|
</div>
|
</template>
|
<el-select v-model="value" placeholder="请选择" size="small">
|
<el-option
|
v-for="item in options"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>机械质检</span
|
>
|
</div>
|
</template>
|
<el-select v-model="value" placeholder="请选择" size="small">
|
<el-option
|
v-for="item in options"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>地沟质检</span
|
>
|
</div>
|
</template>
|
<el-select v-model="value" placeholder="请选择" size="small">
|
<el-option
|
v-for="item in options"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row>
|
<span
|
style="
|
color: rgb(16, 16, 16);
|
font-size: 1rem;
|
font-weight: bold;
|
margin-bottom: 1.25rem;
|
"
|
>电气组</span
|
>
|
</el-row>
|
<el-row :gutter="20">
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>电气力矩作业员</span
|
>
|
</div>
|
</template>
|
<el-select v-model="value" placeholder="请选择" size="small">
|
<el-option
|
v-for="item in options"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>电气辅助员</span
|
>
|
</div>
|
</template>
|
<el-select v-model="value" placeholder="请选择" size="small">
|
<el-option
|
v-for="item in options"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row>
|
<span
|
style="
|
color: rgb(16, 16, 16);
|
font-size: 1rem;
|
font-weight: bold;
|
margin-bottom: 1.25rem;
|
"
|
>机械组</span
|
>
|
</el-row>
|
<el-row :gutter="20">
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>机械力矩作业员</span
|
>
|
</div>
|
</template>
|
<el-select v-model="value" placeholder="请选择" size="small">
|
<el-option
|
v-for="item in options"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>机械辅助员</span
|
>
|
</div>
|
</template>
|
<el-select v-model="value" placeholder="请选择" size="small">
|
<el-option
|
v-for="item in options"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row>
|
<span
|
style="
|
color: rgb(16, 16, 16);
|
font-size: 1rem;
|
font-weight: bold;
|
margin-bottom: 1.25rem;
|
"
|
>地沟组</span
|
>
|
</el-row>
|
<el-row :gutter="20">
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>地沟力矩作业员</span
|
>
|
</div>
|
</template>
|
<el-select v-model="value" placeholder="请选择" size="small">
|
<el-option
|
v-for="item in options"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
>地沟辅助员</span
|
>
|
</div>
|
</template>
|
<el-select v-model="value" placeholder="请选择" size="small">
|
<el-option
|
v-for="item in options"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
</el-form>
|
<template #footer>
|
<div class="dialog-footer" style="text-align: center">
|
<el-button
|
size="small"
|
@click="SenddialogVisible = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>取消</el-button
|
>
|
<el-button
|
size="small"
|
type="primary"
|
@click="SenddialogVisible = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>
|
保存模板并提交
|
</el-button>
|
<el-button
|
size="small"
|
type="primary"
|
@click="SenddialogVisible = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>
|
提交
|
</el-button>
|
</div>
|
</template>
|
</el-dialog>
|
|
<!-- 批量导入弹出框 -->
|
<el-dialog
|
v-model="dialogVisible"
|
title=""
|
width="60%"
|
:before-close="handleClose"
|
style="margin-top: 15.625rem"
|
>
|
<template #title>
|
<div
|
style="
|
height: 3.63rem;
|
display: flex;
|
border-bottom: 1px solid #e6e6e6;
|
"
|
>
|
<span
|
style="color: rgb(16, 16, 16); font-size: 1rem; font-weight: bold"
|
>批量导入</span
|
>
|
</div>
|
</template>
|
<el-table :data="gridtableData" style="width: 100%">
|
<el-table-column prop="date" label="车型" width="180" />
|
<el-table-column prop="name" label="车组" width="180" />
|
<el-table-column prop="address" label="股道" />
|
<el-table-column prop="address" label="车厢号位置" />
|
<el-table-column prop="address" label="转向架位置" />
|
<el-table-column prop="address" label="检修班组" />
|
<el-table-column prop="address" label="检修日期" />
|
</el-table>
|
<template #footer>
|
<div class="dialog-footer" style="text-align: center">
|
<el-button
|
size="small"
|
type="primary"
|
@click="dialogVisible = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>
|
确认
|
</el-button>
|
<el-button
|
size="small"
|
@click="dialogVisible = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>取消</el-button
|
>
|
</div>
|
</template>
|
</el-dialog>
|
</div>
|
</template>
|
<script setup>
|
import { ref, reactive } from "vue";
|
import { useRouter } from "vue-router";
|
const router = useRouter();
|
const queryForm = reactive({
|
selectName: "",
|
selectTime: [], // 时间范围
|
});
|
|
const tableData = ref([]);
|
|
const options = ref([]);
|
const props = { multiple: true };
|
|
const table = ref(false);
|
const form = reactive({});
|
|
function cancelClick() {
|
table.value = false;
|
}
|
function confirmClick() {
|
table.value = false;
|
}
|
//删除
|
const dialogVisible1 = ref(false);
|
//派任务
|
const SenddialogVisible = ref(false);
|
//批量导入
|
const dialogVisible = ref(false);
|
//批量导入数据
|
const gridtableData = ref([]);
|
//派任务方法
|
const Send = () => {
|
SenddialogVisible.value = true;
|
};
|
//删除方法
|
const delt = () => {
|
dialogVisible1.value = true;
|
};
|
</script>
|
<style lang="scss" scoped>
|
.Taskmanagement {
|
display: flex;
|
background-color: #fff;
|
.content {
|
width: 100%;
|
display: flex;
|
flex-direction: column;
|
.serch {
|
display: flex;
|
margin-top: 1.31rem;
|
align-items: center;
|
.time_box {
|
display: flex;
|
align-items: center;
|
text-align: center;
|
margin-left: 0.98rem;
|
.time {
|
box-sizing: border-box;
|
width: 6.88rem;
|
height: 2rem;
|
text-align: center;
|
border: 0.06rem solid rgba(222, 222, 222, 1);
|
border-radius: 0.25rem 0 0 0.25rem;
|
font-size: 0.75rem;
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
}
|
}
|
.serch_box {
|
display: flex;
|
align-items: center;
|
text-align: center;
|
margin-left: 0.98rem;
|
border-radius: 0.38rem;
|
.serchb {
|
box-sizing: border-box;
|
width: 6.88rem;
|
height: 2rem;
|
text-align: center;
|
border: 0.06rem solid rgba(222, 222, 222, 1);
|
border-radius: 0.25rem 0 0 0.25rem;
|
font-size: 0.75rem;
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
}
|
input {
|
box-sizing: border-box;
|
outline: none;
|
width: 19rem;
|
height: 2rem;
|
border: 0.06rem solid rgba(222, 222, 222, 1);
|
border-radius: 0 0.25rem 0.25rem 0;
|
padding-left: 0.3125rem;
|
font-size: 1rem;
|
}
|
}
|
}
|
.btns {
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
margin-top: 1.31rem;
|
margin-left: 1.13rem;
|
padding-right: 2rem;
|
box-sizing: border-box;
|
}
|
}
|
}
|
</style>
|
<style>
|
.confirmButtonClass {
|
margin-right: 10px;
|
}
|
.el-message-box .el-message-box__btns {
|
flex-direction: row-reverse !important;
|
justify-content: normal !important;
|
}
|
</style>
|