400 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			400 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
 | 
						|
<template>
 | 
						|
    <BasicLayout>
 | 
						|
        <template #wrapper>
 | 
						|
            <el-card class="box-card">
 | 
						|
                <el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px">
 | 
						|
                    <el-form-item label="line_user 表的id" prop="userId"><el-select v-model="queryParams.userId"
 | 
						|
                                           placeholder="请选择" clearable size="small" >
 | 
						|
                                    <el-option
 | 
						|
                                            v-for="dict in userIdOptions"
 | 
						|
                                            :key="dict.key"
 | 
						|
                                            :label="dict.value"
 | 
						|
                                            :value="dict.key"
 | 
						|
                                    />
 | 
						|
                                </el-select>
 | 
						|
                            </el-form-item>
 | 
						|
                        <el-form-item label="line_apiuser 表的id" prop="apiId"><el-select v-model="queryParams.apiId"
 | 
						|
                                           placeholder="请选择" clearable size="small" >
 | 
						|
                                    <el-option
 | 
						|
                                            v-for="dict in apiIdOptions"
 | 
						|
                                            :key="dict.key"
 | 
						|
                                            :label="dict.value"
 | 
						|
                                            :value="dict.key"
 | 
						|
                                    />
 | 
						|
                                </el-select>
 | 
						|
                            </el-form-item>
 | 
						|
                        <el-form-item label="line_pre_order 主订单id" prop="preOrderId"><el-select v-model="queryParams.preOrderId"
 | 
						|
                                           placeholder="请选择" clearable size="small" >
 | 
						|
                                    <el-option
 | 
						|
                                            v-for="dict in preOrderIdOptions"
 | 
						|
                                            :key="dict.key"
 | 
						|
                                            :label="dict.value"
 | 
						|
                                            :value="dict.key"
 | 
						|
                                    />
 | 
						|
                                </el-select>
 | 
						|
                            </el-form-item>
 | 
						|
                        <el-form-item label="成交数量" prop="num"><el-input v-model="queryParams.num" placeholder="请输入成交数量" clearable
 | 
						|
                                              size="small" @keyup.enter.native="handleQuery"/>
 | 
						|
                            </el-form-item>
 | 
						|
                        <el-form-item label="交易对" prop="symbol"><el-input v-model="queryParams.symbol" placeholder="请输入交易对" clearable
 | 
						|
                                              size="small" @keyup.enter.native="handleQuery"/>
 | 
						|
                            </el-form-item>
 | 
						|
                        
 | 
						|
                    <el-form-item>
 | 
						|
                        <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
 | 
						|
                        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
 | 
						|
                    </el-form-item>
 | 
						|
                </el-form>
 | 
						|
 | 
						|
                <el-row :gutter="10" class="mb8">
 | 
						|
                    <el-col :span="1.5">
 | 
						|
                        <el-button
 | 
						|
                                v-permisaction="['admin:lineUserProfitLogs:add']"
 | 
						|
                                type="primary"
 | 
						|
                                icon="el-icon-plus"
 | 
						|
                                size="mini"
 | 
						|
                                @click="handleAdd"
 | 
						|
                        >新增
 | 
						|
                        </el-button>
 | 
						|
                    </el-col>
 | 
						|
                    <el-col :span="1.5">
 | 
						|
                        <el-button
 | 
						|
                                v-permisaction="['admin:lineUserProfitLogs:edit']"
 | 
						|
                                type="success"
 | 
						|
                                icon="el-icon-edit"
 | 
						|
                                size="mini"
 | 
						|
                                :disabled="single"
 | 
						|
                                @click="handleUpdate"
 | 
						|
                        >修改
 | 
						|
                        </el-button>
 | 
						|
                    </el-col>
 | 
						|
                    <el-col :span="1.5">
 | 
						|
                        <el-button
 | 
						|
                                v-permisaction="['admin:lineUserProfitLogs:remove']"
 | 
						|
                                type="danger"
 | 
						|
                                icon="el-icon-delete"
 | 
						|
                                size="mini"
 | 
						|
                                :disabled="multiple"
 | 
						|
                                @click="handleDelete"
 | 
						|
                        >删除
 | 
						|
                        </el-button>
 | 
						|
                    </el-col>
 | 
						|
                </el-row>
 | 
						|
 | 
						|
                <el-table v-loading="loading" :data="lineUserProfitLogsList" @selection-change="handleSelectionChange">
 | 
						|
                    <el-table-column type="selection" width="55" align="center"/><el-table-column label="line_user 表的id" align="center" prop="userId" :formatter="userIdFormat" width="100">
 | 
						|
                                <template slot-scope="scope">
 | 
						|
                                    {{ userIdFormat(scope.row) }}
 | 
						|
                                </template>
 | 
						|
                            </el-table-column><el-table-column label="line_apiuser 表的id" align="center" prop="apiId" :formatter="apiIdFormat" width="100">
 | 
						|
                                <template slot-scope="scope">
 | 
						|
                                    {{ apiIdFormat(scope.row) }}
 | 
						|
                                </template>
 | 
						|
                            </el-table-column><el-table-column label="line_pre_order 主订单id" align="center" prop="preOrderId" :formatter="preOrderIdFormat" width="100">
 | 
						|
                                <template slot-scope="scope">
 | 
						|
                                    {{ preOrderIdFormat(scope.row) }}
 | 
						|
                                </template>
 | 
						|
                            </el-table-column><el-table-column label="成交数量" align="center" prop="num"
 | 
						|
                                                 :show-overflow-tooltip="true"/><el-table-column label="交易对" align="center" prop="symbol"
 | 
						|
                                                 :show-overflow-tooltip="true"/><el-table-column label="盈利比例" align="center" prop="rate"
 | 
						|
                                                 :show-overflow-tooltip="true"/>
 | 
						|
                    <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
 | 
						|
                        <template slot-scope="scope">
 | 
						|
                         <el-popconfirm
 | 
						|
                           class="delete-popconfirm"
 | 
						|
                           title="确认要修改吗?"
 | 
						|
                           confirm-button-text="修改"
 | 
						|
                           @confirm="handleUpdate(scope.row)"
 | 
						|
                         >
 | 
						|
                           <el-button
 | 
						|
                             slot="reference"
 | 
						|
                             v-permisaction="['admin:lineUserProfitLogs:edit']"
 | 
						|
                             size="mini"
 | 
						|
                             type="text"
 | 
						|
                             icon="el-icon-edit"
 | 
						|
                           >修改
 | 
						|
                           </el-button>
 | 
						|
                         </el-popconfirm>
 | 
						|
                         <el-popconfirm
 | 
						|
                            class="delete-popconfirm"
 | 
						|
                            title="确认要删除吗?"
 | 
						|
                            confirm-button-text="删除"
 | 
						|
                            @confirm="handleDelete(scope.row)"
 | 
						|
                         >
 | 
						|
                            <el-button
 | 
						|
                              slot="reference"
 | 
						|
                              v-permisaction="['admin:lineUserProfitLogs:remove']"
 | 
						|
                              size="mini"
 | 
						|
                              type="text"
 | 
						|
                              icon="el-icon-delete"
 | 
						|
                            >删除
 | 
						|
                            </el-button>
 | 
						|
                         </el-popconfirm>
 | 
						|
                        </template>
 | 
						|
                    </el-table-column>
 | 
						|
                </el-table>
 | 
						|
 | 
						|
                <pagination
 | 
						|
                        v-show="total>0"
 | 
						|
                        :total="total"
 | 
						|
                        :page.sync="queryParams.pageIndex"
 | 
						|
                        :limit.sync="queryParams.pageSize"
 | 
						|
                        @pagination="getList"
 | 
						|
                />
 | 
						|
 | 
						|
                <!-- 添加或修改对话框 -->
 | 
						|
                <el-dialog :title="title" :visible.sync="open" width="500px">
 | 
						|
                    <el-form ref="form" :model="form" :rules="rules" label-width="80px">
 | 
						|
                        
 | 
						|
                                    <el-form-item label="line_user 表的id" prop="userId">
 | 
						|
                                        <el-input v-model="form.userId" placeholder="line_user 表的id"
 | 
						|
                                                      />
 | 
						|
                                    </el-form-item>
 | 
						|
                                    <el-form-item label="line_apiuser 表的id" prop="apiId">
 | 
						|
                                        <el-input v-model="form.apiId" placeholder="line_apiuser 表的id"
 | 
						|
                                                      />
 | 
						|
                                    </el-form-item>
 | 
						|
                                    <el-form-item label="line_pre_order 主订单id" prop="preOrderId">
 | 
						|
                                        <el-input v-model="form.preOrderId" placeholder="line_pre_order 主订单id"
 | 
						|
                                                      />
 | 
						|
                                    </el-form-item>
 | 
						|
                                    <el-form-item label="成交数量" prop="num">
 | 
						|
                                        <el-input v-model="form.num" placeholder="成交数量"
 | 
						|
                                                      />
 | 
						|
                                    </el-form-item>
 | 
						|
                                    <el-form-item label="交易对" prop="symbol">
 | 
						|
                                        <el-input v-model="form.symbol" placeholder="交易对"
 | 
						|
                                                      />
 | 
						|
                                    </el-form-item>
 | 
						|
                                    <el-form-item label="盈利比例" prop="rate">
 | 
						|
                                        <el-input v-model="form.rate" placeholder="盈利比例"
 | 
						|
                                                      />
 | 
						|
                                    </el-form-item>
 | 
						|
                    </el-form>
 | 
						|
                    <div slot="footer" class="dialog-footer">
 | 
						|
                        <el-button type="primary" @click="submitForm">确 定</el-button>
 | 
						|
                        <el-button @click="cancel">取 消</el-button>
 | 
						|
                    </div>
 | 
						|
                </el-dialog>
 | 
						|
            </el-card>
 | 
						|
        </template>
 | 
						|
    </BasicLayout>
 | 
						|
