Blame view

ant-design-vue-jeecg/src/views/system/modules/SelectUserModal.vue 6.58 KB
肖超群 authored
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')">
肖超群 authored
11
12
13

      <!-- 查询区域 -->
      <div class="table-page-search-wrapper">
肖超群 authored
14
        <a-form layout="inline" @keyup.enter.native="searchQuery">
肖超群 authored
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>
肖超群 authored
20
21
22
              </a-form-item>
            </a-col>
            <a-col :span="8">
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>
肖超群 authored
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>
肖超群 authored
54
55
import {filterObj} from '@/utils/util'
import {getAction} from '@/api/manage'
肖超群 authored
56
肖超群 authored
57
58
59
60
export default {
  name: "SelectUserModal",
  data() {
    return {
曾湘平 authored
61
      title: this.$t('system.addExistingUser'),
肖超群 authored
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;
肖超群 authored
78
          }
肖超群 authored
79
80
        },
        {
81
          title: this.$t('system.account'),
肖超群 authored
82
83
84
85
86
          align: "center",
          width: 100,
          dataIndex: 'username'
        },
        {
87
          title: this.$t('system.name2'),
肖超群 authored
88
89
90
91
92
          align: "center",
          width: 100,
          dataIndex: 'realname'
        },
        {
93
          title: this.$t('system.staffId'),
肖超群 authored
94
95
          align: "center",
          width: 100,
96
          dataIndex: 'workNo'
肖超群 authored
97
98
        },
        {
99
          title: this.$t('system.mobile'),
肖超群 authored
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) => {
114
          return range[0] + "-" + range[1] + " " + this.$t('list.showing') + " " + total + " " + this.$t('list.records')
肖超群 authored
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",
肖超群 authored
129
      }
肖超群 authored
130
131
132
133
134
135
136
137
    }
  },
  created() {
    this.loadData();
  },
  methods: {
    searchQuery() {
      this.loadData(1);
肖超群 authored
138
    },
肖超群 authored
139
140
141
    searchReset() {
      this.queryParam = {};
      this.loadData(1);
肖超群 authored
142
    },
肖超群 authored
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;
肖超群 authored
165
        }
肖超群 authored
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]);
肖超群 authored
182
        }
肖超群 authored
183
184
185
      } else {
        for (var b = 0; b < changeRows.length; b++) {
          this.dataSource2.splice(this.dataSource2.indexOf(changeRows[b]), 1);
肖超群 authored
186
        }
肖超群 authored
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);
肖超群 authored
198
        }
肖超群 authored
199
肖超群 authored
200
      }
肖超群 authored
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();
肖超群 authored
223
224
    }
  }
肖超群 authored
225
}
肖超群 authored
226
227
</script>
<style lang="less" scoped>
肖超群 authored
228
229
230
.ant-card-body .table-operator {
  margin-bottom: 18px;
}
肖超群 authored
231
肖超群 authored
232
233
234
235
.ant-table-tbody .ant-table-row td {
  padding-top: 15px;
  padding-bottom: 15px;
}
肖超群 authored
236
肖超群 authored
237
238
239
.anty-row-operator button {
  margin: 0 5px
}
肖超群 authored
240
肖超群 authored
241
242
243
.ant-btn-danger {
  background-color: #ffffff
}
肖超群 authored
244
肖超群 authored
245
246
247
.ant-modal-cust-warp {
  height: 100%
}
肖超群 authored
248
肖超群 authored
249
250
251
252
.ant-modal-cust-warp .ant-modal-body {
  height: calc(100% - 110px) !important;
  overflow-y: auto
}
肖超群 authored
253
肖超群 authored
254
255
256
257
.ant-modal-cust-warp .ant-modal-content {
  height: 90% !important;
  overflow-y: hidden
}
肖超群 authored
258
</style>