|
1
2
3
4
5
6
7
8
9
|
<template>
<div>
<a-modal
centered
:title="title"
:width="1000"
:visible="visible"
@ok="handleOk"
@cancel="handleCancel"
|
谭毅彬
authored
|
10
|
:cancelText="$t('button.close')">
|
|
11
12
13
|
<!-- 查询区域 -->
<div class="table-page-search-wrapper">
|
|
14
|
<a-form layout="inline" @keyup.enter.native="searchQuery">
|
|
15
16
17
|
<a-row :gutter="24">
<a-col :span="10">
|
|
18
19
|
<a-form-item :label="this.$t('system.account')">
<a-input :placeholder="this.$t('system.enterAccount')" v-model="queryParam.username"></a-input>
|
|
20
21
22
|
</a-form-item>
</a-col>
<a-col :span="8">
|
谭毅彬
authored
|
23
24
25
26
|
<span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
<a-button type="primary" @click="searchQuery" icon="search">{{ $t('button.search') }}</a-button>
<a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">{{ $t('button.reset') }}</a-button>
</span>
|
|
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
</a-col>
</a-row>
</a-form>
</div>
<!-- table区域-begin -->
<div>
<a-table
size="small"
bordered
rowKey="id"
:columns="columns1"
:dataSource="dataSource1"
:pagination="ipagination"
:loading="loading"
:rowSelection="{selectedRowKeys: selectedRowKeys,onSelectAll:onSelectAll,onSelect:onSelect,onChange: onSelectChange}"
@change="handleTableChange">
</a-table>
</div>
<!-- table区域-end -->
</a-modal>
</div>
</template>
<script>
|
|
54
55
|
import {filterObj} from '@/utils/util'
import {getAction} from '@/api/manage'
|
|
56
|
|
|
57
58
59
60
|
export default {
name: "SelectUserModal",
data() {
return {
|
曾湘平
authored
|
61
|
title: this.$t('system.addExistingUser'),
|
|
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
names: [],
visible: false,
placement: 'right',
description: '',
// 查询条件
queryParam: {},
// 表头
columns1: [
{
title: '#',
dataIndex: '',
key: 'rowIndex',
width: 50,
align: "center",
customRender: function (t, r, index) {
return parseInt(index) + 1;
|
|
78
|
}
|
|
79
80
|
},
{
|
|
81
|
title: this.$t('system.account'),
|
|
82
83
84
85
86
|
align: "center",
width: 100,
dataIndex: 'username'
},
{
|
|
87
|
title: this.$t('system.name2'),
|
|
88
89
90
91
92
|
align: "center",
width: 100,
dataIndex: 'realname'
},
{
|
谭毅彬
authored
|
93
|
title: this.$t('system.staffId'),
|
|
94
95
|
align: "center",
width: 100,
|
谭毅彬
authored
|
96
|
dataIndex: 'workNo'
|
|
97
98
|
},
{
|
|
99
|
title: this.$t('system.mobile'),
|
|
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
align: "center",
width: 100,
dataIndex: 'phone'
}
],
//数据集
dataSource1: [],
dataSource2: [],
// 分页参数
ipagination: {
current: 1,
pageSize: 10,
pageSizeOptions: ['10', '20', '30'],
showTotal: (total, range) => {
|
谭毅彬
authored
|
114
|
return range[0] + "-" + range[1] + " " + this.$t('list.showing') + " " + total + " " + this.$t('list.records')
|
|
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
},
showQuickJumper: true,
showSizeChanger: true,
total: 0
},
isorter: {
column: 'createTime',
order: 'desc',
},
loading: false,
selectedRowKeys: [],
selectedRows: [],
url: {
list: "/sys/user/list",
|
|
129
|
}
|
|
130
131
132
133
134
135
136
137
|
}
},
created() {
this.loadData();
},
methods: {
searchQuery() {
this.loadData(1);
|
|
138
|
},
|
|
139
140
141
|
searchReset() {
this.queryParam = {};
this.loadData(1);
|
|
142
|
},
|
|
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
|
handleCancel() {
this.visible = false;
},
handleOk() {
this.dataSource2 = this.selectedRowKeys;
console.log("data:" + this.dataSource2);
this.$emit("selectFinished", this.dataSource2);
this.visible = false;
},
add() {
this.visible = true;
},
loadData(arg) {
//加载数据 若传入参数1则加载第一页的内容
if (arg === 1) {
this.ipagination.current = 1;
}
var params = this.getQueryParams();//查询条件
getAction(this.url.list, params).then((res) => {
if (res.success) {
this.dataSource1 = res.result.records;
this.ipagination.total = res.result.total;
|
|
165
|
}
|
|
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
|
})
},
getQueryParams() {
var param = Object.assign({}, this.queryParam, this.isorter);
param.field = this.getQueryField();
param.pageNo = this.ipagination.current;
param.pageSize = this.ipagination.pageSize;
return filterObj(param);
},
getQueryField() {
//TODO 字段权限控制
},
onSelectAll(selected, selectedRows, changeRows) {
if (selected === true) {
for (var a = 0; a < changeRows.length; a++) {
this.dataSource2.push(changeRows[a]);
|
|
182
|
}
|
|
183
184
185
|
} else {
for (var b = 0; b < changeRows.length; b++) {
this.dataSource2.splice(this.dataSource2.indexOf(changeRows[b]), 1);
|
|
186
|
}
|
|
187
188
189
190
191
192
193
194
195
196
197
|
}
// console.log(selected, selectedRows, changeRows);
},
onSelect(record, selected) {
if (selected === true) {
this.dataSource2.push(record);
} else {
var index = this.dataSource2.indexOf(record);
//console.log();
if (index >= 0) {
this.dataSource2.splice(this.dataSource2.indexOf(record), 1);
|
|
198
|
}
|
|
199
|
|
|
200
|
}
|
|
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
|
},
onSelectChange(selectedRowKeys, selectedRows) {
this.selectedRowKeys = selectedRowKeys;
this.selectionRows = selectedRows;
},
onClearSelected() {
this.selectedRowKeys = [];
this.selectionRows = [];
},
handleDelete: function (record) {
this.dataSource2.splice(this.dataSource2.indexOf(record), 1);
},
handleTableChange(pagination, filters, sorter) {
//分页、排序、筛选变化时触发
console.log(sorter);
//TODO 筛选
if (Object.keys(sorter).length > 0) {
this.isorter.column = sorter.field;
this.isorter.order = "ascend" == sorter.order ? "asc" : "desc"
}
this.ipagination = pagination;
this.loadData();
|
|
223
224
|
}
}
|
|
225
|
}
|
|
226
227
|
</script>
<style lang="less" scoped>
|
|
228
229
230
|
.ant-card-body .table-operator {
margin-bottom: 18px;
}
|
|
231
|
|
|
232
233
234
235
|
.ant-table-tbody .ant-table-row td {
padding-top: 15px;
padding-bottom: 15px;
}
|
|
236
|
|
|
237
238
239
|
.anty-row-operator button {
margin: 0 5px
}
|
|
240
|
|
|
241
242
243
|
.ant-btn-danger {
background-color: #ffffff
}
|
|
244
|
|
|
245
246
247
|
.ant-modal-cust-warp {
height: 100%
}
|
|
248
|
|
|
249
250
251
252
|
.ant-modal-cust-warp .ant-modal-body {
height: calc(100% - 110px) !important;
overflow-y: auto
}
|
|
253
|
|
|
254
255
256
257
|
.ant-modal-cust-warp .ant-modal-content {
height: 90% !important;
overflow-y: hidden
}
|
|
258
|
</style>
|