123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328 |
- <template>
- <j-modal
- :width="modalWidth"
- :visible="visible"
- :title="title"
- switchFullscreen
- wrapClassName="j-user-select-modal"
- @ok="handleSubmit"
- @cancel="close"
- style="top:50px"
- cancelText="关闭"
- >
- <a-row :gutter="10" style="background-color: #ececec; padding: 10px; margin: -10px">
- <a-col :md="6" :sm="24">
- <a-card :bordered="false">
- <!--组织机构-->
- <a-directory-tree
- selectable
- :selectedKeys="selectedDepIds"
- :checkStrictly="true"
- :dropdownStyle="{maxHeight:'200px',overflow:'auto'}"
- :treeData="departTree"
- :expandAction="false"
- :expandedKeys.sync="expandedKeys"
- @select="onDepSelect"
- />
- </a-card>
- </a-col>
- <a-col :md="18" :sm="24">
- <a-card :bordered="false">
- 用户账号:
- <a-input-search
- :style="{width:'150px',marginBottom:'15px'}"
- placeholder="请输入账号"
- v-model="queryParam.username"
- @search="onSearch"
- ></a-input-search>
- <a-button @click="searchReset(1)" style="margin-left: 20px" icon="redo">重置</a-button>
- <!--用户列表-->
- <a-table
- ref="table"
- :scroll="scrollTrigger"
- size="middle"
- rowKey="id"
- :columns="columns"
- :dataSource="dataSource"
- :pagination="ipagination"
- :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange,type: getType}"
- :loading="loading"
- @change="handleTableChange">
- </a-table>
- </a-card>
- </a-col>
- </a-row>
- </j-modal>
- </template>
- <script>
- import { pushIfNotExist, filterObj } from '@/utils/util'
- import {queryDepartTreeList, getUserList, queryUserByDepId} from '@/api/api'
- import { getAction } from '@/api/manage'
- export default {
- name: 'JSelectUserByDepModal',
- components: {},
- props: ['modalWidth', 'multi', 'userIds', 'store', 'text'],
- data() {
- return {
- queryParam: {
- username: "",
- },
- columns: [
- {
- title: '用户账号',
- align: 'center',
- dataIndex: 'username'
- },
- {
- title: '用户姓名',
- align: 'center',
- dataIndex: 'realname'
- },
- {
- title: '性别',
- align: 'center',
- dataIndex: 'sex',
- customRender: function (text) {
- if (text === 1) {
- return '男'
- } else if (text === 2) {
- return '女'
- } else {
- return text
- }
- }
- },
- {
- title: '手机',
- align: 'center',
- dataIndex: 'phone'
- },
- {
- title: '部门',
- align: 'center',
- dataIndex: 'orgCodeTxt'
- }
- ],
- scrollTrigger: {},
- dataSource: [],
- selectionRows: [],
- selectedRowKeys: [],
- selectUserRows: [],
- selectUserIds: [],
- title: '根据部门选择用户',
- ipagination: {
- current: 1,
- pageSize: 10,
- pageSizeOptions: ['10', '20', '30'],
- showTotal: (total, range) => {
- return range[0] + '-' + range[1] + ' 共' + total + '条'
- },
- showQuickJumper: true,
- showSizeChanger: true,
- total: 0
- },
- isorter: {
- column: 'createTime',
- order: 'desc'
- },
- selectedDepIds: [],
- departTree: [],
- visible: false,
- form: this.$form.createForm(this),
- loading: false,
- expandedKeys: [],
- }
- },
- computed: {
- // 计算属性的 getter
- getType: function () {
- return this.multi == true ? 'checkbox' : 'radio';
- }
- },
- watch: {
- userIds: {
- immediate: true,
- handler() {
- this.initUserNames()
- }
- },
- },
- created() {
- // 该方法触发屏幕自适应
- this.resetScreenSize();
- this.loadData()
- },
- methods: {
- initUserNames() {
- if (this.userIds) {
- // 这里最后加一个 , 的原因是因为无论如何都要使用 in 查询,防止后台进行了模糊匹配,导致查询结果不准确
- let values = this.userIds.split(',') + ','
- let param = {[this.store]: values}
- getAction('/sys/user/getMultiUser', param).then((list)=>{
- this.selectionRows = []
- let selectedRowKeys = []
- let textArray = []
- if(list && list.length>0){
- for(let user of list){
- textArray.push(user[this.text])
- selectedRowKeys.push(user['id'])
- this.selectionRows.push(user)
- }
- }
- this.selectedRowKeys = selectedRowKeys
- this.$emit('initComp', textArray.join(','))
- })
- } else {
- // JSelectUserByDep组件bug issues/I16634
- this.$emit('initComp', '')
- // 前端用户选择单选无法置空的问题 #2610
- this.selectedRowKeys = []
- }
- },
- async loadData(arg) {
- if (arg === 1) {
- this.ipagination.current = 1;
- }
- let params = this.getQueryParams()//查询条件
- this.loading = true
- getAction('/sys/user/queryUserComponentData', params).then(res=>{
- if (res.success) {
- this.dataSource = res.result.records
- this.ipagination.total = Number(res.result.total)
- }
- }).finally(() => {
- this.loading = false
- })
- },
- // 触发屏幕自适应
- resetScreenSize() {
- let screenWidth = document.body.clientWidth;
- if (screenWidth < 500) {
- this.scrollTrigger = {x: 800};
- } else {
- this.scrollTrigger = {};
- }
- },
- showModal() {
- this.visible = true;
- this.queryDepartTree();
- this.initUserNames()
- this.loadData();
- this.form.resetFields();
- },
- getQueryParams() {
- let param = Object.assign({}, this.queryParam, this.isorter);
- param.field = this.getQueryField();
- param.pageNo = this.ipagination.current;
- param.pageSize = this.ipagination.pageSize;
- param.departId = this.selectedDepIds.join(',')
- return filterObj(param);
- },
- getQueryField() {
- let str = 'id,';
- for (let a = 0; a < this.columns.length; a++) {
- str += ',' + this.columns[a].dataIndex;
- }
- return str;
- },
- searchReset(num) {
- let that = this;
- that.selectedRowKeys = [];
- that.selectUserIds = [];
- that.selectedDepIds = [];
- if (num !== 0) {
- that.queryParam = {};
- that.loadData(1);
- }
- },
- close() {
- this.searchReset(0);
- this.visible = false;
- },
- handleTableChange(pagination, filters, 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();
- },
- handleSubmit() {
- let that = this;
- this.getSelectUserRows();
- that.$emit('ok', that.selectUserRows);
- that.searchReset(0)
- that.close();
- },
- //获取选择用户信息
- getSelectUserRows() {
- this.selectUserRows = []
- for (let row of this.selectionRows) {
- if (this.selectedRowKeys.includes(row.id)) {
- this.selectUserRows.push(row)
- }
- }
- this.selectUserIds = this.selectUserRows.map(row => row.username).join(',')
- },
- // 点击树节点,筛选出对应的用户
- onDepSelect(selectedDepIds) {
- if (selectedDepIds[0] != null) {
- if (this.selectedDepIds[0] !== selectedDepIds[0]) {
- this.selectedDepIds = [selectedDepIds[0]];
- }
- this.loadData(1);
- }
- },
- onSelectChange(selectedRowKeys, selectionRows) {
- this.selectedRowKeys = selectedRowKeys;
- selectionRows.forEach(row => pushIfNotExist(this.selectionRows, row, 'id'))
- },
- onSearch() {
- this.loadData(1);
- },
- // 根据选择的id来查询用户信息
- initQueryUserByDepId(selectedDepIds) {
- this.loading = true
- return queryUserByDepId({id: selectedDepIds.toString()}).then((res) => {
- if (res.success) {
- this.dataSource = res.result;
- this.ipagination.total = res.result.length;
- }
- }).finally(() => {
- this.loading = false
- })
- },
- queryDepartTree() {
- queryDepartTreeList().then((res) => {
- if (res.success) {
- this.departTree = res.result;
- // 默认展开父节点
- this.expandedKeys = this.departTree.map(item => item.id)
- }
- })
- },
- modalFormOk() {
- this.loadData();
- }
- }
- }
- </script>
- <style scoped>
- .ant-table-tbody .ant-table-row td {
- padding-top: 10px;
- padding-bottom: 10px;
- }
- #components-layout-demo-custom-trigger .trigger {
- font-size: 18px;
- line-height: 64px;
- padding: 0 24px;
- cursor: pointer;
- transition: color .3s;
- }
- </style>
|