2023-05-06 15:58:45 +08:00
|
|
|
|
<template>
|
|
|
|
|
<a-card :bordered="false">
|
|
|
|
|
<!-- 抽屉 -->
|
|
|
|
|
<a-drawer
|
2023-05-25 19:43:05 +08:00
|
|
|
|
title="Dict List"
|
2023-05-06 15:58:45 +08:00
|
|
|
|
:width="screenWidth"
|
|
|
|
|
@close="onClose"
|
|
|
|
|
:visible="visible"
|
|
|
|
|
>
|
|
|
|
|
<!-- 抽屉内容的border -->
|
|
|
|
|
<div
|
|
|
|
|
:style="{
|
|
|
|
|
padding:'10px',
|
|
|
|
|
border: '1px solid #e9e9e9',
|
|
|
|
|
background: '#fff',
|
|
|
|
|
}">
|
|
|
|
|
|
|
|
|
|
<div class="table-page-search-wrapper">
|
|
|
|
|
<a-form layout="inline" :form="form" @keyup.enter.native="searchQuery">
|
|
|
|
|
<a-row :gutter="10">
|
|
|
|
|
<a-col :md="8" :sm="12">
|
2023-05-25 19:43:05 +08:00
|
|
|
|
<a-form-item label="Name">
|
|
|
|
|
<a-input style="width: 120px;" placeholder="Please Enter Name" v-model="queryParam.itemText"></a-input>
|
2023-05-06 15:58:45 +08:00
|
|
|
|
</a-form-item>
|
|
|
|
|
</a-col>
|
|
|
|
|
<a-col :md="9" :sm="24">
|
2023-05-25 19:43:05 +08:00
|
|
|
|
<a-form-item label="Status" style="width: 170px" :labelCol="labelCol" :wrapperCol="wrapperCol">
|
2023-05-06 15:58:45 +08:00
|
|
|
|
<a-select
|
2023-05-25 19:43:05 +08:00
|
|
|
|
placeholder="Please Select"
|
2023-05-06 15:58:45 +08:00
|
|
|
|
v-model="queryParam.status"
|
|
|
|
|
>
|
2023-05-25 19:43:05 +08:00
|
|
|
|
<a-select-option value="1">Enable</a-select-option>
|
|
|
|
|
<a-select-option value="0">Disable</a-select-option>
|
2023-05-06 15:58:45 +08:00
|
|
|
|
</a-select>
|
|
|
|
|
</a-form-item>
|
|
|
|
|
</a-col>
|
|
|
|
|
<a-col :md="7" :sm="24">
|
|
|
|
|
<span style="float: left;" class="table-page-search-submitButtons">
|
2023-05-25 19:43:05 +08:00
|
|
|
|
<a-button type="primary" @click="searchQuery">Search</a-button>
|
|
|
|
|
<a-button type="primary" @click="searchReset" style="margin-left: 8px">Reset</a-button>
|
2023-05-06 15:58:45 +08:00
|
|
|
|
</span>
|
|
|
|
|
</a-col>
|
|
|
|
|
</a-row>
|
|
|
|
|
<a-row>
|
|
|
|
|
<a-col :md="2" :sm="24">
|
2023-05-25 19:43:05 +08:00
|
|
|
|
<a-button style="margin-bottom: 10px" type="primary" @click="handleAdd">Add</a-button>
|
2023-05-06 15:58:45 +08:00
|
|
|
|
</a-col>
|
|
|
|
|
</a-row>
|
|
|
|
|
</a-form>
|
|
|
|
|
</div>
|
|
|
|
|
<div>
|
|
|
|
|
<a-table
|
|
|
|
|
ref="table"
|
|
|
|
|
rowKey="id"
|
|
|
|
|
size="middle"
|
|
|
|
|
:columns="columns"
|
|
|
|
|
:dataSource="dataSource"
|
|
|
|
|
:pagination="ipagination"
|
|
|
|
|
:loading="loading"
|
|
|
|
|
@change="handleTableChange"
|
|
|
|
|
:rowClassName="getRowClassname"
|
|
|
|
|
>
|
|
|
|
|
|
|
|
|
|
<span slot="action" slot-scope="text, record">
|
2023-05-25 19:43:05 +08:00
|
|
|
|
<a @click="handleEdit(record)">Edit</a>
|
2023-05-06 15:58:45 +08:00
|
|
|
|
<a-divider type="vertical"/>
|
2023-05-25 19:43:05 +08:00
|
|
|
|
<a-popconfirm title="Ensure Delete?" @confirm="() => handleDelete(record.id)" :cancelButtonProps="{ props: { type: 'warn' } }">
|
|
|
|
|
<a>Delete</a>
|
2023-05-06 15:58:45 +08:00
|
|
|
|
</a-popconfirm>
|
|
|
|
|
</span>
|
|
|
|
|
|
|
|
|
|
</a-table>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</a-drawer>
|
|
|
|
|
<dict-item-modal ref="modalForm" @ok="modalFormOk"></dict-item-modal> <!-- 字典数据 -->
|
|
|
|
|
</a-card>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
import pick from 'lodash.pick'
|
|
|
|
|
import {filterObj} from '@/utils/util';
|
|
|
|
|
import DictItemModal from './modules/DictItemModal'
|
|
|
|
|
import {JeecgListMixin} from '@/mixins/JeecgListMixin'
|
|
|
|
|
|
|
|
|
|
export default {
|
|
|
|
|
name: "DictItemList",
|
|
|
|
|
mixins: [JeecgListMixin],
|
|
|
|
|
components: {DictItemModal},
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
columns: [
|
|
|
|
|
{
|
2023-05-25 19:43:05 +08:00
|
|
|
|
title: 'Item Name',
|
2023-05-06 15:58:45 +08:00
|
|
|
|
align: "center",
|
|
|
|
|
dataIndex: 'itemText',
|
|
|
|
|
},
|
|
|
|
|
{
|
2023-05-25 19:43:05 +08:00
|
|
|
|
title: 'Item Value',
|
2023-05-06 15:58:45 +08:00
|
|
|
|
align: "center",
|
|
|
|
|
dataIndex: 'itemValue',
|
|
|
|
|
},
|
|
|
|
|
{
|
2023-05-25 19:43:05 +08:00
|
|
|
|
title: 'Action',
|
2023-05-06 15:58:45 +08:00
|
|
|
|
dataIndex: 'action',
|
|
|
|
|
align: "center",
|
|
|
|
|
scopedSlots: {customRender: 'action'},
|
|
|
|
|
}
|
|
|
|
|
],
|
|
|
|
|
queryParam: {
|
|
|
|
|
dictId: "",
|
|
|
|
|
dictName: "",
|
|
|
|
|
itemText: "",
|
|
|
|
|
delFlag: "1",
|
|
|
|
|
status: [],
|
|
|
|
|
},
|
|
|
|
|
title: "操作",
|
|
|
|
|
visible: false,
|
|
|
|
|
screenWidth: 800,
|
|
|
|
|
model: {},
|
|
|
|
|
dictId: "",
|
|
|
|
|
status: 1,
|
|
|
|
|
labelCol: {
|
|
|
|
|
xs: {span: 5},
|
|
|
|
|
sm: {span: 5},
|
|
|
|
|
},
|
|
|
|
|
wrapperCol: {
|
|
|
|
|
xs: {span: 12},
|
|
|
|
|
sm: {span: 12},
|
|
|
|
|
},
|
|
|
|
|
form: this.$form.createForm(this),
|
|
|
|
|
validatorRules: {
|
2023-05-25 19:43:05 +08:00
|
|
|
|
itemText: {rules: [{required: true, message: 'Please Enter Name'}]},
|
|
|
|
|
itemValue: {rules: [{required: true, message: 'Please Enter item Value'}]},
|
2023-05-06 15:58:45 +08:00
|
|
|
|
},
|
|
|
|
|
url: {
|
|
|
|
|
list: "/sys/dictItem/list",
|
|
|
|
|
delete: "/sys/dictItem/delete",
|
|
|
|
|
deleteBatch: "/sys/dictItem/deleteBatch",
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
created() {
|
|
|
|
|
// 当页面初始化时,根据屏幕大小来给抽屉设置宽度
|
|
|
|
|
this.resetScreenSize();
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
add(dictId) {
|
|
|
|
|
this.dictId = dictId;
|
|
|
|
|
this.edit({});
|
|
|
|
|
},
|
|
|
|
|
edit(record) {
|
|
|
|
|
if (record.id) {
|
|
|
|
|
this.dictId = record.id;
|
|
|
|
|
}
|
|
|
|
|
this.queryParam = {}
|
|
|
|
|
this.form.resetFields();
|
|
|
|
|
this.model = Object.assign({}, record);
|
|
|
|
|
this.model.dictId = this.dictId;
|
|
|
|
|
this.model.status = this.status;
|
|
|
|
|
this.visible = true;
|
|
|
|
|
this.$nextTick(() => {
|
|
|
|
|
this.form.setFieldsValue(pick(this.model, 'itemText', 'itemValue'))
|
|
|
|
|
});
|
|
|
|
|
// 当其它模块调用该模块时,调用此方法加载字典数据
|
|
|
|
|
this.loadData();
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
getQueryParams() {
|
|
|
|
|
//update--begin--autor:wangshuai-----date:20191204------for:清空总条数 teambition JT-113------
|
|
|
|
|
this.ipagination.total=0;
|
|
|
|
|
//update--end--autor:wangshuai-----date:20191204------for:清空总条数 teambition JT-113------
|
|
|
|
|
var param = Object.assign({}, this.queryParam);
|
|
|
|
|
param.dictId = this.dictId;
|
|
|
|
|
param.field = this.getQueryField();
|
|
|
|
|
param.pageNo = this.ipagination.current;
|
|
|
|
|
param.pageSize = this.ipagination.pageSize;
|
|
|
|
|
if (this.superQueryParams) {
|
|
|
|
|
param['superQueryParams'] = encodeURI(this.superQueryParams)
|
|
|
|
|
param['superQueryMatchType'] = this.superQueryMatchType
|
|
|
|
|
}
|
|
|
|
|
return filterObj(param);
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
// 添加字典数据
|
|
|
|
|
handleAdd() {
|
|
|
|
|
this.$refs.modalForm.add(this.dictId);
|
2023-05-25 19:43:05 +08:00
|
|
|
|
this.$refs.modalForm.title = "Add";
|
2023-05-06 15:58:45 +08:00
|
|
|
|
},
|
|
|
|
|
showDrawer() {
|
|
|
|
|
this.visible = true
|
|
|
|
|
},
|
|
|
|
|
onClose() {
|
|
|
|
|
this.visible = false
|
|
|
|
|
this.form.resetFields();
|
|
|
|
|
this.dataSource = [];
|
|
|
|
|
},
|
|
|
|
|
// 抽屉的宽度随着屏幕大小来改变
|
|
|
|
|
resetScreenSize() {
|
|
|
|
|
let screenWidth = document.body.clientWidth;
|
|
|
|
|
if (screenWidth < 600) {
|
|
|
|
|
this.screenWidth = screenWidth;
|
|
|
|
|
} else {
|
|
|
|
|
this.screenWidth = 600;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
//update--begin--autor:wangshuai-----date:20191204------for:系统管理 数据字典禁用和正常区别开,添加背景颜色 teambition JT-22------
|
|
|
|
|
//增加样式方法返回值
|
|
|
|
|
getRowClassname(record){
|
|
|
|
|
if(record.status==0){
|
|
|
|
|
return "data-rule-invalid"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
//update--end--autor:wangshuai-----date:20191204------for:系统管理 数据字典禁用和正常区别开,添加背景颜色 teambition JT-22------
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</script>
|
|
|
|
|
<style lang="less" scoped>
|
|
|
|
|
//update--begin--autor:wangshuai-----date:20191204------for:系统管理 数据字典禁用和正常区别开,添加背景颜色 teambition JT-22------
|
|
|
|
|
/deep/ .data-rule-invalid{
|
|
|
|
|
background: #f4f4f4;
|
|
|
|
|
color: #bababa;
|
|
|
|
|
}
|
|
|
|
|
//update--begin--autor:wangshuai-----date:20191204------for:系统管理 数据字典禁用和正常区别开,添加背景颜色 teambition JT-22------
|
|
|
|
|
</style>
|