站点配置

This commit is contained in:
jjLv 2024-11-08 16:13:43 +08:00
parent dec4a044b8
commit ce21f53e0e
2 changed files with 291 additions and 270 deletions

View File

@ -4,6 +4,13 @@
<div class="section">
<el-header>库管员配置</el-header>
<el-main>
<el-button
type="success"
icon="el-icon-plus"
size="small"
@click="handleSaveKeeper"
>保存库管员配置</el-button
>
<el-checkbox-group v-model="selectedValues" class="checkbox-group">
<el-checkbox
v-for="item in options"
@ -16,18 +23,18 @@
{{ item.roleKey }}
</el-checkbox>
</el-checkbox-group>
<el-button
type="success"
icon="el-icon-plus"
size="mini"
@click="handleSaveKeeper"
>保存库管员配置</el-button
>
</el-main>
</div>
<div class="section">
<el-header>维修员配置</el-header>
<el-main>
<el-button
type="success"
icon="el-icon-plus"
size="small"
@click="handleSaveRepair"
>保存维修员配置</el-button
>
<el-checkbox-group
v-model="selectedValuesRepair"
class="checkbox-group"
@ -43,13 +50,6 @@
{{ item.roleKey }}
</el-checkbox>
</el-checkbox-group>
<el-button
type="success"
icon="el-icon-plus"
size="mini"
@click="handleSaveRepair"
>保存维修员配置</el-button
>
</el-main>
</div>
</el-tab-pane>

View File

