| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288 | <template>    <drawer-tabs-container>        <div class="project-users">            <!-- 按钮 -->            <Button :loading="loadIng > 0" type="primary" icon="md-add" @click="addUser">{{$L('添加成员')}}</Button>            <!-- 列表 -->            <Table class="tableFill" ref="tableRef" :columns="columns" :data="lists" :loading="loadIng > 0" :no-data-text="noDataText" stripe></Table>            <!-- 分页 -->            <Page class="pageBox" :total="listTotal" :current="listPage" :disabled="loadIng > 0" @on-change="setPage" @on-page-size-change="setPageSize" :page-size-opts="[10,20,30,50,100]" placement="top" show-elevator show-sizer show-total transfer></Page>        </div>    </drawer-tabs-container></template><style lang="scss" scoped>    .project-users {        padding: 0 12px;        .tableFill {            margin: 12px 0 20px;        }    }</style><script>    import DrawerTabsContainer from "../DrawerTabsContainer";    export default {        name: 'ProjectUsers',        components: {DrawerTabsContainer},        props: {            projectid: {                default: 0            },            canload: {                type: Boolean,                default: true            },        },        data () {            return {                loadYet: false,                loadIng: 0,                columns: [],                lists: [],                listPage: 1,                listTotal: 0,                noDataText: "",            }        },        created() {            this.noDataText = this.$L("数据加载中.....");            this.columns = [{                "title": this.$L("头像"),                "minWidth": 60,                "maxWidth": 100,                render: (h, params) => {                    return h('img', {                        style: {                            width: "32px",                            height: "32px",                            verticalAlign: "middle",                            objectFit: "cover",                            borderRadius: "50%"                        },                        attrs: {                            src: params.row.userimg                        },                    });                }            }, {                "title": this.$L("用户名"),                "key": 'username',                "minWidth": 80,                "ellipsis": true,            }, {                "title": this.$L("昵称"),                "minWidth": 80,                "ellipsis": true,                render: (h, params) => {                    return h('span', params.row.nickname || '-');                }            }, {                "title": this.$L("职位/职称"),                "minWidth": 100,                "ellipsis": true,                render: (h, params) => {                    return h('span', params.row.profession || '-');                }            }, {                "title": this.$L("成员角色"),                "minWidth": 100,                render: (h, params) => {                    return h('span', params.row.isowner ? this.$L('项目负责人') : this.$L('成员'));                }            }, {                "title": this.$L("加入时间"),                "width": 160,                render: (h, params) => {                    return h('span', $A.formatDate("Y-m-d H:i:s", params.row.indate));                }            }, {                "title": this.$L("操作"),                "key": 'action',                "width": 80,                "align": 'center',                render: (h, params) => {                    return h('Button', {                        props: {                            type: 'primary',                            size: 'small'                        },                        style: {                            fontSize: '12px'                        },                        on: {                            click: () => {                                this.$Modal.confirm({                                    title: this.$L('移出成员'),                                    content: this.$L('你确定要将此成员移出项目吗?'),                                    loading: true,                                    onOk: () => {                                        $A.aAjax({                                            url: 'project/users/join',                                            data: {                                                act: 'delete',                                                projectid: params.row.projectid,                                                username: params.row.username,                                            },                                            error: () => {                                                this.$Modal.remove();                                                alert(this.$L('网络繁忙,请稍后再试!'));                                            },                                            success: (res) => {                                                this.$Modal.remove();                                                this.getLists();                                                setTimeout(() => {                                                    if (res.ret === 1) {                                                        this.$Message.success(res.msg);                                                    }else{                                                        this.$Modal.error({title: this.$L('温馨提示'), content: res.msg });                                                    }                                                }, 350);                                            }                                        });                                    }                                });                            }                        }                    }, this.$L('删除'));                }            }];        },        mounted() {            if (this.canload) {                this.loadYet = true;                this.getLists(true);            }        },        watch: {            projectid() {                if (this.loadYet) {                    this.getLists(true);                }            },            canload(val) {                if (val && !this.loadYet) {                    this.loadYet = true;                    this.getLists(true);                }            }        },        methods: {            setPage(page) {                this.listPage = page;                this.getLists();            },            setPageSize(size) {                if (Math.max($A.runNum(this.listPageSize), 10) != size) {                    this.listPageSize = size;                    this.getLists();                }            },            getLists(resetLoad) {                if (resetLoad === true) {                    this.listPage = 1;                }                if (this.projectid == 0) {                    this.lists = [];                    this.listTotal = 0;                    this.noDataText = this.$L("没有相关的数据");                    return;                }                this.loadIng++;                this.noDataText = this.$L("数据加载中.....");                $A.aAjax({                    url: 'project/users/lists',                    data: {                        page: Math.max(this.listPage, 1),                        pagesize: Math.max($A.runNum(this.listPageSize), 10),                        projectid: this.projectid,                    },                    complete: () => {                        this.loadIng--;                    },                    error: () => {                        this.noDataText = this.$L("数据加载失败!");                    },                    success: (res) => {                        if (res.ret === 1) {                            this.lists = res.data.lists;                            this.listTotal = res.data.total;                            this.noDataText = this.$L("没有相关的数据");                        } else {                            this.lists = [];                            this.listTotal = 0;                            this.noDataText = res.msg;                        }                    }                });            },            addUser() {                this.userValue = "";                this.$Modal.confirm({                    render: (h) => {                        return h('div', [                            h('div', {                                style: {                                    fontSize: '16px',                                    fontWeight: '500',                                    marginBottom: '20px',                                }                            }, this.$L('添加成员')),                            h('UserInput', {                                props: {                                    value: this.userValue,                                    multiple: true,                                    noprojectid: this.projectid,                                    placeholder: this.$L('请输入昵称/用户名搜索')                                },                                on: {                                    input: (val) => {                                        this.userValue = val;                                    }                                }                            })                        ])                    },                    loading: true,                    onOk: () => {                        if (this.userValue) {                            let username = this.userValue;                            $A.aAjax({                                url: 'project/users/join',                                data: {                                    act: 'join',                                    projectid: this.projectid,                                    username: username,                                },                                error: () => {                                    this.$Modal.remove();                                    alert(this.$L('网络繁忙,请稍后再试!'));                                },                                success: (res) => {                                    this.$Modal.remove();                                    this.getLists();                                    setTimeout(() => {                                        if (res.ret === 1) {                                            this.$Message.success(res.msg);                                        } else {                                            this.$Modal.error({title: this.$L('温馨提示'), content: res.msg});                                        }                                    }, 350);                                }                            });                        } else {                            this.$Modal.remove();                        }                    },                });            }        }    }</script>
 |