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

742 lines
22 KiB

8 months ago
<template>
<basic-container>
<!-- 薪资维护标准 -->
<avue-crud
:option="option"
:table-loading="loading"
:data="data"
v-model="form"
v-model:page="page"
ref="crud"
@row-update="rowUpdate"
@row-save="rowSave"
@search-change="searchChange"
@search-reset="searchReset"
@selection-change="selectionChange"
@current-change="currentChange"
@size-change="sizeChange"
@refresh-change="refreshChange"
@on-load="onLoad"
:span-method="spanMethod"
:before-open="beforeOpen"
>
<template #menu-left>
<el-button type="danger" @click="handleDelete"
>删除</el-button
>
</template>
6 months ago
<template #menu-right>
<el-button type="primary" @click="handleImport"
6 months ago
>导入
</el-button>
</template>
<template #standardType="scope">
<el-tag v-if="scope.row.standardType == 1" type="success">军品</el-tag>
<el-tag v-if="scope.row.standardType == 2" type="danger">非军品</el-tag>
<el-tag v-if="scope.row.standardType == 3">通用</el-tag>
</template>
<!-- 工序选择 -->
<template #processId-form="{ type, disabled }">
<el-select
v-model="form.processId"
remote
filterable
:remote-method="getPpsList"
placeholder="请选择工序"
@change="changeProcess"
>
<el-option v-for="item in ppsData" :key="item.id"
:label="`${item.code}-${item.name}`"
:value="item.id"
></el-option>
</el-select>
</template>
<!-- 零件号 -->
<template #partNo-form="{ type, disabled}">
<el-input v-model="form.partNo" placeholder="多个零件号以空格分隔"></el-input>
</template>
<!-- 阶梯上下限 -->
<template #step-form="{type,disabled}">
<el-select v-model="form.stepType" style="width:30%;" @change="changeType">
<el-option label="无补贴金额" value="1"></el-option>
<el-option label="固定补贴金额" value="2"></el-option>
<el-option label="阶梯补贴金额" value="3"></el-option>
</el-select>
<el-input style="width:68%;margin-left:1%;" :disabled="form.stepType != 3" v-model="form.step" placeholder="阶梯以空格分隔,如:10 20 30"></el-input>
</template>
<!-- 阶梯结算价 -->
<template #stepSettlementPrice-form="{type,disabled}">
<!-- <el-select></el-select> -->
<el-input v-model="form.stepSettlementPrice" :disabled="form.stepType == 1" placeholder="结算价以空格分隔,如:5 10 15 20"></el-input>
</template>
<!-- 阶梯结算单位 -->
<template #stepSettlementUnit-form="{type,disabled}">
<el-select v-model="form.stepSettlementUnit" placeholder="请选择阶梯结算单位" :disabled="form.stepType == 1">
<el-option label="批" value="1"></el-option>
<el-option label="倍" value="2"></el-option>
</el-select>
</template>
<!-- 阶梯单位 -->
<template #stepUnit-form="{type,disabled}">
<el-select v-model="form.stepUnit" placeholder="请选择阶梯单位" :disabled="form.stepType == 1">
<el-option label="件" value="1"></el-option>
<el-option label="面积" value="2"></el-option>
</el-select>
</template>
</avue-crud>
6 months ago
<!-- 导入 -->
<basic-import v-if="isShowImport" title="导入" :isShow="isShowImport"
templateUrl="/blade-desk/QA/CycleTestItem/download-excel-template"
templateName="试验项目模板.xls"
6 months ago
importUrl="/blade-desk/QA/CycleTestItem/import-excel"
@closeDialog="closeDialog"></basic-import>
</basic-container>
8 months ago
</template>
<script>
6 months ago
import basicImport from '@/components/basic-import/main.vue'
import {getProcessList,getList,deleteTable,addTable } from "@/api/performanceManagement/salaryManagement"
8 months ago
export default {
6 months ago
components: {
basicImport,
},
data() {
return {
6 months ago
isShowImport:false,
loading: false,
data: [],
form: {},
page: {
pageSize: 10,
currentPage: 1,
total: 0,
},
ppsData:[],
spanArr: [
{ prop: "standardType", span: [] },
{ prop: "processName", span: [] },
{ prop: "partNo", span: [] },
{ prop: "settlementPrice", span: [] },
{ prop: "settlementUnit", span: [] },
],
selectionList: [],
option: {
height: "auto",
calcHeight: 32,
tip: false,
simplePage: true,
searchShow: true,
searchMenuSpan: 18,
searchIcon: true,
searchIndex: 3,
tree: false,
border: true,
index: true,
selection: true,
viewBtn: false,
delBtn: false,
addBtn: true,
editBtn: true,
editBtnText: "修改",
addBtnIcon: " ",
viewBtnIcon: " ",
delBtnIcon: " ",
editBtnIcon: " ",
viewBtnText: "详情",
labelWidth: 120,
searchLabelWidth: 'auto',
menuWidth: 80,
dialogWidth: 1200,
dialogClickModal: false,
searchEnter: true,
excelBtn: false,
filterBtn: true,
searchShowBtn: false,
columnSort: true,
excelBtn: true,
columnSort: true,
index: false,
showOverflowTooltip: true,
searchLabelPosition: "left",
searchLabelPosition: "left",
searchGutter: 24,
searchSpan: 6,
menuAlign: "center",
gridBtn: false,
searchMenuPosition: "right",
align: "center",
column: [
{
label: "规则类型",
prop: "standardType",
type: "select",
search: false,
sortable: true,
overHidden: true,
width: 100,
rules: [
{
required: true,
message: "请输入是否军品",
trigger: "blur",
},
],
dicData: [
{ label: "军品", value: 1 },
{ label: "非军品", value: 2 },
{ label: "通用", value: 3 },
],
},
{
label: "工序",
prop: "processName",
search: true,
sortable: true,
overHidden: true,
addDisplay: false,
editDisplay: false,
width: 100,
rules: [
{
required: true,
message: "请输入工序",
trigger: "blur",
},
],
},
{
label: "工序",
prop: "processId",
search: false,
sortable: true,
hide:true,
overHidden: true,
addDisplay: true,
editDisplay: true,
width: 100,
rules: [
{
required: true,
message: "请选择工序",
trigger: "blur",
},
8 months ago
],
},
{
label: "零件号",
prop: "partNo",
search: false,
sortable: true,
overHidden: true,
minWidth: 160,
// rules: [
// {
// required: true,
// message: '请输入其他',
// trigger: 'blur',
// },
// ],
},
{
label: "工人结算价",
prop: "settlementPrice",
type: "number",
search: false,
sortable: true,
overHidden: true,
width: 110,
rules: [
{
required: true,
message: "请输入工人结算价",
trigger: "blur",
},
],
},
{
label: "工人结算单位",
prop: "settlementUnit",
type: "select",
search: false,
sortable: true,
overHidden: true,
width: 120,
rules: [
{
required: true,
message: "请输入工人结算单位",
trigger: "blur",
},
],
dicData: [
{ label: "件", value: 1 },
{ label: "批", value: 2 },
{ label: "面积", value: 3 },
],
},
{
label: "阶梯上下限",
prop: "step",
hide:true,
search: false,
sortable: true,
overHidden: true,
width: 100,
addDisplay: true,
editDisplay: true,
rules: [
{
required: false,
message: '请填写阶梯上下限',
trigger: 'blur',
},
],
},
{
label: "阶梯下限",
prop: "minStep",
type: "number",
search: false,
sortable: true,
overHidden: true,
width: 95,
addDisplay: false,
editDisplay: false,
},
{
label: "阶梯上限",
prop: "maxStep",
search: false,
type: "number",
sortable: true,
overHidden: true,
addDisplay: false,
editDisplay: false,
width: 95,
},
{
label: "阶梯单位",
prop: "stepUnit",
type: "select",
search: false,
sortable: true,
overHidden: true,
width: 100,
dicData: [
{ label: "件", value: 1 },
{ label: "面积", value: 2 },
],
rules: [
{
required: false,
message: '请选择阶梯单位',
trigger: 'blur',
},
],
},
{
label: "阶梯结算价",
prop:"stepSettlementPrice",
search: false,
sortable: true,
overHidden: true,
hide: true,
width: 110,
addDisplay: true,
editDisplay: true,
rules: [
{
required: false,
message: '请输入阶梯结算价',
trigger: 'blur',
},
],
},
{
label: "阶梯结算价",
prop: "price",
type: "number",
search: false,
sortable: true,
overHidden: true,
addDisplay: false,
editDisplay: false,
width: 110,
},
{
label: "阶梯结算单位",
prop: "stepSettlementUnit",
type: "select",
search: false,
sortable: true,
overHidden: true,
width: 120,
dicData: [
{ label: "批", value: 1 },
{ label: "倍", value: 2 },
],
rules: [
{
required: false,
message: '请选择阶梯结算单位',
trigger: 'blur',
},
],
},
],
},
};
},
mounted() {
},
methods: {
getPpsList(query){
console.log('form============',this.form)
getProcessList({
current:1,
size:300,
name:query
}).then(res =>{
this.ppsData = res.data.data.records
if(this.form.processId){
let tmp = this.ppsData.find(item => item.id == this.form.processId)
if(!tmp){
this.ppsData.unshift({
name:this.form.processName,
code:this.form.ppsCode,
id:this.form.processId
})
}
}
})
},
changeProcess(val){
this.form.processName = this.ppsData.find(item => item.id == val).name
this.form.ppsCode = this.ppsData.find(item => item.id == val).code
},
changeType(val){
if(val == 1){
this.form.step = ''
this.form.stepSettlementPrice = ''
this.form.stepSettlementUnit = ''
this.form.stepUnit = ''
this.option.column.find(item => item.prop == "stepUnit").rules[0].required = false
this.option.column.find(item => item.prop == "step").rules[0].required = false
this.option.column.find(item => item.prop == "stepSettlementPrice").rules[0].required = false
this.option.column.find(item => item.prop == "stepSettlementUnit").rules[0].required = false
}else if(val == 2){
this.form.step = ''
this.option.column.find(item => item.prop == "step").rules[0].required = false
this.option.column.find(item => item.prop == "stepUnit").rules[0].required = true
this.option.column.find(item => item.prop == "stepSettlementPrice").rules[0].required = true
this.option.column.find(item => item.prop == "stepSettlementUnit").rules[0].required = true
}else{
this.option.column.find(item => item.prop == "step").rules[0].required = true
this.option.column.find(item => item.prop == "stepUnit").rules[0].required = true
this.option.column.find(item => item.prop == "stepSettlementPrice").rules[0].required = true
this.option.column.find(item => item.prop == "stepSettlementUnit").rules[0].required = true
}
},
rowCalc() {
console.log('spanArr===========',this.spanArr)
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;
console.log('data------------',this.data)
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);
8 months ago
}
} else {
list.push(1);
position = index;
}
8 months ago
}
});
return list;
8 months ago
},
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,
};
} else if (columnIndex == 0) {
const _row = ele.span[rowIndex];
const _col = _row > 0 ? 1 : 0;
return {
rowspan: _row,
colspan: _col,
};
} else if (columnIndex == 11) {
const _row = ele.span[rowIndex];
const _col = _row > 0 ? 1 : 0;
return {
rowspan: _row,
colspan: _col,
};
}
}
8 months ago
},
selectionChange(val) {
this.selectionList = val;
},
beforeOpen(done, type){
if(type == 'add'){
this.form = {
...this.form,
settlementUnit:1
}
done()
}else{
done()
}
},
// 新增数据
rowSave(row, done, loading) {
console.log('row---------------',row)
if(row.stepType == 2){
let stepSettlementPriceArr = row.stepSettlementPrice.split(' ')
if(stepSettlementPriceArr.length > 1){
this.$message.error('【固定补贴金额】时,阶梯结算价应只有一个')
loading()
return
}
}else if(row.stepType == 3){
let stepArr = row.step.split(' ')
let stepSettlementPriceArr = row.stepSettlementPrice.split(' ')
if(stepArr.length > 0 && stepSettlementPriceArr.length > 0 && stepSettlementPriceArr.length - stepArr.length != 1){
this.$message.error('【阶梯补贴金额】时,阶梯结算价应比阶梯上下限数量多一个')
loading()
return
}
}
done();
},
// 修改数据
rowUpdate(row, index, done, loading) {
done();
},
// 批量删除
handleDelete() {
if (this.selectionList.length == 0) {
this.$message.error("请先选择数据");
return;
}
this.$confirm("确定将选择数据删除?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning",
}).then(() => {
deleteTable({
ids:this.selectionList.map(item => item.id).join(",")
}).then(res =>{
if(res.data.code == 200){
this.$message.success('删除成功')
this.onLoad()
}
})
});
},
currentChange(currentPage) {
this.page.currentPage = currentPage;
},
sizeChange(pageSize) {
this.page.pageSize = pageSize;
},
refreshChange() {
this.onLoad(this.page, this.query);
},
searchReset() {
this.query = {};
this.treeDeptId = "";
this.onLoad(this.page);
},
searchChange(params, done) {
this.query = params;
this.page.currentPage = 1;
this.onLoad(this.page, params);
done();
},
selectionChange(list) {
this.selectionList = list;
},
selectionClear() {
this.selectionList = [];
this.$refs.crud.toggleSelection();
6 months ago
},
// 点击导入按钮
handleImport() {
this.isShowImport = true
},
onLoad() {
this.loading = true
getList({
curremt:this.page.currentPage,
size:this.page.pageSize,
...this.query
}).then(res =>{
this.data = res.data.data.records
this.page.total = res.data.data.total
// this.$nextTick(() =>{
this.rowSort();
this.rowCalc();
// })
this.loading = false
})
// this.data = [
// {
// countUnit: 1,
// stepUnit: "件",
// createTime: "2023-12-07 20:57:12",
// keyValue: 2,
// maxStep: 10,
// standardType: 1,
// minStep: 0,
// settlementUnit: 1,
// stepSettlementUnit: "批",
// bound: "10,20",
// stepSettlementPrice: "10,20,30",
// twlId: 2,
// partNo: "21E8-0041",
// twlType: 2,
// twlTypeTitle: "异性壳体",
// twlUnit: 1,
// settlementUnit: "件(根)",
// settlementPrice: 3.0,
// xplSettlement: 10.0,
// },
// {
// bsProcedureSet: null,
// countUnit: 1,
// stepUnit: "件",
// createTime: "2023-12-07 20:57:12",
// keyValue: 2,
// maxStep: 20,
// standardType: 1,
// minStep: 10,
// settlementUnit: 1,
// stepSettlementUnit: "批",
// twlId: 2,
// partNo: "21E8-0041",
// twlType: 2,
// bound: "10,20",
// stepSettlementPrice: "10,20,30",
// twlTypeTitle: "异性壳体",
// twlUnit: 1,
// settlementUnit: "件(根)",
// settlementPrice: 3.0,
// xplSettlement: 20.0,
// },
// {
// bsProcedureSet: null,
// countUnit: 1,
// stepUnit: "件",
// createTime: "2023-12-07 20:57:12",
// keyValue: 2,
// maxStep: null,
// standardType: 1,
// minStep: 20,
// settlementUnit: 1,
// stepSettlementUnit: "批",
// twlId: 2,
// partNo: "21E8-0041",
// bound: "10,20",
// stepSettlementPrice: "10,20,30",
// twlType: 2,
// twlTypeTitle: "异性壳体",
// twlUnit: 1,
// settlementUnit: "件(根)",
// settlementPrice: 3.0,
// xplSettlement: 30.0,
// },
// {
// countUnit: null,
// stepUnit: null,
// createTime: "2023-12-07 20:23:57",
// keyValue: 3,
// maxStep: null,
// standardType: 2,
// minStep: null,
// settlementUnit: null,
// stepSettlementUnit: null,
// twlId: 3,
// partNo: null,
// twlType: 1,
// twlTypeTitle: "工序",
// twlUnit: 2,
// settlementUnit: "批",
// settlementPrice: 22.0,
// xplSettlement: null,
// },
// {
// countUnit: null,
// stepUnit: null,
// createTime: "2023-12-07 20:23:57",
// keyValue: 3,
// maxStep: null,
// standardType: 3,
// minStep: null,
// settlementUnit: null,
// stepSettlementUnit: null,
// twlId: 4,
// partNo: null,
// twlType: 1,
// twlTypeTitle: "工序",
// twlUnit: 2,
// settlementUnit: "批",
// settlementPrice: 22.0,
// xplSettlement: null,
// },
// ];
// this.page.total = this.data.length;
},
},
};
8 months ago
</script>
<style></style>