中航光电热表web
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.

855 lines
26 KiB

<template>
6 months ago
<basic-container>
<!-- 上岗证台账 -->
<avue-crud :option="option" :table-loading="loading" :data="data" v-model="form" v-model:page="page" ref="crud"
@row-del="rowDel" @search-change="searchChange" @search-reset="searchReset" @selection-change="selectionChange"
@current-change="currentChange" @size-change="sizeChange" @refresh-change="refreshChange" @on-load="onLoad"
:span-method="spanMethod">
<!-- <template #userName="{ row }">{{ row.jtPostHandle.personnel.userName }}</template>
<template #deptName="{ row }">{{ row.jtPostHandle.dept.deptName }}</template>
<template #station="{ row }">{{ row.jtPostHandle.station }}</template>
<template #skillTitle="{ row }">{{ row.jtPostHandle.skillTitle }}</template>
<template #userSex="{ row }">{{ row.jtPostHandle.personnel.userSex ? '男' : '女' }}</template>
<template #education="{ row }">{{ row.jtPostHandle.education }}</template>
<template #dataBirth="{ row }">{{ row.jtPostHandle.dataBirth }}</template> -->
<template #menu-left>
<el-button type="primary" icon="el-icon-plus">维护</el-button>
<el-button type="danger" icon="el-icon-delete" @click="handleDeletes">删除</el-button>
<el-button type="success" icon="el-icon-upload" @click="handleImport">导入</el-button>
<el-button type="primary" icon="el-icon-operation" @click="handleCertificate">批量发证</el-button>
<el-button type="primary" icon="el-icon-setting" @click="handleIndate">设置有效期</el-button>
</template>
<template #menu="scope">
<el-button type="text" @click="setCode(scope.row)">设置上岗证编号</el-button>
</template>
</avue-crud>
<el-dialog append-to-body title="批量发证" v-model="ccieDialog" width="80%">
<div style="display: flex;margin-bottom: 10px;">
<el-button plain type="danger" @click="remove">删除选择行</el-button>
<el-select style="width: 240px;margin: 0 10px;" v-model="selectValue" placeholder="请选择">
<el-option v-for="item in ccieOptions" :key="item.value" :label="item.label" :value="item.value"></el-option>
</el-select>
<el-date-picker v-model="dateNum" type="date" placeholder="选择日期" />
<el-button type="primary" style="margin: 0 10px;">批量设置</el-button>
<el-button type="primary">保存</el-button>
</div>
<el-table :data="selectionArr">
<el-table-column type="selection"></el-table-column>
<el-table-column align="center" label="上岗证日期" prop="wlTime"></el-table-column>
<el-table-column align="center" label="适航日期" prop="seaTime"></el-table-column>
<el-table-column align="center" label="宇航日期" prop="astrTime"></el-table-column>
<el-table-column align="center" label="设备日期" prop="deviceTime"></el-table-column>
</el-table>
</el-dialog>
<el-dialog append-to-body title="设置有效期" v-model="indateDialog" width="80%">
<div style="display: flex;margin-bottom: 10px;">
<el-button plain type="danger" @click="remove">删除选择行</el-button>
<el-select style="width: 240px;margin: 0 10px;" v-model="selectValue" placeholder="请选择">
<el-option v-for="item in inDateOptions" :key="item.value" :label="item.label" :value="item.value"></el-option>
</el-select>
<el-date-picker v-model="dateNum" type="date" placeholder="选择日期" />
<el-button type="primary" style="margin: 0 10px;">批量设置</el-button>
<el-button type="primary">保存</el-button>
</div>
<el-table :data="inDateArr">
<el-table-column type="selection"></el-table-column>
<el-table-column align="center" label="上岗证日期" prop="wlTime"></el-table-column>
<el-table-column align="center" label="上岗证有效期(年)" prop="wlTime"></el-table-column>
<el-table-column align="center" label="适航日期" prop="seaTime"></el-table-column>
<el-table-column align="center" label="适航有效期(年)" prop="seaTime"></el-table-column>
<el-table-column align="center" label="宇航日期" prop="astrTime"></el-table-column>
<el-table-column align="center" label="宇航有效期(年)" prop="astrTime"></el-table-column>
<el-table-column align="center" label="设备日期" prop="deviceTime"></el-table-column>
<el-table-column align="center" label="设备有效期(年)" prop="deviceTime"></el-table-column>
</el-table>
</el-dialog>
<el-dialog append-to-body title="设置上岗证编号" v-model="setDialog">
<el-form :model="setForm" :rules="setRules">
<el-form-item label="编号">
<el-input placeholder="请输入编号" v-model="setForm.wlCode"></el-input>
</el-form-item>
</el-form>
<template #footer>
<span class="dialog-footer">
<el-button @click="setDialog = false"> </el-button>
<el-button type="primary" @click="setDialog = false"> </el-button>
</span>
</template>
</el-dialog>
</basic-container>
</template>
<script>
export default {
6 months ago
data() {
return {
ccieDialog: false,
indateDialog:false,
selectValue: '',
dateNum: '',
loading: false,
setDialog:false,
setForm:{},
setRules:{},
data: [],
inDateArr:[],
form: {},
page: {
pageSize: 10,
currentPage: 1,
total: 0,
},
ccieOptions: [
{
value: 1,
label: '上岗证日期'
},
{
value: 2,
label: '适航日期'
},
{
value: 3,
label: '宇航日期'
},
{
value: 4,
label: '设备日期'
}
],
inDateOptions:[
{
value: 1,
label: '上岗证有效期'
},
{
value: 2,
label: '适航有效期'
},
{
value: 3,
label: '宇航有效期'
},
{
value: 4,
label: '设备有效期'
}
],
selectionList: [],
spanArr: [
{
prop: 'userName',
span: []
},
{prop: 'deptName',span: []},
{prop: 'station',span: []},
{prop: 'skillTitle',span: []},
{prop: 'userSex',span: []},
{prop: 'education',span: []},
{prop: 'dataBirth',span: []},
{prop: 'wlCode',span: []},
{prop: 'toNewJobDueDate',span: []},
{prop: 'wlTime',span: []},
{prop: 'wlLifespan',span: []},
{prop: 'wlDueDate',span: []},
{prop: 'seaTime',span: []},
{prop: 'seaLifespan',span: []},
{prop: 'seaDueDate',span: []},
{prop: 'astrTime',span: []},
{prop: 'astrLifespan',span: []},
{prop: 'astrdueDate',span: []},
],
option: {
columnSort: true,
tip: false,
height: 'auto',
align: 'center',
calcHeight: 32,
simplePage: false,
searchShow: true,
searchMenuSpan: 6,
searchIcon: true,
searchIndex: 3,
tree: false,
border: true,
index: false,
selection: true,
viewBtn: false,
delBtn: false,
editBtn: false,
delBtnIcon: ' ',
addBtn: false,
labelWidth: 120,
searchLabelWidth: 120,
menu: true,
menuWidth: 200,
dialogWidth: 600,
dialogClickModal: false,
searchEnter: true,
excelBtn: true,
gridBtn: false,
searchShowBtn: false,
showOverflowTooltip: true,
column: [
{
label: '姓名',
prop: 'userName',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: true,
rules: [
{
required: true,
message: '请输入姓名',
trigger: 'blur',
},
],
},
{
label: '所属班组',
prop: 'deptName',
type: 'select',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: true,
rules: [
{
required: true,
message: '请输入所属班组',
trigger: 'blur',
},
],
props: {
label: 'deptName',
value: 'deptId'
},
dicData: [
{
"appLink": null,
"createTime": "2022-08-31",
"deleted": false,
"deptCode": "001",
"deptId": 1,
"deptName": "MES开发部",
"deptType": 1,
"deptTypeTitle": "厂",
"keyValue": 1,
"memo": null,
"orders": "00",
"parentDeptId": null,
"parentPath": null,
"ucDeptId": null,
"updateTime": "2022-08-31 16:32:46"
},
{
"appLink": null,
"createTime": "2023-02-06",
"deleted": false,
"deptCode": "3400",
"deptId": 41,
"deptName": "热表分厂",
"deptType": 1,
"deptTypeTitle": "厂",
"keyValue": 41,
"memo": null,
"orders": "1",
"parentDeptId": null,
"parentPath": null,
"ucDeptId": null,
"updateTime": "2023-02-06 10:25:08"
},
{
"appLink": null,
"createTime": "2023-02-06",
"deleted": false,
"deptCode": "01",
"deptId": 42,
"deptName": "化学镀镍",
"deptType": 1,
"deptTypeTitle": "厂",
"keyValue": 42,
"memo": null,
"orders": "1",
"parentDeptId": 41,
"parentPath": null,
"ucDeptId": null,
"updateTime": "2023-02-06 10:26:13"
},
]
},
{
label: '所属岗位',
prop: 'station',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: true,
rules: [
{
required: true,
message: '请输入所属岗位',
trigger: 'blur',
},
],
},
{
label: '技能等级',
prop: 'skillTitle',
type: 'select',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: true,
rules: [
{
required: true,
message: '请输入技能等级',
trigger: 'blur',
},
],
dicData: [
{
value: 1,
label: '中级'
}, {
value: 2,
label: '高级'
}, {
value: 3,
label: '技师'
}
]
},
{
label: '性别',
prop: 'userSex',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入性别',
trigger: 'blur',
},
],
},
{
label: '最高学历',
prop: 'education',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入最高学历',
trigger: 'blur',
},
],
},
{
label: '出生年月',
prop: 'dataBirth',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入出生年月',
trigger: 'blur',
},
],
},
{
label: '上岗证编号',
prop: 'wlCode',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: true,
rules: [
{
required: true,
message: '请输入上岗证编号',
trigger: 'blur',
},
],
},
{
label: '从事本岗位或工种时间',
prop: 'toNewJobDueDate',
span: 24,
width: 200,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入从事本岗位或工种时间',
trigger: 'blur',
},
],
},
{
label: '上岗证日期',
prop: 'wlTime',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入上岗证日期',
trigger: 'blur',
},
],
},
{
label: '上岗证有效期(年)',
prop: 'wlLifespan',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入上岗证有效期(年)',
trigger: 'blur',
},
],
},
{
label: '到期日期',
prop: 'wlDueDate',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入到期日期',
trigger: 'blur',
},
],
},
{
label: '适航日期',
prop: 'seaTime',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入适航日期',
trigger: 'blur',
},
],
},
{
label: '适航有效期(年)',
prop: 'seaLifespan',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入适航有效期(年)',
trigger: 'blur',
},
],
},
{
label: '到期日期',
prop: 'seaDueDate',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入到期日期',
trigger: 'blur',
},
],
},
{
label: '宇航日期',
prop: 'astrTime',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入宇航日期',
trigger: 'blur',
},
],
},
{
label: '宇航有效期',
prop: 'astrLifespan',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入宇航有效期',
trigger: 'blur',
},
],
},
{
label: '到期日期',
prop: 'astrdueDate',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入到期日期',
trigger: 'blur',
},
],
},
{
label: '设备型号',
prop: 'deviceModel',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入设备型号',
trigger: 'blur',
},
],
},
{
label: '设备名称',
prop: 'deviceName',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入设备名称',
trigger: 'blur',
},
],
},
{
label: '设备时间',
prop: 'deviceTime',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入设备时间',
trigger: 'blur',
},
],
},
{
label: '设备有效期',
prop: 'deviceLifespan',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入设备有效期',
trigger: 'blur',
},
],
},
{
label: '到期日期',
prop: 'deviceDueDate',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
search: false,
rules: [
{
required: true,
message: '请输入到期日期',
trigger: 'blur',
},
],
},
{
label: '状态',
prop: 'wlStatusTitle',
type: 'select',
span: 24,
width: 150,
labelWidth: 140,
overflow: true,
fixed: 'right',
search: true,
rules: [
{
required: true,
message: '请输入状态',
trigger: 'blur',
},
],
dicData: [
{
value: 1,
label: '正常'
}, {
value: 2,
label: '过期'
}, {
value: 3,
label: '离职'
}
]
},
]
},
}
},
mounted() {
this.rowSort()
this.rowCalc();
},
methods: {
rowCalc() {
this.spanArr.forEach((ele, index) => {
let parent
if (index !== 0) parent = this.spanArr[ele.parent || index - 1].span
ele.span = this.rowSpan(ele.prop, parent)
})
},
rowSort(list) {
let propList = this.spanArr.map(ele => ele.prop)
this.spanArr.forEach((ele, index) => {
let key = ele.prop
this.data = this.data.sort((a, b) => {
let flag = true;
for (let i = 0; i < index; i++) {
let prop = this.spanArr[i].prop
flag = flag && a[prop] == b[prop]
}
if (flag) {
if (a[key] < b[key]) { return 1; }
else if (a[key] > b[key]) { return -1; }
return 0;
}
return 0;
})
})
},
rowSpan(key, parent) {
let list = [];
let position = 0;
this.data.forEach((item, index) => {
if (index === 0) {
list.push(1)
let position = 0;
} else {
if (this.data[index][key] === this.data[index - 1][key]) {
if (parent && parent[index] !== 0) {
list.push(1)
position = index
} else {
list[position] += 1;
list.push(0)
}
} else {
list.push(1)
position = index
}
}
})
return list
},
spanMethod({ row, column, rowIndex, columnIndex }) {
for (let i = 0; i < this.spanArr.length; i++) {
const ele = this.spanArr[i]
if (column.property == ele.prop) {
const _row = ele.span[rowIndex];
const _col = _row > 0 ? 1 : 0;
return {
rowspan: _row,
colspan: _col
}
}
}
},
setCode(){
this.setDialog = true
},
// 批量发证
handleCertificate() {
this.ccieDialog = true
},
// 有效期
handleIndate(){
this.indateDialog = true
},
// 多选
selectionChange(val) {
this.selectionList = val
},
// 批量删除
handleDeletes() {
if (this.selectionList.length == 0) {
this.$message.error('请至少选择一条数据')
} else {
6 months ago
}
},
// 导入
handleImport() {
},
onLoad() {
this.data = [
{
id: 1,
userName: "张三",
// jtPostHandle: {
// personnel: {
userName: "张三",
userSex: "男",
// },
// dept: {
deptName: "班组一",
// },
station: '试验员',
skillTitle: '初级',
education: '本科',
dataBirth: '1992-11-20',
// },
wlCode: '0010', toNewJobDueDate: '2年', wlTime: '2023-10-28', wlLifespan: '2年', wlDueDate: '2025-10-28',
seaTime: '2023-10-11', seaLifespan: '3年', seaDueDate: '2026-10-11', astrTime: '2023-10-31', astrLifespan: '3年',
astrdueDate: '2026-10-31', deviceTime: '2023-10-11', deviceLifespan: '3年', deviceDueDate: '2026-10-11',
wlStatusTitle: '过期',deviceModel:'型号一',deviceName:'设备名称一'
},
{
id: 1,
userName: "张三",
// jtPostHandle: {
// personnel: {
userName: "张三",
userSex: "男",
// },
// dept: {
deptName: "班组一",
// },
station: '试验员',
skillTitle: '初级',
education: '本科',
dataBirth: '1992-11-20',
// },
wlCode: '0010', toNewJobDueDate: '2年', wlTime: '2023-10-28', wlLifespan: '2年', wlDueDate: '2025-10-28',
seaTime: '2023-10-11', seaLifespan: '3年', seaDueDate: '2026-10-11', astrTime: '2023-10-31', astrLifespan: '3年',
astrdueDate: '2026-10-31', deviceTime: '2023-10-11', deviceLifespan: '3年', deviceDueDate: '2026-10-11',
wlStatusTitle: '过期',deviceModel:'型号一',deviceName:'设备名称一'
},
{
id: 1,
userName: "张三",
// jtPostHandle: {
// personnel: {
userName: "张三",
userSex: "男",
// },
// dept: {
deptName: "班组一",
// },
station: '试验员',
skillTitle: '初级',
education: '本科',
dataBirth: '1992-11-20',
// },
wlCode: '0020', toNewJobDueDate: '2年', wlTime: '2023-10-31', wlLifespan: '2年', wlDueDate: '2025-10-31',
seaTime: '2023-10-11', seaLifespan: '3年', seaDueDate: '2026-10-11', astrTime: '2023-10-31', astrLifespan: '3年',
astrdueDate: '2026-10-31', deviceTime: '2023-10-11', deviceLifespan: '3年', deviceDueDate: '2026-10-11',
wlStatusTitle: '过期',deviceModel:'型号一',deviceName:'设备名称一'
},
{
id: 2,
userName: "李四",
// jtPostHandle: {
// personnel: {
userName: "李四",
userSex: "男",
// },
// dept: {
deptName: "班组一",
// },
station: '试验员',
skillTitle: '初级',
education: '本科',
dataBirth: '1992-11-20',
// },
wlCode: '0030', toNewJobDueDate: '2年', wlTime: '2023-10-31', wlLifespan: '2年', wlDueDate: '2025-10-31',
seaTime: '2023-10-11', seaLifespan: '3年', seaDueDate: '2026-10-11', astrTime: '2023-10-31', astrLifespan: '3年',
astrdueDate: '2026-10-31', deviceTime: '2023-10-11', deviceLifespan: '3年', deviceDueDate: '2026-10-11',
wlStatusTitle: '过期',deviceModel:'型号一',deviceName:'设备名称一'
},
]
this.page.total = this.data.length
}
}
}
</script>
6 months ago
<style></style>