Compare commits

...

22 Commits

Author SHA1 Message Date
ce4d14c11c 1\持仓信息 2025-08-28 09:06:25 +08:00
425ff32236 1 2025-08-26 16:37:10 +08:00
9fdcbd2060 1 2025-08-26 16:34:01 +08:00
27ef79d25a 1 2025-06-17 15:00:09 +08:00
f37617ab42 1 2025-06-17 14:56:31 +08:00
c248dcc929 1暂存 2025-05-21 09:10:30 +08:00
6c43454aa3 1、反单配置 2025-05-20 17:30:07 +08:00
4a0a1f929e 1 2025-05-20 09:15:45 +08:00
dabb3e6ce6 Merge branch 'exchange_vue_single'
# Conflicts:
#	src/views/dev-tools/gen/editTable.vue
2025-05-19 09:57:50 +08:00
3fe0558954 1 2025-05-19 09:52:29 +08:00
a5e774e6f1 1、策略下单 2025-04-12 18:35:32 +08:00
ee5934973c 1、减仓策略
2、下单策略模板
3、缓存交易对价格
2025-04-03 18:36:14 +08:00
3342cc220b 1 2025-03-26 09:24:48 +08:00
a686354f2e 1 2025-03-20 09:31:33 +08:00
3cf626e60e 1、模板修改 2025-03-19 10:02:38 +08:00
63a5dfbdf3 1 2025-03-13 10:02:50 +08:00
06b3771f66 1 2025-03-12 18:03:29 +08:00
443778cf36 1 2025-03-12 16:55:49 +08:00
9d34d37c11 1 2025-02-19 14:23:28 +08:00
f54cd7beaa Merge branch 'master' of http://120.25.162.35:82/hucan/exchange_vue 2025-02-18 18:14:55 +08:00
ea32ec317c 1代码生成 2025-02-18 18:14:10 +08:00
9d4c6e5f6e 1 2025-02-18 18:13:23 +08:00
46 changed files with 8241 additions and 3305 deletions

View File

@ -2,5 +2,5 @@
ENV = 'development'
# base api
VUE_APP_BASE_API = 'http://192.168.1.11:6789'
VUE_APP_BASE_API = 'http://127.0.0.1:6789'

View File

@ -0,0 +1,53 @@
import request from '@/utils/request'
// 查询LineApiUserGroup列表
export function listLineApiUserGroup(query) {
return request({
url: '/api/v1/line-api-user-group',
method: 'get',
params: query
})
}
// 查询LineApiUserGroup详细
export function getLineApiUserGroup(id) {
return request({
url: '/api/v1/line-api-user-group/' + id,
method: 'get'
})
}
// 新增LineApiUserGroup
export function addLineApiUserGroup(data) {
return request({
url: '/api/v1/line-api-user-group',
method: 'post',
data: data
})
}
// 修改LineApiUserGroup
export function updateLineApiUserGroup(data) {
return request({
url: '/api/v1/line-api-user-group/' + data.id,
method: 'put',
data: data
})
}
// 删除LineApiUserGroup
export function delLineApiUserGroup(data) {
return request({
url: '/api/v1/line-api-user-group',
method: 'delete',
data: data
})
}
export function getLineApiUserGroupList(query) {
return request({
url: '/api/v1/line-api-user-group/options',
method: 'get',
params: query
})
}

View File

@ -51,3 +51,11 @@ export function getMainUser(data) {
})
}
// 获取未绑定下反单列表
export function getLineApiUserUnBindReverse(data) {
return request({
url: '/api/v1/line-api-user/unbind-reverse',
method: 'get',
params: data
})
}

View File