</template>
 | 
						|
 | 
						|
<script>
 | 
						|
    import {addLineUserProfitLogs, delLineUserProfitLogs, getLineUserProfitLogs, listLineUserProfitLogs, updateLineUserProfitLogs} from '@/api/admin/line-user-profit-logs'
 | 
						|
    
 | 
						|
    import {listLineUser } from '@/api/admin/line-user'
 | 
						|
    import {listLineApiUser } from '@/api/admin/line-api-user'
 | 
						|
    import {listLinePreOrder } from '@/api/admin/line-pre-order'
 | 
						|
    export default {
 | 
						|
        name: 'LineUserProfitLogs',
 | 
						|
        components: {
 | 
						|
        },
 | 
						|
        data() {
 | 
						|
            return {
 | 
						|
                // 遮罩层
 | 
						|
                loading: true,
 | 
						|
                // 选中数组
 | 
						|
                ids: [],
 | 
						|
                // 非单个禁用
 | 
						|
                single: true,
 | 
						|
                // 非多个禁用
 | 
						|
                multiple: true,
 | 
						|
                // 总条数
 | 
						|
                total: 0,
 | 
						|
                // 弹出层标题
 | 
						|
                title: '',
 | 
						|
                // 是否显示弹出层
 | 
						|
                open: false,
 | 
						|
                isEdit: false,
 | 
						|
                // 类型数据字典
 | 
						|
                typeOptions: [],
 | 
						|
                lineUserProfitLogsList: [],
 | 
						|
                
 | 
						|
                // 关系表类型
 | 
						|
                userIdOptions :[],
 | 
						|
                apiIdOptions :[],
 | 
						|
                preOrderIdOptions :[],
 | 
						|
                
 | 
						|
                // 查询参数
 | 
						|
                queryParams: {
 | 
						|
                    pageIndex: 1,
 | 
						|
                    pageSize: 10,
 | 
						|
                    userId:undefined,
 | 
						|
                    apiId:undefined,
 | 
						|
                    preOrderId:undefined,
 | 
						|
                    num:undefined,
 | 
						|
                    symbol:undefined,
 | 
						|
                    
 | 
						|
                },
 | 
						|
                // 表单参数
 | 
						|
                form: {
 | 
						|
                },
 | 
						|
                // 表单校验
 | 
						|
                rules: {userId:  [ {required: true, message: 'line_user 表的id不能为空', trigger: 'blur'} ],
 | 
						|
                apiId:  [ {required: true, message: 'line_apiuser 表的id不能为空', trigger: 'blur'} ],
 | 
						|
                preOrderId:  [ {required: true, message: 'line_pre_order 主订单id不能为空', trigger: 'blur'} ],
 | 
						|
                num:  [ {required: true, message: '成交数量不能为空', trigger: 'blur'} ],
 | 
						|
                symbol:  [ {required: true, message: '交易对不能为空', trigger: 'blur'} ],
 | 
						|
                }
 | 
						|
        }
 | 
						|
        },
 | 
						|
        created() {
 | 
						|
            this.getList()
 | 
						|
            this.getLineUserItems()
 | 
						|
            this.getLineApiUserItems()
 | 
						|
            this.getLinePreOrderItems()
 | 
						|
            },
 | 
						|
        methods: {
 | 
						|
            /** 查询参数列表 */
 | 
						|
            getList() {
 | 
						|
                this.loading = true
 | 
						|
                listLineUserProfitLogs(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
 | 
						|
                        this.lineUserProfitLogsList = response.data.list
 | 
						|
                        this.total = response.data.count
 | 
						|
                        this.loading = false
 | 
						|
                    }
 | 
						|
                )
 | 
						|
            },
 | 
						|
            // 取消按钮
 | 
						|
            cancel() {
 | 
						|
                this.open = false
 | 
						|
                this.reset()
 | 
						|
            },
 | 
						|
            // 表单重置
 | 
						|
            reset() {
 | 
						|
                this.form = {
 | 
						|
                
 | 
						|
                id: undefined,
 | 
						|
                userId: undefined,
 | 
						|
                apiId: undefined,
 | 
						|
                preOrderId: undefined,
 | 
						|
                num: undefined,
 | 
						|
                symbol: undefined,
 | 
						|
                rate: undefined,
 | 
						|
            }
 | 
						|
                this.resetForm('form')
 | 
						|
            },
 | 
						|
            getImgList: function() {
 | 
						|
              this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl
 | 
						|
            },
 | 
						|
            fileClose: function() {
 | 
						|
              this.fileOpen = false
 | 
						|
            },
 | 
						|
            userIdFormat(row) {
 | 
						|
                return this.selectItemsLabel(this.userIdOptions, row.userId)
 | 
						|
            },
 | 
						|
            apiIdFormat(row) {
 | 
						|
                return this.selectItemsLabel(this.apiIdOptions, row.apiId)
 | 
						|
            },
 | 
						|
            preOrderIdFormat(row) {
 | 
						|
                return this.selectItemsLabel(this.preOrderIdOptions, row.preOrderId)
 | 
						|
            },
 | 
						|
            // 关系
 | 
						|
            getLineUserItems() {
 | 
						|
               this.getItems(listLineUser, undefined).then(res => {
 | 
						|
                   this.userIdOptions = this.setItems(res, 'id', 'username')
 | 
						|
               })
 | 
						|
            },
 | 
						|
            getLineApiUserItems() {
 | 
						|
               this.getItems(listLineApiUser, undefined).then(res => {
 | 
						|
                   this.apiIdOptions = this.setItems(res, 'id', 'apiName')
 | 
						|
               })
 | 
						|
            },
 | 
						|
            getLinePreOrderItems() {
 | 
						|
               this.getItems(listLinePreOrder, undefined).then(res => {
 | 
						|
                   this.preOrderIdOptions = this.setItems(res, 'id', 'orderSn')
 | 
						|
               })
 | 
						|
            },
 | 
						|
            // 文件
 | 
						|
            /** 搜索按钮操作 */
 | 
						|
            handleQuery() {
 | 
						|
                this.queryParams.pageIndex = 1
 | 
						|
                this.getList()
 | 
						|
            },
 | 
						|
            /** 重置按钮操作 */
 | 
						|
            resetQuery() {
 | 
						|
                this.dateRange = []
 | 
						|
                this.resetForm('queryForm')
 | 
						|
                this.handleQuery()
 | 
						|
            },
 | 
						|
            /** 新增按钮操作 */
 | 
						|
            handleAdd() {
 | 
						|
                this.reset()
 | 
						|
                this.open = true
 | 
						|
                this.title = '添加会员盈利记录表'
 | 
						|
                this.isEdit = false
 | 
						|
            },
 | 
						|
            // 多选框选中数据
 | 
						|
            handleSelectionChange(selection) {
 | 
						|
                this.ids = selection.map(item => item.id)
 | 
						|
                this.single = selection.length !== 1
 | 
						|
                this.multiple = !selection.length
 | 
						|
            },
 | 
						|
            /** 修改按钮操作 */
 | 
						|
            handleUpdate(row) {
 | 
						|
                this.reset()
 | 
						|
                const id =
 | 
						|
                row.id || this.ids
 | 
						|
                getLineUserProfitLogs(id).then(response => {
 | 
						|
                    this.form = response.data
 | 
						|
                    this.open = true
 | 
						|
                    this.title = '修改会员盈利记录表'
 | 
						|
                    this.isEdit = true
 | 
						|
                })
 | 
						|
            },
 | 
						|
            /** 提交按钮 */
 | 
						|
            submitForm: function () {
 | 
						|
                this.$refs['form'].validate(valid => {
 | 
						|
                    if (valid) {
 | 
						|
                        if (this.form.id !== undefined) {
 | 
						|
                            updateLineUserProfitLogs(this.form).then(response => {
 | 
						|
                                if (response.code === 200) {
 | 
						|
                                    this.msgSuccess(response.msg)
 | 
						|
                                    this.open = false
 | 
						|
                                    this.getList()
 | 
						|
                                } else {
 | 
						|
                                    this.msgError(response.msg)
 | 
						|
                                }
 | 
						|
                            })
 | 
						|
                        } else {
 | 
						|
                            addLineUserProfitLogs(this.form).then(response => {
 | 
						|
                                if (response.code === 200) {
 | 
						|
                                    this.msgSuccess(response.msg)
 | 
						|
                                    this.open = false
 | 
						|
                                    this.getList()
 | 
						|
                                } else {
 | 
						|
                                    this.msgError(response.msg)
 | 
						|
                                }
 | 
						|
                            })
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                })
 | 
						|
            },
 | 
						|
            /** 删除按钮操作 */
 | 
						|
            handleDelete(row) {
 | 
						|
                var Ids = (row.id && [row.id]) || this.ids
 | 
						|
 | 
						|
                this.$confirm('是否确认删除编号为"' + Ids + '"的数据项?', '警告', {
 | 
						|
                    confirmButtonText: '确定',
 | 
						|
                    cancelButtonText: '取消',
 | 
						|
                    type: 'warning'
 | 
						|
                }).then(function () {
 | 
						|
                      return delLineUserProfitLogs( { 'ids': Ids })
 | 
						|
                }).then((response) => {
 | 
						|
                   if (response.code === 200) {
 | 
						|
                     this.msgSuccess(response.msg)
 | 
						|
                     this.open = false
 | 
						|
                     this.getList()
 | 
						|
                   } else {
 | 
						|
                     this.msgError(response.msg)
 | 
						|
                   }
 | 
						|
                }).catch(function () {
 | 
						|
                })
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
</script>
 |