index.vue 7.58 KB
<template>
    <div class="NCC-common-layout">
        <div class="NCC-common-layout-center">
            <el-row class="NCC-common-search-box" :gutter="16">
                <el-form @submit.native.prevent>
                    <el-col :span="6">
                        <el-form-item label="代理商等级">
                            <num-range v-model="query.level"></num-range>
                        </el-form-item>
                    </el-col>
                    <el-col :span="6">
                        <el-form-item label="分润比例">
                            <num-range v-model="query.profitPercent"></num-range>
                        </el-form-item>
                    </el-col>
                    <el-col :span="6">
                        <el-form-item>
                            <el-button type="primary" icon="el-icon-search" @click="search()">查询</el-button>
                            <el-button icon="el-icon-refresh-right" @click="reset()">重置</el-button>
                        </el-form-item>
                    </el-col>
                </el-form>
            </el-row>
            <div class="NCC-common-layout-main NCC-flex-main">
                <div class="NCC-common-head">
                    <div>
                        <el-button type="primary" icon="el-icon-plus" @click="addOrUpdateHandle()">新增代理商</el-button>
                    </div>
                    <div class="NCC-common-head-right">
                        <el-tooltip effect="dark" content="刷新" placement="top">
                            <el-link icon="icon-ym icon-ym-Refresh NCC-common-head-icon" :underline="false"
                                @click="reset()" />
                        </el-tooltip>
                        <screenfull isContainer />
                    </div>
                </div>
                <NCC-table v-loading="listLoading" :data="list">
                    <el-table-column label="代理商" prop="agent_name" align="left" />
                    <el-table-column label="上级代理商" prop="parentAgent_name" align="left" />
                    <el-table-column prop="level" label="代理商等级" align="left" />
                    <el-table-column prop="profitPercent" label="分润比例" align="left">
                        <template slot-scope="scope">
                            {{ scope.row.profitPercent * 100 }}%
                        </template>
                    </el-table-column>
                    <el-table-column prop="status" label="状态" align="left" />
                    <el-table-column prop="remark" label="备注信息" align="left" />
                    <el-table-column label="操作" fixed="right" width="180">
                        <template slot-scope="scope">
                            <el-button type="text" @click="addOrUpdateHandle(scope.row.id)">编辑</el-button>
                            <el-button type="text" @click="UpdateRoleHandle(scope.row.agentId)">权限设置</el-button>
                            <el-button type="text" @click="handleDel(scope.row.id)"
                                class="NCC-table-delBtn">删除</el-button>
                        </template>
                    </el-table-column>
                </NCC-table>
                <pagination :total="total" :page.sync="listQuery.currentPage" :limit.sync="listQuery.pageSize"
                    @pagination="initData" />
            </div>
        </div>
        <NCC-Form v-if="formVisible" ref="NCCForm" @refresh="refresh" />
        <NCCRoleForm v-if="roleFormVisible" ref="NCCRoleForm" @refresh="refresh" />
        <ExportBox v-if="exportBoxVisible" ref="ExportBox" @download="download" />
    </div>
</template>
<script>
import request from '@/utils/request'
import { getDictionaryDataSelector } from '@/api/systemData/dictionary'
import NCCForm from './Form'
import NCCRoleForm from './RoleForm'
import ExportBox from './ExportBox'
import { previewDataInterface } from '@/api/systemData/dataInterface'
export default {
    components: { NCCForm, ExportBox, NCCRoleForm },
    data() {
        return {
            query: {
                level: undefined,
                profitPercent: undefined,
            },
            list: [],
            listLoading: true,
            multipleSelection: [], total: 0,
            listQuery: {
                currentPage: 1,
                pageSize: 20,
                sort: "desc",
                sidx: "",
            },
            formVisible: false,
            roleFormVisible: false,
            exportBoxVisible: false,
            columnList: [
                { prop: 'agentId', label: '代理商ID' },
                { prop: 'level', label: '代理商等级' },
                { prop: 'profitPercent', label: '分润比例' },
                { prop: 'status', label: '状态' },
                { prop: 'remark', label: '备注信息' },
            ],
            agentIdOptions: [],
        }
    },
    computed: {},
    created() {
        this.initData()
        this.getagentIdOptions();
    },
    methods: {
        getagentIdOptions() {
            previewDataInterface('702758837928592645').then(res => {
                this.agentIdOptions = res.data
            });
        },
        initData() {
            this.listLoading = true;
            let _query = {
                ...this.listQuery,
                ...this.query
            };
            let query = {}
            for (let key in _query) {
                if (Array.isArray(_query[key])) {
                    query[key] = _query[key].join()
                } else {
                    query[key] = _query[key]
                }
            }
            request({
                url: `/api/Extend/UavAgentProfitConfig`,
                method: 'GET',
                data: query
            }).then(res => {
                this.list = res.data.list
                this.total = res.data.pagination.total
                this.listLoading = false
            })
        },
        handleDel(id) {
            this.$confirm('此操作将永久删除该数据, 是否继续?', '提示', {
                type: 'warning'
            }).then(() => {
                request({
                    url: `/api/Extend/UavAgentProfitConfig/${id}`,
                    method: 'DELETE'
                }).then(res => {
                    this.$message({
                        type: 'success',
                        message: res.msg,
                        onClose: () => {
                            this.initData()
                        }
                    });
                })
            }).catch(() => {
            });
        },
        addOrUpdateHandle(id, isDetail) {
            this.formVisible = true
            this.$nextTick(() => {
                this.$refs.NCCForm.init(id, isDetail)
            })
        },
        UpdateRoleHandle(agentId) {
            this.roleFormVisible = true
            this.$nextTick(() => {
                this.$refs.NCCRoleForm.init(agentId)
            })
        },
        search() {
            this.listQuery = {
                currentPage: 1,
                pageSize: 20,
                sort: "desc",
                sidx: "",
            }
            this.initData()
        },
        refresh(isrRefresh) {
            this.formVisible = false
            if (isrRefresh) this.reset()
        },
        reset() {
            for (let key in this.query) {
                this.query[key] = undefined
            }
            this.listQuery = {
                currentPage: 1,
                pageSize: 20,
                sort: "desc",
                sidx: "",
            }
            this.initData()
        }
    }
}
</script>