@ -16,7 +16,7 @@
/>
</div>
<div class="head-container" style>
<div class="grid-content bg-purple-dark" align="left">组织人员树</div>
<div class="grid-content bg-purple-dark" align="left">组织人员树</div>
<el-tree
style="height: 700px; overflow: scroll"
:data="treeOptions"
@ -47,7 +47,7 @@
/>
</div>
<div class="head-container" style>
<div class="grid-content bg-purple-dark" align="left">物资类型树</div>
<div class="grid-content bg-purple-dark" align="left">物资类型树</div>
<el-tree
style="height: 700px; overflow: scroll"
:data="treeOptionsTwo"
@ -142,9 +142,9 @@
ref="multipleTable"
row-key="typeId"
default-expand-all
:tree-props="{children: 'children', hasChildren: 'hasChildren'}"
:tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
@selection-change="handleSelectionChange"
@select="handlerSelect"
@select="handlerSelect"
@select-all="handlerSelectAll"
>
<el-table-column
@ -167,30 +167,30 @@
align="center"
show-overflow-tooltip
prop="itemType"
>
</el-table-column>
>
</el-table-column>
<el-table-column
label="物资类型"
align="center"
show-overflow-tooltip
width="100"
prop="materialType"
>
</el-table-column>
>
</el-table-column>
<el-table-column
label="物资名称"
align="center"
show-overflow-tooltip
prop="materialName"
>
</el-table-column>
>
</el-table-column>
<el-table-column
label="规格型号"
align="center"
show-overflow-tooltip
prop="typeName"
>
</el-table-column>
>
</el-table-column>
<el-table-column
label="库管员"
align="center"
@ -222,13 +222,13 @@
</el-table-column>
</el-table>
<pagination
v-show="total>0"
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<pagination
v-show="total > 0"
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
</el-col>
</el-row>
</div>
@ -248,7 +248,7 @@ import {
import {
bindKeeper,
noBindKeeper,
getKeeperIds
getKeeperIds,
} from "@/api/ma/typeConfigKeeper";
import { getUserList } from "@/api/basic/basic";
import { getInfo } from "@/api/login";
@ -270,9 +270,9 @@ export default {
showSearch: true,
//
total: 0,
totalTemp:0,
totalTemp: 0,
countTemp: 1,
totalAll:0,
totalAll: 0,
//
keeperList: null,
keeperDataRange: [],
@ -318,20 +318,20 @@ export default {
children: "children",
label: "label",
},
roleIdsTemp:[],
userList:[],
userNoList:[],
roleIdsTemp: [],
userList: [],
userNoList: [],
userIdTemp: -1,
typeIdTemp: -1,
maxLength:100,//
maxLength: 100, //
//
queryParams: {
typeName: "",
level: 0,
pageNum: 1,
pageSize: 10,
displayBindRelationship:true,
houseId:"",
displayBindRelationship: true,
houseId: "",
// phonenumber: undefined,
// status: undefined,
// typeId: undefined
@ -343,8 +343,8 @@ export default {
afterPrice: "",
useDate: "",
},
isAllSelect:false,
selectionRows:[],
isAllSelect: false,
selectionRows: [],
};
},
// mounted(){
@ -362,13 +362,12 @@ export default {
},
created() {
// this.getInfo()
this.getTreeData();
this.getTreeDataTwo();
this.getTreeData();
this.getTreeDataTwo();
// this.getKeeperDataList();
// setTimeout(()=>{
// this.getList();
// },200)
},
methods: {
// getInfo() {
@ -377,22 +376,22 @@ export default {
// this.companyId = res.user.companyId
// })
// },
selectFirstNode(){
const firstNode = this.$refs.treeTwo.getNode(1);
if(firstNode){
this.queryParams.typeId = firstNode.id
this.queryParams.level = 0
this.queryParams.houseId = firstNode.id
this.$refs.treeTwo.setChecked(firstNode,true);
}
},
selectFirstNode() {
const firstNode = this.$refs.treeTwo.getNode(1);
if (firstNode) {
this.queryParams.typeId = firstNode.id;
this.queryParams.level = 0;
this.queryParams.houseId = firstNode.id;
this.$refs.treeTwo.setChecked(firstNode, true);
}
},
renderConent(h, { node }) {
let iconClass = '';
renderConent(h, { node }) {
let iconClass = "";
// node
if (node.data.level == 99) {
iconClass = 'el-icon-user-solid';
}
iconClass = "el-icon-user-solid";
}
// else if (node.type === 'file') {
// iconClass = 'el-icon-document';
// }
@ -402,10 +401,8 @@ export default {
<i class={iconClass}></i> {node.label}
</span>
);
},
/** 查询物资类型 */
async getKeeperDataList(data) {
let keepdataRes = await queryKeeperDataApi({
@ -444,40 +441,44 @@ export default {
this.form.keeperDataPro = this.keeperProRange.value;
},
/** 查询新增页面-上级类型下拉树结构 */
async getTreeData() {;
const itemName = 'ku_guan_role_ids'
await getKeeperIds(itemName).then((response) =>{
const roleIds = response.rows[0].itemValue.split(',').map(item => Number(item))
this.roleIdsTemp = roleIds
})
await getUserList({ roleIds: this.roleIdsTemp}).then(response => {
this.treeOptions = response.data
async getTreeData() {
const itemName = "ku_guan_role_ids";
await getKeeperIds(itemName).then((response) => {
const roleIds = response.rows[0].itemValue
.split(",")
.map((item) => Number(item));
this.roleIdsTemp = roleIds;
});
await getUserList({ roleIds: this.roleIdsTemp }).then((response) => {
this.treeOptions = response.data;
});
},
/** 查询新增页面-上级类型下拉树结构 */
async getTreeDataTwo() {
getMaTypeList().then((response) => {
this.treeOptionsTwo = response.data
if(this.treeOptionsTwo.length>0 && this.treeOptionsTwo[0].children.length>0){
const firstNode = this.treeOptionsTwo[0].children[0];
this.queryParams.typeId = firstNode.id
this.queryParams.level = 1
this.queryParams.houseId = firstNode.houseId
this.getList();
}
})
async getTreeDataTwo() {
getMaTypeList().then((response) => {
this.treeOptionsTwo = response.data;
if (
this.treeOptionsTwo.length > 0 &&
this.treeOptionsTwo[0].children.length > 0
) {
const firstNode = this.treeOptionsTwo[0].children[0];
this.queryParams.typeId = firstNode.id;
this.queryParams.level = 1;
this.queryParams.houseId = firstNode.houseId;
this.getList();
}
});
},
/** 查询列表 */
async getList() {
this.loading = true
this.queryParams.displayBindRelationship="true";
console.log('queryParams1',this.queryParams)
await getListByMaType(this.queryParams).then((response) => {
this.typeList = response.data.rows
this.total = response.data.total
this.loading = false
})
async getList() {
this.loading = true;
this.queryParams.displayBindRelationship = "true";
console.log("queryParams1", this.queryParams);
await getListByMaType(this.queryParams).then((response) => {
this.typeList = response.data.rows;
this.total = response.data.total;
this.loading = false;
});
},
// -
filterNode(value, data) {
@ -493,22 +494,22 @@ export default {
},
// -
filterNodeTwo(value, data) {
if (!value) return true
return data.label.indexOf(value) !== -1
},
// -
async handleNodeClickTwo(data,node) {
if(data.level==0){
this.queryParams.typeId = data.id
this.queryParams.level = data.level
this.queryParams.houseId = data.id
}else{
this.queryParams.typeId = data.id
this.queryParams.level = data.level
this.queryParams.houseId = data.houseId
}
this.handleQuery()
},
if (!value) return true;
return data.label.indexOf(value) !== -1;
},
// -
async handleNodeClickTwo(data, node) {
if (data.level == 0) {
this.queryParams.typeId = data.id;
this.queryParams.level = data.level;
this.queryParams.houseId = data.id;
} else {
this.queryParams.typeId = data.id;
this.queryParams.level = data.level;
this.queryParams.houseId = data.houseId;
}
this.handleQuery();
},
//
cancel() {
@ -545,108 +546,131 @@ export default {
this.handleQuery();
},
//
handleSelectionChange(selection) {
this.userList=[];
this.userNoList=[];
this.selectionRows = selection,
this.ids = selection.map((item) =>item.typeId);
this.userList = [];
this.userNoList = [];
(this.selectionRows = selection),
(this.ids = selection.map((item) => item.typeId));
selection.forEach(item=>{
this.userList.push({'typeId':item.typeId,'userId':this.userIdTemp})
})
selection.forEach(item=>{
if(item.keeperUserId!=null){
this.userNoList.push({'typeId':item.typeId,'userId':item.keeperUserId})
selection.forEach((item) => {
this.userList.push({ typeId: item.typeId, userId: this.userIdTemp });
});
selection.forEach((item) => {
if (item.keeperUserId != null) {
this.userNoList.push({
typeId: item.typeId,
userId: item.keeperUserId,
});
}
})
});
this.single = selection.length != 1;
this.multiple = !selection.length;
},
//-
handlerSelect(val, row) {
const index = this.userList.findIndex(item=>item.typeId===row.typeId);
if(this.ids.indexOf(row.typeId) === -1){
this.userList.push({'typeId':row.typeId,'userId':this.userIdTemp})
}else if(index!== -1){
this.userList.splice(index,1);
}
const indexNo = this.userNoList.findIndex(item=>item.typeId===row.typeId);
if(this.ids.indexOf(row.typeId) === -1){
this.userNoList.push({'typeId':row.typeId,'userId':row.keeperUserId})
}else if(indexNo!== -1){
this.userNoList.splice(indexNo,1);
}
},
//-
handlerSelect(val, row) {
const index = this.userList.findIndex(
(item) => item.typeId === row.typeId
);
if (this.ids.indexOf(row.typeId) === -1) {
this.userList.push({ typeId: row.typeId, userId: this.userIdTemp });
} else if (index !== -1) {
this.userList.splice(index, 1);
}
const indexNo = this.userNoList.findIndex(
(item) => item.typeId === row.typeId
);
if (this.ids.indexOf(row.typeId) === -1) {
this.userNoList.push({ typeId: row.typeId, userId: row.keeperUserId });
} else if (indexNo !== -1) {
this.userNoList.splice(indexNo, 1);
}
},
//-
handlerSelectAll(val) {
if (val.length) {
// :
// 1 2
//
// tableDatavalcurrentSelection
// tableDatavalcurrentSelection
const isAllSelect = this.tableData.every(item =>
val.some(valItem => valItem.typeId === item.typeId)
)
if (isAllSelect) {
//
const diff = val.filter(
item => !this.userList.some(user => user.typeId === item.typeId)
)
if (this.userList.length + diff.length > this.maxLength) {
const spaceLeft = this.maxLength - this.userList.length
const toAdd = diff.slice(0,spaceLeft)
this.userList = this.userList.concat(toAdd.map(item =>({
typeId:item.typeId,
userId:this.userIdTemp
})));
diff.slice(spaceLeft).forEach(item => this.$refs.multipleTable.toggleRowSelection(item, false))
} else {
this.userList = this.userList.concat(diff.map(item=>({
typeId:item.typeId,
userId:this.userIdTemp
})))
}
//
const diffNo = val.filter(
item => !this.userNoList.some(user => user.typeId === item.typeId)
)
if (this.userNoList.length + diff.length > this.maxLength) {
const spaceLeft = this.maxLength - this.userNoList.length
const toAdd = diff.slice(0,spaceLeft)
this.userNoList = this.userNoList.concat(toAdd.map(item =>({
typeId:item.typeId,
userId:item.userId
})));
diff.slice(spaceLeft).forEach(item => this.$refs.multipleTable.toggleRowSelection(item, false))
} else {
this.userNoList = this.userNoList.concat(diff.map(item=>({
typeId:item.typeId,
userId:item.userId
})))
}
} else {
this.userList = this.userList.filter(
user => !this.tableData.some(item => item.typeId === user.typeId)
)
this.userNoList = this.userNoList.filter(
user => !this.tableData.some(item => item.typeId === user.typeId)
)
}
//-
handlerSelectAll(val) {
if (val.length) {
// :
// 1 2
//
// tableDatavalcurrentSelection
// tableDatavalcurrentSelection
const isAllSelect = this.tableData.every((item) =>
val.some((valItem) => valItem.typeId === item.typeId)
);
if (isAllSelect) {
//
const diff = val.filter(
(item) => !this.userList.some((user) => user.typeId === item.typeId)
);
if (this.userList.length + diff.length > this.maxLength) {
const spaceLeft = this.maxLength - this.userList.length;
const toAdd = diff.slice(0, spaceLeft);
this.userList = this.userList.concat(
toAdd.map((item) => ({
typeId: item.typeId,
userId: this.userIdTemp,
}))
);
diff
.slice(spaceLeft)
.forEach((item) =>
this.$refs.multipleTable.toggleRowSelection(item, false)
);
} else {
// :
//
this.userList = []
this.userNoList = []
this.userList = this.userList.concat(
diff.map((item) => ({
typeId: item.typeId,
userId: this.userIdTemp,
}))
);
}
},
//
const diffNo = val.filter(
(item) =>
!this.userNoList.some((user) => user.typeId === item.typeId)
);
if (this.userNoList.length + diff.length > this.maxLength) {
const spaceLeft = this.maxLength - this.userNoList.length;
const toAdd = diff.slice(0, spaceLeft);
this.userNoList = this.userNoList.concat(
toAdd.map((item) => ({
typeId: item.typeId,
userId: item.userId,
}))
);
diff
.slice(spaceLeft)
.forEach((item) =>
this.$refs.multipleTable.toggleRowSelection(item, false)
);
} else {
this.userNoList = this.userNoList.concat(
diff.map((item) => ({
typeId: item.typeId,
userId: item.userId,
}))
);
}
} else {
this.userList = this.userList.filter(
(user) =>
!this.tableData.some((item) => item.typeId === user.typeId)
);
this.userNoList = this.userNoList.filter(
(user) =>
!this.tableData.some((item) => item.typeId === user.typeId)
);
}
} else {
// :
//
this.userList = [];
this.userNoList = [];
}
},
// handleSelect(selection, row) {
// this.toggleSelection(selection, row);
// },
@ -654,57 +678,55 @@ export default {
// this.isAllSelect = !this.isAllSelect;
// let data = this.typeList;
// this.toggleSelect(data,this.isAllSelect,'all');
// },
// //
// selectTr(selection,row){
// this.$set(row,'isChecked',!row.isChecked);
// this.$nextTick(()=>{
// this.isAllSelect = row.isChecked;
// this.toggleSelect(row,row.isChecked,'tr');
// });
// },
// //
// selectTr(selection,row){
// this.$set(row,'isChecked',!row.isChecked);
// this.$nextTick(()=>{
// this.isAllSelect = row.isChecked;
// this.toggleSelect(row,row.isChecked,'tr');
// });
// },
// //
// toggleSelect(data,flag,type){
// if(type === 'all'){
// if(data.length > 0){
// data.forEach(item=>{
// this.toggleSelection(item, flag);
// if(item.children && item.children.length > 0){
// this.toggleSelect(item.children,flag,type)
// }
// })
// }
// }else {
// if(data.children && data.children.length > 0){
// data.children.forEach(item =>{
// item.isChecked = !item.isChecked;
// this.$refs.multipleTable.toggleRowSelection(item, flag);
// this.toggleSelect(item,flag,type);
// })
// }
// }
// },
// //
// toggleSelection(row, flag) {
// this.$set(row,'isChecked',flag);
// this.$nextTick(()=>{
// if (flag) {
// this.$refs.multipleTable.toggleRowSelection(row, flag);
// } else {
// this.$refs.multipleTable.clearSelection();
// }
// });
// },
// //
// toggleSelect(data,flag,type){
// if(type === 'all'){
// if(data.length > 0){
// data.forEach(item=>{
// this.toggleSelection(item, flag);
// if(item.children && item.children.length > 0){
// this.toggleSelect(item.children,flag,type)
// }
// })
// }
// }else {
// if(data.children && data.children.length > 0){
// data.children.forEach(item =>{
// item.isChecked = !item.isChecked;
// this.$refs.multipleTable.toggleRowSelection(item, flag);
// this.toggleSelect(item,flag,type);
// })
// }
// }
// },
// //
// toggleSelection(row, flag) {
// this.$set(row,'isChecked',flag);
// this.$nextTick(()=>{
// if (flag) {
// this.$refs.multipleTable.toggleRowSelection(row, flag);
// } else {
// this.$refs.multipleTable.clearSelection();
// }
// });
// },
/** 绑定按钮操作 */
handleBind() {
console.log('ids----',this.ids)
console.log("ids----", this.ids);
if (this.userIdTemp == -1) {
this.$alert("未勾选绑定人,无法绑定", "提示", {
type: "warning",
@ -712,21 +734,21 @@ export default {
});
return;
}
if (this.ids.length == 0) {
this.$alert("未进行勾选相关物资,无法绑定", "提示", {
type: "warning",
confirmButtonText: "确定",
});
return;
} else {
const ids = this.ids.join(",");
}
console.log('userList',this.userList)
if (this.ids.length == 0) {
this.$alert("未进行勾选相关物资,无法绑定", "提示", {
type: "warning",
confirmButtonText: "确定",
});
return;
} else {
const ids = this.ids.join(",");
}
console.log("userList", this.userList);
bindKeeper(this.userList).then((response) => {
this.$modal.msgSuccess("绑定成功");
this.ids = null;
this.userList = null;
this.userIdTemp = -1
this.userIdTemp = -1;
this.getTreeData();
this.getList();
this.$refs.multipleTable.clearSelection();
@ -741,16 +763,16 @@ export default {
confirmButtonText: "确定",
});
return;
}else{
noBindKeeper(this.userNoList).then((response) => {
this.$modal.msgSuccess("解绑成功");
this.ids = null;
this.userList = null;
this.userNoList= null;
this.getTreeData();
this.getList();
this.$refs.multipleTable.clearSelection();
});
} else {
noBindKeeper(this.userNoList).then((response) => {
this.$modal.msgSuccess("解绑成功");
this.ids = null;
this.userList = null;
this.userNoList = null;
this.getTreeData();
this.getList();
this.$refs.multipleTable.clearSelection();
});
}
},
/** 修改按钮操作 */
@ -773,7 +795,7 @@ export default {
userTwo.push({
typeId: typeId,
userId: userId,
})
});
noBindKeeper(userTwo).then((response) => {
this.$modal.msgSuccess("解绑成功");
this.getList();
@ -822,8 +844,8 @@ export default {
/** 导出按钮操作 */
handleExport() {
let queryTemp = this.queryParams;
queryTemp.level = 0;
let queryTemp = this.queryParams;
queryTemp.level = 0;
this.download(
"/material/ma_type/export4Keeper",
{
@ -832,7 +854,6 @@ export default {
`物资类型信息_${new Date().getTime()}.xlsx`
);
},
},
};
</script>
@ -854,11 +875,11 @@ export default {
}
}
.grid-content {
border-radius: 4px;
min-height: 24px;
border-radius: 4px;
min-height: 24px;
}
.bg-purple-dark {
background: #e5e9f2;
background: #e5e9f2;
}
::v-deep .el-tree .el-tree-node__expand-icon.expanded {