@ -82,13 +82,6 @@ export function orderMarginType(data) {
data
})
}
export function manuallyCover(data) {
return request({
url: '/api/v1/line-pre-order/manuallyCover',
method: 'post',
data
})
}
export function closePosition(data) {
return request({
url: '/api/v1/line-pre-order/closePosition',

View File

@ -0,0 +1,46 @@
import request from '@/utils/request'
// 查询LineReduceStrategy列表
export function listLineReduceStrategy(query) {
return request({
url: '/api/v1/line-reduce-strategy',
method: 'get',
params: query
})
}
// 查询LineReduceStrategy详细
export function getLineReduceStrategy(id) {
return request({
url: '/api/v1/line-reduce-strategy/' + id,
method: 'get'
})
}
// 新增LineReduceStrategy
export function addLineReduceStrategy(data) {
return request({
url: '/api/v1/line-reduce-strategy',
method: 'post',
data: data
})
}
// 修改LineReduceStrategy
export function updateLineReduceStrategy(data) {
return request({
url: '/api/v1/line-reduce-strategy/' + data.id,
method: 'put',
data: data
})
}
// 删除LineReduceStrategy
export function delLineReduceStrategy(data) {
return request({
url: '/api/v1/line-reduce-strategy',
method: 'delete',
data: data
})
}

View File

@ -0,0 +1,46 @@
import request from '@/utils/request'
// 查询LineReverseOrderExt列表
export function listLineReverseOrderExt(query) {
return request({
url: '/api/v1/line-reverse-order-ext',
method: 'get',
params: query
})
}
// 查询LineReverseOrderExt详细
export function getLineReverseOrderExt(id) {
return request({
url: '/api/v1/line-reverse-order-ext/' + id,
method: 'get'
})
}
// 新增LineReverseOrderExt
export function addLineReverseOrderExt(data) {
return request({
url: '/api/v1/line-reverse-order-ext',
method: 'post',
data: data
})
}
// 修改LineReverseOrderExt
export function updateLineReverseOrderExt(data) {
return request({
url: '/api/v1/line-reverse-order-ext/' + data.id,
method: 'put',
data: data
})
}
// 删除LineReverseOrderExt
export function delLineReverseOrderExt(data) {
return request({
url: '/api/v1/line-reverse-order-ext',
method: 'delete',
data: data
})
}

View File

@ -0,0 +1,46 @@
import request from '@/utils/request'
// 查询LineReverseOrder列表
export function listLineReverseOrder(query) {
return request({
url: '/api/v1/line-reverse-order',
method: 'get',
params: query
})
}
// 查询LineReverseOrder详细
export function getLineReverseOrder(id) {
return request({
url: '/api/v1/line-reverse-order/' + id,
method: 'get'
})
}
// 新增LineReverseOrder
export function addLineReverseOrder(data) {
return request({
url: '/api/v1/line-reverse-order',
method: 'post',
data: data
})
}
// 修改LineReverseOrder
export function updateLineReverseOrder(data) {
return request({
url: '/api/v1/line-reverse-order/' + data.id,
method: 'put',
data: data
})
}
// 删除LineReverseOrder
export function delLineReverseOrder(data) {
return request({
url: '/api/v1/line-reverse-order',
method: 'delete',
data: data
})
}

View File

@ -0,0 +1,69 @@
import request from '@/utils/request'
// 查询LineReversePosition列表
export function listLineReversePosition(query) {
return request({
url: '/api/v1/line-reverse-position',
method: 'get',
params: query
})
}
// 查询LineReversePosition详细
export function getLineReversePosition(id) {
return request({
url: '/api/v1/line-reverse-position/' + id,
method: 'get'
})
}
// 新增LineReversePosition
export function addLineReversePosition(data) {
return request({
url: '/api/v1/line-reverse-position',
method: 'post',
data: data
})
}
// 修改LineReversePosition
export function updateLineReversePosition(data) {
return request({
url: '/api/v1/line-reverse-position/' + data.id,
method: 'put',
data: data
})
}
// 删除LineReversePosition
export function delLineReversePosition(data) {
return request({
url: '/api/v1/line-reverse-position',
method: 'delete',
data: data
})
}
// 平仓
export function closePosition(data) {
return request({
url: '/api/v1/line-reverse-position/close/' + data.id,
method: 'PUT'
})
}
// 批量平仓
export function batchClosePosition(data) {
return request({
url: '/api/v1/line-reverse-position/close-batch',
method: 'PUT',
data: data
})
}
// 清除所有仓位
export function cleanAllPosition() {
return request({
url: '/api/v1/line-reverse-position/clean-all',
method: 'DELETE'
})
}

View File

@ -0,0 +1,46 @@
import request from '@/utils/request'
// 查询LineReverseSetting列表
export function listLineReverseSetting(query) {
return request({
url: '/api/v1/line-reverse-setting',
method: 'get',
params: query
})
}
// 查询LineReverseSetting详细
export function getLineReverseSetting(id) {
return request({
url: '/api/v1/line-reverse-setting/' + id,
method: 'get'
})
}
// 新增LineReverseSetting
export function addLineReverseSetting(data) {
return request({
url: '/api/v1/line-reverse-setting',
method: 'post',
data: data
})
}
// 修改LineReverseSetting
export function updateLineReverseSetting(data) {
return request({
url: '/api/v1/line-reverse-setting/' + data.id,
method: 'put',
data: data
})
}
// 删除LineReverseSetting
export function delLineReverseSetting(data) {
return request({
url: '/api/v1/line-reverse-setting',
method: 'delete',
data: data
})
}

View File

@ -0,0 +1,46 @@
import request from '@/utils/request'
// 查询LineStrategyTemplate列表
export function listLineStrategyTemplate(query) {
return request({
url: '/api/v1/line-strategy-template',
method: 'get',
params: query
})
}
// 查询LineStrategyTemplate详细
export function getLineStrategyTemplate(id) {
return request({
url: '/api/v1/line-strategy-template/' + id,
method: 'get'
})
}
// 新增LineStrategyTemplate
export function addLineStrategyTemplate(data) {
return request({
url: '/api/v1/line-strategy-template',
method: 'post',
data: data
})
}
// 修改LineStrategyTemplate
export function updateLineStrategyTemplate(data) {
return request({
url: '/api/v1/line-strategy-template/' + data.id,
method: 'put',
data: data
})
}
// 删除LineStrategyTemplate
export function delLineStrategyTemplate(data) {
return request({
url: '/api/v1/line-strategy-template',
method: 'delete',
data: data
})
}

View File

@ -17,7 +17,6 @@ export function getLineSymbolBlack (id) {
})
}
// 新增LineSymbolBlack
export function addLineSymbolBlack(data) {
return request({
@ -45,7 +44,6 @@ export function delLineSymbolBlack(data) {
})
}
// 重新加载交易对
export function reloadSymbol() {
return request({

View File

@ -0,0 +1,46 @@
import request from '@/utils/request'
// 查询LineSymbolPrice列表
export function listLineSymbolPrice(query) {
return request({
url: '/api/v1/line-symbol-price',
method: 'get',
params: query
})
}
// 查询LineSymbolPrice详细
export function getLineSymbolPrice(id) {
return request({
url: '/api/v1/line-symbol-price/' + id,
method: 'get'
})
}
// 新增LineSymbolPrice
export function addLineSymbolPrice(data) {
return request({
url: '/api/v1/line-symbol-price',
method: 'post',
data: data
})
}
// 修改LineSymbolPrice
export function updateLineSymbolPrice(data) {
return request({
url: '/api/v1/line-symbol-price/' + data.id,
method: 'put',
data: data
})
}
// 删除LineSymbolPrice
export function delLineSymbolPrice(data) {
return request({
url: '/api/v1/line-symbol-price',
method: 'delete',
data: data
})
}

View File

@ -17,7 +17,6 @@ export function getLineUser (id) {
})
}
// 新增LineUser
export function addLineUser(data) {
return request({

View File

@ -17,7 +17,6 @@ export function getMemberBalanceLog (id) {
})
}
// 新增MemberBalanceLog
export function addMemberBalanceLog(data) {
return request({

View File

@ -17,7 +17,6 @@ export function getMemberBalance (id) {
})
}
// 新增MemberBalance
export function addMemberBalance(data) {
return request({

View File

@ -17,7 +17,6 @@ export function getMemberRenwaLog (id) {
})
}
// 新增MemberRenwaLog
export function addMemberRenwaLog(data) {
return request({

View File

@ -17,7 +17,6 @@ export function getMemberRenwalConfig (id) {
})
}
// 新增MemberRenwalConfig
export function addMemberRenwalConfig(data) {
return request({

View File

@ -17,7 +17,6 @@ export function getMemberWithdrawalLog (id) {
})
}
// 新增MemberWithdrawalLog
export function addMemberWithdrawalLog(data) {
return request({

View File

@ -9,8 +9,13 @@
</el-select>
</el-form-item>
<el-form-item label="字典标签" prop="dictLabel">
<el-input v-model="queryParams.dictLabel" placeholder="请输入字典标签" clearable size="small"
@keyup.enter.native="handleQuery" />
<el-input
v-model="queryParams.dictLabel"
placeholder="请输入字典标签"
clearable
size="small"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="状态" prop="status">
<el-select v-model="queryParams.status" placeholder="数据状态" clearable size="small">
@ -25,16 +30,33 @@
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button v-permisaction="['admin:sysDictData:add']" type="primary" icon="el-icon-plus" size="mini"
@click="handleAdd">新增</el-button>
<el-button
v-permisaction="['admin:sysDictData: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:sysDictData:edit']" type="success" icon="el-icon-edit" size="mini"
:disabled="single" @click="handleUpdate">修改</el-button>
<el-button
v-permisaction="['admin:sysDictData: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:sysDictData:remove']" type="danger" icon="el-icon-delete" size="mini"
:disabled="multiple" @click="handleDelete">删除</el-button>
<el-button
v-permisaction="['admin:sysDictData:remove']"
type="danger"
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
>删除</el-button>
</el-col>
</el-row>
@ -53,16 +75,31 @@
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button v-permisaction="['admin:sysDictData:edit']" size="mini" type="text" icon="el-icon-edit"
@click="handleUpdate(scope.row)">修改</el-button>
<el-button v-permisaction="['admin:sysDictData:remove']" size="mini" type="text" icon="el-icon-delete"
@click="handleDelete(scope.row)">删除</el-button>
<el-button
v-permisaction="['admin:sysDictData:edit']"
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
>修改</el-button>
<el-button
v-permisaction="['admin:sysDictData:remove']"
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
>删除</el-button>
</template>
</el-table-column>
</el-table>
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageIndex"
:limit.sync="queryParams.pageSize" @pagination="getList" />
<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" :close-on-click-modal="false">
@ -89,13 +126,23 @@
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容" />
</el-form-item>
<div style="text-align: right;"><el-button @click="addLuanguage">新增多语言</el-button></div>
<el-form-item v-for="(item, index) in form.languageData" :key="'luanguage_' + index"
:label="'多语言' + (index + 1)" prop="languageData">
<el-form-item
v-for="(item, index) in form.languageData"
:key="'luanguage_' + index"
:label="'多语言' + (index + 1)"
prop="languageData"
>
<div class="luanguage-item">
<el-input v-model="item.k" placeholder="多语言key(zh-CN,en)" style="width: 45%;" />
<el-input v-model="item.v" placeholder="请输入多语言文本" style="width: 45%;" />
<el-button type="warning" size="mini" circle icon="el-icon-delete" @click="luanguageDel(index)"
round></el-button>
<el-button
type="warning"
size="mini"
circle
icon="el-icon-delete"
round
@click="luanguageDel(index)"
/>
</div>
</el-form-item>
</el-form>
@ -317,7 +364,7 @@ export default {
}).catch(function() { })
},
addLuanguage() {
this.form.languageData.push({ k: "", v: "" })
this.form.languageData.push({ k: '', v: '' })
},
luanguageDel(index) {
if (this.form.languageData) {

View File

@ -0,0 +1,367 @@
<template>
<BasicLayout>
<template #wrapper>
<el-card class="box-card">
<el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px">
<el-form-item label="分组名称" prop="groupName"><el-input
v-model="queryParams.groupName"
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:lineApiUserGroup: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:lineApiUserGroup: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:lineApiUserGroup: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="lineApiUserGroupList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="交易所" align="center" prop="exchangeType" :show-overflow-tooltip="true">
<template #default="{ row }">
{{ exchangeTypeFormat(row) }}
</template>
</el-table-column>
<el-table-column label="分组名称" align="center" prop="groupName" :show-overflow-tooltip="true" />
<el-table-column label="数量" align="center" prop="count" />
<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:lineApiUserGroup: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:lineApiUserGroup: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="交易所" prop="exchangeType">
<el-select
v-model="form.exchangeType"
style="width: 100%;"
placeholder="请选择交易所"
clearable
filterable
size="small"
@change="exchangeTypeChange"
>
<el-option
v-for="dict in exchangeTypes"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="分组名称" prop="groupName">
<el-input v-model="form.groupName" show-word-limit maxlength="30" placeholder="请输入分组名称" />
</el-form-item>
<el-form-item label="api用户" prop="userIds">
<el-select
v-model="form.userIds"
multiple
style="width: 100%;"
placeholder="请选择api用户"
clearable
filterable
size="small"
>
<el-option
v-for="dict in lineUsers"
:key="dict.id"
:label="dict.apiName"
:value="dict.id"
:disabled="dict.openStatus === 0"
/>
</el-select>
</el-form-item>
<el-form-item label="状态" prop="status">
<el-radio-group v-model="form.status">
<el-radio :label="1">开启</el-radio>
<el-radio :label="0">关闭</el-radio>
</el-radio-group>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button v-loading="loading" type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
</el-card>
</template>
</BasicLayout>
</template>
<script>
import { addLineApiUserGroup, delLineApiUserGroup, getLineApiUserGroup, listLineApiUserGroup, updateLineApiUserGroup } from '@/api/admin/line-api-user-group'
import { listLineApiUser } from '@/api/admin/line-api-user'
export default {
name: 'LineApiUserGroup',
components: {
},
data() {
return {
// 遮罩层
loading: true,
// 选中数组
ids: [],
// 非单个禁用
single: true,
// 非多个禁用
multiple: true,
// 总条数
total: 0,
// 弹出层标题
title: '',
// 是否显示弹出层
open: false,
isEdit: false,
// 类型数据字典
typeOptions: [],
lineApiUserGroupList: [],
lineUsers: [],
lineTotal: 0,
// 关系表类型
// 查询参数
queryParams: {
pageIndex: 1,
pageSize: 10,
groupName: undefined
},
// 表单参数
form: {
},
// 表单校验
rules: {
groupName: [{ required: true, message: '分组名称不能为空', trigger: 'blur' }],
userIds: [{ required: true, message: '用户不能为空', trigger: 'blur' }]
},
exchangeTypes: []
}
},
created() {
this.getList()
// 获取交易所字典数据
this.getDicts('exchange_type').then(response => {
this.exchangeTypes = response.data
})
},
methods: {
exchangeTypeFormat(row) {
return this.selectDictLabel(this.exchangeTypes || [], row.exchangeType)
},
/** 查询参数列表 */
getList() {
this.loading = true
listLineApiUserGroup(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
this.lineApiUserGroupList = response.data.list
this.total = response.data.count
this.loading = false
}
)
},
// 取消按钮
cancel() {
this.open = false
this.reset()
},
// 表单重置
reset() {
this.form = {
id: undefined,
exchangeType: this.exchangeTypes.length ? this.exchangeTypes[0].value : '',
groupName: undefined,
userId: undefined,
status: 1,
userIds: []
}
this.resetForm('form')
},
getImgList: function() {
this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl
},
fileClose: function() {
this.fileOpen = false
},
getLineApiUser() {
listLineApiUser({ pageIndex: 1, pageSize: 999, exchangeType: this.form.exchangeType }).then(response => {
this.lineUsers = response.data.list
this.lineTotal = response.data.count
})
},
// 关系
// 文件
/** 搜索按钮操作 */
handleQuery() {
this.queryParams.pageIndex = 1
this.getList()
},
/** 重置按钮操作 */
resetQuery() {
this.dateRange = []
this.resetForm('queryForm')
this.handleQuery()
},
/** 新增按钮操作 */
handleAdd() {
this.reset()
this.open = true
this.title = '添加api用户分组'
this.isEdit = false
this.getLineApiUser()
},
// 多选框选中数据
handleSelectionChange(selection) {
this.ids = selection.map(item => item.id)
this.single = selection.length !== 1
this.multiple = !selection.length
},
/** 修改按钮操作 */
handleUpdate(row) {
this.reset()
this.getLineApiUser()
const id =
row.id || this.ids
getLineApiUserGroup(id).then(response => {
this.form = response.data
this.open = true
this.title = '修改api用户分组'
this.isEdit = true
})
},
exchangeTypeChange() {
this.form.userIds = []
this.getLineApiUser()
},
/** 提交按钮 */
submitForm: function() {
this.$refs['form'].validate(valid => {
if (valid) {
if (this.form.id !== undefined) {
updateLineApiUserGroup(this.form).then(response => {
if (response.code === 200) {
this.msgSuccess(response.msg)
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
})
} else {
addLineApiUserGroup(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 delLineApiUserGroup({ '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>

View File

@ -83,48 +83,7 @@
prop="ipAddress"
:show-overflow-tooltip="true"
/>
<!-- <el-table-column
label="代码账号密码"
align="center"
prop="userPass"
:show-overflow-tooltip="true"
/> -->
<!-- <el-table-column
label="归属"
align="center"
prop="affiliation"
:show-overflow-tooltip="true"
>
<template #default="{row}">{{ ['现货','合约','现货合约'][row.affiliation-1] }}</template>
</el-table-column> -->
<el-table-column
label="是否超管可见"
align="center"
prop="adminShow"
:show-overflow-tooltip="true"
>
<template #default="{row}">{{ ['否','是'][row.adminShow] }}</template>
</el-table-column>
<!-- <el-table-column
label="允许下单的方向"
align="center"
prop="site"
:show-overflow-tooltip="true"
>
<template #default="{row}">{{ ['多','空','多空'][row.site-1] }}</template>
</el-table-column> -->
<el-table-column
label="从属关系"
align="center"
prop="subordinate"
:show-overflow-tooltip="true"
>
<template #default="{row}">{{ ['','主账号','副帐号'][row.subordinate] }}</template>
</el-table-column><el-table-column label="所属组id" align="center" prop="groupId" :formatter="groupIdFormat" width="100">
<template slot-scope="scope">
{{ groupIdFormat(scope.row) }}
</template>
</el-table-column><el-table-column
label="开启状态"
align="center"
prop="openStatus"
@ -194,14 +153,6 @@
<el-dialog :title="title" :visible.sync="open" width="500px">
<el-form ref="form" :model="form" :rules="rules" label-width="120px">
<!-- <el-form-item label="用户id" prop="userId">
<el-input v-model="form.userId" placeholder="用户id"
/>
</el-form-item> -->
<!-- <el-form-item label="关联交易所账号id" prop="jysId">
<el-input v-model="form.jysId" placeholder="关联交易所账号id"
/>
</el-form-item> -->
<el-form-item label="交易所" prop="exchangeType">
<el-select
v-model="form.exchangeType"
@ -249,42 +200,25 @@
placeholder="代码账号密码"
/>
</el-form-item>
<!-- <el-form-item label="管理员id" prop="adminId">
<el-input v-model="form.adminId" placeholder="管理员id"
/>
</el-form-item> -->
<!-- <el-form-item label="归属" prop="affiliation">
<el-radio-group v-model="form.affiliation">
<el-radio :label="3">现货合约</el-radio>
<el-radio :label="1">现货</el-radio>
<el-radio :label="2">合约</el-radio>
</el-radio-group>
</el-form-item> -->
<!-- <el-form-item label="是否超管可见" prop="adminShow">
<el-input v-model="form.adminShow" placeholder="是否超管可见"
/>
</el-form-item> -->
<!-- <el-form-item label="允许下单的方向" prop="site">
<el-radio-group v-model="form.site">
<el-radio label="3">多空</el-radio>
<el-radio label="1"></el-radio>
<el-radio label="2"></el-radio>
</el-radio-group>
</el-form-item> -->
<!-- <el-form-item label="从属关系" prop="subordinate">
<el-input v-model="form.subordinate" placeholder="从属关系"
/>
</el-form-item> -->
<!-- <el-form-item label="所属组id" prop="groupId">
<el-input v-model="form.groupId" placeholder="所属组id"
/>
</el-form-item> -->
<el-form-item label="开启状态" prop="openStatus">
<el-radio-group v-model="form.openStatus">
<el-radio :label="1">开启</el-radio>
<el-radio :label="0">关闭</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="反单状态" prop="reverseStatus">
<el-radio-group v-model="form.reverseStatus">
<el-radio v-for="(item,index) in reverseStatusOptions" :key="'formReverseStatus'+index" :label="item.value">{{ item.label }}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item v-if="form.reverseStatus==1" label="反单Api" prop="reverseApiId">
<el-select v-model="form.reverseApiId" placeholder="请选择反单Api" filterable clearable>
<el-option v-for="item in unBindReverseList" :key="'formReverseApi'+item.id" :label="item.apiName" :disabled="item.disabled" :value="item.id" />
</el-select>
</el-form-item>
<el-form-item v-if="form.reverseStatus==1" label="下单比例" prop="orderProportion">
<el-input v-model="form.orderProportion" placeholder="下单比例" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
@ -297,10 +231,9 @@
</template>
<script>
import { addLineApiUser, delLineApiUser, getLineApiUser, listLineApiUser, updateLineApiUser } from '@/api/admin/line-api-user'
import { addLineApiUser, delLineApiUser, getLineApiUser, listLineApiUser, updateLineApiUser, getLineApiUserUnBindReverse } from '@/api/admin/line-api-user'
import { listLineUser } from '@/api/admin/line-user'
import { listLineApiGroup } from '@/api/admin/line-api-group'
export default {
name: 'LineApiUser',
components: {
@ -325,7 +258,15 @@ export default {
// 类型数据字典
typeOptions: [],
lineApiUserList: [],
unBindReverseList: [],
// 下反单状态
reverseStatusOptions: [{
label: '开启',
value: 1
}, {
label: '关闭',
value: 2
}],
// 关系表类型
userIdOptions: [],
groupIdOptions: [],
@ -341,7 +282,8 @@ export default {
},
// 表单校验
rules: {
exchangeType: [{ required: true, message: '交易所不能为空', trigger: 'blur' }]
exchangeType: [{ required: true, message: '交易所不能为空', trigger: 'blur' }],
orderProportion: [{ required: true, message: '下单比例不能为空', trigger: 'blur' }]
},
exchangeTypes: []
}
@ -349,7 +291,7 @@ export default {
created() {
this.getList()
this.getLineUserItems()
this.getLineApiGroupItems()
// this.getLineApiGroupItems()
// 获取交易所字典数据
this.getDicts('exchange_type').then(response => {
this.exchangeTypes = response.data
@ -392,7 +334,9 @@ export default {
site: '3',
subordinate: '0',
groupId: undefined,
openStatus: 1
openStatus: 1,
reverseStatus: 2,
orderProportion: undefined
}
this.resetForm('form')
},
@ -408,17 +352,23 @@ export default {
groupIdFormat(row) {
return this.selectItemsLabel(this.groupIdOptions || [], row.groupId)
},
getUnBindReverse(exchangeType, apiId) {
this.loading = true
getLineApiUserUnBindReverse({ exchangeType, apiId })
.then(response => {
if (response && response.code === 200) {
this.unBindReverseList = response.data
}
}).finally(() => {
this.loading = false
})
},
// 关系
getLineUserItems() {
this.getItems(listLineUser, undefined).then(res => {
this.userIdOptions = this.setItems(res, 'id', 'username')
})
},
getLineApiGroupItems() {
this.getItems(listLineApiGroup, undefined).then(res => {
this.groupIdOptions = this.setItems(res, 'id', 'groupName')
})
},
// 文件
/** 搜索按钮操作 */
handleQuery() {
@ -437,6 +387,8 @@ export default {
this.open = true
this.title = '添加api用户管理'
this.isEdit = false
this.getUnBindReverse(this.form.exchangeType, null)
},
// 多选框选中数据
handleSelectionChange(selection) {
@ -454,12 +406,17 @@ export default {
this.open = true
this.title = '修改api用户管理'
this.isEdit = true
this.getUnBindReverse(this.form.exchangeType, id)
})
},
/** 提交按钮 */
submitForm: function() {
this.$refs['form'].validate(valid => {
if (valid) {
this.form.reverseApiId = this.form.reverseApiId ? Number(this.form.reverseApiId) : null
this.form.orderProportion = this.form.orderProportion ? Number(this.form.orderProportion) : null
if (this.form.id !== undefined) {
updateLineApiUser(this.form).then(response => {
if (response.code === 200) {

View File

@ -12,18 +12,35 @@
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button v-permisaction="['admin:lineCoinnetwork:add']" type="primary" icon="el-icon-plus"
size="mini" @click="handleAdd">新增
<el-button
v-permisaction="['admin:lineCoinnetwork: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:lineCoinnetwork:edit']" type="success" icon="el-icon-edit"
size="mini" :disabled="single" @click="handleUpdate">修改
<el-button
v-permisaction="['admin:lineCoinnetwork: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:lineCoinnetwork:remove']" type="danger" icon="el-icon-delete"
size="mini" :disabled="multiple" @click="handleDelete">删除
<el-button
v-permisaction="['admin:lineCoinnetwork:remove']"
type="danger"
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
>删除
</el-button>
</el-col>
</el-row>
@ -40,24 +57,47 @@
</el-table-column>
<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:lineCoinnetwork:edit']" size="mini"
type="text" icon="el-icon-edit">修改
<el-popconfirm
class="delete-popconfirm"
title="确认要修改吗?"
confirm-button-text="修改"
@confirm="handleUpdate(scope.row)"
>
<el-button
slot="reference"
v-permisaction="['admin:lineCoinnetwork: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:lineCoinnetwork:remove']"
size="mini" type="text" icon="el-icon-delete">删除
<el-popconfirm
class="delete-popconfirm"
title="确认要删除吗?"
confirm-button-text="删除"
@confirm="handleDelete(scope.row)"
>
<el-button
slot="reference"
v-permisaction="['admin:lineCoinnetwork: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" />
<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">
@ -67,7 +107,7 @@
<el-input v-model="form.networkName" placeholder="网络名称" />
</el-form-item>
<el-form-item label="最小提现金额" prop="minWithdrawal">
<el-input v-model="form.minWithdrawal" placeholder="最小提现金额"></el-input>
<el-input v-model="form.minWithdrawal" placeholder="最小提现金额" />
</el-form-item>
<!-- <el-form-item label="网络token名称" prop="tokenName">
<el-input v-model="form.tokenName" placeholder="网络token名称"
@ -89,9 +129,13 @@
<el-input v-model="form.fee" placeholder="手续费(百分比)" />
</el-form-item>
<el-form-item label="状态" prop="status">
<el-switch v-model="form.status" active-text="启用" :active-value="1" :inactive-value="2"
inactive-text="禁用">
</el-switch>
<el-switch
v-model="form.status"
active-text="启用"
:active-value="1"
:inactive-value="2"
inactive-text="禁用"
/>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
@ -132,10 +176,10 @@ export default {
typeOptions: [],
lineCoinnetworkList: [],
statusOptions: [{
label: "启用",
label: '启用',
value: 1
}, {
label: "禁用",
label: '禁用',
value: 2
}],
// 关系表类型
@ -144,7 +188,7 @@ export default {
queryParams: {
pageIndex: 1,
pageSize: 10,
idOrder:"desc",
idOrder: 'desc'
},
// 表单参数
form: {
@ -153,7 +197,7 @@ export default {
rules: {
networkName: [{ required: true, message: '网络名称不能为空', trigger: 'blur' }],
minWithdrawal: [{ required: true, message: '最小提现金额不能为空', trigger: 'blur' }],
fee: [{ required: true, message: '手续费不能为空', trigger: 'blur' }],
fee: [{ required: true, message: '手续费不能为空', trigger: 'blur' }]
}
}
},
@ -184,7 +228,7 @@ export default {
networkName: undefined,
status: 1,
minWithdrawal: undefined,
fee: undefined,
fee: undefined
}
this.resetForm('form')
},

View File

@ -48,17 +48,11 @@
>新增
</el-button>
</el-col> -->
<el-col :span="1.5">
<el-button
v-permisaction="['admin:lineOrderTemplateLogs:edit']"
type="success"
icon="el-icon-edit"
size="mini"
:disabled="single"
@click="handleUpdate"
>修改
<!-- <el-col :span="1.5">
<el-button v-permisaction="['admin:lineOrderTemplateLogs:edit']" type="success" icon="el-icon-edit"
size="mini" :disabled="single" @click="handleUpdate">修改
</el-button>
</el-col>
</el-col> -->
<el-col :span="1.5">
<el-button
v-permisaction="['admin:lineOrderTemplateLogs:remove']"
@ -107,6 +101,21 @@
</el-table-column>
<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="handleCopy(scope.row)"
>
<el-button
slot="reference"
v-permisaction="['admin:lineOrderTemplateLogs:copy']"
size="mini"
type="text"
icon="el-icon-document-copy"
>复制
</el-button>
</el-popconfirm>
<el-popconfirm
class="delete-popconfirm"
title="确认要修改吗?"
@ -150,7 +159,7 @@
/>
<!-- 添加或修改对话框 -->
<el-dialog :title="title" :visible.sync="open" width="1200px" :close-on-click-modal="false">
<el-dialog :title="title" :visible.sync="open" width="1300px" :close-on-click-modal="false">
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="模板名称" prop="name">
<el-input v-model="form.name" placeholder="模板名称" />
@ -181,6 +190,13 @@
<el-radio :label="2">合约</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="api用户类型" prop="api_id_type">
<el-radio-group v-model="inForm.api_id_type" @change="apiIdTypeChange">
<el-radio :label="1">单个</el-radio>
<el-radio :label="2">分组</el-radio>
</el-radio-group>
</el-form-item>
<!-- <el-form-item label="对冲类型" prop="cover_type">
<el-radio-group v-model="inForm.cover_type">
<el-radio :label="1" :disabled="inForm.order_type==2">现货对合约</el-radio>
@ -188,7 +204,7 @@
<el-radio :label="3" :disabled="inForm.order_type==1">合约对现货</el-radio>
</el-radio-group>
</el-form-item> -->
<el-form-item label="api用户" prop="api_id">
<el-form-item v-if="inForm.api_id_type === 1" label="api用户" prop="api_id">
<el-row>
<el-col :span="21">
<el-select
@ -213,6 +229,24 @@
</el-col>
</el-row>
</el-form-item>
<el-form-item v-if="inForm.api_id_type === 2" label="api用户组" prop="api_user_group_id">
<el-select
v-model="inForm.api_user_group_id"
size="small"
clearable
filterable
@change="apiUserGroupChange"
>
<el-option
v-for="(op, index) in apiUserGroupList"
:key="'op_user_group' + index"
:label="op.label"
:value="op.id"
:disabled="op.disabled"
/>
</el-select>
</el-form-item>
<el-form-item v-if="form.type === 2" label="交易对组" prop="symbol_group_id">
<el-select
v-if="form.type === 2"
@ -267,6 +301,47 @@
<el-form-item label="购买金额U" prop="buy_price">
<el-input v-model="inForm.buy_price" placeholder="购买金额U" />
</el-form-item>
<el-form-item label="策略类型">
<el-radio-group v-model="inForm.strategy_template_type" @input="changeStrategyTemplateType">
<el-radio
v-for="(item, index) in strategyTemplateTypeOptions"
:key="'strategyTemplateType' + index"
:label="item.value"
>{{ item.label }}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item v-if="inForm.strategy_template_type === 1" label="策略模板">
<el-select
v-model="inForm.strategy_template_id"
style="width: 100%;"
placeholder="请选择策略"
clearable
filterable
:remote-method="queryStrategyTemplate"
:loading="searchLoding"
remote
size="small"
>
<el-option
v-for="dict in strategyTemplateOptions"
:key="'strategyTemplateId' + dict.id"
:label="dict.name"
:value="dict.id"
/>
<div class="page">
<pagination
v-show="strategyTemplatePagition.total > 0"
:background="false"
:total="strategyTemplatePagition.total"
layout="prev, pager, next"
:page.sync="strategyTemplatePagition.pageIndex"
:limit.sync="strategyTemplatePagition.pageSize"
@pagination="queryStrategyTemplate"
/>
</div>
</el-select>
</el-form-item>
<el-form-item label="价格模式" prop="price_pattern">
<el-radio-group v-model="inForm.price_pattern" @change="onchangePattern">
<el-radio label="percentage">百分比</el-radio>
@ -315,8 +390,18 @@
<el-button type="primary" style="margin-left: 50px;" @click="onCalc">计算</el-button>
</el-col>
</el-row>
<el-form-item label="止盈百分比" prop="profit">
<el-input v-model="inForm.profit" placeholder="止盈百分比" />
<el-form-item :label="inForm.price_pattern === 'mixture' ? '止盈价格' : '止盈百分比'" prop="profit">
<el-input v-model="inForm.profit" :placeholder="inForm.price_pattern === 'mixture' ? '止盈价格' : '止盈百分比'">
<template v-if="inForm.price_pattern === 'mixture'" slot="append">{{ comTakePrice }}</template>
</el-input>
</el-form-item>
<el-form-item :label="inForm.price_pattern === 'mixture' ? '止损价格' : '止损价百分比'" prop="stop_loss">
<el-input
v-model="inForm.stop_loss"
min="0"
type="number"
:placeholder="inForm.price_pattern === 'mixture' ? '止损价格' : '止损价百分比'"
/>
</el-form-item>
<el-form-item label="止盈数量百分比" prop="profit_num_ratio">
<el-input v-model="inForm.profit_num_ratio" placeholder="止盈数量百分比" />
@ -403,8 +488,45 @@
<el-radio label="0">直接执行</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="主单亏损百分比" prop="reduce_price">
<el-input v-model.number="inForm.reduce_price" type="number" placeholder="主单亏损百分比" />
<el-form-item label="减仓策略">
<el-select
v-model="inForm.reduce_strategy_id"
style="width: 100%;"
placeholder="请选择策略"
clearable
filterable
:remote-method="queryReduceStrategy"
:loading="searchLoding"
remote
size="small"
>
<el-option
v-for="dict in reduceStrategyPagition.reduceStrategyList"
:key="'reduce_stratefy.' + dict.id"
:label="dict.name"
:value="dict.id"
/>
<div class="page">
<pagination
v-show="reduceStrategyPagition.total > 0"
:background="false"
:total="reduceStrategyPagition.total"
layout="prev, pager, next"
:page.sync="reduceStrategyPagition.pageIndex"
:limit.sync="reduceStrategyPagition.pageSize"
@pagination="queryReduceStrategy"
/>
</div>
</el-select>
</el-form-item>
<el-form-item :label="inForm.price_pattern === 'mixture' ? '主单亏损价格' : '主单亏损百分比'" prop="reduce_price">
<el-input
v-model="inForm.reduce_price"
type="number"
:placeholder="inForm.price_pattern === 'mixture' ? '主单亏损价格' : '主单亏损百分比'"
>
<template v-if="inForm.price_pattern === 'mixture'" slot="append">{{ comReducePrice }}</template>
</el-input>
</el-form-item>
<el-form-item label="主单减仓数量百分比" prop="reduce_num">
<el-input v-model.number="inForm.reduce_num" type="number" placeholder="主单减仓数量百分比" />
@ -428,6 +550,7 @@
@click="onCalculate"
>计算</el-button></el-col>
</el-row>
<el-form ref="extForm" :model="inForm" label-position="top" :rules="inRules" class="ext-form">
<div v-for="(item, index) in inForm.ext" :key="index" class="exts">
<el-row v-if="item.addType === 1" :gutter="20" style="margin-bottom: 20px;">
<el-col :span="5">
@ -447,15 +570,31 @@
</el-row>
<el-row :gutter="20">
<el-col :span="3">{{ item.addType === 1 ? '加仓下跌百分比' : '减仓下跌百分比' }}
<el-col :span="3">
<!-- {{ item.addType === 1 ? '加仓下跌百分比' : '减仓下跌百分比' }} -->
<el-form-item
:prop="'ext.' + index + '.priceRatio'"
:rules="inRules.priceRatio"
class="ext-form-item"
:label="item.addType === 1 ? '加仓下跌百分比' : '减仓下跌百分比'"
>
<el-input
v-model.number="item.priceRatio"
min="0"
size="mini"
type="number"
:placeholder="item.addType === 1 ? '加仓下跌百分比' : '减仓下跌百分比'"
/></el-col>
<el-col :span="3">{{ item.addType === 1 ? '加仓数值' : '减仓百分比' }}
/>
</el-form-item>
</el-col>
<el-col :span="3">
<!-- {{ item.addType === 1 ? '加仓数值' : '减仓百分比' }} -->
<el-form-item
:prop="'ext.' + index + '.addPositionVal'"
:label="item.addType === 1 ? '加仓数值' : '减仓百分比'"
:rules="inRules.addPositionVal"
class="ext-form-item"
>
<el-input
v-model.number="item.addPositionVal"
min="0"
@ -463,9 +602,16 @@
type="number"
:placeholder="item.addType === 1 ? '加仓数值' : '减仓百分比'"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<span>止盈/止损百分比</span>
<!-- <span>止盈/止损百分比</span> -->
<el-form-item
label="止盈/止损百分比"
:prop="'ext.' + index + '.takeProfitRatio'"
:rules="[{ validator: validateTakeProfitAndStopLoss, trigger: 'blur' }]"
class="ext-form-item"
>
<div>
<el-input
v-model="item.takeProfitRatio"
@ -487,20 +633,35 @@
placeholder="止损百分比"
/>
</div>
</el-form-item>
</el-col>
<!-- <el-col :span="3">止损百分比<el-input v-model.number="item.stopLossRatio" size="mini" type="number" placeholder="止损百分比" /></el-col> -->
<template v-if="item.addType === 1">
<el-col :span="3">
止盈数量百分比<el-input
<!-- 止盈数量百分比 -->
<el-form-item
label="止盈数量(%)"
:prop="'ext.' + index + '.takeProfitNumRatio'"
:rules="inRules.takeProfitNumRatio"
class="ext-form-item"
>
<el-input
v-model.number="item.takeProfitNumRatio"
size="mini"
type="number"
placeholder="止盈数量百分比"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<span>第二止盈/止损百分比</span>
<el-col :span="4">
<!-- <span>第二止盈/止损百分比</span> -->
<el-form-item
label="第二止盈/止损百分比"
:prop="'ext.' + index + '.tpTpPriceRatio'"
:rules="[{ validator: validateTp, trigger: 'blur' }]"
class="ext-form-item"
>
<div>
<el-input
v-model.number="item.tpTpPriceRatio"
@ -520,8 +681,19 @@
placeholder="第二止损价百分比"
/>
</div>
</el-form-item>
</el-col>
</template>
<el-col :span="2">
<el-form-item
label="过期(H)"
:prop="'ext.' + index + '.expirateHour'"
:rules="inRules.expirateHour"
class="ext-form-item"
>
<el-input v-model.number="item.expirateHour" size="mini" type="number" placeholder="过期时间(小时)" />
</el-form-item>
</el-col>
<el-col :span="3">
<div style="margin-bottom: 14px;" /><el-button
size="mini"
@ -531,6 +703,8 @@
</el-col>
</el-row>
</div>
</el-form>
<!-- <el-form-item label="是否保存模板" prop="save_template">
<el-radio-group v-model="inForm.save_template">
<el-radio label="0"></el-radio>
@ -569,6 +743,10 @@ import { addLineOrderTemplateLogs, delLineOrderTemplateLogs, getLineOrderTemplat
import { listLineSymbolGroup } from '@/api/admin/line-symbol-group'
import { getMainUser, listLineApiUser } from '@/api/admin/line-api-user'
import { calculate, aicoinSymbol, quickAddPreOrder } from '@/api/admin/line-pre-order'
import { getLineApiUserGroupList } from '@/api/admin/line-api-user-group'
import { listLineStrategyTemplate } from '@/api/admin/line-strategy-template'
import { listLineReduceStrategy } from '@/api/admin/line-reduce-strategy'
export default {
name: 'LineOrderTemplateLogs',
components: {
@ -608,6 +786,7 @@ export default {
// 关系表类型
userIdOptions: [],
apiUserGroupList: [],
// 查询参数
queryParams: {
@ -636,17 +815,62 @@ export default {
percenter: undefined,
symbolGroups: [],
inRules: {
reduce_price: [{ required: true, message: '主单亏损减仓百分比不能为空', trigger: 'blur' }],
reduce_num: [{ required: true, message: '主单减仓数量百分比不能为空', trigger: 'blur' }],
reduce_take_profit: [{ required: true, message: '主单减仓后止盈价百分比不能为空', trigger: 'blur' }],
// reduce_stop_price: [{ required: true, message: '主单减仓后止损价不能为空', trigger: 'blur' }],
buy_price: [{ required: true, message: '购买金额不能为空', trigger: 'blur' }],
price: [{ required: true, message: '请输入下单百分比不能为空', trigger: 'blur' },
{ validator: this.validatePercentage, trigger: 'blur' }
],
profit: [{ required: true, message: '请输入', trigger: 'blur' },
{ validator: this.validateProfit, trigger: 'blur' }],
stop_loss: [{ required: true, message: '请输入止损', trigger: 'blur' }, { validator: this.validateStopLoss, trigger: 'blur' }],
reduce_price: [
{ required: true, message: '主单亏损不能为空', trigger: 'blur' },
{ validator: this.validateReducePrice, trigger: 'blur' }],
reduce_num: [
{ required: true, message: '主单减仓数量百分比不能为空', trigger: 'blur' },
{ validator: this.validateReduceNum, trigger: 'blur' }],
reduce_take_profit: [
{ required: true, message: '主单减仓后止盈价百分比不能为空', trigger: 'blur' },
{ validator: this.validateReduceTakeProfit, trigger: 'blur' }],
reduce_stop_price: [{ required: true, message: '主单减仓后止损价百分比不能为空', trigger: 'blur' }],
buy_price: [
{ required: true, message: '购买金额不能为空', trigger: 'blur' },
{ validator: this.validateBuyPrice, trigger: 'blur' }
],
exchange_type: [{ required: true, message: '交易所不能为空', trigger: 'blur' }],
api_id: [{ required: true, message: 'api用户不能为空', trigger: 'blur' }],
symbol: [{ required: true, message: '交易对不能为空', trigger: 'blur' }],
symbol_group_id: [{ required: true, message: '交易对组不能为空', trigger: 'blur' }],
quote_symbol: [{ required: true, message: '计货币不能为空', trigger: 'blur' }],
order_sn: [{ required: true, message: '订单号不能为空', trigger: 'blur' }]
quote_symbol: [{ required: true, message: '计货币不能为空', trigger: 'blur' }],
order_sn: [{ required: true, message: '订单号不能为空', trigger: 'blur' }],
profit_num_ratio: [
{ required: true, message: '止盈数量百分比不能为空', trigger: 'blur' },
{ validator: this.validateProfitNumRatio, trigger: 'blur' }
],
profit_tp_tp_price_ratio: [{ validator: this.validateTptpPriceRatio, trigger: 'blur' }],
priceRatio: [{ required: true, message: '下跌百分比不能为空', trigger: 'blur' }, { validator: this.validateExtPriceRatio, trigger: 'blur' }],
addPositionVal: [
{ required: true, message: '追加仓位不能为空', trigger: 'blur' },
{ validator: this.validateAddPosition, trigger: 'blur' }],
takeProfitRatio: [
{ required: true, message: '请输入止盈百分比', trigger: 'blur' },
{ type: 'number', message: '止盈百分比必须为数字', trigger: 'blur' },
{ min: 0, message: '止盈百分比不能小于 0', trigger: 'blur' }
],
stopLossRatio: [
{ required: true, message: '请输入止损百分比', trigger: 'blur' },
{ type: 'number', message: '止损百分比必须为数字', trigger: 'blur' },
{ min: 0, message: '止损百分比不能小于 0', trigger: 'blur' }
],
takeProfitNumRatio: [
{ required: true, message: '止盈数量不能为空', trigger: 'blur' },
{ validator: this.validateExtTakeProfitNumRatio, trigger: 'blur' }
],
tpTpPriceRatio: [{ required: true, message: '第二止盈价格百分比不能为空', trigger: 'blur' }],
slSlPriceRatio: [{ required: true, message: '第二止损价格百分比不能为空', trigger: 'blur' }],
expirateHour: [{ required: true, message: '请输入过期时间(H)', trigger: 'blur' }],
api_id_type: [{ required: true, message: '请选择用户类型', trigger: 'blur' }],
api_user_group_id: [{ required: true, message: '请选择用户组', trigger: 'blur' }]
},
inForm: {},
searchLoding: false,
@ -656,7 +880,28 @@ export default {
aicoins: {},
aicoinPrice: undefined,
ext: [],
re_take_profit_ratio: 0
re_take_profit_ratio: 0,
strategyTemplateOptions: [],
// 策略分页数据
strategyTemplatePagition: {
total: 0,
pageIndex: 1,
pageSize: 10
},
reduceStrategyPagition: {
total: 0,
pageIndex: 1,
pageSize: 10,
// 减仓策略信息
reduceStrategyList: []
},
strategyTemplateTypeOptions: [{
value: 0,
label: '无'
}, {
value: 1,
label: '波段涨跌幅'
}]
}
},
computed: {
@ -671,15 +916,51 @@ export default {
const s = this.comSymbols.find(item => item.symbol === symbol)
if (s) {
const res = ((price - s.lastPrice) / s.lastPrice) * 100
return `${res}%`
return `${res.toFixed(2)}%`
}
return 0
}
return 0
},
/* 计算止盈百分比 */
comTakePrice() {
// console.log('this.form', this.form)
const { profit, price, price_pattern, site } = this.inForm
if (price_pattern === 'mixture' && Number(price) > 0 && Number(profit) > 0) {
let res = 0
if (site === 'BUY') {
res = ((Number(profit) - Number(price)) / Number(price)) * 100
} else {
res = ((Number(price) - Number(profit)) / Number(price)) * 100
}
return `${res.toFixed(2)}%` // 取绝对值并保留两位小数
}
return 0
},
/* 计算减仓百分比 */
comReducePrice() {
const { reduce_price, price, price_pattern, site } = this.inForm
if (price_pattern === 'mixture' && Number(price) > 0 && Number(reduce_price) > 0) {
let res = 0
if (site === 'BUY') {
res = ((Number(price) - Number(reduce_price)) / Number(price)) * 100
} else {
res = ((Number(reduce_price) - Number(price)) / Number(price)) * 100
}
return `${res.toFixed(2)}%` // 取绝对值并保留两位小数
}
return 0
}
},
created() {
this.getList()
this.queryReduceStrategy()
// this.getLineApiUserItems()
this.getSymbolGroup()
// 获取交易所字典数据
@ -688,6 +969,162 @@ export default {
})
},
methods: {
/** 主单止损价 */
validateStopLoss(rule, value, callback) {
if (value < 0) {
callback(new Error('止损价不能小于0'))
} else if (this.inForm.price_pattern !== 'mixture' && value > 100) {
callback(new Error('止损价不能大于100'))
} else {
callback()
}
},
validatePercentage(rule, value, callback) {
if (value <= 0 || value === undefined || value === null || value === '') {
callback(new Error('百分比必须大于0'))
} else {
callback()
}
},
validateExtTakeProfitNumRatio(rule, value, callback) {
if (value === 0 || value === undefined || value === null || value === '') {
callback(new Error('止盈数量百分比必须大于0'))
} else {
callback()
}
},
validateReducePrice(rule, value, callback) {
if (value === 0 || value === undefined || value === null || value === '') {
callback(new Error('必须大于0'))
} else {
callback()
}
},
validateBuyPrice(rule, value, callback) {
if (value === 0) {
callback(new Error('购买金额必须大于0'))
} else {
callback()
}
},
validateReduceTakeProfit(rule, value, callback) {
if (this.inForm.reduce_num > 0 && this.inForm.reduce_num < 100 && this.inForm.reduce_take_profit === 0) {
callback(new Error('主单减仓后止盈必须大于0'))
} else if (this.inForm.reduce_num === 100 && this.inForm.reduce_take_profit > 0) {
callback(new Error('主单减仓全部后无需止盈'))
} else {
callback()
}
},
/** 主单减仓数量 */
validateReduceNum(rule, value, callback) {
if (value <= 0) {
callback(new Error('主单减仓数量必须大于0'))
} else {
callback()
}
},
/** 主单止盈数量 */
validateProfitNumRatio(rule, value, callback) {
if (value <= 0) {
callback(new Error('止盈数量比例必须大于0'))
} else {
callback()
}
},
/** 验证第二止盈止损 */
validateTptpPriceRatio(rule, value, callback) {
if (!this.inForm) {
callback(new Error('表单未初始化'))
return
}
if (this.inForm.profit_num_ratio > 0 && this.inForm.profit_num_ratio < 100 && (!value || value <= 0)) {
callback(new Error('第二止盈百分比不能为空且必须大于 0'))
} else if (this.inForm.profit_num_ratio === 100 && value > 0) {
callback(new Error('第一止盈已经全部止盈了,不需要第二止盈百分比'))
} else {
callback()
}
},
validateProfit(rule, value, callback) {
if (this.inForm.profit === '' || this.inForm.profit === undefined || this.inForm.profit === null) {
callback(new Error('不能为空'))
} else if (this.inForm.profit <= 0) {
callback(new Error('不能小于0'))
} else {
callback()
}
},
validateExtPriceRatio(rule, value, callback) {
const index = rule.fullField.split('.')[1] // 获取索引
const item = this.inForm.ext[index]
const message = item.addType === 1 ? '加仓下跌百分比' : '减仓下跌百分比'
if (item.priceRatio === '') {
callback(new Error(message + '不能为空'))
} else if (isNaN(item.priceRatio)) {
callback(new Error('必须输入数字'))
} else if (item.priceRatio < 0) {
callback(new Error('百分比不能小于 0'))
}
if (index === 0 && Number(item.priceRatio) <= Number(this.inForm.reduce_price)) {
callback(new Error('下跌百分比不能小于上一节点'))
} else if (index > 0 && Number(item.priceRatio) <= Number(this.inForm.ext[index - 1].priceRatio)) {
callback(new Error('下跌百分比不能小于上一节点'))
} else {
callback()
}
},
validateAddPosition(rule, value, callback) {
const index = rule.fullField.split('.')[1] // 获取索引
const item = this.inForm.ext[index]
const message = item.addType === 1 ? '加仓数值' : '减仓百分比'
if (item.addPositionVal === '') {
callback(new Error(message + '不能为空'))
} else if (isNaN(item.addPositionVal)) {
callback(new Error('必须输入数字'))
} else if (item.addPositionVal <= 0) {
callback(new Error(message + '必须大于 0'))
} else {
callback() // 校验通过
}
},
// 自定义校验逻辑
validateTakeProfitAndStopLoss(rule, value, callback) {
const index = rule.fullField.split('.')[1] // 获取索引
const item = this.inForm.ext[index]
if (item.takeProfitRatio === '' || item.stopLossRatio === '') {
callback(new Error('止盈和止损百分比都不能为空'))
} else if (isNaN(item.takeProfitRatio) || isNaN(item.stopLossRatio)) {
callback(new Error('必须输入数字'))
} else if (item.takeProfitRatio < 0 || item.stopLossRatio < 0) {
callback(new Error('百分比不能小于 0'))
} else if (item.addType === 2 && item.addPositionVal < 100 && item.takeProfitRatio === 0) {
callback(new Error('止盈百分比不能为0'))
} else {
callback() // 校验通过
}
},
// 自定义 第二止盈止损校验
validateTp(rule, value, callback) {
const index = rule.fullField.split('.')[1] // 获取索引
const item = this.inForm.ext[index]
if (item.tpTpPriceRatio === '' || item.tpSlPriceRatio === '') {
callback(new Error('第二止盈、止损百分比不能为空'))
} else if (isNaN(item.tpTpPriceRatio) || isNaN(item.tpSlPriceRatio)) {
callback(new Error('必须输入数字'))
} else if (item.tpTpPriceRatio < 0 || item.tpSlPriceRatio < 0) {
callback(new Error('百分比不能小于 0'))
} else if (item.takeProfitNumRatio < 100 && item.takeProfitNumRatio > 0 && item.tpTpPriceRatio <= 0) {
callback(new Error('第二止盈百分比必须大于0'))
} else {
callback() // 校验通过
}
},
onChangeSymbolType() {
if (this.inForm.symbol_type === 1) {
this.inForm.cover_type = 0
@ -736,7 +1173,7 @@ export default {
this.inForm.ext.splice(index, 1)
return false
}
console.log('ext', this.inForm.ext)
this.inForm.ext.push({
// 类型 订单类型 加仓类型 加仓数值 价格百分比 止盈百分比 止损百分比
addType: type === 0 ? 1 : 2,
@ -747,20 +1184,10 @@ export default {
takeProfitRatio: 0,
stopLossRatio: 0,
// 止盈数量百分比 止盈后止盈价格百分比 止盈后止损价格百分比
takeProfitNumRatio: 0,
takeProfitNumRatio: 100,
tpTpPriceRatio: 0,
tpSlPriceRatio: 0
// reducePriceRatio: undefined,
// reduceNumRatio: undefined,
// reduceTakeProfitRatio: undefined,
// reduceStopLossRatio: undefined,
// takeProfitRatio: undefined,
// addPositionPriceRatio: undefined,
// addPositionOrderType: 'LIMIT',
// addPositionType: 1,
// addPositionVal: undefined
tpSlPriceRatio: 0,
expirateHour: 0
})
},
onchangeForm() {
@ -777,11 +1204,17 @@ export default {
},
// 获取杠杆api用户
getListLineApiUser(exchangeType) {
listLineApiUser({ pageIndex: 1, pageSize: 999, exchangeType: exchangeType || this.inForm.exchange_type }).then(response => {
listLineApiUser({ pageIndex: 1, pageSize: 999, exchangeType: exchangeType || this.inForm.exchange_type, openStatus: 1 }).then(response => {
this.lineUsers = response.data.list
this.lineTotal = response.data.count
})
},
// 获取api用户分组
getApiUserGroupList(exchangeType) {
getLineApiUserGroupList({ exchangeType: exchangeType || this.inForm.exchange_type }).then(response => {
this.apiUserGroupList = response.data
})
},
// 交易对列表
getSymbol(e, type, exchangeType) {
this.searchLoding = true
@ -812,7 +1245,7 @@ export default {
res = (1 + (this.percenter / 100)) * Number(this.inForm.price)
}
const [num, decimal] = String(res).split('.')
console.log(num, decimal, '?')
// console.log(num, decimal, '?')
if (decimal) {
this.inForm.price = decimal.length > 4 ? `${num}.${decimal.substring(0, 4)}` : res
} else {
@ -840,6 +1273,27 @@ export default {
}
})
},
/* 切换用户选择 */
apiIdTypeChange() {
this.inForm.api_id = undefined
this.inForm.api_user_group_id = undefined
},
/* 用户分组选中 */
apiUserGroupChange(selection) {
console.log(selection)
if (selection) {
// 过滤出匹配的项
const matchedGroup = this.apiUserGroupList.find(x => x.id === selection)
console.log(matchedGroup)
// 确保 matchedGroup 存在,并且有 value 数组
if (matchedGroup && matchedGroup.value) {
this.inForm.api_id = matchedGroup.value // 转字符串
} else {
this.inForm.api_id = undefined // 处理未找到的情况
}
}
},
// 取消按钮
cancel() {
this.open = false
@ -854,7 +1308,8 @@ export default {
userId: undefined,
params: undefined,
type: 1,
switch: '0'
switch: '0',
ext: []
}
this.resetForm('form')
},
@ -873,6 +1328,36 @@ export default {
this.userIdOptions = this.setItems(res, 'id', 'apiName')
})
},
changeStrategyTemplateType(val) {
if (val === 1) {
this.queryStrategyTemplate()
} else {
this.form.strategy_template_id = undefined
}
},
queryStrategyTemplate() {
this.searchLoding = true
listLineStrategyTemplate({ pageIndex: this.strategyTemplatePagition.pageIndex, pageSize: this.strategyTemplatePagition.pageSize }).then(res => {
this.strategyTemplatePagition.total = res.data.count
this.strategyTemplateOptions = res.data.list
})
.finally(() => {
this.searchLoding = false
})
},
// 查询减仓策略
queryReduceStrategy() {
this.searchLoding = true
listLineReduceStrategy({ pageIndex: this.reduceStrategyPagition.pageIndex, pageSize: this.reduceStrategyPagition.pageSize }).then(res => {
this.reduceStrategyPagition.reduceStrategyList = res.data.list
this.reduceStrategyPagition.total = res.data.count
})
.finally(() => {
this.searchLoding = false
})
},
// 文件
/** 搜索按钮操作 */
handleQuery() {
@ -898,8 +1383,7 @@ export default {
this.single = selection.length !== 1
this.multiple = !selection.length
},
/** 修改按钮操作 */
handleUpdate(row) {
handleCopy(row) {
this.reset()
this.ext = []
const id =
@ -915,6 +1399,41 @@ export default {
this.form.type === 1 && this.onCalculate()
// 获取交易对用于计算
this.getSymbol(this.inForm.symbol)
this.form.id = undefined
this.open = true
this.title = '添加委托下单模板'
this.isEdit = false
})
},
/** 修改按钮操作 */
handleUpdate(row) {
this.reset()
this.ext = []
const id =
row.id || this.ids
getLineOrderTemplateLogs(id).then(response => {
this.form = response.data
const x = JSON.parse(response.data.params)
this.inForm = {
...x,
api_id: x.api_id.split(','),
api_id_type: x.api_id_type ? x.api_id_type : 1,
api_user_group_id: x.api_user_group_id ? x.api_user_group_id : undefined,
symbol_group_id: x.symbol_group_id ? Number(x.symbol_group_id) : undefined
}
if (this.inForm.price_pattern === 'aicoin') {
this.inForm.price = null
}
this.getApiUserGroupList()
this.onchangePattern(false)
this.getListLineApiUser()
this.form.type === 2 && this.getSymbolGroup(this.inForm.symbol_type)
this.form.type === 1 && this.onCalculate()
// 获取交易对用于计算
this.getSymbol(this.inForm.symbol)
this.open = true
this.title = '修改委托下单模板'
this.isEdit = true
@ -922,12 +1441,18 @@ export default {
},
/** 提交按钮 */
submitForm: function() {
this.$refs['form'].validate(valid => {
if (valid) {
Promise.all([
this.$refs['inForm'].validate(), // 验证第一个表单
this.$refs['extForm'].validate() // 验证第二个表单
])
.then((formValid) => {
if (formValid.every(valid => valid)) {
this.inForm.price = this.inForm.price ? String(this.inForm.price) : ''
if (this.form.id !== undefined) {
this.$refs['inForm'].validate(valided => {
if (!valided) return false
if (this.inForm.api_user_group_id && this.inForm.api_id_type === 2) {
this.apiUserGroupChange(this.inForm.api_user_group_id)
}
const params = JSON.stringify({
...this.inForm,
reduce_price: this.inForm.reduce_price || 0,
@ -947,10 +1472,14 @@ export default {
stopLossRatio: item.stopLossRatio || 0,
takeProfitNumRatio: item.takeProfitNumRatio || 0,
tpTpPriceRatio: item.tpTpPriceRatio || 0,
tpSlPriceRatio: item.tpSlPriceRatio || 0
tpSlPriceRatio: item.tpSlPriceRatio || 0,
expirateHour: item.expirateHour || 0
}))
: []
})
if (this.form.id !== undefined) {
this.$refs['inForm'].validate(valided => {
if (!valided) return false
updateLineOrderTemplateLogs({ ...this.form, params }).then(response => {
if (response.code === 200) {
@ -963,7 +1492,7 @@ export default {
})
})
} else {
addLineOrderTemplateLogs({ ...this.inForm, symbol_group_id: String(this.inForm.symbol_group_id), api_id: this.inForm.api_id.toString() }).then(response => {
addLineOrderTemplateLogs({ ...this.form, params }).then(response => {
if (response.code === 200) {
this.msgSuccess(response.msg)
this.open = false
@ -1007,9 +1536,17 @@ export default {
return quickAddPreOrder({ ids: Ids.toString() })
}).then((response) => {
if (response.code === 200) {
if (response.data !== '') {
this.$notify({
title: '部分失败',
message: response.data,
type: 'warning'
})
} else {
this.msgSuccess(response.msg)
}
this.ids = []
this.$refs.table?.clearSelection()
this.msgSuccess(response.msg)
} else {
this.msgError(response.msg)
}
@ -1033,6 +1570,20 @@ export default {
}
}
::v-deep.ext-form-item {
.el-form-item__label {
padding: 0px !important;
}
}
.el-form--label-top .el-form-item__label {
padding: 0px !important;
}
.ext-form .el-form-item__content .el-input-group {
vertical-align: middle;
}
.page {
.pagination-container {
padding: 0 !important;

View File

@ -98,10 +98,29 @@
v-model="queryParams.status"
placeholder="请选择状态"
size="small"
clearable
>
<el-option v-for="dict in statuss" :key="dict.k" :label="dict.l" :value="dict.v" />
</el-select>
</el-form-item>
<el-form-item label="下单百分比">
<el-input
v-model="queryParams.percentStart"
placeholder="下单百分比"
style="width: 100px;"
clearable
size="small"
/>
-
<el-input
v-model="queryParams.percentEnd"
placeholder="下单百分比"
style="width: 100px;"
clearable
size="small"
/>
</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>
@ -964,7 +983,9 @@ export default {
idOrder: 'desc',
addPositionStatus: -1,
hedgeStatus: -1,
status: ''
status: '',
percentStart: undefined,
percentEnd: undefined
},
// 表单参数
form: {

View File

@ -365,10 +365,9 @@
</template>
<script>
import { resetForm } from '@/utils/costum';
export default {
name: "AddPosition",
name: 'AddPosition',
props: {
open: {
type: Boolean,
@ -389,16 +388,16 @@ export default {
buyer: [
{ v: 'BUY', l: '买(多)' },
{ v: 'SELL', l: '卖(空)' }
],
]
}
},
methods: {
resetForm() {
this.form = {
id: null,
exchangeType:"",
exchangeType: '',
orderType: 1,
symbol:"",
symbol: '',
apiId: null,
site: '',
buyPrice: null,
@ -411,7 +410,7 @@ export default {
reducePriceRatio: null,
reduceNumRatio: null,
reduceTakeProfitRatio: null,
reduceStopLossRatio:null,
reduceStopLossRatio: null
}
},
// 提交
@ -420,7 +419,7 @@ export default {
},
// 取消
cancel() {
this.$emit("update:open", false)
this.$emit('update:open', false)
}
}
}

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,448 @@
<template>
<BasicLayout>
<template #wrapper>
<el-card class="box-card">
<el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px">
<el-form-item label="策略名称" prop="name"><el-input
v-model="queryParams.name"
placeholder="请输入策略名称"
clearable
size="small"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="状态" prop="status">
<el-select v-model="queryParams.status" size="mini" placeholder="请选择订单类型" clearable>
<el-option
v-for="(item2, index2) in statusOptions"
:key="'queryStatus.' + index2"
:label="item2.label"
:value="item2.value"
/>
</el-select>
</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:lineReduceStrategy: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:lineReduceStrategy: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:lineReduceStrategy: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="lineReduceStrategyList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="策略名称" align="center" prop="name" :show-overflow-tooltip="true" />
<el-table-column label="状态" align="center" prop="status" :show-overflow-tooltip="true">
<template slot-scope="scope">
{{ statusFormat(scope.row.status) }}
</template>
</el-table-column>
<el-table-column
label="创建时间"
align="center"
prop="createdAt"
width="150"
:show-overflow-tooltip="true"
>
<template #default="{ row }">{{ parseTime(row.createdAt) }}</template>
</el-table-column>
<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:lineReduceStrategy: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:lineReduceStrategy: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="800px">
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="策略名称" prop="name">
<el-input v-model="form.name" placeholder="减仓策略名称" show-word-limit maxlength="50" />
</el-form-item>
<el-form-item label="状态" prop="status">
<el-radio-group v-model="form.status">
<el-radio v-for="dict in statusOptions" :key="dict.value" :label="dict.value">{{
dict.label
}}</el-radio>
</el-radio-group>
</el-form-item>
<el-row>
<el-col :span="4"><el-form-item label="减仓配置" /></el-col>
<el-col :span="2"><el-button
type="primary"
size="mini"
@click="onAddItem"
>新增减仓</el-button></el-col>
</el-row>
<el-row
v-for="(item, index) in form.items"
:key="'item_' + index"
style="margin-top: 10px;"
:gutter="20"
>
<!-- <el-card shadow="hover"> -->
<el-col :span="6">
<el-form-item
label="亏损比例"
:prop="'items.' + index + '.lossPercent'"
:rules="rules.lossPercent"
>
<el-input v-model="item.lossPercent" size="mini" placeholder="请输入亏损比例" />
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="减仓比例" :prop="'items.' + index + '.quantityPercent'" :rules="rules.quantityPercent">
<el-input v-model="item.quantityPercent" size="mini" placeholder="请输入减仓数量比例" />
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item
label="订单类型"
:prop="'items.' + index + '.orderType'"
:rules="rules.orderType"
>
<el-select v-model="item.orderType" size="mini" placeholder="请选择订单类型">
<el-option
v-for="(item2, index2) in orderTypeOptions"
:key="index + '.orderType.' + index2"
:label="item2.label"
:value="item2.value"
/>
</el-select>
</el-form-item>
</el-col>
<!-- <el-form-item> -->
<!-- </el-form-item> -->
<el-col :span="4" style="height: 36px; line-height: 36px;"><el-button
size="mini"
type="danger"
@click="removeItem(index)"
>删除</el-button></el-col>
<!-- </el-card> -->
</el-row>
</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 { addLineReduceStrategy, delLineReduceStrategy, getLineReduceStrategy, listLineReduceStrategy, updateLineReduceStrategy } from '@/api/admin/line-reduce-strategy'
export default {
name: 'LineReduceStrategy',
components: {
},
data() {
return {
// 遮罩层
loading: true,
// 选中数组
ids: [],
// 非单个禁用
single: true,
// 非多个禁用
multiple: true,
// 总条数
total: 0,
// 弹出层标题
title: '',
// 是否显示弹出层
open: false,
isEdit: false,
// 类型数据字典
typeOptions: [],
lineReduceStrategyList: [],
orderTypeOptions: [{
value: 'LIMIT',
label: '限价'
}, {
value: 'MARKET',
label: '市价'
}],
statusOptions: [{
value: 1,
label: '启用'
}, {
value: 2,
label: '禁用'
}],
// 关系表类型
// 查询参数
queryParams: {
pageIndex: 1,
pageSize: 10,
name: undefined,
status: undefined,
idOrder: 'desc'
},
// 表单参数
form: {
},
// 表单校验
rules: {
name: [{ required: true, message: '减仓策略名称不能为空', trigger: 'blur' }],
status: [{ required: true, message: '状态 1-启用 2-禁用不能为空', trigger: 'blur' }],
lossPercent: [{ required: true, message: '亏损百分比不能为空', trigger: 'blur' },
{ validator: this.validateOrderType, trigger: 'blur' }],
orderType: [{ required: true, message: '订单类型不能为空', trigger: 'blur' }
],
quantityPercent: [{ required: true, message: '减仓数量百分比不能为空', trigger: 'blur' },
{ validator: this.validateQuantityPercent, trigger: 'blur' }
]
}
}
},
created() {
this.getList()
},
methods: {
// 校验节点百分比
validateOrderType(rule, value, callback) {
const index = rule.fullField.split('.')[1] // 获取索引
const item = this.form.items[index]
if (value === '') {
callback(new Error('不能为空'))
} else if (isNaN(value)) {
callback(new Error('必须输入数字'))
} else if (value < 0) {
callback(new Error('百分比不能小于 0'))
}
if (index > 0 && item.lossPercent <= this.form.items[index - 1].lossPercent) {
callback(new Error('亏损百分比不能小于上一节点'))
} else {
callback()
}
},
validateQuantityPercent(rule, value, callback) {
// const index = rule.fullField.split('.')[1] // 获取索引
if (value === '') {
callback(new Error('不能为空'))
} else if (isNaN(value)) {
callback(new Error('必须输入数字'))
} else if (value < 0) {
callback(new Error('百分比不能小于 0'))
} else if (value > 100) {
callback(new Error('百分比不能大于 100'))
} else {
callback()
}
},
/** 查询参数列表 */
getList() {
this.loading = true
listLineReduceStrategy(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
this.lineReduceStrategyList = response.data.list
this.total = response.data.count
this.loading = false
}
)
},
statusFormat(status) {
const op = this.statusOptions.find(x => x.value === status)
if (op) {
return op.label
}
return ''
},
// 取消按钮
cancel() {
this.open = false
this.reset()
},
// 表单重置
reset() {
this.form = {
id: undefined,
name: undefined,
status: 1,
items: []
}
this.resetForm('form')
},
getImgList: function() {
this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl
},
fileClose: function() {
this.fileOpen = false
},
// 关系
// 文件
/** 搜索按钮操作 */
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
getLineReduceStrategy(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) {
updateLineReduceStrategy(this.form).then(response => {
if (response.code === 200) {
this.msgSuccess(response.msg)
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
})
} else {
addLineReduceStrategy(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 delLineReduceStrategy({ 'ids': Ids })
}).then((response) => {
if (response.code === 200) {
this.msgSuccess(response.msg)
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
}).catch(function() {
})
},
onAddItem() {
this.form.items.push({ lossPercent: undefined, orderType: 'LIMIT' })
},
removeItem(index) {
this.form.items.splice(index, 1)
}
}
}
</script>

View File

@ -0,0 +1,230 @@
<template>
<!-- 添加或修改对话框 -->
<el-dialog title="反向订单详情" :visible.sync="visible" width="500px" @open="handleOpen" @close="handleClose">
<el-form ref="form" :model="form" label-width="80px">
<el-form-item label="主单id" prop="pId">
<el-input v-model="form.pId" placeholder="主单id" />
</el-form-item>
<el-form-item label="订单号" prop="orderSn">
<el-input v-model="form.orderSn" placeholder="订单号" />
</el-form-item>
<el-form-item label="币安订单号" prop="orderId">
<el-input v-model="form.orderId" placeholder="币安订单号" />
</el-form-item>
<el-form-item label="跟随币安订单号" prop="followOrderSn">
<el-input v-model="form.followOrderSn" 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="orderType">
<el-input v-model="form.orderType" placeholder="订单类型 0-主单 1-止损单 2-加仓 3-减仓" />
</el-form-item>
<el-form-item label="购买金额" prop="buyPrice">
<el-input v-model="form.buyPrice" placeholder="购买金额" />
</el-form-item>
<el-form-item label="委托价格" prop="price">
<el-input v-model="form.price" placeholder="委托价格" />
</el-form-item>
<el-form-item label="委托价格(U)" prop="priceU">
<el-input v-model="form.priceU" placeholder="委托价格(U)" />
</el-form-item>
<el-form-item label="实际成交价" prop="finalPrice">
<el-input v-model="form.finalPrice" placeholder="实际成交价" />
</el-form-item>
<el-form-item label="持仓方向" prop="positionSide">
{{ positionSideFormat(form.positionSide) }}
</el-form-item>
<el-form-item label="买卖方向" prop="side">
{{ sideFormat(form.side) }}
</el-form-item>
<el-form-item label="行情价" prop="signPrice">
<el-input v-model="form.signPrice" placeholder="行情价" />
</el-form-item>
<el-form-item label="触发时间" prop="triggerTime">
<el-date-picker v-model="form.triggerTime" type="datetime" placeholder="选择日期" />
</el-form-item>
<el-form-item label="状态" prop="status">
{{ statusFormat(form.status) }}
</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>
</template>
<script>
import { addLineReverseOrder, getLineReverseOrder, updateLineReverseOrder } from '@/api/admin/line-reverse-order'
export default {
name: 'ReverseOrderModal',
props: {
visible: {
type: Boolean,
default: false
},
id: {
type: Number,
default: null
}
},
data() {
return {
loading: false,
// 表单参数
form: {
},
// 表单校验
rules: {
orderSn: [{ required: true, message: '订单号不能为空', trigger: 'blur' }],
orderId: [{ required: true, message: '币安订单号不能为空', trigger: 'blur' }],
followOrderSn: [{ required: true, message: '跟随币安订单号不能为空', trigger: 'blur' }],
orderType: [{ required: true, message: '订单类型 0-主单 1-止损单 2-加仓 3-减仓不能为空', trigger: 'blur' }],
positionSide: [{ required: true, message: '持仓方向 LONG-多 SHORT-空不能为空', trigger: 'blur' }],
side: [{ required: true, message: '买卖方向 SELL-卖 BUY-买不能为空', trigger: 'blur' }],
status: [{ required: true, message: '状态 1-待下单 2-已下单 3-已成交 4-已平仓 5-已止损不能为空', trigger: 'blur' }]
},
typeOptions: [{
label: '主单',
value: 0
}, {
label: '止损单',
value: 1
}, {
label: '加仓',
value: 2
}, {
label: '减仓',
value: 3
}],
positionSideOptions: [{
label: '多',
value: 'LONG'
}, {
label: '空',
value: 'SHORT'
}],
sideOptions: [{
label: '卖',
value: 'SELL'
}, {
label: '买',
value: 'BUY'
}],
statusOptions: [{
label: '待下单',
value: 1
}, {
label: '已下单',
value: 2
}, {
label: '已成交',
value: 3
}, {
label: '已平仓',
value: 4
}, {
label: '已止损',
value: 5
}]
}
},
methods: {
sideFormat(val) {
const side = this.sideOptions.filter(item => item.value === val)
return side.length ? side[0].label : ''
},
positionSideFormat(val) {
const positionSide = this.positionSideOptions.filter(item => item.value === val)
return positionSide.length ? positionSide[0].label : ''
},
statusFormat(val) {
const status = this.statusOptions.filter(item => item.value === val)
return status.length ? status[0].label : ''
},
typeFormat(val) {
const type = this.typeOptions.filter(item => item.value === val)
return type.length ? type[0].label : ''
},
handleOpen() {
this.loading = true
this.reset()
if (this.id !== null) {
getLineReverseOrder(this.id).then(response => {
if (response.code === 200) {
this.form = response.data
// this.form.triggerTime = new Date(this.form.triggerTime)
}
}).finally(() => {
this.loading = false
})
} else {
this.loading = false
}
},
// 取消按钮
cancel() {
this.visible = false
this.reset()
},
// 表单重置
reset() {
this.form = {
id: undefined,
pId: undefined,
orderSn: undefined,
orderId: undefined,
followOrderSn: undefined,
symbol: undefined,
orderType: undefined,
buyPrice: undefined,
price: undefined,
priceU: undefined,
finalPrice: undefined,
positionSide: undefined,
side: undefined,
signPrice: undefined,
triggerTime: undefined,
status: undefined
}
this.resetForm('form')
},
/** 提交按钮 */
submitForm: function() {
this.$refs['form'].validate(valid => {
if (valid) {
if (this.form.id !== undefined) {
updateLineReverseOrder(this.form).then(response => {
if (response.code === 200) {
this.msgSuccess(response.msg)
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
})
} else {
addLineReverseOrder(this.form).then(response => {
if (response.code === 200) {
this.msgSuccess(response.msg)
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
})
}
}
})
},
handleClose() {
this.$emit('update:visible', false)
}
}
}
</script>

View File

@ -0,0 +1,366 @@
<template>
<BasicLayout>
<template #wrapper>
<el-card class="box-card">
<el-form ref="queryForm" :model="queryParams" :inline="true" label-width="88px">
<el-form-item label="订单号" prop="orderSn"><el-input
v-model="queryParams.orderSn"
placeholder="请输入订单号"
clearable
size="small"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="币安订单号" prop="orderId"><el-input
v-model="queryParams.orderId"
placeholder="请输入币安订单号"
clearable
size="small"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="跟随订单号" prop="followOrderSn"><el-input
v-model="queryParams.followOrderSn"
placeholder="请输入跟随币安订单号"
clearable
size="small"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="订单类型" prop="orderType">
<el-select v-model="queryParams.orderType" clearable>
<el-option
v-for="(item, index) in typeOptions"
:key="'queryOrderType' + index"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="持仓方向" prop="positionSide">
<el-select v-model="queryParams.positionSide" clearable>
<el-option
v-for="(item, index) in positionSideOptions"
:key="'queryPositionSide' + index"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="买卖方向" prop="side">
<el-select v-model="queryParams.side" clearable>
<el-option
v-for="(item, index) in sideOptions"
:key="'querySide' + index"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="状态" prop="status">
<el-select v-model="queryParams.status" clearable>
<el-option
v-for="(item, index) in statusOptions"
:key="'queryStatus' + index"
:label="item.label"
:value="item.value"
/>
</el-select>
</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:lineReverseOrder: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:lineReverseOrder: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:lineReverseOrder: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="lineReverseOrderList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="订单号" align="center" prop="orderSn" :show-overflow-tooltip="true" />
<el-table-column label="币安订单号" align="center" prop="orderId" :show-overflow-tooltip="true" />
<el-table-column
label="跟随币安订单号"
align="center"
prop="followOrderSn"
:show-overflow-tooltip="true"
/>
<el-table-column label="交易对" align="center" prop="symbol" :show-overflow-tooltip="true" />
<el-table-column label="订单类型" align="center" prop="orderType" :show-overflow-tooltip="true" />
<el-table-column label="购买金额" align="center" prop="buyPrice" :show-overflow-tooltip="true" />
<el-table-column label="委托价格" align="center" prop="price" :show-overflow-tooltip="true" />
<el-table-column label="实际成交价" align="center" prop="finalPrice" :show-overflow-tooltip="true" />
<el-table-column label="持仓方向" align="center" prop="positionSide" :show-overflow-tooltip="true" />
<el-table-column label="买卖方向" align="center" prop="side" :show-overflow-tooltip="true" />
<el-table-column label="行情价" align="center" prop="signPrice" :show-overflow-tooltip="true" />
<el-table-column label="触发时间" align="center" prop="triggerTime" :show-overflow-tooltip="true">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.triggerTime) }}</span>
</template>
</el-table-column>
<el-table-column label="状态" align="center" prop="status" :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:lineReverseOrder: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:lineReverseOrder: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-card>
</template>
</BasicLayout>
</template>
<script>
import { delLineReverseOrder, getLineReverseOrder, listLineReverseOrder } from '@/api/admin/line-reverse-order'
export default {
name: 'LineReverseOrder',
components: {
},
data() {
return {
// 遮罩层
loading: true,
// 选中数组
ids: [],
// 非单个禁用
single: true,
// 非多个禁用
multiple: true,
// 总条数
total: 0,
// 弹出层标题
title: '',
// 是否显示弹出层
open: false,
detailId: null,
isEdit: false,
// 类型数据字典
typeOptions: [{
label: '主单',
value: 0
}, {
label: '止损单',
value: 1
}, {
label: '加仓',
value: 2
}, {
label: '减仓',
value: 3
}],
lineReverseOrderList: [],
positionSideOptions: [{
label: '多',
value: 'LONG'
}, {
label: '空',
value: 'SHORT'
}],
sideOptions: [{
label: '卖',
value: 'SELL'
}, {
label: '买',
value: 'BUY'
}],
statusOptions: [{
label: '待下单',
value: 1
}, {
label: '已下单',
value: 2
}, {
label: '已成交',
value: 3
}, {
label: '已平仓',
value: 4
}, {
label: '已止损',
value: 5
}],
// 查询参数
queryParams: {
pageIndex: 1,
pageSize: 10,
orderSn: undefined,
orderId: undefined,
followOrderSn: undefined,
orderType: undefined,
positionSide: undefined,
side: undefined,
status: undefined
}
}
},
created() {
this.getList()
},
methods: {
/** 查询参数列表 */
getList() {
this.loading = true
listLineReverseOrder(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
this.lineReverseOrderList = response.data.list
this.total = response.data.count
}
).finally(() => {
this.loading = false
})
},
typeFormat(val) {
const type = this.typeOptions.filter(item => item.value === val)
return type.length ? type[0].label : ''
},
sideFormat(val) {
const side = this.sideOptions.filter(item => item.value === val)
return side.length ? side[0].label : ''
},
positionSideFormat(val) {
const positionSide = this.positionSideOptions.filter(item => item.value === val)
return positionSide.length ? positionSide[0].label : ''
},
statusFormat(val) {
const status = this.statusOptions.filter(item => item.value === val)
return status.length ? status[0].label : ''
},
getImgList: function() {
this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl
},
fileClose: function() {
this.fileOpen = false
},
// 关系
// 文件
/** 搜索按钮操作 */
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) {
const id =
row.id || this.ids
getLineReverseOrder(id).then(response => {
this.form = response.data
this.open = true
this.title = '修改反单下单列表'
this.isEdit = true
})
},
/** 删除按钮操作 */
handleDelete(row) {
var Ids = (row.id && [row.id]) || this.ids
this.$confirm('是否确认删除编号为"' + Ids + '"的数据项?', '警告', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(function() {
return delLineReverseOrder({ '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>

View File

@ -0,0 +1,201 @@
<template>
<!-- 添加或修改对话框 -->
<el-dialog title="批量平仓" :visible.sync="open" width="500px" @close="handleClose" @open="handleOpen">
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="下单Api" prop="reverseApiId">
<el-select v-model="form.reverseApiId" placeholder="请选择">
<el-option
v-for="dict in reverseApiIdOptions"
:key="'reverseApiId' + dict.id"
:label="dict.name"
:value="dict.id"
/>
</el-select>
</el-form-item>
<el-form-item label="持仓方向" prop="positionSide">
<el-select v-model="form.positionSide" placeholder="请选择">
<el-option
v-for="dict in positionSideOptions"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="交易对" prop="symbol">
<template #label>
<span>交易对</span>
<el-popover trigger="hover" content="交易对为空时,代表平仓全部">
<template #reference>
<i class="el-icon-question" />
</template>
</el-popover>
</template>
<el-select
v-model="form.symbol"
style="width: 100%;"
placeholder="请选择交易对"
clearable
filterable
:remote-method="(e) => getSymbol(e, 1, 'binance')"
:loading="searchLoding"
remote
size="small"
>
<el-option
v-for="dict in symbol.symbolList"
:key="dict.id"
:label="dict.symbol"
:value="dict.symbol"
/>
<div class="page">
<pagination
v-show="symbol.total > 0"
:background="false"
:total="symbol.total"
layout="prev, pager, next"
:page.sync="symbol.pageIndex"
:limit.sync="symbol.pageSize"
@pagination="getSymbol($event, 1, 'binance')"
/>
</div>
</el-select>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" :loading="loading" @click="submitForm">确 定</el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
</template>
<script>
import { batchClosePosition } from '@/api/admin/line-reverse-position'
import { listLineSymbol } from '@/api/admin/line-symbol'
import { getReverseOptionsAll } from '@/api/admin/line-api-user'
export default {
name: 'Detail',
props: {
open: {
type: Boolean,
default: false
}
},
data() {
return {
reverseApiIdOptions: [],
positionSideOptions: [{
value: 'LONG',
label: '多'
}, {
value: 'SHORT',
label: '空'
}],
sideOptions: [{
value: 'SELL',
label: '卖'
}, {
value: 'BUY',
label: '买'
}],
form: {
reverseApiId: undefined,
positionSide: undefined,
symbol: undefined
},
// 表单校验
rules: {
apiId: [{ required: true, message: 'api_id不能为空', trigger: 'blur' }],
reverseApiId: [{ required: true, message: '反单api_id不能为空', trigger: 'blur' }],
side: [{ required: true, message: '买卖方向 BUY SELL不能为空', trigger: 'blur' }],
positionSide: [{ required: true, message: '持仓方向 LONG SHORT不能为空', trigger: 'blur' }]
},
loading: false,
searchLoding: false,
symbol: {
symbolList: [],
total: 0,
pageIndex: 1,
pageSize: 6
}
}
},
methods: {
// 取消按钮
cancel() {
this.handleClose()
},
// 表单重置
reset() {
this.form = {
reverseApiId: undefined,
positionSide: undefined,
symbol: undefined
}
this.resetForm('form')
},
/** 提交按钮 */
submitForm: function() {
this.$refs['form'].validate(valid => {
if (valid) {
this.loading = true
batchClosePosition(this.form).then(res => {
console.log('res', res)
if (res.code === 200) {
if (res.data === null || res.data === undefined || res.data === '') {
this.$message.success('批量平仓成功')
this.handleClose()
} else {
this.$notify.error({
title: '错误',
message: res.data
})
}
}
}).catch(err => {
console.log(err)
}).finally(() => {
this.loading = false
})
}
})
},
handleClose() {
this.reset()
this.$emit('update:open', false)
},
// 交易对列表
getSymbol(e, type, exchangeType) {
this.searchLoding = true
const { pageIndex } = this.symbol
const symbol = typeof e === 'object' ? '' : e
listLineSymbol({ pageIndex, pageSize: 6, type: 1, symbol, exchangeType: 'binance' }).then(res => {
this.symbol.total = res.data.count
this.symbol.symbolList = res.data.list
}).finally(() => {
this.searchLoding = false
})
},
// 打开弹窗
handleOpen() {
this.getSymbol('', 1, 'binance')
this.getApiOptions()
},
// 获取api列表
getApiOptions() {
getReverseOptionsAll({}).then(res => {
if (res.code === 200) {
this.reverseApiIdOptions = res.data
}
})
.catch(err => {
console.log(err)
})
}
}
}
</script>

View File

@ -0,0 +1,139 @@
<template>
<!-- 添加或修改对话框 -->
<el-dialog :title="title" :visible.sync="open" width="500px" @close="handleClose">
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="api_id" prop="apiId">
<el-select v-model="form.apiId" placeholder="请选择">
<el-option v-for="dict in apiIdOptions" :key="dict.value" :label="dict.label" :value="dict.value" />
</el-select>
</el-form-item>
<el-form-item label="反单api_id" prop="reverseApiId">
<el-select v-model="form.reverseApiId" placeholder="请选择">
<el-option v-for="dict in reverseApiIdOptions" :key="dict.value" :label="dict.label" :value="dict.value" />
</el-select>
</el-form-item>
<el-form-item label="反单仓位" prop="reverseAmount">
<el-input v-model="form.reverseAmount" placeholder="反单仓位" />
</el-form-item>
<el-form-item label="买卖方向 BUY SELL" prop="side">
<el-select v-model="form.side" placeholder="请选择">
<el-option v-for="dict in sideOptions" :key="dict.value" :label="dict.label" :value="dict.value" />
</el-select>
</el-form-item>
<el-form-item label="持仓方向 LONG SHORT" prop="positionSide">
<el-select v-model="form.positionSide" placeholder="请选择">
<el-option v-for="dict in positionSideOptions" :key="dict.value" :label="dict.label" :value="dict.value" />
</el-select>
</el-form-item>
<el-form-item label="交易对" prop="symbol">
<el-input v-model="form.symbol" placeholder="交易对" />
</el-form-item>
<el-form-item label="仓位状态 1-已开仓 2-已平仓" prop="status">
<el-input v-model="form.status" placeholder="仓位状态 1-已开仓 2-已平仓" />
</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>
</template>
<script>
export default {
name: 'Detail',
props: {
open: {
type: Boolean,
default: false
},
title: {
type: String,
default: '添加'
},
form: {
type: Object,
default: () => ({})
}
},
data() {
return {
reverseApiIdOptions: [],
positionSideOptions: [],
apiIdOptions: [],
sideOptions: [{
value: 'SELL',
label: '卖'
}, {
value: 'BUY',
label: '买'
}],
// 表单校验
rules: {
apiId: [{ required: true, message: 'api_id不能为空', trigger: 'blur' }],
reverseApiId: [{ required: true, message: '反单api_id不能为空', trigger: 'blur' }],
side: [{ required: true, message: '买卖方向 BUY SELL不能为空', trigger: 'blur' }],
positionSide: [{ required: true, message: '持仓方向 LONG SHORT不能为空', trigger: 'blur' }],
symbol: [{ required: true, message: '交易对不能为空', trigger: 'blur' }]
}
}
},
methods: {
// 取消按钮
cancel() {
this.open = false
this.reset()
},
// 表单重置
reset() {
this.form = {
id: undefined,
apiId: undefined,
reverseApiId: undefined,
reverseAmount: undefined,
side: undefined,
positionSide: undefined,
symbol: undefined,
status: undefined
}
this.resetForm('form')
},
/** 提交按钮 */
submitForm: function() {
this.$refs['form'].validate(valid => {
if (valid) {
// if (this.form.id !== undefined) {
// updateLineReversePosition(this.form).then(response => {
// if (response.code === 200) {
// this.msgSuccess(response.msg)
// this.handleClose()
// } else {
// this.msgError(response.msg)
// }
// })
// } else {
// addLineReversePosition(this.form).then(response => {
// if (response.code === 200) {
// this.msgSuccess(response.msg)
// this.handleClose()
// } else {
// this.msgError(response.msg)
// }
// })
// }
}
})
},
handleClose() {
this.$emit('update:open', false)
this.$emit('close')
this.reset()
}
}
}
</script>

View File

@ -0,0 +1,397 @@
<template>
<BasicLayout>
<template #wrapper>
<el-card class="box-card">
<el-form ref="queryForm" :model="queryParams" :inline="true" label-width="100px">
<el-form-item label="反单买卖方向" prop="side">
<el-select v-model="queryParams.side" prop="side" size="small" clearable>
<el-option
v-for="item in sideOptions"
:key="'query-side-' + item.value"
:value="item.value"
:label="item.label"
/>
</el-select>
</el-form-item>
<el-form-item label="反单持仓方向" prop="positionSide">
<el-select v-model="queryParams.positionSide" clearable size="small">
<el-option
v-for="item in positionSideOptions"
:key="'query-positionSide-' + item.value"
:value="item.value"
:label="item.label"
/>
</el-select>
</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:lineReversePosition:closePosition']"
type="primary"
icon="el-icon-s-flag"
size="mini"
@click="handleCloseBatches"
>平仓
</el-button>
</el-col>
<!-- <el-col :span="1.5">
<el-button v-permisaction="['admin:lineReversePosition: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:lineReversePosition: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:lineReversePosition:remove']"
type="danger"
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
>删除
</el-button>
</el-col>
<el-col :span="1.5">
<el-popconfirm
class="delete-popconfirm"
title="确认要清除所有吗?"
confirm-button-text="清除"
@confirm="handleCleanPosition()"
>
<el-button
slot="reference"
v-permisaction="['admin:lineReversePosition:cleanAll']"
type="danger"
icon="el-icon-delete"
size="mini"
>清除所有
</el-button>
</el-popconfirm>
</el-col>
</el-row>
<el-table v-loading="loading" :data="lineReversePositionList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="交易对" align="center" prop="symbol" width="120px" />
<el-table-column label="主单用户" align="center" prop="apiName" width="100px" />
<el-table-column label="反单用户" align="center" prop="reverseApiName" width="100px" />
<el-table-column label="主单仓位" align="center" prop="amount" :show-overflow-tooltip="true" />
<el-table-column label="主单总仓位" align="center" prop="totalAmount" />
<el-table-column label="主单持仓方向" align="center" prop="side" width="100px" />
<el-table-column label="反单仓位" align="center" prop="reverseAmount" :show-overflow-tooltip="true" />
<el-table-column label="反单总仓位" align="center" prop="totalReverseAmount" />
<el-table-column label="反单持仓方向" align="center" prop="positionSide" width="100px">
<template slot-scope="scope">
{{ scope.row.positionSide === 'LONG' ? '多' : '空' }}
</template>
</el-table-column>
<el-table-column label="主单仓位" align="center" prop="status">
<template slot-scope="scope">
<el-tag v-if="scope.row.status === 0">正常</el-tag>
<el-tag v-else-if="scope.row.status === 1" type="primary">开仓</el-tag>
<el-tag v-else type="success">平仓</el-tag>
</template>
</el-table-column>
<el-table-column label="反单仓位" align="center" prop="reverseStatus" width="80px">
<template slot-scope="scope">
<el-tag v-if="scope.row.reverseStatus === 0">正常</el-tag>
<el-tag v-else-if="scope.row.reverseStatus === 1" type="primary">开仓</el-tag>
<el-tag v-else type="success">平仓</el-tag>
</template>
</el-table-column>
<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:lineReversePosition: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:lineReversePosition:remove']"
size="mini"
type="text"
icon="el-icon-delete"
>删除
</el-button>
</el-popconfirm>
<el-popconfirm
class="delete-popconfirm"
title="确认要平仓吗?"
confirm-button-text="平仓"
@confirm="handleClosePosition(scope.row)"
>
<el-button
v-if="scope.row.reverseStatus === 1"
slot="reference"
v-permisaction="['admin:lineReversePosition:closePosition']"
size="mini"
type="text"
icon="el-icon-s-flag"
>平仓
</el-button>
</el-popconfirm>
<el-button
v-permisaction="['admin:lineReversePosition:edit']"
size="mini"
type="text"
icon="el-icon-s-order"
@click="handleShowOrders(scope.row)"
>订单明细
</el-button>
</template>
</el-table-column>
</el-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="queryParams.pageIndex"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<!--仓位详情-->
<detail :open.sync="open" :title="title" :form="form" :is-edit="isEdit" @close="handleClose" />
<!--仓位订单明细-->
<order-list :show.sync="showOrders" :position-id="selectedPositionId" />
<!--平仓操作-->
<close-position :open.sync="showClosePosition" />
</el-card>
</template>
</BasicLayout>
</template>
<script>
import { delLineReversePosition, listLineReversePosition, getLineReversePosition, closePosition, cleanAllPosition } from '@/api/admin/line-reverse-position'
import Detail from './detail.vue'
import OrderList from './order-list.vue'
import ClosePosition from './close-position.vue'
export default {
name: 'LineReversePosition',
components: {
Detail,
OrderList,
ClosePosition
},
data() {
return {
// 遮罩层
loading: true,
// 选中数组
ids: [],
// 非单个禁用
single: true,
// 非多个禁用
multiple: true,
// 总条数
total: 0,
// 弹出层标题
title: '',
// 是否显示弹出层
open: false,
isEdit: false,
// 类型数据字典
typeOptions: [],
lineReversePositionList: [],
positionSideOptions: [{
label: '多',
value: 'LONG'
}, {
label: '空',
value: 'SHORT'
}],
sideOptions: [{
label: '买',
value: 'BUY'
}, {
label: '卖',
value: 'SELL'
}],
// 关系表类型
// 查询参数
queryParams: {
pageIndex: 1,
pageSize: 10,
apiId: undefined,
reverseApiId: undefined,
side: undefined,
positionSide: undefined,
symbol: undefined,
idOrder: 'desc'
},
// 表单参数
form: {
},
showOrders: false,
selectedPositionId: null,
showClosePosition: false
}
},
created() {
this.getList()
},
methods: {
/** 查询参数列表 */
getList() {
this.loading = true
listLineReversePosition(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
this.lineReversePositionList = response.data.list
this.total = response.data.count
this.loading = false
}
)
},
getImgList: function() {
this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl
},
fileClose: function() {
this.fileOpen = false
},
// 关系
// 文件
/** 搜索按钮操作 */
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
getLineReversePosition(id).then(response => {
this.form = response.data
this.open = true
this.title = '修改反单管理-仓位'
this.isEdit = true
})
},
handleClose() {
this.getList()
},
/** 删除按钮操作 */
handleDelete(row) {
var Ids = (row.id && [row.id]) || this.ids
this.$confirm('是否确认删除编号为"' + Ids + '"的数据项?', '警告', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(function() {
return delLineReversePosition({ 'ids': Ids })
}).then((response) => {
if (response.code === 200) {
this.msgSuccess(response.msg)
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
}).catch(function() {
})
},
// 仓位订单明细
handleShowOrders(row) {
this.showOrders = true
this.selectedPositionId = row.id
},
// 批量平仓
handleCloseBatches() {
this.showClosePosition = true
},
// 平仓
handleClosePosition(row) {
this.loading = true
const data = {
id: Number(row.id)
}
closePosition(data).then(response => {
if (response.code === 200) {
this.msgSuccess(response.msg)
} else {
this.msgError(response.msg)
}
})
.catch(error => {
console.log(error)
})
.finally(() => {
this.loading = false
this.getList()
})
},
// 清除所有仓位
handleCleanPosition() {
cleanAllPosition().then(res => {
this.loading = true
if (res.code === 200) {
this.msgSuccess(res.msg)
this.getList()
} else {
this.msgError(res.msg)
}
})
.catch(err => {
console.log('err', err)
})
.finally(() => {
this.loading = false
})
}
}
}
</script>

View File

@ -0,0 +1,282 @@
<template>
<el-drawer title="仓位订单明细" :visible.sync="show" direction="rtl" size="80%" @open="handleOpen" @close="handleClose">
<el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px">
<el-form-item label="类别" prop="category">
<el-select v-model="queryParams.category" clearable>
<el-option
v-for="item in categoryOptions"
:key="'query-category' + item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="下单类型" prop="type">
<el-select v-model="queryParams.type" clearable>
<el-option
v-for="item in typeOptions"
:key="'query-type' + item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="订单类型" prop="orderType">
<el-select v-model="queryParams.orderType" clearable>
<el-option
v-for="item in orderTypeOptions"
:key="'query-orderType' + item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="状态" prop="status">
<el-select v-model="queryParams.status" clearable>
<el-option
v-for="item in statusOptions"
:key="'query-status' + item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</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-table v-loading="loading" :data="lineReverseOrderList" :row-class-name="tableRowClassName">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="类别" align="center" prop="category" width="80px">
<template slot-scope="scope">
{{ categoryFormat(scope) }}
</template>
</el-table-column>
<el-table-column label="订单号" align="center" prop="orderSn" :show-overflow-tooltip="true" />
<el-table-column label="币安订单号" align="center" prop="orderId" :show-overflow-tooltip="true" />
<el-table-column label="交易对" align="center" prop="symbol" :show-overflow-tooltip="true" />
<el-table-column label="下单类型" align="center" prop="type">
<template slot-scope="scope">
{{ typeFormat(scope) }}
</template>
</el-table-column>
<el-table-column label="订单类型" align="center" prop="orderType">
<template slot-scope="scope">
{{ orderTypeFormat(scope) }}
</template>
</el-table-column>
<el-table-column label="购买金额" align="center" prop="buyPrice" :show-overflow-tooltip="true" />
<el-table-column label="委托价格" align="center" prop="price" :show-overflow-tooltip="true" />
<el-table-column label="实际成交价" align="center" prop="finalPrice" :show-overflow-tooltip="true" />
<el-table-column label="成交数量" align="center" prop="totalNum" :show-overflow-tooltip="true" />
<el-table-column label="持仓方向" align="center" prop="positionSide">
<template slot-scope="scope">
<el-tag v-if="scope.row.positionSide === 'LONG'" type="warning" effect="plain"></el-tag>
<el-tag v-else type="success" effect="plain"></el-tag>
</template>
</el-table-column>
<el-table-column label="买卖方向" align="center" prop="side" :show-overflow-tooltip="true" />
<el-table-column label="触发时间" align="center" prop="triggerTime">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.triggerTime) }}</span>
</template>
</el-table-column><el-table-column label="状态" align="center" prop="status">
<template slot-scope="scope">
{{ statusFormat(scope) }}
</template>
</el-table-column>
<el-table-column label="描述" align="center" prop="remark" :show-overflow-tooltip="true" />
</el-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="queryParams.pageIndex"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
</el-drawer>
</template>
<script>
import { listLineReverseOrder } from '@/api/admin/line-reverse-order'
export default {
name: 'OrderList',
props: {
show: {
type: Boolean,
default: false
},
positionId: {
type: Number,
default: null
}
},
data() {
return {
categoryOptions: [{
value: 0,
label: '主单'
}, {
value: 1,
label: '反单'
}],
typeOptions: [{
value: 'LIMIT',
label: '限价'
}, {
value: 'MARKET',
label: '市价'
}, {
value: 'STOP',
label: '限价止损'
}, {
value: 'TAKE_PROFIT',
label: '限价止盈'
}, {
value: 'STOP_MARKET',
label: '市价止损'
}, {
value: 'TAKE_PROFIT_MARKET',
label: '市价止盈'
}, {
value: 'LIQUIDATION',
label: '爆仓'
}],
positionSideOptions: [{
value: 'LONG',
label: '多'
}, {
value: 'SHORT',
label: '空'
}],
sideOptions: [{
value: 'SELL',
label: '卖'
}, {
value: 'BUY',
label: '买'
}],
orderTypeOptions: [{
value: 0,
label: '主单'
}, {
value: 1,
label: '止盈单'
}, {
value: 2,
label: '止损单'
}, {
value: 3,
label: '减仓单'
}, {
value: 4,
label: '平仓单'
}],
statusOptions: [{
value: 1,
label: '待下单'
}, {
value: 2,
label: '已下单'
}, {
value: 3,
label: '已成交'
}, {
value: 6,
label: '已取消'
}, {
value: 7,
label: '已过期'
}, {
value: 8,
label: '已失败'
}],
queryParams: {
pageIndex: 1,
pageSize: 10,
category: undefined,
type: undefined,
orderType: undefined,
status: undefined,
idOrder: 'desc'
},
total: 0,
loading: false,
lineReverseOrderList: []
}
},
methods: {
categoryFormat(scope) {
const category = this.categoryOptions.find(item => item.value === scope.row.category)
return category ? category.label : ''
},
typeFormat(scope) {
const type = this.typeOptions.find(item => item.value === scope.row.type)
return type ? type.label : ''
},
statusFormat(scope) {
const status = this.statusOptions.find(item => item.value === scope.row.status)
return status ? status.label : ''
},
orderTypeFormat(scope) {
const orderType = this.orderTypeOptions.find(item => item.value === scope.row.orderType)
return orderType ? orderType.label : ''
},
handleOpen() {
this.lineReverseOrderList = []
this.getList()
},
handleClose() {
this.$emit('update:show', false)
},
/** 搜索按钮操作 */
handleQuery() {
this.queryParams.pageIndex = 1
this.getList()
},
/** 重置按钮操作 */
resetQuery() {
this.resetForm('queryForm')
this.handleQuery()
},
/** 查询参数列表 */
getList() {
this.loading = true
const queryData = { positionId: this.positionId, ...this.queryParams }
console.log('queryData', queryData)
if (queryData.category === undefined || queryData.category === null || queryData.category === '') {
queryData.category = -1
} else {
queryData.category = Number(queryData.category)
}
listLineReverseOrder(this.addDateRange(queryData, this.dateRange)).then(response => {
this.lineReverseOrderList = response.data.list
this.total = response.data.count
this.loading = false
}
)
},
tableRowClassName({ row, rowIndex }) {
if (row.category === 0) {
return 'main-order'
}
return ''
}
}
}
</script>
<style scoped>
::v-deep .el-table__body tr.main-order {
background-color: oldlace !important;
}
</style>

View File

@ -0,0 +1,273 @@
<template>
<BasicLayout>
<template #wrapper>
<el-card class="box-card">
<el-table v-loading="loading" :data="lineReverseSettingList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" /><el-table-column
label="反单下单类型"
align="center"
prop="reverseOrderType"
:show-overflow-tooltip="true"
>
<template slot-scope="scope">{{ reverseOrderTypeFormat(scope.row.reverseOrderType) }}</template>
</el-table-column>
<el-table-column
label="溢价百分比"
align="center"
prop="reversePremiumRatio"
:show-overflow-tooltip="true"
>
<template slot-scope="scope">{{ scope.row.reverseOrderType==='LIMIT'? scope.row.reversePremiumRatio :"-" }}</template>
</el-table-column>
<el-table-column label="止损百分比" align="center" prop="stopLossRatio" />
<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:lineReverseSetting:edit']"
size="mini"
type="text"
icon="el-icon-edit"
>修改
</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="100px">
<el-form-item label="下单类型" prop="reverseOrderType">
<el-radio-group v-model="form.reverseOrderType">
<el-radio
v-for="dict in reverseOrderTypeOptions"
:key="dict.value"
:label="dict.value"
>{{ dict.label }}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item v-if="form.reverseOrderType==='LIMIT'" label="溢价百分比" prop="reversePremiumRatio">
<el-input
v-model="form.reversePremiumRatio"
placeholder="溢价百分比"
/>
</el-form-item>
<el-form-item label="止损百分比" prop="stopLossRatio">
<el-input v-model="form.stopLossRatio" 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 { addLineReverseSetting, delLineReverseSetting, getLineReverseSetting, listLineReverseSetting, updateLineReverseSetting } from '@/api/admin/line-reverse-setting'
export default {
name: 'LineReverseSetting',
components: {
},
data() {
return {
// 遮罩层
loading: true,
// 选中数组
ids: [],
// 非单个禁用
single: true,
// 非多个禁用
multiple: true,
// 总条数
total: 0,
// 弹出层标题
title: '',
// 是否显示弹出层
open: false,
isEdit: false,
// 类型数据字典
reverseOrderTypeOptions: [{
label: '限价',
value: 'LIMIT'
}, {
label: '市价',
value: 'MARKET'
}],
lineReverseSettingList: [],
// 关系表类型
// 查询参数
queryParams: {
pageIndex: 1,
pageSize: 10
},
// 表单参数
form: {
},
// 表单校验
rules: {
reverseOrderType: [
{ required: true, message: '请选择下单类型', trigger: 'blur' }
],
reversePremiumRatio: [
{ required: true, message: '请输入溢价百分比', trigger: 'blur' }
]
}
}
},
created() {
this.getList()
},
methods: {
/** 查询参数列表 */
getList() {
this.loading = true
listLineReverseSetting(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
this.lineReverseSettingList = response.data.list
this.total = response.data.count
this.loading = false
}
)
},
// 取消按钮
cancel() {
this.open = false
this.reset()
},
// 表单重置
reset() {
this.form = {
id: undefined,
reverseOrderType: undefined,
reversePremiumRatio: undefined
}
this.resetForm('form')
},
getImgList: function() {
this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl
},
reverseOrderTypeFormat(data) {
const orderType = this.reverseOrderTypeOptions.find(item => item.value === data)
return orderType ? orderType.label : ''
},
fileClose: function() {
this.fileOpen = false
},
// 关系
// 文件
/** 搜索按钮操作 */
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
getLineReverseSetting(id).then(response => {
this.form = response.data
this.open = true
this.title = '修改反单下单配置'
this.isEdit = true
})
},
/** 提交按钮 */
submitForm: function() {
this.$refs['form'].validate(valid => {
if (valid) {
this.form.stopLossRatio = this.form.stopLossRatio ? Number(this.form.stopLossRatio) : undefined
if (this.form.id !== undefined) {
updateLineReverseSetting(this.form).then(response => {
if (response.code === 200) {
this.msgSuccess(response.msg)
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
})
} else {
addLineReverseSetting(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 delLineReverseSetting({ '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>

View File

@ -0,0 +1,416 @@
<template>
<BasicLayout>
<template #wrapper>
<el-card class="box-card">
<el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px">
<el-form-item label="涨跌方向" prop="direction">
<el-select v-model="queryParams.direction" placeholder="请选择涨跌方向" clearable>
<el-option
v-for="item in directionOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="比较类型" prop="compareType">
<el-select v-model="queryParams.compareType" placeholder="请选择比较类型" clearable>
<el-option
v-for="item in compareTypeOptions"
:key="item.value"
:label="item.description"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="策略名称" prop="name" />
<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:lineStrategyTemplate: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:lineStrategyTemplate: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:lineStrategyTemplate: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="lineStrategyTemplateList"
@selection-change="handleSelectionChange"
>
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="策略名称" align="center" prop="name" />
<el-table-column label="涨跌方向" align="center" prop="direction" :show-overflow-tooltip="true">
<template slot-scope="scope">
{{ directionFormat(scope.row.direction) }}
</template>
</el-table-column>
<el-table-column label="涨跌点数" align="center" prop="percentag" :show-overflow-tooltip="true" />
<el-table-column label="比较类型" align="center" prop="compareType" :show-overflow-tooltip="true">
<template slot-scope="scope">
{{ compareTypeFormat(scope.row.compareType) }}
</template>
</el-table-column>
<el-table-column
label="时间段(分)"
align="center"
prop="timeSlotStart"
:show-overflow-tooltip="true"
/>
<!-- <el-table-column label="时间断截至(分)" align="center" prop="timeSlotEnd" :show-overflow-tooltip="true" /> -->
<el-table-column
label="创建时间"
align="center"
prop="createdAt"
width="150"
:show-overflow-tooltip="true"
>
<template #default="{ row }">{{ parseTime(row.createdAt) }}</template>
</el-table-column>
<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:lineStrategyTemplate: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:lineStrategyTemplate: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="120px">
<el-form-item label="策略名称" prop="name">
<el-input v-model="form.name" placeholder="策略名称" maxlength="50" show-word-limit />
</el-form-item>
<el-form-item label="涨跌方向" prop="direction">
<el-radio-group v-model="form.direction">
<el-radio v-for="dict in directionOptions" :key="dict.value" :label="dict.value">{{
dict.label
}}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="涨跌点数" prop="percentag">
<el-input v-model="form.percentag" placeholder="涨跌点数" />
</el-form-item>
<el-form-item label="比较类型" prop="compareType">
<el-select v-model="form.compareType" placeholder="请选择">
<el-option
v-for="dict in compareTypeOptions"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="时间段(分)" prop="timeSlotStart">
<el-input v-model.number="form.timeSlotStart" placeholder="时间段(分)" />
</el-form-item>
<!-- <el-form-item label="时间断截至(分)" prop="timeSlotEnd">
<el-input v-model.number="form.timeSlotEnd" 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 { addLineStrategyTemplate, delLineStrategyTemplate, getLineStrategyTemplate, listLineStrategyTemplate, updateLineStrategyTemplate } from '@/api/admin/line-strategy-template'
export default {
name: 'LineStrategyTemplate',
components: {
},
data() {
return {
// 遮罩层
loading: true,
// 选中数组
ids: [],
// 非单个禁用
single: true,
// 非多个禁用
multiple: true,
// 总条数
total: 0,
// 弹出层标题
title: '',
// 是否显示弹出层
open: false,
isEdit: false,
// 类型数据字典
typeOptions: [],
lineStrategyTemplateList: [],
// 关系表类型
// 查询参数
queryParams: {
pageIndex: 1,
pageSize: 10,
direction: undefined,
percentag: undefined,
compareType: undefined,
idOrder: 'desc'
},
directionOptions: [
{
value: 1,
label: '涨'
}, {
value: 2,
label: '跌'
}
],
compareTypeOptions: [{
value: 1,
label: '>',
description: '大于'
}, {
value: 2,
label: '>=',
description: '大于等于'
},
// {
// value: 3,
// label: '<',
// description: '小于'
// }, {
// value: 4,
// label: '<=',
// description: '小于等于'
// },
{
value: 5,
label: '=',
description: '等于'
}],
// 表单参数
form: {
},
// 表单校验
rules: {
direction: [{ required: true, message: '涨跌方向不能为空', trigger: 'blur' }],
compareType: [{ required: true, message: '比较类型不能为空', trigger: 'blur' }],
percentag: [{ required: true, message: '涨跌点数不能为空', trigger: 'blur' }],
timeSlotStart: [{ required: true, message: '时间段开始', trigger: 'blur' }],
timeSlotEnd: [{ required: true, message: '时间段截至', trigger: 'blur' }],
name: [{ required: true, message: '策略名称不能为空', trigger: 'blur' }]
}
}
},
created() {
this.getList()
},
methods: {
compareTypeFormat(compareType) {
const op = this.compareTypeOptions.find(x => x.value === compareType)
if (op && op.description) {
return op.description
}
},
directionFormat(direction) {
const op = this.directionOptions.find(x => x.value === direction)
if (op && op.label) {
return op.label
}
},
/** 查询参数列表 */
getList() {
this.loading = true
listLineStrategyTemplate(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
this.lineStrategyTemplateList = response.data.list
this.total = response.data.count
this.loading = false
}
)
},
// 取消按钮
cancel() {
this.open = false
this.reset()
},
// 表单重置
reset() {
this.form = {
id: undefined,
direction: 1,
percentag: undefined,
compareType: undefined,
timeSlotStart: undefined,
timeSlotEnd: undefined
}
this.resetForm('form')
},
getImgList: function() {
this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl
},
fileClose: function() {
this.fileOpen = false
},
// 关系
// 文件
/** 搜索按钮操作 */
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
getLineStrategyTemplate(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) {
updateLineStrategyTemplate(this.form).then(response => {
if (response.code === 200) {
this.msgSuccess(response.msg)
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
})
} else {
addLineStrategyTemplate(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 delLineStrategyTemplate({ '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>

View File

@ -206,7 +206,7 @@ export default {
pageSize: 10,
symbol: undefined,
type: undefined,
idOrder:"desc",
idOrder: 'desc'
},
// 表单参数
form: {

View File

@ -0,0 +1,330 @@
<template>
<BasicLayout>
<template #wrapper>
<el-card class="box-card">
<el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px">
<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 label="状态" prop="status">
<el-select v-model="queryParams.status" placeholder="请选择比较类型" clearable>
<el-option
v-for="item in statusOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</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:lineSymbolPrice: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:lineSymbolPrice: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:lineSymbolPrice: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="lineSymbolPriceList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="交易对" align="center" prop="symbol" :show-overflow-tooltip="true" />
<el-table-column label="状态" align="center" prop="status" :show-overflow-tooltip="true">
<template slot-scope="scope">{{ scope.row.status === 1 ? "已启用" : "禁用" }} </template>
</el-table-column>
<el-table-column
label="创建时间"
align="center"
prop="createdAt"
width="150"
:show-overflow-tooltip="true"
>
<template #default="{ row }">{{ parseTime(row.createdAt) }}</template>
</el-table-column>
<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:lineSymbolPrice: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:lineSymbolPrice: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="交易对" prop="symbol">
<el-input v-model="form.symbol" placeholder="交易对" />
</el-form-item>
<el-form-item label="状态" prop="status">
<el-radio-group v-model="form.status">
<el-radio :label="1">启用</el-radio>
<el-radio :label="2">禁用</el-radio>
</el-radio-group>
<!-- <el-select v-model="form.status" placeholder="请选择">
<el-option v-for="dict in statusOptions" :key="dict.value" :label="dict.label"
:value="dict.value" />
</el-select> -->
</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 { addLineSymbolPrice, delLineSymbolPrice, getLineSymbolPrice, listLineSymbolPrice, updateLineSymbolPrice } from '@/api/admin/line-symbol-price'
export default {
name: 'LineSymbolPrice',
components: {
},
data() {
return {
// 遮罩层
loading: true,
// 选中数组
ids: [],
// 非单个禁用
single: true,
// 非多个禁用
multiple: true,
// 总条数
total: 0,
// 弹出层标题
title: '',
// 是否显示弹出层
open: false,
isEdit: false,
// 类型数据字典
typeOptions: [],
lineSymbolPriceList: [],
statusOptions: [{
label: '启用',
value: 1
}, {
label: '禁用',
value: 2
}],
// 关系表类型
// 查询参数
queryParams: {
pageIndex: 1,
pageSize: 10,
symbol: undefined,
status: undefined,
idOrder: 'desc'
},
// 表单参数
form: {
},
// 表单校验
rules: {
symbol: [{ required: true, message: '交易对不能为空', trigger: 'blur' }],
status: [{ required: true, message: '状态不能为空', trigger: 'blur' }]
}
}
},
created() {
this.getList()
},
methods: {
/** 查询参数列表 */
getList() {
this.loading = true
listLineSymbolPrice(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
this.lineSymbolPriceList = response.data.list
this.total = response.data.count
this.loading = false
}
)
},
// 取消按钮
cancel() {
this.open = false
this.reset()
},
// 表单重置
reset() {
this.form = {
id: undefined,
symbol: undefined,
status: 1
}
this.resetForm('form')
},
getImgList: function() {
this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl
},
fileClose: function() {
this.fileOpen = false
},
// 关系
// 文件
/** 搜索按钮操作 */
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
getLineSymbolPrice(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) {
updateLineSymbolPrice(this.form).then(response => {
if (response.code === 200) {
this.msgSuccess(response.msg)
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
})
} else {
addLineSymbolPrice(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 delLineSymbolPrice({ '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>

View File

@ -19,6 +19,11 @@
align="center"
prop="reducePremium"
/>
<el-table-column
label="减仓策略提前触发百分比"
align="center"
prop="reduceEarlyTriggerPercent"
/>
<!-- <el-table-column
label="主账号加仓溢价百分比"
align="center"
@ -143,6 +148,9 @@
<el-form-item label="限价减仓溢价" prop="reducePremium">
<el-input v-model="form.reducePremium" placeholder="限价减仓溢价" />
</el-form-item>
<el-form-item label="减仓策略提前触发百分比" prop="reduceEarlyTriggerPercent">
<el-input v-model="form.reduceEarlyTriggerPercent" placeholder="减仓策略提前触发百分比" />
</el-form-item>
<!-- <el-form-item label="主账号加仓溢价百分比" prop="scaleOrderTypeARate">
<el-input v-model="form.scaleOrderTypeARate" placeholder="主账号限价加仓买入百分比" />
</el-form-item>
@ -221,7 +229,8 @@ export default {
rules: {
stopLossPremium: [{ required: true, message: '限价止损溢价不能为空', trigger: 'blur' }],
addPositionPremium: [{ required: true, message: '限价加仓溢价不能为空', trigger: 'blur' }],
reducePremium: [{ required: true, message: '限价减仓溢价不能为空', trigger: 'blur' }]
reducePremium: [{ required: true, message: '限价减仓溢价不能为空', trigger: 'blur' }],
reduceEarlyTriggerPercent: [{ required: true, message: '减仓策略提前触发百分比不能为空', trigger: 'blur' }]
}
}

View File

@ -21,13 +21,25 @@
</el-button>
</el-col> -->
<el-col :span="1.5">
<el-button v-permisaction="['admin:lineUser:edit']" type="success" icon="el-icon-edit" size="mini"
:disabled="single" @click="handleUpdate">修改
<el-button
v-permisaction="['admin:lineUser: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:lineUser:remove']" type="danger" icon="el-icon-delete" size="mini"
:disabled="multiple" @click="handleDelete">删除
<el-button
v-permisaction="['admin:lineUser:remove']"
type="danger"
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
>删除
</el-button>
</el-col>
</el-row>
@ -58,29 +70,57 @@
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-popconfirm v-if="scope.row.open_status===1" class="delete-popconfirm" title="确认要新资产吗?" confirm-button-text="更新"
@confirm="handleReload(scope.row)">
<el-popconfirm
v-if="scope.row.open_status===1"
class="delete-popconfirm"
title="确认要新资产吗?"
confirm-button-text="更新"
@confirm="handleReload(scope.row)"
>
<el-button slot="reference" size="mini" type="text" icon="el-icon-edit">更新资产
</el-button>
</el-popconfirm>
<el-popconfirm class="delete-popconfirm" title="确认要修改吗?" confirm-button-text="修改"
@confirm="handleUpdate(scope.row)">
<el-button slot="reference" v-permisaction="['admin:lineUser:edit']" size="mini" type="text"
icon="el-icon-edit">修改
<el-popconfirm
class="delete-popconfirm"
title="确认要修改吗?"
confirm-button-text="修改"
@confirm="handleUpdate(scope.row)"
>
<el-button
slot="reference"
v-permisaction="['admin:lineUser: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:lineUser:remove']" size="mini" type="text"
icon="el-icon-delete">删除
<el-popconfirm
class="delete-popconfirm"
title="确认要删除吗?"
confirm-button-text="删除"
@confirm="handleDelete(scope.row)"
>
<el-button
slot="reference"
v-permisaction="['admin:lineUser: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" />
<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">
@ -266,7 +306,7 @@ export default {
queryParams: {
pageIndex: 1,
pageSize: 10,
idOrder: "desc"
idOrder: 'desc'
},
// 表单参数
form: {

View File

@ -4,8 +4,12 @@
<template #wrapper>
<el-card class="box-card">
<el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px">
<el-form-item label="变更来源 (member_change_source)" prop="changeSource"><el-select v-model="queryParams.changeSource"
placeholder="用户余额变更记录变更来源 (member_change_source)" clearable size="small">
<el-form-item label="变更来源 (member_change_source)" prop="changeSource"><el-select
v-model="queryParams.changeSource"
placeholder="用户余额变更记录变更来源 (member_change_source)"
clearable
size="small"
>
<el-option
v-for="dict in changeSourceOptions"
:key="dict.value"
@ -14,8 +18,13 @@
/>
</el-select>
</el-form-item>
<el-form-item label="变更类别 1-收入 2-支出" prop="changeType"><el-input v-model="queryParams.changeType" placeholder="请输入变更类别 1-收入 2-支出" clearable
size="small" @keyup.enter.native="handleQuery"/>
<el-form-item label="变更类别 1-收入 2-支出" prop="changeType"><el-input
v-model="queryParams.changeType"
placeholder="请输入变更类别 1-收入 2-支出"
clearable
size="small"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item>
@ -60,16 +69,37 @@
</el-row>
<el-table v-loading="loading" :data="memberBalanceLogList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center"/><el-table-column label="变更来源 (member_change_source)" align="center" prop="changeSource"
:formatter="changeSourceFormat" width="100">
<el-table-column type="selection" width="55" align="center" /><el-table-column
label="变更来源 (member_change_source)"
align="center"
prop="changeSource"
:formatter="changeSourceFormat"
width="100"
>
<template slot-scope="scope">
{{ changeSourceFormat(scope.row) }}
</template>
</el-table-column><el-table-column label="变更类别 1-收入 2-支出" align="center" prop="changeType"
:show-overflow-tooltip="true"/><el-table-column label="变更金额" align="center" prop="amount"
:show-overflow-tooltip="true"/><el-table-column label="变更前余额" align="center" prop="balanceBefore"
:show-overflow-tooltip="true"/><el-table-column label="变更后余额" align="center" prop="balanceAfter"
:show-overflow-tooltip="true"/>
</el-table-column><el-table-column
label="变更类别 1-收入 2-支出"
align="center"
prop="changeType"
:show-overflow-tooltip="true"
/><el-table-column
label="变更金额"
align="center"
prop="amount"
:show-overflow-tooltip="true"
/><el-table-column
label="变更前余额"
align="center"
prop="balanceBefore"
:show-overflow-tooltip="true"
/><el-table-column
label="变更后余额"
align="center"
prop="balanceAfter"
:show-overflow-tooltip="true"
/>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-popconfirm
@ -119,7 +149,9 @@
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="用户id" prop="userId">
<el-input v-model="form.userId" placeholder="用户id"
<el-input
v-model="form.userId"
placeholder="用户id"
/>
</el-form-item>
<el-form-item label="变更来源 (member_change_source)" prop="changeSource">
@ -132,19 +164,27 @@
</el-radio-group>
</el-form-item>
<el-form-item label="变更类别 1-收入 2-支出" prop="changeType">
<el-input v-model="form.changeType" placeholder="变更类别 1-收入 2-支出"
<el-input
v-model="form.changeType"
placeholder="变更类别 1-收入 2-支出"
/>
</el-form-item>
<el-form-item label="变更金额" prop="amount">
<el-input v-model="form.amount" placeholder="变更金额"
<el-input
v-model="form.amount"
placeholder="变更金额"
/>
</el-form-item>
<el-form-item label="变更前余额" prop="balanceBefore">
<el-input v-model="form.balanceBefore" placeholder="变更前余额"
<el-input
v-model="form.balanceBefore"
placeholder="变更前余额"
/>
</el-form-item>
<el-form-item label="变更后余额" prop="balanceAfter">
<el-input v-model="form.balanceAfter" placeholder="变更后余额"
<el-input
v-model="form.balanceAfter"
placeholder="变更后余额"
/>
</el-form-item>
<el-form-item label="备注" prop="remark">
@ -152,8 +192,8 @@
v-model="form.remark"
type="textarea"
:rows="2"
placeholder="请输入内容">
</el-input>
placeholder="请输入内容"
/>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
@ -201,7 +241,7 @@
pageIndex: 1,
pageSize: 10,
changeSource: undefined,
changeType:undefined,
changeType: undefined
},
// 表单参数
@ -209,7 +249,7 @@
},
// 表单校验
rules: { changeSource: [{ required: true, message: '变更来源 (member_change_source)不能为空', trigger: 'blur' }],
changeType: [ {required: true, message: '变更类别 1-收入 2-支出不能为空', trigger: 'blur'} ],
changeType: [{ required: true, message: '变更类别 1-收入 2-支出不能为空', trigger: 'blur' }]
}
}
},
@ -246,7 +286,7 @@
amount: undefined,
balanceBefore: undefined,
balanceAfter: undefined,
remark: undefined,
remark: undefined
}
this.resetForm('form')
},

View File

@ -97,15 +97,21 @@
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="总余额" prop="totalAmont">
<el-input v-model="form.totalAmont" placeholder="总余额"
<el-input
v-model="form.totalAmont"
placeholder="总余额"
/>
</el-form-item>
<el-form-item label="可用余额" prop="freeAmount">
<el-input v-model="form.freeAmount" placeholder="可用余额"
<el-input
v-model="form.freeAmount"
placeholder="可用余额"
/>
</el-form-item>
<el-form-item label="冻结金额" prop="frozenAmount">
<el-input v-model="form.frozenAmount" placeholder="冻结金额"
<el-input
v-model="form.frozenAmount"
placeholder="冻结金额"
/>
</el-form-item>
</el-form>
@ -152,7 +158,7 @@
// 查询参数
queryParams: {
pageIndex: 1,
pageSize: 10,
pageSize: 10
},
// 表单参数
@ -188,7 +194,7 @@
id: undefined,
totalAmont: undefined,
freeAmount: undefined,
frozenAmount: undefined,
frozenAmount: undefined
}
this.resetForm('form')
},

View File

@ -33,8 +33,14 @@
</el-button>
</el-col> -->
<el-col :span="1.5">
<el-button v-permisaction="['admin:memberRenwaLog:remove']" type="danger" icon="el-icon-delete"
size="mini" :disabled="multiple" @click="handleDelete">删除
<el-button
v-permisaction="['admin:memberRenwaLog:remove']"
type="danger"
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
>删除
</el-button>
</el-col>
</el-row>
@ -43,17 +49,38 @@
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="昵称" align="center" prop="nickName" :show-overflow-tooltip="true" />
<el-table-column label="续期套餐名称" align="center" prop="renwalName"
:show-overflow-tooltip="true" /><el-table-column label="续期时长(天数)" align="center"
prop="renwalDuration" :show-overflow-tooltip="true" /><el-table-column label="订单状态"
align="center" prop="status" :formatter="statusFormat" width="100">
<el-table-column
label="续期套餐名称"
align="center"
prop="renwalName"
:show-overflow-tooltip="true"
/><el-table-column
label="续期时长(天数)"
align="center"
prop="renwalDuration"
:show-overflow-tooltip="true"
/><el-table-column
label="订单状态"
align="center"
prop="status"
:formatter="statusFormat"
width="100"
>
<template slot-scope="scope">
{{ statusFormat(scope.row.status) }}
</template>
</el-table-column><el-table-column label="应付金额" align="center" prop="payableAmount"
:show-overflow-tooltip="true" />
<el-table-column label="实付金额" align="center" prop="actualPaymentAmount"
:show-overflow-tooltip="true" />
</el-table-column><el-table-column
label="应付金额"
align="center"
prop="payableAmount"
:show-overflow-tooltip="true"
/>
<el-table-column
label="实付金额"
align="center"
prop="actualPaymentAmount"
:show-overflow-tooltip="true"
/>
<el-table-column label="付款地址" align="center" prop="fromAddress" :show-overflow-tooltip="true" />
<el-table-column label="代币" align="center" prop="coin" :show-overflow-tooltip="true" />
@ -75,18 +102,33 @@
type="text" icon="el-icon-edit">修改
</el-button>
</el-popconfirm> -->
<el-popconfirm v-if="scope.row.status == 'expired'" class="delete-popconfirm" title="确认要删除吗?"
confirm-button-text="删除" @confirm="handleDelete(scope.row)">
<el-button slot="reference" v-permisaction="['admin:memberRenwaLog:remove']" size="mini"
type="text" icon="el-icon-delete">删除
<el-popconfirm
v-if="scope.row.status == 'expired'"
class="delete-popconfirm"
title="确认要删除吗?"
confirm-button-text="删除"
@confirm="handleDelete(scope.row)"
>
<el-button
slot="reference"
v-permisaction="['admin:memberRenwaLog: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" />
<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">
@ -118,8 +160,7 @@
<el-input v-model="form.coin" placeholder="代币" />
</el-form-item>
<el-form-item label="支付时间" prop="paymentTime">
<el-date-picker v-model="form.paymentTime" type="datetime" placeholder="选择日期">
</el-date-picker>
<el-date-picker v-model="form.paymentTime" type="datetime" placeholder="选择日期" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
@ -166,7 +207,7 @@ export default {
queryParams: {
pageIndex: 1,
pageSize: 10,
idOrder: "desc"
idOrder: 'desc'
},
// 表单参数
form: {
@ -210,7 +251,7 @@ export default {
actualPaymentAmount: undefined,
fromAddress: undefined,
coin: undefined,
paymentTime: undefined,
paymentTime: undefined
}
this.resetForm('form')
},

View File

@ -3,13 +3,26 @@
<template #wrapper>
<el-card class="box-card">
<el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px">
<el-form-item label="套餐名称" prop="packageName"><el-input v-model="queryParams.packageName"
placeholder="请输入套餐名称" clearable size="small" @keyup.enter.native="handleQuery" />
<el-form-item label="套餐名称" prop="packageName"><el-input
v-model="queryParams.packageName"
placeholder="请输入套餐名称"
clearable
size="small"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="套餐状态" prop="status"><el-select v-model="queryParams.status"
placeholder="会员套餐管理套餐状态" clearable size="small">
<el-option v-for="dict in statusOptions" :key="dict.value" :label="dict.label"
:value="dict.value" />
<el-form-item label="套餐状态" prop="status"><el-select
v-model="queryParams.status"
placeholder="会员套餐管理套餐状态"
clearable
size="small"
>
<el-option
v-for="dict in statusOptions"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
@ -21,18 +34,35 @@
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button v-permisaction="['admin:memberRenwalConfig:add']" type="primary" icon="el-icon-plus"
size="mini" @click="handleAdd">新增
<el-button
v-permisaction="['admin:memberRenwalConfig: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:memberRenwalConfig:edit']" type="success" icon="el-icon-edit"
size="mini" :disabled="single" @click="handleUpdate">修改
<el-button
v-permisaction="['admin:memberRenwalConfig: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:memberRenwalConfig:remove']" type="danger"
icon="el-icon-delete" size="mini" :disabled="multiple" @click="handleDelete">删除
<el-button
v-permisaction="['admin:memberRenwalConfig:remove']"
type="danger"
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
>删除
</el-button>
</el-col>
</el-row>
@ -41,20 +71,24 @@
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="套餐名称" align="center" prop="packageName" :show-overflow-tooltip="true" />
<el-table-column label="续期时间(天)" align="center" prop="durationDay" :show-overflow-tooltip="true" />
<el-table-column label="原始单价U" align="center" prop="originalPrice"
:show-overflow-tooltip="true" />
<el-table-column
label="原始单价U"
align="center"
prop="originalPrice"
:show-overflow-tooltip="true"
/>
<el-table-column label="折扣价格U" align="center" prop="discountPrice" :show-overflow-tooltip="true">
<template slot-scope="scope">
{{ scope.row.discountPrice > 0 ? scope.row.discountPrice : '' }}
</template>
</el-table-column>
<el-table-column label="排序" align="center" prop="sort"></el-table-column>
<el-table-column label="排序" align="center" prop="sort" />
<el-table-column label="是否可见" align="center" prop="isDefault">
<template slot-scope="scope">
{{ defaultFormat(scope.row.isVisible) }}
</template>
</el-table-column>
<el-table-column label="是否默认套餐" align="center" :defaultFormat="statusFormat" prop="isDefault">\
<el-table-column label="是否默认套餐" align="center" :default-format="statusFormat" prop="isDefault">\
<template slot-scope="scope">
{{ defaultFormat(scope.row.isDefault) }}
</template>
@ -66,24 +100,47 @@
</el-table-column>
<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:memberRenwalConfig:edit']"
size="mini" type="text" icon="el-icon-edit">修改
<el-popconfirm
class="delete-popconfirm"
title="确认要修改吗?"
confirm-button-text="修改"
@confirm="handleUpdate(scope.row)"
>
<el-button
slot="reference"
v-permisaction="['admin:memberRenwalConfig: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:memberRenwalConfig:remove']"
size="mini" type="text" icon="el-icon-delete">删除
<el-popconfirm
class="delete-popconfirm"
title="确认要删除吗?"
confirm-button-text="删除"
@confirm="handleDelete(scope.row)"
>
<el-button
slot="reference"
v-permisaction="['admin:memberRenwalConfig: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" />
<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">
@ -109,15 +166,21 @@
</el-form-item>
<el-form-item label="是否可见 " prop="isVisible">
<el-radio-group v-model="form.isVisible">
<el-radio v-for="dict in defaultOptions" :key="'default' + dict.value"
:label="dict.value">{{ dict.label
<el-radio
v-for="dict in defaultOptions"
:key="'default' + dict.value"
:label="dict.value"
>{{ dict.label
}}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="是否默认套餐 " prop="isDefault">
<el-radio-group v-model="form.isDefault">
<el-radio v-for="dict in defaultOptions" :key="'default' + dict.value"
:label="dict.value">{{ dict.label
<el-radio
v-for="dict in defaultOptions"
:key="'default' + dict.value"
:label="dict.value"
>{{ dict.label
}}</el-radio>
</el-radio-group>
</el-form-item>
@ -182,7 +245,7 @@ export default {
pageSize: 10,
packageName: undefined,
status: undefined,
sortOrder: "asc",
sortOrder: 'asc'
},
// 表单参数
form: {
@ -193,7 +256,7 @@ export default {
packageNameEn: [{ required: true, message: '套餐英文名称不能为空', trigger: 'blur' }],
status: [{ required: true, message: '套餐状态不能为空', trigger: 'blur' }],
durationDay: [{ required: true, message: '套餐时长不能为空', trigger: 'blur' }],
originalPrice: [{ required: true, message: '原价不能为空', trigger: 'blur' }],
originalPrice: [{ required: true, message: '原价不能为空', trigger: 'blur' }]
}
}
},
@ -231,7 +294,7 @@ export default {
isDefault: 1,
isVisible: 1,
sort: 0,
status: 'enable',
status: 'enable'
}
this.resetForm('form')
},
@ -245,13 +308,13 @@ export default {
return this.selectDictLabel(this.statusOptions, row.status)
},
defaultFormat(val) {
var label = ""
var label = ''
this.defaultOptions.forEach(element => {
if (element.value === val) {
label = element.label
}
});
})
return label
},

View File

@ -1,6 +1,11 @@
<template>
<el-dialog :title="title" :visible.sync="dialogVisible" width="500px" :close-on-click-modal="false"
@closed="closeDialog">
<el-dialog
:title="title"
:visible.sync="dialogVisible"
width="500px"
:close-on-click-modal="false"
@closed="closeDialog"
>
<el-form ref="form" :model="form" :rules="rules" label-width="90px">
<el-form-item label="网络名称" prop="networkName">
{{ form.networkName }}
@ -21,16 +26,22 @@
<el-form-item label="手续费" prop="fee">
{{ form.fee }}
</el-form-item>
<el-form-item v-if="form.status === 'pending' || form.status === 'approved'" label="审核状态"
prop="approveStatus">
<el-form-item
v-if="form.status === 'pending' || form.status === 'approved'"
label="审核状态"
prop="approveStatus"
>
<el-radio-group v-model="form.approveStatus">
<template v-if="form.status === 'pending'">
<el-radio v-for="(item, index) in options" :key="'option_' + index" :label="item.value">{{
item.label }}</el-radio>
</template>
<template v-else-if="form.status === 'approved'">
<el-radio v-for="(item, index) in confirmOptions" :key="'confirm_option_' + index"
:label="item.value">{{
<el-radio
v-for="(item, index) in confirmOptions"
:key="'confirm_option_' + index"
:label="item.value"
>{{
item.label }}</el-radio>
</template>
</el-radio-group>
@ -53,7 +64,7 @@
import { approve, confirm } from '@/api/admin/member-withdrawal-log'
export default {
name: 'approve',
name: 'Approve',
props: {
open: {
type: Boolean,
@ -61,21 +72,13 @@ export default {
},
title: {
type: String,
default: "提现审核"
default: '提现审核'
},
data: {
type: Object,
default: () => { }
}
},
watch: {
open(val) {
this.dialogVisible = val
},
data(val) {
this.form = { approveStatus: 1, ...val }
}
},
data() {
return {
dialogVisible: this.open,
@ -96,16 +99,24 @@ export default {
}],
confirmOptions: [
{
label: "已转账",
label: '已转账',
value: 1
},
{
label: "转账失败",
label: '转账失败',
value: 2
}
]
}
},
watch: {
open(val) {
this.dialogVisible = val
},
data(val) {
this.form = { approveStatus: 1, ...val }
}
},
methods: {
submitForm() {
this.loading = true
@ -122,7 +133,7 @@ export default {
})
} else if (this.form.status === 'approved') { // 确认提现
confirm({ id: this.form.id, confirmVal: this.form.approveStatus, remark: this.form.remark, hash: this.form.hash }).then(res => {
console.log("res", res)
console.log('res', res)
if (res.code === 200) {
this.msgSuccess(res.msg)
this.cancel()

View File

@ -3,13 +3,26 @@
<template #wrapper>
<el-card class="box-card">
<el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px">
<el-form-item label="网络名称" prop="networkName"><el-input v-model="queryParams.networkName"
placeholder="请输入网络名称" clearable size="small" @keyup.enter.native="handleQuery" />
<el-form-item label="网络名称" prop="networkName"><el-input
v-model="queryParams.networkName"
placeholder="请输入网络名称"
clearable
size="small"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="提现状态" prop="status"><el-select v-model="queryParams.status" placeholder="提现状态"
clearable size="small">
<el-option v-for="dict in statusOptions" :key="dict.value" :label="dict.label"
:value="dict.value" />
<el-form-item label="提现状态" prop="status"><el-select
v-model="queryParams.status"
placeholder="提现状态"
clearable
size="small"
>
<el-option
v-for="dict in statusOptions"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
@ -42,8 +55,14 @@
</el-button>
</el-col> -->
<el-col :span="1.5">
<el-button v-permisaction="['admin:memberWithdrawalLog:remove']" type="danger"
icon="el-icon-delete" size="mini" :disabled="multiple" @click="handleDelete">删除
<el-button
v-permisaction="['admin:memberWithdrawalLog:remove']"
type="danger"
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
>删除
</el-button>
</el-col>
</el-row>
@ -54,9 +73,17 @@
<el-table-column label="用户名" align="center" prop="userName" :show-overflow-tooltip="true" />
<el-table-column label="提现金额(U)" align="center" prop="amount" :show-overflow-tooltip="true" />
<el-table-column label="手续费" align="center" prop="fee"
:show-overflow-tooltip="true" /><el-table-column label="备注" align="center" prop="remark"
:show-overflow-tooltip="true" />
<el-table-column
label="手续费"
align="center"
prop="fee"
:show-overflow-tooltip="true"
/><el-table-column
label="备注"
align="center"
prop="remark"
:show-overflow-tooltip="true"
/>
<el-table-column label="提现状态" align="center" prop="status" :formatter="statusFormat" width="100">
<template slot-scope="scope">
@ -81,26 +108,48 @@
size="mini" type="text" icon="el-icon-edit">修改
</el-button>
</el-popconfirm> -->
<el-button v-permisaction="['admin:memberWithdrawalLog:approve']"
v-if="scope.row.status == 'pending'" @click="handleApprove(scope.row, '提现审核')"
size="mini" type="text">审核
<el-button
v-if="scope.row.status == 'pending'"
v-permisaction="['admin:memberWithdrawalLog:approve']"
size="mini"
type="text"
@click="handleApprove(scope.row, '提现审核')"
>审核
</el-button>
<el-button v-permisaction="['admin:memberWithdrawalLog:confirm']"
v-if="scope.row.status == 'approved'" @click="handleApprove(scope.row, '确认到账')"
size="mini" type="text">确认到账
<el-button
v-if="scope.row.status == 'approved'"
v-permisaction="['admin:memberWithdrawalLog:confirm']"
size="mini"
type="text"
@click="handleApprove(scope.row, '确认到账')"
>确认到账
</el-button>
<el-popconfirm class="delete-popconfirm" title="确认要删除吗?" confirm-button-text="删除"
@confirm="handleDelete(scope.row)">
<el-button slot="reference" v-permisaction="['admin:memberWithdrawalLog:remove']"
size="mini" type="text" icon="el-icon-delete">删除
<el-popconfirm
class="delete-popconfirm"
title="确认要删除吗?"
confirm-button-text="删除"
@confirm="handleDelete(scope.row)"
>
<el-button
slot="reference"
v-permisaction="['admin:memberWithdrawalLog: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" />
<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">
@ -122,8 +171,7 @@
<el-input v-model="form.status" placeholder="提现状态(member_withdrawal_status)" />
</el-form-item>
<el-form-item label="确认时间" prop="confirmTime">
<el-date-picker v-model="form.confirmTime" type="datetime" placeholder="选择日期">
</el-date-picker>
<el-date-picker v-model="form.confirmTime" type="datetime" placeholder="选择日期" />
</el-form-item>
<el-form-item label="手续费比例" prop="fee">
<el-input v-model="form.fee" placeholder="手续费比例" />
@ -138,7 +186,7 @@
</div>
</el-dialog>
</el-card>
<approve :open.sync="showApprove" :title="showApproveTitle" :data="approveData" @update:open="handleClose"></approve>
<approve :open.sync="showApprove" :title="showApproveTitle" :data="approveData" @update:open="handleClose" />
</template>
</BasicLayout>
</template>
@ -180,10 +228,10 @@ export default {
pageSize: 10,
networkName: undefined,
status: undefined,
idOrder: "desc"
idOrder: 'desc'
},
showApprove: false,
showApproveTitle: "",
showApproveTitle: '',
approveData: {},
// 表单参数
form: {
@ -191,7 +239,7 @@ export default {
// 表单校验
rules: {
networkName: [{ required: true, message: '网络名称不能为空', trigger: 'blur' }],
status: [{ required: true, message: '提现状态(member_withdrawal_status)不能为空', trigger: 'blur' }],
status: [{ required: true, message: '提现状态(member_withdrawal_status)不能为空', trigger: 'blur' }]
}
}
},
@ -229,7 +277,7 @@ export default {
status: undefined,
confirmTime: undefined,
fee: undefined,
remark: undefined,
remark: undefined
}
this.resetForm('form')
},

View File

@ -315,7 +315,8 @@ export default {
paths: undefined,
action: undefined,
parentId: undefined,
sort: undefined
sort: undefined,
type: 'BUS'
}
this.resetForm('form')
},