Compare commits
	
		
			14 Commits
		
	
	
		
			1069707953
			...
			dabb3e6ce6
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| dabb3e6ce6 | |||
| 3fe0558954 | |||
| a5e774e6f1 | |||
| ee5934973c | |||
| 3342cc220b | |||
| a686354f2e | |||
| 3cf626e60e | |||
| 63a5dfbdf3 | |||
| 06b3771f66 | |||
| 443778cf36 | |||
| 9d34d37c11 | |||
| f54cd7beaa | |||
| ea32ec317c | |||
| 9d4c6e5f6e | 
| @ -2,5 +2,5 @@ | ||||
| ENV = 'development' | ||||
|  | ||||
| # base api | ||||
| VUE_APP_BASE_API = 'http://192.168.1.11:6789' | ||||
| VUE_APP_BASE_API = 'http://192.168.2.102:6789' | ||||
|  | ||||
|  | ||||
							
								
								
									
										53
									
								
								src/api/admin/line-api-user-group.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								src/api/admin/line-api-user-group.js
									
									
									
									
									
										Normal 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 | ||||
|   }) | ||||
| } | ||||
| @ -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', | ||||
|  | ||||
							
								
								
									
										46
									
								
								src/api/admin/line-reduce-strategy.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								src/api/admin/line-reduce-strategy.js
									
									
									
									
									
										Normal 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 | ||||
|   }) | ||||
| } | ||||
|  | ||||
							
								
								
									
										46
									
								
								src/api/admin/line-strategy-template.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								src/api/admin/line-strategy-template.js
									
									
									
									
									
										Normal 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 | ||||
|   }) | ||||
| } | ||||
|  | ||||
| @ -2,54 +2,52 @@ import request from '@/utils/request' | ||||
|  | ||||
| // 查询LineSymbolBlack列表 | ||||
| export function listLineSymbolBlack(query) { | ||||
|     return request({ | ||||
|         url: '/api/v1/line-symbol-black', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/line-symbol-black', | ||||
|     method: 'get', | ||||
|     params: query | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 查询LineSymbolBlack详细 | ||||
| export function getLineSymbolBlack (id) { | ||||
|     return request({ | ||||
|         url: '/api/v1/line-symbol-black/' + id, | ||||
|         method: 'get' | ||||
|     }) | ||||
| export function getLineSymbolBlack(id) { | ||||
|   return request({ | ||||
|     url: '/api/v1/line-symbol-black/' + id, | ||||
|     method: 'get' | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| // 新增LineSymbolBlack | ||||
| export function addLineSymbolBlack(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/line-symbol-black', | ||||
|         method: 'post', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/line-symbol-black', | ||||
|     method: 'post', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 修改LineSymbolBlack | ||||
| export function updateLineSymbolBlack(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/line-symbol-black/'+data.id, | ||||
|         method: 'put', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/line-symbol-black/' + data.id, | ||||
|     method: 'put', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 删除LineSymbolBlack | ||||
| export function delLineSymbolBlack(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/line-symbol-black', | ||||
|         method: 'delete', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/line-symbol-black', | ||||
|     method: 'delete', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| //重新加载交易对 | ||||
| export function reloadSymbol(){ | ||||
|     return request({ | ||||
|         url: '/api/v1/line-symbol-black/reload-symbol', | ||||
|         method: 'get' | ||||
|     }) | ||||
| } | ||||
| // 重新加载交易对 | ||||
| export function reloadSymbol() { | ||||
|   return request({ | ||||
|     url: '/api/v1/line-symbol-black/reload-symbol', | ||||
|     method: 'get' | ||||
|   }) | ||||
| } | ||||
|  | ||||
							
								
								
									
										46
									
								
								src/api/admin/line-symbol-price.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								src/api/admin/line-symbol-price.js
									
									
									
									
									
										Normal 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 | ||||
|   }) | ||||
| } | ||||
|  | ||||
| @ -2,53 +2,52 @@ import request from '@/utils/request' | ||||
|  | ||||
| // 查询LineUser列表 | ||||
| export function listLineUser(query) { | ||||
|     return request({ | ||||
|         url: '/api/v1/line-user', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/line-user', | ||||
|     method: 'get', | ||||
|     params: query | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 查询LineUser详细 | ||||
| export function getLineUser (id) { | ||||
|     return request({ | ||||
|         url: '/api/v1/line-user/' + id, | ||||
|         method: 'get' | ||||
|     }) | ||||
| export function getLineUser(id) { | ||||
|   return request({ | ||||
|     url: '/api/v1/line-user/' + id, | ||||
|     method: 'get' | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| // 新增LineUser | ||||
| export function addLineUser(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/line-user', | ||||
|         method: 'post', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/line-user', | ||||
|     method: 'post', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 修改LineUser | ||||
| export function updateLineUser(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/line-user/'+data.id, | ||||
|         method: 'put', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/line-user/' + data.id, | ||||
|     method: 'put', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 删除LineUser | ||||
| export function delLineUser(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/line-user', | ||||
|         method: 'delete', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/line-user', | ||||
|     method: 'delete', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| export function reloadProperty(data){ | ||||
|     return request({ | ||||
|         url: '/api/v1/line-user/property', | ||||
|         method: 'put', | ||||
|         data: data | ||||
|     }) | ||||
| } | ||||
| export function reloadProperty(data) { | ||||
|   return request({ | ||||
|     url: '/api/v1/line-user/property', | ||||
|     method: 'put', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| @ -2,46 +2,45 @@ import request from '@/utils/request' | ||||
|  | ||||
| // 查询MemberBalanceLog列表 | ||||
| export function listMemberBalanceLog(query) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-balance-log', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-balance-log', | ||||
|     method: 'get', | ||||
|     params: query | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 查询MemberBalanceLog详细 | ||||
| export function getMemberBalanceLog (id) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-balance-log/' + id, | ||||
|         method: 'get' | ||||
|     }) | ||||
| export function getMemberBalanceLog(id) { | ||||
|   return request({ | ||||
|     url: '/api/v1/member-balance-log/' + id, | ||||
|     method: 'get' | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| // 新增MemberBalanceLog | ||||
| export function addMemberBalanceLog(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-balance-log', | ||||
|         method: 'post', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-balance-log', | ||||
|     method: 'post', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 修改MemberBalanceLog | ||||
| export function updateMemberBalanceLog(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-balance-log/'+data.id, | ||||
|         method: 'put', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-balance-log/' + data.id, | ||||
|     method: 'put', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 删除MemberBalanceLog | ||||
| export function delMemberBalanceLog(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-balance-log', | ||||
|         method: 'delete', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-balance-log', | ||||
|     method: 'delete', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -2,46 +2,45 @@ import request from '@/utils/request' | ||||
|  | ||||
| // 查询MemberBalance列表 | ||||
| export function listMemberBalance(query) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-balance', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-balance', | ||||
|     method: 'get', | ||||
|     params: query | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 查询MemberBalance详细 | ||||
| export function getMemberBalance (id) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-balance/' + id, | ||||
|         method: 'get' | ||||
|     }) | ||||
| export function getMemberBalance(id) { | ||||
|   return request({ | ||||
|     url: '/api/v1/member-balance/' + id, | ||||
|     method: 'get' | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| // 新增MemberBalance | ||||
| export function addMemberBalance(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-balance', | ||||
|         method: 'post', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-balance', | ||||
|     method: 'post', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 修改MemberBalance | ||||
| export function updateMemberBalance(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-balance/'+data.id, | ||||
|         method: 'put', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-balance/' + data.id, | ||||
|     method: 'put', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 删除MemberBalance | ||||
| export function delMemberBalance(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-balance', | ||||
|         method: 'delete', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-balance', | ||||
|     method: 'delete', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -2,46 +2,45 @@ import request from '@/utils/request' | ||||
|  | ||||
| // 查询MemberRenwaLog列表 | ||||
| export function listMemberRenwaLog(query) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-renwa-log', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-renwa-log', | ||||
|     method: 'get', | ||||
|     params: query | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 查询MemberRenwaLog详细 | ||||
| export function getMemberRenwaLog (id) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-renwa-log/' + id, | ||||
|         method: 'get' | ||||
|     }) | ||||
| export function getMemberRenwaLog(id) { | ||||
|   return request({ | ||||
|     url: '/api/v1/member-renwa-log/' + id, | ||||
|     method: 'get' | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| // 新增MemberRenwaLog | ||||
| export function addMemberRenwaLog(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-renwa-log', | ||||
|         method: 'post', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-renwa-log', | ||||
|     method: 'post', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 修改MemberRenwaLog | ||||
| export function updateMemberRenwaLog(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-renwa-log/'+data.id, | ||||
|         method: 'put', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-renwa-log/' + data.id, | ||||
|     method: 'put', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 删除MemberRenwaLog | ||||
| export function delMemberRenwaLog(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-renwa-log', | ||||
|         method: 'delete', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-renwa-log', | ||||
|     method: 'delete', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -2,46 +2,45 @@ import request from '@/utils/request' | ||||
|  | ||||
| // 查询MemberRenwalConfig列表 | ||||
| export function listMemberRenwalConfig(query) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-renwal-config', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-renwal-config', | ||||
|     method: 'get', | ||||
|     params: query | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 查询MemberRenwalConfig详细 | ||||
| export function getMemberRenwalConfig (id) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-renwal-config/' + id, | ||||
|         method: 'get' | ||||
|     }) | ||||
| export function getMemberRenwalConfig(id) { | ||||
|   return request({ | ||||
|     url: '/api/v1/member-renwal-config/' + id, | ||||
|     method: 'get' | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| // 新增MemberRenwalConfig | ||||
| export function addMemberRenwalConfig(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-renwal-config', | ||||
|         method: 'post', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-renwal-config', | ||||
|     method: 'post', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 修改MemberRenwalConfig | ||||
| export function updateMemberRenwalConfig(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-renwal-config/'+data.id, | ||||
|         method: 'put', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-renwal-config/' + data.id, | ||||
|     method: 'put', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 删除MemberRenwalConfig | ||||
| export function delMemberRenwalConfig(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-renwal-config', | ||||
|         method: 'delete', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-renwal-config', | ||||
|     method: 'delete', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -2,64 +2,63 @@ import request from '@/utils/request' | ||||
|  | ||||
| // 查询MemberWithdrawalLog列表 | ||||
| export function listMemberWithdrawalLog(query) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-withdrawal-log', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-withdrawal-log', | ||||
|     method: 'get', | ||||
|     params: query | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 查询MemberWithdrawalLog详细 | ||||
| export function getMemberWithdrawalLog (id) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-withdrawal-log/' + id, | ||||
|         method: 'get' | ||||
|     }) | ||||
| export function getMemberWithdrawalLog(id) { | ||||
|   return request({ | ||||
|     url: '/api/v1/member-withdrawal-log/' + id, | ||||
|     method: 'get' | ||||
|   }) | ||||
| } | ||||
|  | ||||
|  | ||||
| // 新增MemberWithdrawalLog | ||||
| export function addMemberWithdrawalLog(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-withdrawal-log', | ||||
|         method: 'post', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-withdrawal-log', | ||||
|     method: 'post', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 修改MemberWithdrawalLog | ||||
| export function updateMemberWithdrawalLog(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-withdrawal-log/'+data.id, | ||||
|         method: 'put', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-withdrawal-log/' + data.id, | ||||
|     method: 'put', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 删除MemberWithdrawalLog | ||||
| export function delMemberWithdrawalLog(data) { | ||||
|     return request({ | ||||
|         url: '/api/v1/member-withdrawal-log', | ||||
|         method: 'delete', | ||||
|         data: data | ||||
|     }) | ||||
|   return request({ | ||||
|     url: '/api/v1/member-withdrawal-log', | ||||
|     method: 'delete', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| //确认提现申请 | ||||
| // 确认提现申请 | ||||
|  | ||||
| export function approve(data){ | ||||
|     return request({ | ||||
|         url: '/api/v1/member-withdrawal-log/approve', | ||||
|         method: 'put', | ||||
|         data: data | ||||
|     }) | ||||
| export function approve(data) { | ||||
|   return request({ | ||||
|     url: '/api/v1/member-withdrawal-log/approve', | ||||
|     method: 'put', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| //到账提现申请 | ||||
| export function confirm(data){ | ||||
|     return request({ | ||||
|         url: '/api/v1/member-withdrawal-log/confirm', | ||||
|         method: 'put', | ||||
|         data: data | ||||
|     }) | ||||
| } | ||||
| // 到账提现申请 | ||||
| export function confirm(data) { | ||||
|   return request({ | ||||
|     url: '/api/v1/member-withdrawal-log/confirm', | ||||
|     method: 'put', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| @ -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"> | ||||
| @ -82,20 +119,30 @@ | ||||
|             <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> | ||||
|               </el-radio-group> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="备注" prop="remark"> | ||||
|               <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> | ||||
| @ -255,10 +302,10 @@ export default { | ||||
|       }) | ||||
|     }, | ||||
|     /** 提交按钮 */ | ||||
|     submitForm: function () { | ||||
|     submitForm: function() { | ||||
|       this.$refs['form'].validate(valid => { | ||||
|         if (valid) { | ||||
|           console.log('form',this.form) | ||||
|           console.log('form', this.form) | ||||
|           this.form.status = parseInt(this.form.status) | ||||
|           if (this.form.dictCode !== undefined) { | ||||
|             updateData(this.form).then(response => { | ||||
| @ -291,7 +338,7 @@ export default { | ||||
|         confirmButtonText: '确定', | ||||
|         cancelButtonText: '取消', | ||||
|         type: 'warning' | ||||
|       }).then(function () { | ||||
|       }).then(function() { | ||||
|         return delData({ 'ids': dictCodes }) | ||||
|       }).then((response) => { | ||||
|         if (response.code === 200) { | ||||
| @ -301,7 +348,7 @@ export default { | ||||
|         } else { | ||||
|           this.msgError(response.msg) | ||||
|         } | ||||
|       }).catch(function () { }) | ||||
|       }).catch(function() { }) | ||||
|     }, | ||||
|     /** 导出按钮操作 */ | ||||
|     handleExport() { | ||||
| @ -310,14 +357,14 @@ export default { | ||||
|         confirmButtonText: '确定', | ||||
|         cancelButtonText: '取消', | ||||
|         type: 'warning' | ||||
|       }).then(function () { | ||||
|       }).then(function() { | ||||
|         return exportData(queryParams) | ||||
|       }).then(response => { | ||||
|         this.download(response.msg) | ||||
|       }).catch(function () { }) | ||||
|       }).catch(function() { }) | ||||
|     }, | ||||
|     addLuanguage() { | ||||
|       this.form.languageData.push({ k: "", v: "" }) | ||||
|       this.form.languageData.push({ k: '', v: '' }) | ||||
|     }, | ||||
|     luanguageDel(index) { | ||||
|       if (this.form.languageData) { | ||||
|  | ||||
							
								
								
									
										367
									
								
								src/views/admin/line-api-user-group/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										367
									
								
								src/views/admin/line-api-user-group/index.vue
									
									
									
									
									
										Normal 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> | ||||
| @ -97,14 +97,14 @@ | ||||
|           > | ||||
|             <template #default="{row}">{{ ['现货','合约','现货合约'][row.affiliation-1] }}</template> | ||||
|           </el-table-column> --> | ||||
|           <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> --> | ||||
|           <!-- <el-table-column | ||||
|             label="允许下单的方向" | ||||
|             align="center" | ||||
| @ -113,7 +113,7 @@ | ||||
|           > | ||||
|             <template #default="{row}">{{ ['多','空','多空'][row.site-1] }}</template> | ||||
|           </el-table-column> --> | ||||
|           <el-table-column | ||||
|           <!-- <el-table-column | ||||
|             label="从属关系" | ||||
|             align="center" | ||||
|             prop="subordinate" | ||||
| @ -124,7 +124,8 @@ | ||||
|             <template slot-scope="scope"> | ||||
|               {{ groupIdFormat(scope.row) }} | ||||
|             </template> | ||||
|           </el-table-column><el-table-column | ||||
|           </el-table-column> --> | ||||
|           <el-table-column | ||||
|             label="开启状态" | ||||
|             align="center" | ||||
|             prop="openStatus" | ||||
| @ -300,7 +301,7 @@ | ||||
| import { addLineApiUser, delLineApiUser, getLineApiUser, listLineApiUser, updateLineApiUser } from '@/api/admin/line-api-user' | ||||
|  | ||||
| import { listLineUser } from '@/api/admin/line-user' | ||||
| import { listLineApiGroup } from '@/api/admin/line-api-group' | ||||
| // import { listLineApiGroup } from '@/api/admin/line-api-group' | ||||
| export default { | ||||
|   name: 'LineApiUser', | ||||
|   components: { | ||||
| @ -349,7 +350,7 @@ export default { | ||||
|   created() { | ||||
|     this.getList() | ||||
|     this.getLineUserItems() | ||||
|     this.getLineApiGroupItems() | ||||
|     // this.getLineApiGroupItems() | ||||
|     // 获取交易所字典数据 | ||||
|     this.getDicts('exchange_type').then(response => { | ||||
|       this.exchangeTypes = response.data | ||||
| @ -414,11 +415,11 @@ export default { | ||||
|         this.userIdOptions = this.setItems(res, 'id', 'username') | ||||
|       }) | ||||
|     }, | ||||
|     getLineApiGroupItems() { | ||||
|       this.getItems(listLineApiGroup, undefined).then(res => { | ||||
|         this.groupIdOptions = this.setItems(res, 'id', 'groupName') | ||||
|       }) | ||||
|     }, | ||||
|     // getLineApiGroupItems() { | ||||
|     //   this.getItems(listLineApiGroup, undefined).then(res => { | ||||
|     //     this.groupIdOptions = this.setItems(res, 'id', 'groupName') | ||||
|     //   }) | ||||
|     // }, | ||||
|     // 文件 | ||||
|     /** 搜索按钮操作 */ | ||||
|     handleQuery() { | ||||
|  | ||||
| @ -1,79 +1,119 @@ | ||||
| <template> | ||||
|     <BasicLayout> | ||||
|         <template #wrapper> | ||||
|             <el-card class="box-card"> | ||||
|                 <el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px"> | ||||
|   <BasicLayout> | ||||
|     <template #wrapper> | ||||
|       <el-card class="box-card"> | ||||
|         <el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px"> | ||||
|  | ||||
|                     <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-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: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> | ||||
|                     </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> | ||||
|                     </el-col> | ||||
|                 </el-row> | ||||
|         <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> | ||||
|           </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> | ||||
|           </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> | ||||
|           </el-col> | ||||
|         </el-row> | ||||
|  | ||||
|                 <el-table v-loading="loading" :data="lineCoinnetworkList" @selection-change="handleSelectionChange"> | ||||
|                     <el-table-column type="selection" width="55" align="center" /> | ||||
|                     <el-table-column label="网络名称" prop="networkName" align="center" /> | ||||
|                     <el-table-column label="最小提现金额" prop="minWithdrawal" align="center" /> | ||||
|                     <el-table-column label="手续费" prop="fee" align="center" /> | ||||
|                     <el-table-column label="状态" prop="status" align="center"> | ||||
|                         <template slot-scope="scope"> | ||||
|                             {{ scope.row.status == 1 ? '启用' : '禁用' }} | ||||
|                         </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: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-button> | ||||
|                             </el-popconfirm> | ||||
|                         </template> | ||||
|                     </el-table-column> | ||||
|                 </el-table> | ||||
|         <el-table v-loading="loading" :data="lineCoinnetworkList" @selection-change="handleSelectionChange"> | ||||
|           <el-table-column type="selection" width="55" align="center" /> | ||||
|           <el-table-column label="网络名称" prop="networkName" align="center" /> | ||||
|           <el-table-column label="最小提现金额" prop="minWithdrawal" align="center" /> | ||||
|           <el-table-column label="手续费" prop="fee" align="center" /> | ||||
|           <el-table-column label="状态" prop="status" align="center"> | ||||
|             <template slot-scope="scope"> | ||||
|               {{ scope.row.status == 1 ? '启用' : '禁用' }} | ||||
|             </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: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-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"> | ||||
|                     <el-form ref="form" :model="form" :rules="rules" label-width="120px"> | ||||
|         <!-- 添加或修改对话框 --> | ||||
|         <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="networkName"> | ||||
|                             <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-form-item> | ||||
|                         <!-- <el-form-item label="网络token名称" prop="tokenName"> | ||||
|             <el-form-item label="网络名称" prop="networkName"> | ||||
|               <el-input v-model="form.networkName" placeholder="网络名称" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="最小提现金额" prop="minWithdrawal"> | ||||
|               <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名称" | ||||
|                                                       /> | ||||
|                                     </el-form-item> --> | ||||
|                         <!-- <el-form-item label="充值区块确认数" prop="arrivalNum"> | ||||
|             <!-- <el-form-item label="充值区块确认数" prop="arrivalNum"> | ||||
|                                         <el-input v-model="form.arrivalNum" placeholder="充值区块确认数" | ||||
|                                                       /> | ||||
|                                     </el-form-item> | ||||
| @ -85,202 +125,206 @@ | ||||
|                                         <el-input v-model="form.unlockTime" placeholder="提现确认平均时间,单位分钟" | ||||
|                                                       /> | ||||
|                                     </el-form-item> --> | ||||
|                         <el-form-item label="手续费(百分比)" prop="fee"> | ||||
|                             <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-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> | ||||
|             <el-form-item label="手续费(百分比)" prop="fee"> | ||||
|               <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-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 { addLineCoinnetwork, delLineCoinnetwork, getLineCoinnetwork, listLineCoinnetwork, updateLineCoinnetwork } from '@/api/admin/line-coinnetwork' | ||||
|  | ||||
| export default { | ||||
|     name: 'LineCoinnetwork', | ||||
|     components: { | ||||
|     }, | ||||
|     data() { | ||||
|         return { | ||||
|             // 遮罩层 | ||||
|             loading: true, | ||||
|             // 选中数组 | ||||
|             ids: [], | ||||
|             // 非单个禁用 | ||||
|             single: true, | ||||
|             // 非多个禁用 | ||||
|             multiple: true, | ||||
|             // 总条数 | ||||
|             total: 0, | ||||
|             // 弹出层标题 | ||||
|             title: '', | ||||
|             // 是否显示弹出层 | ||||
|             open: false, | ||||
|             isEdit: false, | ||||
|             // 类型数据字典 | ||||
|             typeOptions: [], | ||||
|             lineCoinnetworkList: [], | ||||
|             statusOptions: [{ | ||||
|                 label: "启用", | ||||
|                 value: 1 | ||||
|             }, { | ||||
|                 label: "禁用", | ||||
|                 value: 2 | ||||
|             }], | ||||
|             // 关系表类型 | ||||
|   name: 'LineCoinnetwork', | ||||
|   components: { | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       // 遮罩层 | ||||
|       loading: true, | ||||
|       // 选中数组 | ||||
|       ids: [], | ||||
|       // 非单个禁用 | ||||
|       single: true, | ||||
|       // 非多个禁用 | ||||
|       multiple: true, | ||||
|       // 总条数 | ||||
|       total: 0, | ||||
|       // 弹出层标题 | ||||
|       title: '', | ||||
|       // 是否显示弹出层 | ||||
|       open: false, | ||||
|       isEdit: false, | ||||
|       // 类型数据字典 | ||||
|       typeOptions: [], | ||||
|       lineCoinnetworkList: [], | ||||
|       statusOptions: [{ | ||||
|         label: '启用', | ||||
|         value: 1 | ||||
|       }, { | ||||
|         label: '禁用', | ||||
|         value: 2 | ||||
|       }], | ||||
|       // 关系表类型 | ||||
|  | ||||
|             // 查询参数 | ||||
|             queryParams: { | ||||
|                 pageIndex: 1, | ||||
|                 pageSize: 10, | ||||
|                 idOrder:"desc", | ||||
|             }, | ||||
|             // 表单参数 | ||||
|             form: { | ||||
|             }, | ||||
|             // 表单校验 | ||||
|             rules: { | ||||
|                 networkName: [{ required: true, message: '网络名称不能为空', trigger: 'blur' }], | ||||
|                 minWithdrawal: [{ required: true, message: '最小提现金额不能为空', trigger: 'blur' }], | ||||
|                 fee: [{ required: true, message: '手续费不能为空', trigger: 'blur' }], | ||||
|             } | ||||
|         } | ||||
|     }, | ||||
|     created() { | ||||
|         this.getList() | ||||
|     }, | ||||
|     methods: { | ||||
|         /** 查询参数列表 */ | ||||
|         getList() { | ||||
|             this.loading = true | ||||
|             listLineCoinnetwork(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|                 this.lineCoinnetworkList = response.data.list | ||||
|                 this.total = response.data.count | ||||
|                 this.loading = false | ||||
|             } | ||||
|             ) | ||||
|         }, | ||||
|         // 取消按钮 | ||||
|         cancel() { | ||||
|             this.open = false | ||||
|             this.reset() | ||||
|         }, | ||||
|         // 表单重置 | ||||
|         reset() { | ||||
|             this.form = { | ||||
|  | ||||
|                 id: undefined, | ||||
|                 networkName: undefined, | ||||
|                 status: 1, | ||||
|                 minWithdrawal: undefined, | ||||
|                 fee: 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 | ||||
|             getLineCoinnetwork(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) { | ||||
|                         updateLineCoinnetwork(this.form).then(response => { | ||||
|                             if (response.code === 200) { | ||||
|                                 this.msgSuccess(response.msg) | ||||
|                                 this.open = false | ||||
|                                 this.getList() | ||||
|                             } else { | ||||
|                                 this.msgError(response.msg) | ||||
|                             } | ||||
|                         }) | ||||
|                     } else { | ||||
|                         addLineCoinnetwork(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 delLineCoinnetwork({ 'ids': Ids }) | ||||
|             }).then((response) => { | ||||
|                 if (response.code === 200) { | ||||
|                     this.msgSuccess(response.msg) | ||||
|                     this.open = false | ||||
|                     this.getList() | ||||
|                 } else { | ||||
|                     this.msgError(response.msg) | ||||
|                 } | ||||
|             }).catch(function () { | ||||
|             }) | ||||
|         } | ||||
|       // 查询参数 | ||||
|       queryParams: { | ||||
|         pageIndex: 1, | ||||
|         pageSize: 10, | ||||
|         idOrder: 'desc' | ||||
|       }, | ||||
|       // 表单参数 | ||||
|       form: { | ||||
|       }, | ||||
|       // 表单校验 | ||||
|       rules: { | ||||
|         networkName: [{ required: true, message: '网络名称不能为空', trigger: 'blur' }], | ||||
|         minWithdrawal: [{ required: true, message: '最小提现金额不能为空', trigger: 'blur' }], | ||||
|         fee: [{ required: true, message: '手续费不能为空', trigger: 'blur' }] | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   created() { | ||||
|     this.getList() | ||||
|   }, | ||||
|   methods: { | ||||
|     /** 查询参数列表 */ | ||||
|     getList() { | ||||
|       this.loading = true | ||||
|       listLineCoinnetwork(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|         this.lineCoinnetworkList = response.data.list | ||||
|         this.total = response.data.count | ||||
|         this.loading = false | ||||
|       } | ||||
|       ) | ||||
|     }, | ||||
|     // 取消按钮 | ||||
|     cancel() { | ||||
|       this.open = false | ||||
|       this.reset() | ||||
|     }, | ||||
|     // 表单重置 | ||||
|     reset() { | ||||
|       this.form = { | ||||
|  | ||||
|         id: undefined, | ||||
|         networkName: undefined, | ||||
|         status: 1, | ||||
|         minWithdrawal: undefined, | ||||
|         fee: 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 | ||||
|       getLineCoinnetwork(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) { | ||||
|             updateLineCoinnetwork(this.form).then(response => { | ||||
|               if (response.code === 200) { | ||||
|                 this.msgSuccess(response.msg) | ||||
|                 this.open = false | ||||
|                 this.getList() | ||||
|               } else { | ||||
|                 this.msgError(response.msg) | ||||
|               } | ||||
|             }) | ||||
|           } else { | ||||
|             addLineCoinnetwork(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 delLineCoinnetwork({ '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> | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -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: { | ||||
|  | ||||
| @ -1,31 +1,31 @@ | ||||
| <template> | ||||
|     <el-dialog :title="title" :visible.sync="open" width="1200px" :close-on-click-modal="false"> | ||||
|         <el-form ref="form" :model="form" :rules="rules" label-width="180px" style="height: 600px;overflow: hidden auto;"> | ||||
|               <el-form-item label="交易所" prop="exchange_type"> | ||||
|                 <el-select | ||||
|                   v-model="form.exchange_type" | ||||
|                   style="width: 100%;" | ||||
|                   placeholder="请选择交易所" | ||||
|                   clearable | ||||
|                   filterable | ||||
|                   size="small" | ||||
|                   @change="onchangeForm" | ||||
|                 > | ||||
|                   <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="symbol_type"> | ||||
|                 <el-radio-group v-model="form.symbol_type"> | ||||
|                   <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-dialog :title="title" :visible.sync="open" width="1200px" :close-on-click-modal="false"> | ||||
|     <el-form ref="form" :model="form" :rules="rules" label-width="180px" style="height: 600px;overflow: hidden auto;"> | ||||
|       <el-form-item label="交易所" prop="exchange_type"> | ||||
|         <el-select | ||||
|           v-model="form.exchange_type" | ||||
|           style="width: 100%;" | ||||
|           placeholder="请选择交易所" | ||||
|           clearable | ||||
|           filterable | ||||
|           size="small" | ||||
|           @change="onchangeForm" | ||||
|         > | ||||
|           <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="symbol_type"> | ||||
|         <el-radio-group v-model="form.symbol_type"> | ||||
|           <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="form.cover_type"> | ||||
|                 <el-radio :label="0">无对冲</el-radio> | ||||
|                 <el-radio :label="1" :disabled="form.symbol_type==2">现货对合约</el-radio> | ||||
| @ -33,155 +33,155 @@ | ||||
|                 <el-radio :label="3" :disabled="form.symbol_type==1">合约对现货</el-radio> | ||||
|               </el-radio-group> | ||||
|             </el-form-item> --> | ||||
|               <el-form-item label="api用户" prop="api_id"> | ||||
|                 <el-row> | ||||
|                   <el-col :span="21"> | ||||
|                     <el-select | ||||
|                       v-model="form.api_id" | ||||
|                       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" | ||||
|                       /> | ||||
|                     </el-select> | ||||
|                   </el-col> | ||||
|                   <el-col :span="3"> | ||||
|                     <el-button size="mini" type="primary" style="margin-left: 10px;" @click="onSelectAll">全选</el-button> | ||||
|                   </el-col> | ||||
|                 </el-row> | ||||
|               </el-form-item> | ||||
|               <!-- <el-form-item label="交易对组id" prop="groupId"> | ||||
|       <el-form-item label="api用户" prop="api_id"> | ||||
|         <el-row> | ||||
|           <el-col :span="21"> | ||||
|             <el-select | ||||
|               v-model="form.api_id" | ||||
|               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" | ||||
|               /> | ||||
|             </el-select> | ||||
|           </el-col> | ||||
|           <el-col :span="3"> | ||||
|             <el-button size="mini" type="primary" style="margin-left: 10px;" @click="onSelectAll">全选</el-button> | ||||
|           </el-col> | ||||
|         </el-row> | ||||
|       </el-form-item> | ||||
|       <!-- <el-form-item label="交易对组id" prop="groupId"> | ||||
|               <el-input | ||||
|                 v-model="form.groupId" | ||||
|                 placeholder="交易对组id" | ||||
|               /> | ||||
|             </el-form-item> --> | ||||
|               <el-form-item v-if="title==='批量添加'" label="交易对组" prop="symbol_group_id"> | ||||
|                 <el-select | ||||
|                   v-if="title==='批量添加'" | ||||
|                   v-model="form.symbol_group_id" | ||||
|                   style="width: 100%;" | ||||
|                   placeholder="请选择交易对组" | ||||
|                   clearable | ||||
|                   size="small" | ||||
|                   filterable | ||||
|                 > | ||||
|                   <el-option | ||||
|                     v-for="dict in comSymbols" | ||||
|                     :key="dict.id" | ||||
|                     :label="dict.groupName" | ||||
|                     :value="dict.id" | ||||
|                   /> | ||||
|       <el-form-item v-if="title==='批量添加'" label="交易对组" prop="symbol_group_id"> | ||||
|         <el-select | ||||
|           v-if="title==='批量添加'" | ||||
|           v-model="form.symbol_group_id" | ||||
|           style="width: 100%;" | ||||
|           placeholder="请选择交易对组" | ||||
|           clearable | ||||
|           size="small" | ||||
|           filterable | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="dict in comSymbols" | ||||
|             :key="dict.id" | ||||
|             :label="dict.groupName" | ||||
|             :value="dict.id" | ||||
|           /> | ||||
|         </el-select> | ||||
|       </el-form-item> | ||||
|       <el-form-item v-else label="交易对" prop="symbol"> | ||||
|         <el-select | ||||
|           v-model="form.symbol" | ||||
|           style="width: 100%;" | ||||
|           placeholder="请选择交易对" | ||||
|           clearable | ||||
|           filterable | ||||
|           :remote-method="getSymbol" | ||||
|           :loading="searchLoding" | ||||
|           remote | ||||
|           size="small" | ||||
|           @change="onchangeSymbol" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="dict in comSymbols" | ||||
|             :key="dict.id || dict.symbol" | ||||
|             :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" | ||||
|             /> | ||||
|           </div> | ||||
|         </el-select> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="购买方向" prop="site"> | ||||
|         <el-radio-group v-model="form.site"> | ||||
|           <el-radio label="BUY">买(多)</el-radio> | ||||
|           <el-radio label="SELL" :disabled="form.order_type==1">卖(空)</el-radio> | ||||
|         </el-radio-group> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="购买金额(U)" prop="buy_price"> | ||||
|         <el-input | ||||
|           v-model="form.buy_price" | ||||
|           placeholder="购买金额(U)" | ||||
|         /> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="价格模式" prop="price_pattern"> | ||||
|         <el-radio-group v-model="form.price_pattern"> | ||||
|           <el-radio label="percentage">百分比</el-radio> | ||||
|           <el-radio label="mixture" :disabled="title==='批量添加'">主单实价委托百分比</el-radio> | ||||
|           <el-radio label="aicoin" :disabled="title==='批量添加'">aiCoin买入点</el-radio> | ||||
|         </el-radio-group> | ||||
|       </el-form-item> | ||||
|       <el-form-item v-if="form.price_pattern === 'percentage'" label="下单百分比" prop="price"> | ||||
|         <el-input | ||||
|           v-model="form.price" | ||||
|           placeholder="下单百分比" | ||||
|         /> | ||||
|       </el-form-item> | ||||
|       <el-row v-else type="flex"> | ||||
|         <el-col :span="14"> | ||||
|           <el-form-item label="下单价(实际价格)" prop="price"> | ||||
|             <el-input | ||||
|               v-model="form.price" | ||||
|               placeholder="下单价(实际价格)" | ||||
|             > | ||||
|               <template #prepend> | ||||
|                 <el-select v-if="form.price_pattern === 'aicoin'" v-model="aicoinPrice" placeholder="请选择" style="width: 150px;" @change="onchangeAicoin"> | ||||
|                   <el-option v-for="o in JSON.stringify(aicoins) !== '{}' ? options : []" :key="o.label" :label="o.label" :value="aicoins[o.value] || ''"> | ||||
|                     <span style="float: left">{{ o.label }}</span> | ||||
|                     <span style="float: right">{{ aicoins[o.value] || 0 }}</span> | ||||
|                   </el-option> | ||||
|                 </el-select> | ||||
|               </el-form-item> | ||||
|               <el-form-item v-else label="交易对" prop="symbol"> | ||||
|                 <el-select | ||||
|                   v-model="form.symbol" | ||||
|                   style="width: 100%;" | ||||
|                   placeholder="请选择交易对" | ||||
|                   clearable | ||||
|                   filterable | ||||
|                   :remote-method="getSymbol" | ||||
|                   :loading="searchLoding" | ||||
|                   remote | ||||
|                   size="small" | ||||
|                   @change="onchangeSymbol" | ||||
|                 > | ||||
|                   <el-option | ||||
|                     v-for="dict in comSymbols" | ||||
|                     :key="dict.id || dict.symbol" | ||||
|                     :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" | ||||
|                     /> | ||||
|                   </div> | ||||
|                 </el-select> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="购买方向" prop="site"> | ||||
|                 <el-radio-group v-model="form.site"> | ||||
|                   <el-radio label="BUY">买(多)</el-radio> | ||||
|                   <el-radio label="SELL" :disabled="form.order_type==1">卖(空)</el-radio> | ||||
|                 </el-radio-group> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="购买金额(U)" prop="buy_price"> | ||||
|                 <el-input | ||||
|                   v-model="form.buy_price" | ||||
|                   placeholder="购买金额(U)" | ||||
|                 /> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="价格模式" prop="price_pattern"> | ||||
|                 <el-radio-group v-model="form.price_pattern"> | ||||
|                   <el-radio label="percentage">百分比</el-radio> | ||||
|                   <el-radio label="mixture" :disabled="title==='批量添加'">主单实价委托百分比</el-radio> | ||||
|                   <el-radio label="aicoin" :disabled="title==='批量添加'">aiCoin买入点</el-radio> | ||||
|                 </el-radio-group> | ||||
|               </el-form-item> | ||||
|               <el-form-item v-if="form.price_pattern === 'percentage'" label="下单百分比" prop="price"> | ||||
|                 <el-input | ||||
|                   v-model="form.price" | ||||
|                   placeholder="下单百分比" | ||||
|                 /> | ||||
|               </el-form-item> | ||||
|               <el-row v-else type="flex"> | ||||
|                 <el-col :span="14"> | ||||
|                   <el-form-item label="下单价(实际价格)" prop="price"> | ||||
|                     <el-input | ||||
|                       v-model="form.price" | ||||
|                       placeholder="下单价(实际价格)" | ||||
|                     > | ||||
|                       <template #prepend> | ||||
|                         <el-select v-if="form.price_pattern === 'aicoin'" v-model="aicoinPrice" placeholder="请选择" style="width: 150px;" @change="onchangeAicoin"> | ||||
|                           <el-option v-for="o in JSON.stringify(aicoins) !== '{}' ? options : []" :key="o.label" :label="o.label" :value="aicoins[o.value] || ''"> | ||||
|                             <span style="float: left">{{ o.label }}</span> | ||||
|                             <span style="float: right">{{ aicoins[o.value] || 0 }}</span> | ||||
|                           </el-option> | ||||
|                         </el-select> | ||||
|                       </template> | ||||
|                       <template #append> | ||||
|                         <span v-if="form.price_pattern !== 'percentage'">{{ comPrice }}</span> | ||||
|                       </template> | ||||
|                     </el-input> | ||||
|                   </el-form-item> | ||||
|                 </el-col> | ||||
|                 <el-col :span="5"> | ||||
|                   <el-form-item label="计算百分比"> | ||||
|                     <el-inputNumber v-model="percenter" controls-position="right" :min="0" style="width: 100px;" /> | ||||
|                   </el-form-item> | ||||
|                 </el-col> | ||||
|                 <el-col :span="5"> | ||||
|                   <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="form.profit" | ||||
|                   placeholder="止盈百分比" | ||||
|                 /> | ||||
|               </el-form-item> | ||||
|               <!-- <el-form-item label="亏损百分比" prop="stop_price"> | ||||
|               </template> | ||||
|               <template #append> | ||||
|                 <span v-if="form.price_pattern !== 'percentage'">{{ comPrice }}</span> | ||||
|               </template> | ||||
|             </el-input> | ||||
|           </el-form-item> | ||||
|         </el-col> | ||||
|         <el-col :span="5"> | ||||
|           <el-form-item label="计算百分比"> | ||||
|             <el-inputNumber v-model="percenter" controls-position="right" :min="0" style="width: 100px;" /> | ||||
|           </el-form-item> | ||||
|         </el-col> | ||||
|         <el-col :span="5"> | ||||
|           <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="form.profit" | ||||
|           placeholder="止盈百分比" | ||||
|         /> | ||||
|       </el-form-item> | ||||
|       <!-- <el-form-item label="亏损百分比" prop="stop_price"> | ||||
|               <el-input | ||||
|                 v-model="form.stop_price" | ||||
|                 placeholder="亏损百分比" | ||||
|               /> | ||||
|             </el-form-item> --> | ||||
|               <!-- <template v-if="form.cover_type!=0"> | ||||
|       <!-- <template v-if="form.cover_type!=0"> | ||||
|               <el-form-item label="对冲单购买类型" prop="hedge_buy_type"> | ||||
|                 <el-radio-group v-model="form.hedge_buy_type"> | ||||
|                   <el-radio :label="1">百分比</el-radio> | ||||
| @ -211,7 +211,7 @@ | ||||
|                 /> | ||||
|               </el-form-item> | ||||
|             </template> --> | ||||
|               <!-- <el-form-item label="对冲百分比" prop="cover_rate"> | ||||
|       <!-- <el-form-item label="对冲百分比" prop="cover_rate"> | ||||
|               <el-input | ||||
|                 v-model="form.cover_rate" | ||||
|                 placeholder="对冲百分比" | ||||
| @ -236,19 +236,19 @@ | ||||
|                 <el-col :span="11"><el-input v-model.number="form.hedge_trigger_percent_max" type="number" placeholder="最大值"><template #append>最大值</template></el-input></el-col> | ||||
|               </el-row> | ||||
|             </el-form-item> --> | ||||
|               <el-form-item label="主单类型" prop="main_order_type"> | ||||
|                 <el-radio-group v-model="form.main_order_type"> | ||||
|                   <el-radio label="LIMIT">限价</el-radio> | ||||
|                   <el-radio label="MARKET">市价</el-radio> | ||||
|                 </el-radio-group> | ||||
|               </el-form-item> | ||||
|               <!-- <el-form-item label="对冲单下单类型" prop="hedge_order_type"> | ||||
|       <el-form-item label="主单类型" prop="main_order_type"> | ||||
|         <el-radio-group v-model="form.main_order_type"> | ||||
|           <el-radio label="LIMIT">限价</el-radio> | ||||
|           <el-radio label="MARKET">市价</el-radio> | ||||
|         </el-radio-group> | ||||
|       </el-form-item> | ||||
|       <!-- <el-form-item label="对冲单下单类型" prop="hedge_order_type"> | ||||
|               <el-radio-group v-model="form.hedge_order_type"> | ||||
|                 <el-radio label="LIMIT">限价</el-radio> | ||||
|                 <el-radio label="MARKET">市价</el-radio> | ||||
|               </el-radio-group> | ||||
|             </el-form-item> --> | ||||
|               <!-- <el-form-item label="加仓主单类型" prop="add_position_main_type"> | ||||
|       <!-- <el-form-item label="加仓主单类型" prop="add_position_main_type"> | ||||
|               <el-radio-group v-model="form.add_position_main_type"> | ||||
|                 <el-radio label="LIMIT">限价</el-radio> | ||||
|                 <el-radio label="MARKET">市价</el-radio> | ||||
| @ -260,124 +260,123 @@ | ||||
|                 <el-radio label="MARKET">市价</el-radio> | ||||
|               </el-radio-group> | ||||
|             </el-form-item> --> | ||||
|               <el-form-item label="对标价类型" prop="price_type"> | ||||
|                 <el-radio-group v-model="form.price_type"> | ||||
|                   <el-radio label="new">最新价</el-radio> | ||||
|                   <el-radio label="mixture" :disabled="title==='批量添加'">标记价</el-radio> | ||||
|                   <el-radio label="aicoin" :disabled="title==='批量添加'">aicoin</el-radio> | ||||
|                 </el-radio-group> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="订单过期时间" prop="profit_rate"> | ||||
|                 <el-input | ||||
|                   v-model.number="form.expire_hour" | ||||
|                   class="hour" | ||||
|                   type="number" | ||||
|                   placeholder="订单过期时间" | ||||
|                 > | ||||
|                   <template slot="append">小时</template> | ||||
|                 </el-input> | ||||
|               </el-form-item> | ||||
|               <el-form-item v-if="title==='批量添加'" label="批量下单次数" prop="order_num"> | ||||
|                 <el-input | ||||
|                   v-model.number="form.order_num" | ||||
|                   min="1" | ||||
|                   type="number" | ||||
|                   placeholder="批量下单次数" | ||||
|                 /> | ||||
|               </el-form-item> | ||||
|               <el-form-item v-if="title==='批量添加'" label="执行类型" prop="script"> | ||||
|                 <el-radio-group v-model="form.script"> | ||||
|                   <el-radio label="1"><span>脚本执行</span></el-radio> | ||||
|                   <el-radio label="0">直接执行</el-radio> | ||||
|                 </el-radio-group> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="主单亏损百分比" prop="reduce_price"> | ||||
|                 <el-input v-model.number="form.reduce_price" type="number" placeholder="主单亏损百分比" /> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="主单减仓数量百分比" prop="reduce_num"> | ||||
|                 <el-input v-model.number="form.reduce_num" type="number" placeholder="主单减仓数量百分比" /> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="主单减仓后止盈价百分比" prop="reduce_take_profit"> | ||||
|                 <el-input v-model.number="form.reduce_take_profit" type="number" placeholder="主单减仓后止盈价百分比"> | ||||
|                   <template v-if="title!=='批量添加'" #append>{{ re_take_profit_ratio }}</template> | ||||
|                 </el-input> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="主单减仓后止损价百分比" prop="reduce_stop_price"> | ||||
|                 <el-input v-model.number="form.reduce_stop_price" type="number" placeholder="主单减仓后止损价百分比" /> | ||||
|               </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="onAddExt(0)">新增</el-button></el-col> | ||||
|                 <el-col v-if="title!=='批量添加'" :span="2"><el-button type="primary" size="mini" :disabled="form.ext && form.ext.length===0" @click="onCalculate">计算</el-button></el-col> | ||||
|               </el-row> | ||||
|               <div v-for="(item,index) in form.ext" :key="index" class="exts"> | ||||
|                 <el-row :gutter="20"> | ||||
|                   <el-col :span="5"> | ||||
|                     <div style="margin-bottom: 8px;">加仓类型</div> | ||||
|                     <el-radio-group v-model="item.addPositionOrderType" size="mini"> | ||||
|                       <el-radio label="LIMIT">限价</el-radio> | ||||
|                       <el-radio label="MARKET">市价</el-radio> | ||||
|                     </el-radio-group> | ||||
|                   </el-col> | ||||
|                   <el-col :span="5"> | ||||
|                     <div style="margin-bottom: 8px;">加仓方式</div> | ||||
|                     <el-radio-group v-model="item.addPositionType" size="mini"> | ||||
|                       <el-radio :label="1">百分比</el-radio> | ||||
|                       <el-radio :label="2">实际金额</el-radio> | ||||
|                     </el-radio-group> | ||||
|                   </el-col> | ||||
|                   <el-col :span="5">加仓下跌百分比<el-input v-model.number="item.addPositionPriceRatio" size="mini" type="number" placeholder="加仓下跌百分比" /></el-col> | ||||
|                   <el-col :span="5">加仓数值<el-input v-model.number="item.addPositionVal" size="mini" type="number" placeholder="加仓数值" /></el-col> | ||||
|                   <el-col :span="4">加仓后止盈价百分比<el-input v-model.number="item.takeProfitRatio" size="mini" type="number" placeholder="止盈百分比"> | ||||
|                     <template v-if="title!=='批量添加'" #append>{{ ext[index] ? ext[index].reTakeProfitRatio : 0 }}</template> | ||||
|                   </el-input></el-col> | ||||
|                 </el-row> | ||||
|                 <el-row :gutter="20" style="margin-top: 10px;"> | ||||
|                   <el-col :span="5">减仓下跌百分比<el-input v-model.number="item.reducePriceRatio" size="mini" type="number" placeholder="减仓下跌百分比" /></el-col> | ||||
|                   <el-col :span="5">减仓数量百分比<el-input v-model.number="item.reduceNumRatio" size="mini" type="number" placeholder="减仓数量百分比" /></el-col> | ||||
|                   <el-col :span="5">减仓后止盈价百分比<el-input v-model.number="item.reduceTakeProfitRatio" size="mini" type="number" placeholder="减仓后止盈百分比"> | ||||
|                     <template v-if="title!=='批量添加'" #append>{{ ext[index] ? ext[index].reduceReTakeProfitRatio : 0 }}</template> | ||||
|                   </el-input></el-col> | ||||
|                   <el-col :span="5">减仓后止损价百分比<el-input v-model.number="item.reduceStopLossRatio" size="mini" type="number" placeholder="减仓后止损百分比" /></el-col> | ||||
|                   <el-col :span="4"><div style="margin-bottom: 14px;" /><el-button size="mini" type="danger" @click="onAddExt(1,index)">删除</el-button></el-col> | ||||
|                 </el-row> | ||||
|               </div> | ||||
|               <el-form-item label="是否保存模板" prop="save_template"> | ||||
|                 <el-radio-group v-model="form.save_template"> | ||||
|                   <el-radio label="0">否</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="template_name"> | ||||
|                 <el-input | ||||
|                   v-model="form.template_name" | ||||
|                   placeholder="模板名称" | ||||
|                 /> | ||||
|               </el-form-item> | ||||
|       <el-form-item label="对标价类型" prop="price_type"> | ||||
|         <el-radio-group v-model="form.price_type"> | ||||
|           <el-radio label="new">最新价</el-radio> | ||||
|           <el-radio label="mixture" :disabled="title==='批量添加'">标记价</el-radio> | ||||
|           <el-radio label="aicoin" :disabled="title==='批量添加'">aicoin</el-radio> | ||||
|         </el-radio-group> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="订单过期时间" prop="profit_rate"> | ||||
|         <el-input | ||||
|           v-model.number="form.expire_hour" | ||||
|           class="hour" | ||||
|           type="number" | ||||
|           placeholder="订单过期时间" | ||||
|         > | ||||
|           <template slot="append">小时</template> | ||||
|         </el-input> | ||||
|       </el-form-item> | ||||
|       <el-form-item v-if="title==='批量添加'" label="批量下单次数" prop="order_num"> | ||||
|         <el-input | ||||
|           v-model.number="form.order_num" | ||||
|           min="1" | ||||
|           type="number" | ||||
|           placeholder="批量下单次数" | ||||
|         /> | ||||
|       </el-form-item> | ||||
|       <el-form-item v-if="title==='批量添加'" label="执行类型" prop="script"> | ||||
|         <el-radio-group v-model="form.script"> | ||||
|           <el-radio label="1"><span>脚本执行</span></el-radio> | ||||
|           <el-radio label="0">直接执行</el-radio> | ||||
|         </el-radio-group> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="主单亏损百分比" prop="reduce_price"> | ||||
|         <el-input v-model.number="form.reduce_price" type="number" placeholder="主单亏损百分比" /> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="主单减仓数量百分比" prop="reduce_num"> | ||||
|         <el-input v-model.number="form.reduce_num" type="number" placeholder="主单减仓数量百分比" /> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="主单减仓后止盈价百分比" prop="reduce_take_profit"> | ||||
|         <el-input v-model.number="form.reduce_take_profit" type="number" placeholder="主单减仓后止盈价百分比"> | ||||
|           <template v-if="title!=='批量添加'" #append>{{ re_take_profit_ratio }}</template> | ||||
|         </el-input> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="主单减仓后止损价百分比" prop="reduce_stop_price"> | ||||
|         <el-input v-model.number="form.reduce_stop_price" type="number" placeholder="主单减仓后止损价百分比" /> | ||||
|       </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="onAddExt(0)">新增</el-button></el-col> | ||||
|         <el-col v-if="title!=='批量添加'" :span="2"><el-button type="primary" size="mini" :disabled="form.ext && form.ext.length===0" @click="onCalculate">计算</el-button></el-col> | ||||
|       </el-row> | ||||
|       <div v-for="(item,index) in form.ext" :key="index" class="exts"> | ||||
|         <el-row :gutter="20"> | ||||
|           <el-col :span="5"> | ||||
|             <div style="margin-bottom: 8px;">加仓类型</div> | ||||
|             <el-radio-group v-model="item.addPositionOrderType" size="mini"> | ||||
|               <el-radio label="LIMIT">限价</el-radio> | ||||
|               <el-radio label="MARKET">市价</el-radio> | ||||
|             </el-radio-group> | ||||
|           </el-col> | ||||
|           <el-col :span="5"> | ||||
|             <div style="margin-bottom: 8px;">加仓方式</div> | ||||
|             <el-radio-group v-model="item.addPositionType" size="mini"> | ||||
|               <el-radio :label="1">百分比</el-radio> | ||||
|               <el-radio :label="2">实际金额</el-radio> | ||||
|             </el-radio-group> | ||||
|           </el-col> | ||||
|           <el-col :span="5">加仓下跌百分比<el-input v-model.number="item.addPositionPriceRatio" size="mini" type="number" placeholder="加仓下跌百分比" /></el-col> | ||||
|           <el-col :span="5">加仓数值<el-input v-model.number="item.addPositionVal" size="mini" type="number" placeholder="加仓数值" /></el-col> | ||||
|           <el-col :span="4">加仓后止盈价百分比<el-input v-model.number="item.takeProfitRatio" size="mini" type="number" placeholder="止盈百分比"> | ||||
|             <template v-if="title!=='批量添加'" #append>{{ ext[index] ? ext[index].reTakeProfitRatio : 0 }}</template> | ||||
|           </el-input></el-col> | ||||
|         </el-row> | ||||
|         <el-row :gutter="20" style="margin-top: 10px;"> | ||||
|           <el-col :span="5">减仓下跌百分比<el-input v-model.number="item.reducePriceRatio" size="mini" type="number" placeholder="减仓下跌百分比" /></el-col> | ||||
|           <el-col :span="5">减仓数量百分比<el-input v-model.number="item.reduceNumRatio" size="mini" type="number" placeholder="减仓数量百分比" /></el-col> | ||||
|           <el-col :span="5">减仓后止盈价百分比<el-input v-model.number="item.reduceTakeProfitRatio" size="mini" type="number" placeholder="减仓后止盈百分比"> | ||||
|             <template v-if="title!=='批量添加'" #append>{{ ext[index] ? ext[index].reduceReTakeProfitRatio : 0 }}</template> | ||||
|           </el-input></el-col> | ||||
|           <el-col :span="5">减仓后止损价百分比<el-input v-model.number="item.reduceStopLossRatio" size="mini" type="number" placeholder="减仓后止损百分比" /></el-col> | ||||
|           <el-col :span="4"><div style="margin-bottom: 14px;" /><el-button size="mini" type="danger" @click="onAddExt(1,index)">删除</el-button></el-col> | ||||
|         </el-row> | ||||
|       </div> | ||||
|       <el-form-item label="是否保存模板" prop="save_template"> | ||||
|         <el-radio-group v-model="form.save_template"> | ||||
|           <el-radio label="0">否</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="template_name"> | ||||
|         <el-input | ||||
|           v-model="form.template_name" | ||||
|           placeholder="模板名称" | ||||
|         /> | ||||
|       </el-form-item> | ||||
|  | ||||
|             </el-form> | ||||
|         <div slot="footer" class="dialog-footer" style="text-align: right;"> | ||||
|             <el-button type="primary" @click="submitForm">确 定</el-button> | ||||
|             <el-button @click="cancel">取 消</el-button> | ||||
|         </div> | ||||
|     </el-dialog> | ||||
|     </el-form> | ||||
|     <div slot="footer" class="dialog-footer" style="text-align: right;"> | ||||
|       <el-button type="primary" @click="submitForm">确 定</el-button> | ||||
|       <el-button @click="cancel">取 消</el-button> | ||||
|     </div> | ||||
|   </el-dialog> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { resetForm } from '@/utils/costum'; | ||||
|  | ||||
| export default { | ||||
|     name: "AddPosition", | ||||
|     props: { | ||||
|         open: { | ||||
|             type: Boolean, | ||||
|             default: false | ||||
|         } | ||||
|     }, | ||||
|     data() { | ||||
|         return { | ||||
|             form:{}, | ||||
|   name: 'AddPosition', | ||||
|   props: { | ||||
|     open: { | ||||
|       type: Boolean, | ||||
|       default: false | ||||
|     } | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       form: {}, | ||||
|       options: [ | ||||
|         { label: '买入点1', value: 'buyPoint1' }, | ||||
|         { label: '买入点2', value: 'buyPoint2' }, | ||||
| @ -389,41 +388,41 @@ export default { | ||||
|       buyer: [ | ||||
|         { v: 'BUY', l: '买(多)' }, | ||||
|         { v: 'SELL', l: '卖(空)' } | ||||
|       ], | ||||
|         } | ||||
|     }, | ||||
|     methods: { | ||||
|         resetForm(){ | ||||
|             this.form={ | ||||
|                 id:null, | ||||
|                 exchangeType:"", | ||||
|                 orderType:1, | ||||
|                 symbol:"", | ||||
|                 apiId:null, | ||||
|                 site:'', | ||||
|                 buyPrice:null, | ||||
|                 pricePattern:'', | ||||
|                 price:null, | ||||
|                 profit:null, | ||||
|                 addPositionOrderType:'LIMIT', | ||||
|                 priceType:null, | ||||
|                 reTakeProfitRatio:null, | ||||
|                 reducePriceRatio:null, | ||||
|                 reduceNumRatio:null, | ||||
|                 reduceTakeProfitRatio:null, | ||||
|                 reduceStopLossRatio:null, | ||||
|             } | ||||
|         }, | ||||
|         //提交 | ||||
|         submitForm() { | ||||
|  | ||||
|         }, | ||||
|         //取消 | ||||
|         cancel() { | ||||
|             this.$emit("update:open", false) | ||||
|         } | ||||
|       ] | ||||
|     } | ||||
|   }, | ||||
|   methods: { | ||||
|     resetForm() { | ||||
|       this.form = { | ||||
|         id: null, | ||||
|         exchangeType: '', | ||||
|         orderType: 1, | ||||
|         symbol: '', | ||||
|         apiId: null, | ||||
|         site: '', | ||||
|         buyPrice: null, | ||||
|         pricePattern: '', | ||||
|         price: null, | ||||
|         profit: null, | ||||
|         addPositionOrderType: 'LIMIT', | ||||
|         priceType: null, | ||||
|         reTakeProfitRatio: null, | ||||
|         reducePriceRatio: null, | ||||
|         reduceNumRatio: null, | ||||
|         reduceTakeProfitRatio: null, | ||||
|         reduceStopLossRatio: null | ||||
|       } | ||||
|     }, | ||||
|     // 提交 | ||||
|     submitForm() { | ||||
|  | ||||
|     }, | ||||
|     // 取消 | ||||
|     cancel() { | ||||
|       this.$emit('update:open', false) | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </script> | ||||
|  | ||||
| <style scoped></style> | ||||
| <style scoped></style> | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										448
									
								
								src/views/admin/line-reduce-strategy/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										448
									
								
								src/views/admin/line-reduce-strategy/index.vue
									
									
									
									
									
										Normal 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> | ||||
							
								
								
									
										416
									
								
								src/views/admin/line-strategy-template/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										416
									
								
								src/views/admin/line-strategy-template/index.vue
									
									
									
									
									
										Normal 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> | ||||
| @ -171,7 +171,7 @@ | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { addLineSymbolBlack, delLineSymbolBlack, getLineSymbolBlack, listLineSymbolBlack, updateLineSymbolBlack,reloadSymbol } from '@/api/admin/line-symbol-black' | ||||
| import { addLineSymbolBlack, delLineSymbolBlack, getLineSymbolBlack, listLineSymbolBlack, updateLineSymbolBlack, reloadSymbol } from '@/api/admin/line-symbol-black' | ||||
|  | ||||
| export default { | ||||
|   name: 'LineSymbolBlack', | ||||
| @ -206,7 +206,7 @@ export default { | ||||
|         pageSize: 10, | ||||
|         symbol: undefined, | ||||
|         type: undefined, | ||||
|         idOrder:"desc", | ||||
|         idOrder: 'desc' | ||||
|       }, | ||||
|       // 表单参数 | ||||
|       form: { | ||||
| @ -349,7 +349,7 @@ export default { | ||||
|       }) | ||||
|     }, | ||||
|     /** 重置交易对按钮操作 */ | ||||
|     handleReload(){ | ||||
|     handleReload() { | ||||
|       this.loading = true | ||||
|       reloadSymbol().then((response) => { | ||||
|         if (response.code === 200) { | ||||
|  | ||||
							
								
								
									
										330
									
								
								src/views/admin/line-symbol-price/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										330
									
								
								src/views/admin/line-symbol-price/index.vue
									
									
									
									
									
										Normal 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> | ||||
| @ -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' }] | ||||
|       } | ||||
|  | ||||
|     } | ||||
|  | ||||
| @ -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> | ||||
| @ -53,34 +65,62 @@ | ||||
|           <el-table-column label="启动状态" prop="open_status" align="center"> | ||||
|             <template #default="{ row }"> | ||||
|               <el-tag size="mini" :type="row.open_status ? 'success' : 'danger'">{{ ['停止', '启动'][row.open_status] || '未知' | ||||
|                 }}</el-tag> | ||||
|               }}</el-tag> | ||||
|             </template> | ||||
|           </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: { | ||||
| @ -326,10 +366,10 @@ export default { | ||||
|       } | ||||
|       this.resetForm('form') | ||||
|     }, | ||||
|     getImgList: function () { | ||||
|     getImgList: function() { | ||||
|       this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl | ||||
|     }, | ||||
|     fileClose: function () { | ||||
|     fileClose: function() { | ||||
|       this.fileOpen = false | ||||
|     }, | ||||
|     // 关系 | ||||
| @ -371,7 +411,7 @@ export default { | ||||
|       }) | ||||
|     }, | ||||
|     /** 提交按钮 */ | ||||
|     submitForm: function () { | ||||
|     submitForm: function() { | ||||
|       this.$refs['form'].validate(valid => { | ||||
|         if (valid) { | ||||
|           if (this.form.id !== undefined) { | ||||
| @ -406,7 +446,7 @@ export default { | ||||
|         confirmButtonText: '确定', | ||||
|         cancelButtonText: '取消', | ||||
|         type: 'warning' | ||||
|       }).then(function () { | ||||
|       }).then(function() { | ||||
|         return delLineUser({ 'ids': Ids }) | ||||
|       }).then((response) => { | ||||
|         if (response.code === 200) { | ||||
| @ -416,11 +456,11 @@ export default { | ||||
|         } else { | ||||
|           this.msgError(response.msg) | ||||
|         } | ||||
|       }).catch(function () { | ||||
|       }).catch(function() { | ||||
|       }) | ||||
|     }, | ||||
|     /* | ||||
|     更新资产  | ||||
|     更新资产 | ||||
|      */ | ||||
|     handleReload(row) { | ||||
|       this.loading = true | ||||
|  | ||||
| @ -1,351 +1,391 @@ | ||||
|  | ||||
| <template> | ||||
|     <BasicLayout> | ||||
|         <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-option | ||||
|                                                 v-for="dict in changeSourceOptions" | ||||
|                                                 :key="dict.value" | ||||
|                                                 :label="dict.label" | ||||
|                                                 :value="dict.value" | ||||
|                                         /> | ||||
|                                     </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> | ||||
|                          | ||||
|                     <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> | ||||
|   <BasicLayout> | ||||
|     <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-option | ||||
|               v-for="dict in changeSourceOptions" | ||||
|               :key="dict.value" | ||||
|               :label="dict.label" | ||||
|               :value="dict.value" | ||||
|             /> | ||||
|           </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> | ||||
|  | ||||
|                 <el-row :gutter="10" class="mb8"> | ||||
|                     <el-col :span="1.5"> | ||||
|                         <el-button | ||||
|                                 v-permisaction="['admin:memberBalanceLog: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:memberBalanceLog: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:memberBalanceLog:remove']" | ||||
|                                 type="danger" | ||||
|                                 icon="el-icon-delete" | ||||
|                                 size="mini" | ||||
|                                 :disabled="multiple" | ||||
|                                 @click="handleDelete" | ||||
|                         >删除 | ||||
|                         </el-button> | ||||
|                     </el-col> | ||||
|                 </el-row> | ||||
|           <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="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"> | ||||
|                                     <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 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:memberBalanceLog: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:memberBalanceLog:remove']" | ||||
|                               size="mini" | ||||
|                               type="text" | ||||
|                               icon="el-icon-delete" | ||||
|                             >删除 | ||||
|                             </el-button> | ||||
|                          </el-popconfirm> | ||||
|                         </template> | ||||
|                     </el-table-column> | ||||
|                 </el-table> | ||||
|         <el-row :gutter="10" class="mb8"> | ||||
|           <el-col :span="1.5"> | ||||
|             <el-button | ||||
|               v-permisaction="['admin:memberBalanceLog: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:memberBalanceLog: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:memberBalanceLog:remove']" | ||||
|               type="danger" | ||||
|               icon="el-icon-delete" | ||||
|               size="mini" | ||||
|               :disabled="multiple" | ||||
|               @click="handleDelete" | ||||
|             >删除 | ||||
|             </el-button> | ||||
|           </el-col> | ||||
|         </el-row> | ||||
|  | ||||
|                 <pagination | ||||
|                         v-show="total>0" | ||||
|                         :total="total" | ||||
|                         :page.sync="queryParams.pageIndex" | ||||
|                         :limit.sync="queryParams.pageSize" | ||||
|                         @pagination="getList" | ||||
|                 /> | ||||
|         <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" | ||||
|           > | ||||
|             <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 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:memberBalanceLog: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:memberBalanceLog:remove']" | ||||
|                   size="mini" | ||||
|                   type="text" | ||||
|                   icon="el-icon-delete" | ||||
|                 >删除 | ||||
|                 </el-button> | ||||
|               </el-popconfirm> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|         </el-table> | ||||
|  | ||||
|                 <!-- 添加或修改对话框 --> | ||||
|                 <el-dialog :title="title" :visible.sync="open" width="500px"> | ||||
|                     <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-form-item> | ||||
|                                     <el-form-item label="变更来源 (member_change_source)" prop="changeSource"> | ||||
|                                         <el-radio-group v-model="form.changeSource"> | ||||
|                                                 <el-radio | ||||
|                                                         v-for="dict in changeSourceOptions" | ||||
|                                                         :key="dict.value" | ||||
|                                                         :label="dict.value" | ||||
|                                                 >{{ dict.label }}</el-radio> | ||||
|                                             </el-radio-group> | ||||
|                                     </el-form-item> | ||||
|                                     <el-form-item label="变更类别 1-收入 2-支出" prop="changeType"> | ||||
|                                         <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-form-item> | ||||
|                                     <el-form-item label="变更前余额" prop="balanceBefore"> | ||||
|                                         <el-input v-model="form.balanceBefore" placeholder="变更前余额" | ||||
|                                                       /> | ||||
|                                     </el-form-item> | ||||
|                                     <el-form-item label="变更后余额" prop="balanceAfter"> | ||||
|                                         <el-input v-model="form.balanceAfter" placeholder="变更后余额" | ||||
|                                                       /> | ||||
|                                     </el-form-item> | ||||
|                                     <el-form-item label="备注" prop="remark"> | ||||
|                                         <el-input | ||||
|                                                     v-model="form.remark" | ||||
|                                                     type="textarea" | ||||
|                                                     :rows="2" | ||||
|                                                     placeholder="请输入内容"> | ||||
|                                             </el-input> | ||||
|                                     </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> | ||||
|         <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="用户id" prop="userId"> | ||||
|               <el-input | ||||
|                 v-model="form.userId" | ||||
|                 placeholder="用户id" | ||||
|               /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="变更来源 (member_change_source)" prop="changeSource"> | ||||
|               <el-radio-group v-model="form.changeSource"> | ||||
|                 <el-radio | ||||
|                   v-for="dict in changeSourceOptions" | ||||
|                   :key="dict.value" | ||||
|                   :label="dict.value" | ||||
|                 >{{ dict.label }}</el-radio> | ||||
|               </el-radio-group> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="变更类别 1-收入 2-支出" prop="changeType"> | ||||
|               <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-form-item> | ||||
|             <el-form-item label="变更前余额" prop="balanceBefore"> | ||||
|               <el-input | ||||
|                 v-model="form.balanceBefore" | ||||
|                 placeholder="变更前余额" | ||||
|               /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="变更后余额" prop="balanceAfter"> | ||||
|               <el-input | ||||
|                 v-model="form.balanceAfter" | ||||
|                 placeholder="变更后余额" | ||||
|               /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="备注" prop="remark"> | ||||
|               <el-input | ||||
|                 v-model="form.remark" | ||||
|                 type="textarea" | ||||
|                 :rows="2" | ||||
|                 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 {addMemberBalanceLog, delMemberBalanceLog, getMemberBalanceLog, listMemberBalanceLog, updateMemberBalanceLog} from '@/api/admin/member-balance-log' | ||||
|      | ||||
|     export default { | ||||
|         name: 'MemberBalanceLog', | ||||
|         components: { | ||||
|         }, | ||||
|         data() { | ||||
|             return { | ||||
|                 // 遮罩层 | ||||
|                 loading: true, | ||||
|                 // 选中数组 | ||||
|                 ids: [], | ||||
|                 // 非单个禁用 | ||||
|                 single: true, | ||||
|                 // 非多个禁用 | ||||
|                 multiple: true, | ||||
|                 // 总条数 | ||||
|                 total: 0, | ||||
|                 // 弹出层标题 | ||||
|                 title: '', | ||||
|                 // 是否显示弹出层 | ||||
|                 open: false, | ||||
|                 isEdit: false, | ||||
|                 // 类型数据字典 | ||||
|                 typeOptions: [], | ||||
|                 memberBalanceLogList: [], | ||||
|                 changeSourceOptions: [], | ||||
|                 // 关系表类型 | ||||
|                  | ||||
|                 // 查询参数 | ||||
|                 queryParams: { | ||||
|                     pageIndex: 1, | ||||
|                     pageSize: 10, | ||||
|                     changeSource:undefined, | ||||
|                     changeType:undefined, | ||||
|                      | ||||
|                 }, | ||||
|                 // 表单参数 | ||||
|                 form: { | ||||
|                 }, | ||||
|                 // 表单校验 | ||||
|                 rules: {changeSource:  [ {required: true, message: '变更来源 (member_change_source)不能为空', trigger: 'blur'} ], | ||||
|                 changeType:  [ {required: true, message: '变更类别 1-收入 2-支出不能为空', trigger: 'blur'} ], | ||||
|                 } | ||||
|         } | ||||
|         }, | ||||
|         created() { | ||||
|             this.getList() | ||||
|             this.getDicts('member_change_source').then(response => { | ||||
|                 this.changeSourceOptions = response.data | ||||
|             }) | ||||
|             }, | ||||
|         methods: { | ||||
|             /** 查询参数列表 */ | ||||
|             getList() { | ||||
|                 this.loading = true | ||||
|                 listMemberBalanceLog(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|                         this.memberBalanceLogList = response.data.list | ||||
|                         this.total = response.data.count | ||||
|                         this.loading = false | ||||
|                     } | ||||
|                 ) | ||||
|             }, | ||||
|             // 取消按钮 | ||||
|             cancel() { | ||||
|                 this.open = false | ||||
|                 this.reset() | ||||
|             }, | ||||
|             // 表单重置 | ||||
|             reset() { | ||||
|                 this.form = { | ||||
|                  | ||||
|                 id: undefined, | ||||
|                 userId: undefined, | ||||
|                 changeSource: undefined, | ||||
|                 changeType: undefined, | ||||
|                 amount: undefined, | ||||
|                 balanceBefore: undefined, | ||||
|                 balanceAfter: undefined, | ||||
|                 remark: undefined, | ||||
|             } | ||||
|                 this.resetForm('form') | ||||
|             }, | ||||
|             getImgList: function() { | ||||
|               this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl | ||||
|             }, | ||||
|             fileClose: function() { | ||||
|               this.fileOpen = false | ||||
|             }, | ||||
|             changeSourceFormat(row) { | ||||
|                 return this.selectDictLabel(this.changeSourceOptions, row.changeSource) | ||||
|             }, | ||||
|             // 关系 | ||||
|             // 文件 | ||||
|             /** 搜索按钮操作 */ | ||||
|             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 | ||||
|                 getMemberBalanceLog(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) { | ||||
|                             updateMemberBalanceLog(this.form).then(response => { | ||||
|                                 if (response.code === 200) { | ||||
|                                     this.msgSuccess(response.msg) | ||||
|                                     this.open = false | ||||
|                                     this.getList() | ||||
|                                 } else { | ||||
|                                     this.msgError(response.msg) | ||||
|                                 } | ||||
|                             }) | ||||
|                         } else { | ||||
|                             addMemberBalanceLog(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 | ||||
| import { addMemberBalanceLog, delMemberBalanceLog, getMemberBalanceLog, listMemberBalanceLog, updateMemberBalanceLog } from '@/api/admin/member-balance-log' | ||||
|  | ||||
|                 this.$confirm('是否确认删除编号为"' + Ids + '"的数据项?', '警告', { | ||||
|                     confirmButtonText: '确定', | ||||
|                     cancelButtonText: '取消', | ||||
|                     type: 'warning' | ||||
|                 }).then(function () { | ||||
|                       return delMemberBalanceLog( { 'ids': Ids }) | ||||
|                 }).then((response) => { | ||||
|                    if (response.code === 200) { | ||||
|                      this.msgSuccess(response.msg) | ||||
|                      this.open = false | ||||
|                      this.getList() | ||||
|                    } else { | ||||
|                      this.msgError(response.msg) | ||||
|                    } | ||||
|                 }).catch(function () { | ||||
|                 }) | ||||
|             } | ||||
|         } | ||||
| export default { | ||||
|   name: 'MemberBalanceLog', | ||||
|   components: { | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       // 遮罩层 | ||||
|       loading: true, | ||||
|       // 选中数组 | ||||
|       ids: [], | ||||
|       // 非单个禁用 | ||||
|       single: true, | ||||
|       // 非多个禁用 | ||||
|       multiple: true, | ||||
|       // 总条数 | ||||
|       total: 0, | ||||
|       // 弹出层标题 | ||||
|       title: '', | ||||
|       // 是否显示弹出层 | ||||
|       open: false, | ||||
|       isEdit: false, | ||||
|       // 类型数据字典 | ||||
|       typeOptions: [], | ||||
|       memberBalanceLogList: [], | ||||
|       changeSourceOptions: [], | ||||
|       // 关系表类型 | ||||
|  | ||||
|       // 查询参数 | ||||
|       queryParams: { | ||||
|         pageIndex: 1, | ||||
|         pageSize: 10, | ||||
|         changeSource: undefined, | ||||
|         changeType: undefined | ||||
|  | ||||
|       }, | ||||
|       // 表单参数 | ||||
|       form: { | ||||
|       }, | ||||
|       // 表单校验 | ||||
|       rules: { changeSource: [{ required: true, message: '变更来源 (member_change_source)不能为空', trigger: 'blur' }], | ||||
|         changeType: [{ required: true, message: '变更类别 1-收入 2-支出不能为空', trigger: 'blur' }] | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   created() { | ||||
|     this.getList() | ||||
|     this.getDicts('member_change_source').then(response => { | ||||
|       this.changeSourceOptions = response.data | ||||
|     }) | ||||
|   }, | ||||
|   methods: { | ||||
|     /** 查询参数列表 */ | ||||
|     getList() { | ||||
|       this.loading = true | ||||
|       listMemberBalanceLog(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|         this.memberBalanceLogList = response.data.list | ||||
|         this.total = response.data.count | ||||
|         this.loading = false | ||||
|       } | ||||
|       ) | ||||
|     }, | ||||
|     // 取消按钮 | ||||
|     cancel() { | ||||
|       this.open = false | ||||
|       this.reset() | ||||
|     }, | ||||
|     // 表单重置 | ||||
|     reset() { | ||||
|       this.form = { | ||||
|  | ||||
|         id: undefined, | ||||
|         userId: undefined, | ||||
|         changeSource: undefined, | ||||
|         changeType: undefined, | ||||
|         amount: undefined, | ||||
|         balanceBefore: undefined, | ||||
|         balanceAfter: undefined, | ||||
|         remark: undefined | ||||
|       } | ||||
|       this.resetForm('form') | ||||
|     }, | ||||
|     getImgList: function() { | ||||
|       this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl | ||||
|     }, | ||||
|     fileClose: function() { | ||||
|       this.fileOpen = false | ||||
|     }, | ||||
|     changeSourceFormat(row) { | ||||
|       return this.selectDictLabel(this.changeSourceOptions, row.changeSource) | ||||
|     }, | ||||
|     // 关系 | ||||
|     // 文件 | ||||
|     /** 搜索按钮操作 */ | ||||
|     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 | ||||
|       getMemberBalanceLog(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) { | ||||
|             updateMemberBalanceLog(this.form).then(response => { | ||||
|               if (response.code === 200) { | ||||
|                 this.msgSuccess(response.msg) | ||||
|                 this.open = false | ||||
|                 this.getList() | ||||
|               } else { | ||||
|                 this.msgError(response.msg) | ||||
|               } | ||||
|             }) | ||||
|           } else { | ||||
|             addMemberBalanceLog(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 delMemberBalanceLog({ '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> | ||||
|  | ||||
| @ -1,290 +1,296 @@ | ||||
|  | ||||
| <template> | ||||
|     <BasicLayout> | ||||
|         <template #wrapper> | ||||
|             <el-card class="box-card"> | ||||
|                 <el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px"> | ||||
|                      | ||||
|                     <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> | ||||
|   <BasicLayout> | ||||
|     <template #wrapper> | ||||
|       <el-card class="box-card"> | ||||
|         <el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px"> | ||||
|  | ||||
|                 <el-row :gutter="10" class="mb8"> | ||||
|                     <el-col :span="1.5"> | ||||
|                         <el-button | ||||
|                                 v-permisaction="['admin:memberBalance: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:memberBalance: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:memberBalance:remove']" | ||||
|                                 type="danger" | ||||
|                                 icon="el-icon-delete" | ||||
|                                 size="mini" | ||||
|                                 :disabled="multiple" | ||||
|                                 @click="handleDelete" | ||||
|                         >删除 | ||||
|                         </el-button> | ||||
|                     </el-col> | ||||
|                 </el-row> | ||||
|           <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="memberBalanceList" @selection-change="handleSelectionChange"> | ||||
|                     <el-table-column type="selection" width="55" align="center"/> | ||||
|                     <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:memberBalance: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:memberBalance:remove']" | ||||
|                               size="mini" | ||||
|                               type="text" | ||||
|                               icon="el-icon-delete" | ||||
|                             >删除 | ||||
|                             </el-button> | ||||
|                          </el-popconfirm> | ||||
|                         </template> | ||||
|                     </el-table-column> | ||||
|                 </el-table> | ||||
|         <el-row :gutter="10" class="mb8"> | ||||
|           <el-col :span="1.5"> | ||||
|             <el-button | ||||
|               v-permisaction="['admin:memberBalance: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:memberBalance: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:memberBalance:remove']" | ||||
|               type="danger" | ||||
|               icon="el-icon-delete" | ||||
|               size="mini" | ||||
|               :disabled="multiple" | ||||
|               @click="handleDelete" | ||||
|             >删除 | ||||
|             </el-button> | ||||
|           </el-col> | ||||
|         </el-row> | ||||
|  | ||||
|                 <pagination | ||||
|                         v-show="total>0" | ||||
|                         :total="total" | ||||
|                         :page.sync="queryParams.pageIndex" | ||||
|                         :limit.sync="queryParams.pageSize" | ||||
|                         @pagination="getList" | ||||
|                 /> | ||||
|         <el-table v-loading="loading" :data="memberBalanceList" @selection-change="handleSelectionChange"> | ||||
|           <el-table-column type="selection" width="55" align="center" /> | ||||
|           <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:memberBalance: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:memberBalance:remove']" | ||||
|                   size="mini" | ||||
|                   type="text" | ||||
|                   icon="el-icon-delete" | ||||
|                 >删除 | ||||
|                 </el-button> | ||||
|               </el-popconfirm> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|         </el-table> | ||||
|  | ||||
|                 <!-- 添加或修改对话框 --> | ||||
|                 <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="totalAmont"> | ||||
|                                         <el-input v-model="form.totalAmont" placeholder="总余额" | ||||
|                                                       /> | ||||
|                                     </el-form-item> | ||||
|                                     <el-form-item label="可用余额" prop="freeAmount"> | ||||
|                                         <el-input v-model="form.freeAmount" placeholder="可用余额" | ||||
|                                                       /> | ||||
|                                     </el-form-item> | ||||
|                                     <el-form-item label="冻结金额" prop="frozenAmount"> | ||||
|                                         <el-input v-model="form.frozenAmount" 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> | ||||
|         <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="totalAmont"> | ||||
|               <el-input | ||||
|                 v-model="form.totalAmont" | ||||
|                 placeholder="总余额" | ||||
|               /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="可用余额" prop="freeAmount"> | ||||
|               <el-input | ||||
|                 v-model="form.freeAmount" | ||||
|                 placeholder="可用余额" | ||||
|               /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="冻结金额" prop="frozenAmount"> | ||||
|               <el-input | ||||
|                 v-model="form.frozenAmount" | ||||
|                 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 {addMemberBalance, delMemberBalance, getMemberBalance, listMemberBalance, updateMemberBalance} from '@/api/admin/member-balance' | ||||
|      | ||||
|     export default { | ||||
|         name: 'MemberBalance', | ||||
|         components: { | ||||
|         }, | ||||
|         data() { | ||||
|             return { | ||||
|                 // 遮罩层 | ||||
|                 loading: true, | ||||
|                 // 选中数组 | ||||
|                 ids: [], | ||||
|                 // 非单个禁用 | ||||
|                 single: true, | ||||
|                 // 非多个禁用 | ||||
|                 multiple: true, | ||||
|                 // 总条数 | ||||
|                 total: 0, | ||||
|                 // 弹出层标题 | ||||
|                 title: '', | ||||
|                 // 是否显示弹出层 | ||||
|                 open: false, | ||||
|                 isEdit: false, | ||||
|                 // 类型数据字典 | ||||
|                 typeOptions: [], | ||||
|                 memberBalanceList: [], | ||||
|                  | ||||
|                 // 关系表类型 | ||||
|                  | ||||
|                 // 查询参数 | ||||
|                 queryParams: { | ||||
|                     pageIndex: 1, | ||||
|                     pageSize: 10, | ||||
|                      | ||||
|                 }, | ||||
|                 // 表单参数 | ||||
|                 form: { | ||||
|                 }, | ||||
|                 // 表单校验 | ||||
|                 rules: {} | ||||
|         } | ||||
|         }, | ||||
|         created() { | ||||
|             this.getList() | ||||
|             }, | ||||
|         methods: { | ||||
|             /** 查询参数列表 */ | ||||
|             getList() { | ||||
|                 this.loading = true | ||||
|                 listMemberBalance(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|                         this.memberBalanceList = response.data.list | ||||
|                         this.total = response.data.count | ||||
|                         this.loading = false | ||||
|                     } | ||||
|                 ) | ||||
|             }, | ||||
|             // 取消按钮 | ||||
|             cancel() { | ||||
|                 this.open = false | ||||
|                 this.reset() | ||||
|             }, | ||||
|             // 表单重置 | ||||
|             reset() { | ||||
|                 this.form = { | ||||
|                  | ||||
|                 id: undefined, | ||||
|                 totalAmont: undefined, | ||||
|                 freeAmount: undefined, | ||||
|                 frozenAmount: 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 | ||||
|                 getMemberBalance(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) { | ||||
|                             updateMemberBalance(this.form).then(response => { | ||||
|                                 if (response.code === 200) { | ||||
|                                     this.msgSuccess(response.msg) | ||||
|                                     this.open = false | ||||
|                                     this.getList() | ||||
|                                 } else { | ||||
|                                     this.msgError(response.msg) | ||||
|                                 } | ||||
|                             }) | ||||
|                         } else { | ||||
|                             addMemberBalance(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 | ||||
| import { addMemberBalance, delMemberBalance, getMemberBalance, listMemberBalance, updateMemberBalance } from '@/api/admin/member-balance' | ||||
|  | ||||
|                 this.$confirm('是否确认删除编号为"' + Ids + '"的数据项?', '警告', { | ||||
|                     confirmButtonText: '确定', | ||||
|                     cancelButtonText: '取消', | ||||
|                     type: 'warning' | ||||
|                 }).then(function () { | ||||
|                       return delMemberBalance( { 'ids': Ids }) | ||||
|                 }).then((response) => { | ||||
|                    if (response.code === 200) { | ||||
|                      this.msgSuccess(response.msg) | ||||
|                      this.open = false | ||||
|                      this.getList() | ||||
|                    } else { | ||||
|                      this.msgError(response.msg) | ||||
|                    } | ||||
|                 }).catch(function () { | ||||
|                 }) | ||||
|             } | ||||
|         } | ||||
| export default { | ||||
|   name: 'MemberBalance', | ||||
|   components: { | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       // 遮罩层 | ||||
|       loading: true, | ||||
|       // 选中数组 | ||||
|       ids: [], | ||||
|       // 非单个禁用 | ||||
|       single: true, | ||||
|       // 非多个禁用 | ||||
|       multiple: true, | ||||
|       // 总条数 | ||||
|       total: 0, | ||||
|       // 弹出层标题 | ||||
|       title: '', | ||||
|       // 是否显示弹出层 | ||||
|       open: false, | ||||
|       isEdit: false, | ||||
|       // 类型数据字典 | ||||
|       typeOptions: [], | ||||
|       memberBalanceList: [], | ||||
|  | ||||
|       // 关系表类型 | ||||
|  | ||||
|       // 查询参数 | ||||
|       queryParams: { | ||||
|         pageIndex: 1, | ||||
|         pageSize: 10 | ||||
|  | ||||
|       }, | ||||
|       // 表单参数 | ||||
|       form: { | ||||
|       }, | ||||
|       // 表单校验 | ||||
|       rules: {} | ||||
|     } | ||||
|   }, | ||||
|   created() { | ||||
|     this.getList() | ||||
|   }, | ||||
|   methods: { | ||||
|     /** 查询参数列表 */ | ||||
|     getList() { | ||||
|       this.loading = true | ||||
|       listMemberBalance(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|         this.memberBalanceList = response.data.list | ||||
|         this.total = response.data.count | ||||
|         this.loading = false | ||||
|       } | ||||
|       ) | ||||
|     }, | ||||
|     // 取消按钮 | ||||
|     cancel() { | ||||
|       this.open = false | ||||
|       this.reset() | ||||
|     }, | ||||
|     // 表单重置 | ||||
|     reset() { | ||||
|       this.form = { | ||||
|  | ||||
|         id: undefined, | ||||
|         totalAmont: undefined, | ||||
|         freeAmount: undefined, | ||||
|         frozenAmount: 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 | ||||
|       getMemberBalance(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) { | ||||
|             updateMemberBalance(this.form).then(response => { | ||||
|               if (response.code === 200) { | ||||
|                 this.msgSuccess(response.msg) | ||||
|                 this.open = false | ||||
|                 this.getList() | ||||
|               } else { | ||||
|                 this.msgError(response.msg) | ||||
|               } | ||||
|             }) | ||||
|           } else { | ||||
|             addMemberBalance(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 delMemberBalance({ '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> | ||||
|  | ||||
| @ -1,17 +1,17 @@ | ||||
| <template> | ||||
|     <BasicLayout> | ||||
|         <template #wrapper> | ||||
|             <el-card class="box-card"> | ||||
|                 <el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px"> | ||||
|   <BasicLayout> | ||||
|     <template #wrapper> | ||||
|       <el-card class="box-card"> | ||||
|         <el-form ref="queryForm" :model="queryParams" :inline="true" label-width="68px"> | ||||
|  | ||||
|                     <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-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-row :gutter="10" class="mb8"> | ||||
|           <!-- <el-col :span="1.5"> | ||||
|                         <el-button | ||||
|                                 v-permisaction="['admin:memberRenwaLog:add']" | ||||
|                                 type="primary" | ||||
| @ -21,7 +21,7 @@ | ||||
|                         >新增 | ||||
|                         </el-button> | ||||
|                     </el-col> --> | ||||
|                     <!-- <el-col :span="1.5"> | ||||
|           <!-- <el-col :span="1.5"> | ||||
|                         <el-button | ||||
|                                 v-permisaction="['admin:memberRenwaLog:edit']" | ||||
|                                 type="success" | ||||
| @ -32,284 +32,325 @@ | ||||
|                         >修改 | ||||
|                         </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> | ||||
|                     </el-col> | ||||
|                 </el-row> | ||||
|           <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> | ||||
|           </el-col> | ||||
|         </el-row> | ||||
|  | ||||
|                 <el-table v-loading="loading" :data="memberRenwaLogList" @selection-change="handleSelectionChange"> | ||||
|                     <el-table-column type="selection" width="55" align="center" /> | ||||
|         <el-table v-loading="loading" :data="memberRenwaLogList" @selection-change="handleSelectionChange"> | ||||
|           <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"> | ||||
|                         <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 label="付款地址" align="center" prop="fromAddress" :show-overflow-tooltip="true" /> | ||||
|                     <el-table-column label="代币" align="center" prop="coin" :show-overflow-tooltip="true" /> | ||||
|           <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" | ||||
|           > | ||||
|             <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 label="付款地址" align="center" prop="fromAddress" :show-overflow-tooltip="true" /> | ||||
|           <el-table-column label="代币" align="center" prop="coin" :show-overflow-tooltip="true" /> | ||||
|  | ||||
|                     <el-table-column label="创建时间" align="center" prop="createdAt" :show-overflow-tooltip="true"> | ||||
|                         <template slot-scope="scope"> | ||||
|                             <span>{{ parseTime(scope.row.createdAt) }}</span> | ||||
|                         </template> | ||||
|                     </el-table-column> | ||||
|                     <el-table-column label="支付时间" align="center" prop="paymentTime" :show-overflow-tooltip="true"> | ||||
|                         <template slot-scope="scope"> | ||||
|                             <span>{{ parseTime(scope.row.paymentTime) }}</span> | ||||
|                         </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="修改" | ||||
|           <el-table-column label="创建时间" align="center" prop="createdAt" :show-overflow-tooltip="true"> | ||||
|             <template slot-scope="scope"> | ||||
|               <span>{{ parseTime(scope.row.createdAt) }}</span> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column label="支付时间" align="center" prop="paymentTime" :show-overflow-tooltip="true"> | ||||
|             <template slot-scope="scope"> | ||||
|               <span>{{ parseTime(scope.row.paymentTime) }}</span> | ||||
|             </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:memberRenwaLog:edit']" size="mini" | ||||
|                                     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-button> | ||||
|                             </el-popconfirm> | ||||
|                         </template> | ||||
|                     </el-table-column> | ||||
|                 </el-table> | ||||
|               <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"> | ||||
|                     <el-form ref="form" :model="form" :rules="rules" label-width="80px"> | ||||
|         <!-- 添加或修改对话框 --> | ||||
|         <el-dialog :title="title" :visible.sync="open" width="500px"> | ||||
|           <el-form ref="form" :model="form" :rules="rules" label-width="80px"> | ||||
|  | ||||
|                         <el-form-item label="套餐id" prop="renwalId"> | ||||
|                             <el-input v-model="form.renwalId" placeholder="套餐id" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="续期套餐名称" prop="renwalName"> | ||||
|                             <el-input v-model="form.renwalName" placeholder="续期套餐名称" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="续期时长(天数)" prop="renwalDuration"> | ||||
|                             <el-input v-model="form.renwalDuration" placeholder="续期时长(天数)" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="订单状态" prop="status"> | ||||
|                             {{ statusFormat(form.status) }} | ||||
|                             <el-input v-model="form.status" placeholder="订单状态(member_renwal_log_status)" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="应付金额" prop="payableAmount"> | ||||
|                             <el-input v-model="form.payableAmount" placeholder="应付金额" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="实付金额" prop="actualPaymentAmount"> | ||||
|                             <el-input v-model="form.actualPaymentAmount" placeholder="实付金额" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="付款地址" prop="fromAddress"> | ||||
|                             <el-input v-model="form.fromAddress" placeholder="付款地址" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="代币" prop="coin"> | ||||
|                             <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-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> | ||||
|             <el-form-item label="套餐id" prop="renwalId"> | ||||
|               <el-input v-model="form.renwalId" placeholder="套餐id" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="续期套餐名称" prop="renwalName"> | ||||
|               <el-input v-model="form.renwalName" placeholder="续期套餐名称" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="续期时长(天数)" prop="renwalDuration"> | ||||
|               <el-input v-model="form.renwalDuration" placeholder="续期时长(天数)" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="订单状态" prop="status"> | ||||
|               {{ statusFormat(form.status) }} | ||||
|               <el-input v-model="form.status" placeholder="订单状态(member_renwal_log_status)" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="应付金额" prop="payableAmount"> | ||||
|               <el-input v-model="form.payableAmount" placeholder="应付金额" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="实付金额" prop="actualPaymentAmount"> | ||||
|               <el-input v-model="form.actualPaymentAmount" placeholder="实付金额" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="付款地址" prop="fromAddress"> | ||||
|               <el-input v-model="form.fromAddress" placeholder="付款地址" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="代币" prop="coin"> | ||||
|               <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-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 { addMemberRenwaLog, delMemberRenwaLog, getMemberRenwaLog, listMemberRenwaLog, updateMemberRenwaLog } from '@/api/admin/member-renwa-log' | ||||
|  | ||||
| export default { | ||||
|     name: 'MemberRenwaLog', | ||||
|     components: { | ||||
|     }, | ||||
|     data() { | ||||
|         return { | ||||
|             // 遮罩层 | ||||
|             loading: true, | ||||
|             // 选中数组 | ||||
|             ids: [], | ||||
|             // 非单个禁用 | ||||
|             single: true, | ||||
|             // 非多个禁用 | ||||
|             multiple: true, | ||||
|             // 总条数 | ||||
|             total: 0, | ||||
|             // 弹出层标题 | ||||
|             title: '', | ||||
|             // 是否显示弹出层 | ||||
|             open: false, | ||||
|             isEdit: false, | ||||
|             // 类型数据字典 | ||||
|             typeOptions: [], | ||||
|             memberRenwaLogList: [], | ||||
|             statusOptions: [], | ||||
|             // 关系表类型 | ||||
|   name: 'MemberRenwaLog', | ||||
|   components: { | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       // 遮罩层 | ||||
|       loading: true, | ||||
|       // 选中数组 | ||||
|       ids: [], | ||||
|       // 非单个禁用 | ||||
|       single: true, | ||||
|       // 非多个禁用 | ||||
|       multiple: true, | ||||
|       // 总条数 | ||||
|       total: 0, | ||||
|       // 弹出层标题 | ||||
|       title: '', | ||||
|       // 是否显示弹出层 | ||||
|       open: false, | ||||
|       isEdit: false, | ||||
|       // 类型数据字典 | ||||
|       typeOptions: [], | ||||
|       memberRenwaLogList: [], | ||||
|       statusOptions: [], | ||||
|       // 关系表类型 | ||||
|  | ||||
|             // 查询参数 | ||||
|             queryParams: { | ||||
|                 pageIndex: 1, | ||||
|                 pageSize: 10, | ||||
|                 idOrder: "desc" | ||||
|             }, | ||||
|             // 表单参数 | ||||
|             form: { | ||||
|             }, | ||||
|             // 表单校验 | ||||
|             rules: {} | ||||
|         } | ||||
|     }, | ||||
|     created() { | ||||
|         this.getList() | ||||
|         this.getDicts('member_renwal_log_status').then(response => { | ||||
|             this.statusOptions = response.data | ||||
|         }) | ||||
|     }, | ||||
|     methods: { | ||||
|         /** 查询参数列表 */ | ||||
|         getList() { | ||||
|             this.loading = true | ||||
|             listMemberRenwaLog(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|                 this.memberRenwaLogList = response.data.list | ||||
|                 this.total = response.data.count | ||||
|                 this.loading = false | ||||
|             } | ||||
|             ) | ||||
|         }, | ||||
|         // 取消按钮 | ||||
|         cancel() { | ||||
|             this.open = false | ||||
|             this.reset() | ||||
|         }, | ||||
|         // 表单重置 | ||||
|         reset() { | ||||
|             this.form = { | ||||
|  | ||||
|                 id: undefined, | ||||
|                 renwalId: undefined, | ||||
|                 renwalName: undefined, | ||||
|                 renwalDuration: undefined, | ||||
|                 status: undefined, | ||||
|                 payableAmount: undefined, | ||||
|                 actualPaymentAmount: undefined, | ||||
|                 fromAddress: undefined, | ||||
|                 coin: undefined, | ||||
|                 paymentTime: undefined, | ||||
|             } | ||||
|             this.resetForm('form') | ||||
|         }, | ||||
|         getImgList: function () { | ||||
|             this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl | ||||
|         }, | ||||
|         fileClose: function () { | ||||
|             this.fileOpen = false | ||||
|         }, | ||||
|         statusFormat(status) { | ||||
|             return this.selectDictLabel(this.statusOptions, status) | ||||
|         }, | ||||
|         // 关系 | ||||
|         // 文件 | ||||
|         /** 搜索按钮操作 */ | ||||
|         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 | ||||
|             getMemberRenwaLog(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) { | ||||
|                         updateMemberRenwaLog(this.form).then(response => { | ||||
|                             if (response.code === 200) { | ||||
|                                 this.msgSuccess(response.msg) | ||||
|                                 this.open = false | ||||
|                                 this.getList() | ||||
|                             } else { | ||||
|                                 this.msgError(response.msg) | ||||
|                             } | ||||
|                         }) | ||||
|                     } else { | ||||
|                         addMemberRenwaLog(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 delMemberRenwaLog({ 'ids': Ids }) | ||||
|             }).then((response) => { | ||||
|                 if (response.code === 200) { | ||||
|                     this.msgSuccess(response.msg) | ||||
|                     this.open = false | ||||
|                     this.getList() | ||||
|                 } else { | ||||
|                     this.msgError(response.msg) | ||||
|                 } | ||||
|             }).catch(function () { | ||||
|             }) | ||||
|         } | ||||
|       // 查询参数 | ||||
|       queryParams: { | ||||
|         pageIndex: 1, | ||||
|         pageSize: 10, | ||||
|         idOrder: 'desc' | ||||
|       }, | ||||
|       // 表单参数 | ||||
|       form: { | ||||
|       }, | ||||
|       // 表单校验 | ||||
|       rules: {} | ||||
|     } | ||||
|   }, | ||||
|   created() { | ||||
|     this.getList() | ||||
|     this.getDicts('member_renwal_log_status').then(response => { | ||||
|       this.statusOptions = response.data | ||||
|     }) | ||||
|   }, | ||||
|   methods: { | ||||
|     /** 查询参数列表 */ | ||||
|     getList() { | ||||
|       this.loading = true | ||||
|       listMemberRenwaLog(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|         this.memberRenwaLogList = response.data.list | ||||
|         this.total = response.data.count | ||||
|         this.loading = false | ||||
|       } | ||||
|       ) | ||||
|     }, | ||||
|     // 取消按钮 | ||||
|     cancel() { | ||||
|       this.open = false | ||||
|       this.reset() | ||||
|     }, | ||||
|     // 表单重置 | ||||
|     reset() { | ||||
|       this.form = { | ||||
|  | ||||
|         id: undefined, | ||||
|         renwalId: undefined, | ||||
|         renwalName: undefined, | ||||
|         renwalDuration: undefined, | ||||
|         status: undefined, | ||||
|         payableAmount: undefined, | ||||
|         actualPaymentAmount: undefined, | ||||
|         fromAddress: undefined, | ||||
|         coin: undefined, | ||||
|         paymentTime: undefined | ||||
|       } | ||||
|       this.resetForm('form') | ||||
|     }, | ||||
|     getImgList: function() { | ||||
|       this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl | ||||
|     }, | ||||
|     fileClose: function() { | ||||
|       this.fileOpen = false | ||||
|     }, | ||||
|     statusFormat(status) { | ||||
|       return this.selectDictLabel(this.statusOptions, status) | ||||
|     }, | ||||
|     // 关系 | ||||
|     // 文件 | ||||
|     /** 搜索按钮操作 */ | ||||
|     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 | ||||
|       getMemberRenwaLog(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) { | ||||
|             updateMemberRenwaLog(this.form).then(response => { | ||||
|               if (response.code === 200) { | ||||
|                 this.msgSuccess(response.msg) | ||||
|                 this.open = false | ||||
|                 this.getList() | ||||
|               } else { | ||||
|                 this.msgError(response.msg) | ||||
|               } | ||||
|             }) | ||||
|           } else { | ||||
|             addMemberRenwaLog(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 delMemberRenwaLog({ '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> | ||||
|  | ||||
| @ -1,351 +1,414 @@ | ||||
| <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="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-select> | ||||
|                     </el-form-item> | ||||
|   <BasicLayout> | ||||
|     <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> | ||||
|           <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> | ||||
|  | ||||
|                     <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-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: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> | ||||
|                     </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> | ||||
|                     </el-col> | ||||
|                 </el-row> | ||||
|         <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> | ||||
|           </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> | ||||
|           </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> | ||||
|           </el-col> | ||||
|         </el-row> | ||||
|  | ||||
|                 <el-table v-loading="loading" :data="memberRenwalConfigList" @selection-change="handleSelectionChange"> | ||||
|                     <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="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="isDefault"> | ||||
|                         <template slot-scope="scope"> | ||||
|                             {{ defaultFormat(scope.row.isVisible) }} | ||||
|                         </template> | ||||
|                     </el-table-column> | ||||
|                     <el-table-column label="是否默认套餐" align="center" :defaultFormat="statusFormat" prop="isDefault">\ | ||||
|                         <template slot-scope="scope"> | ||||
|                             {{ defaultFormat(scope.row.isDefault) }} | ||||
|                         </template> | ||||
|                     </el-table-column> | ||||
|                     <el-table-column label="套餐状态" align="center" prop="status" :formatter="statusFormat" width="100"> | ||||
|                         <template slot-scope="scope"> | ||||
|                             {{ statusFormat(scope.row) }} | ||||
|                         </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: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-button> | ||||
|                             </el-popconfirm> | ||||
|                         </template> | ||||
|                     </el-table-column> | ||||
|                 </el-table> | ||||
|         <el-table v-loading="loading" :data="memberRenwalConfigList" @selection-change="handleSelectionChange"> | ||||
|           <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="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 label="是否可见" align="center" prop="isDefault"> | ||||
|             <template slot-scope="scope"> | ||||
|               {{ defaultFormat(scope.row.isVisible) }} | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column label="是否默认套餐" align="center" :default-format="statusFormat" prop="isDefault">\ | ||||
|             <template slot-scope="scope"> | ||||
|               {{ defaultFormat(scope.row.isDefault) }} | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column label="套餐状态" align="center" prop="status" :formatter="statusFormat" width="100"> | ||||
|             <template slot-scope="scope"> | ||||
|               {{ statusFormat(scope.row) }} | ||||
|             </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: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-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"> | ||||
|                     <el-form ref="form" :model="form" :rules="rules" label-width="120px"> | ||||
|         <!-- 添加或修改对话框 --> | ||||
|         <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="packageName"> | ||||
|                             <el-input v-model="form.packageName" placeholder="套餐名称" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="套餐名称(英文)" prop="packageNameEn"> | ||||
|                             <el-input v-model="form.packageNameEn" placeholder="套餐名称(英文)" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="续期时间(天)" prop="durationDay"> | ||||
|                             <el-input v-model="form.durationDay" type="number" :min="1" placeholder="续期时间(天)" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="原始单价" prop="originalPrice"> | ||||
|                             <el-input v-model="form.originalPrice" placeholder="原始单价" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="折扣价格" prop="discountPrice"> | ||||
|                             <el-input v-model="form.discountPrice" placeholder="折扣价格" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="排序(顺序)" prop="sort"> | ||||
|                             <el-input v-model="form.sort" type="number" :min="1" placeholder="排序(顺序)" /> | ||||
|                         </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> | ||||
|                             </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> | ||||
|                             </el-radio-group> | ||||
|                         </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-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> | ||||
|             <el-form-item label="套餐名称" prop="packageName"> | ||||
|               <el-input v-model="form.packageName" placeholder="套餐名称" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="套餐名称(英文)" prop="packageNameEn"> | ||||
|               <el-input v-model="form.packageNameEn" placeholder="套餐名称(英文)" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="续期时间(天)" prop="durationDay"> | ||||
|               <el-input v-model="form.durationDay" type="number" :min="1" placeholder="续期时间(天)" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="原始单价" prop="originalPrice"> | ||||
|               <el-input v-model="form.originalPrice" placeholder="原始单价" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="折扣价格" prop="discountPrice"> | ||||
|               <el-input v-model="form.discountPrice" placeholder="折扣价格" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="排序(顺序)" prop="sort"> | ||||
|               <el-input v-model="form.sort" type="number" :min="1" placeholder="排序(顺序)" /> | ||||
|             </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> | ||||
|               </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> | ||||
|               </el-radio-group> | ||||
|             </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-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 { addMemberRenwalConfig, delMemberRenwalConfig, getMemberRenwalConfig, listMemberRenwalConfig, updateMemberRenwalConfig } from '@/api/admin/member-renwal-config' | ||||
|  | ||||
| export default { | ||||
|     name: 'MemberRenwalConfig', | ||||
|     components: { | ||||
|     }, | ||||
|     data() { | ||||
|         return { | ||||
|             // 遮罩层 | ||||
|             loading: true, | ||||
|             // 选中数组 | ||||
|             ids: [], | ||||
|             // 非单个禁用 | ||||
|             single: true, | ||||
|             // 非多个禁用 | ||||
|             multiple: true, | ||||
|             // 总条数 | ||||
|             total: 0, | ||||
|             // 弹出层标题 | ||||
|             title: '', | ||||
|             // 是否显示弹出层 | ||||
|             open: false, | ||||
|             isEdit: false, | ||||
|             // 类型数据字典 | ||||
|             typeOptions: [], | ||||
|             defaultOptions: [{ | ||||
|                 label: '是', | ||||
|                 value: 1 | ||||
|             }, { | ||||
|                 label: '否', | ||||
|                 value: 2 | ||||
|             }], | ||||
|             memberRenwalConfigList: [], | ||||
|             statusOptions: [], | ||||
|             // 关系表类型 | ||||
|   name: 'MemberRenwalConfig', | ||||
|   components: { | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       // 遮罩层 | ||||
|       loading: true, | ||||
|       // 选中数组 | ||||
|       ids: [], | ||||
|       // 非单个禁用 | ||||
|       single: true, | ||||
|       // 非多个禁用 | ||||
|       multiple: true, | ||||
|       // 总条数 | ||||
|       total: 0, | ||||
|       // 弹出层标题 | ||||
|       title: '', | ||||
|       // 是否显示弹出层 | ||||
|       open: false, | ||||
|       isEdit: false, | ||||
|       // 类型数据字典 | ||||
|       typeOptions: [], | ||||
|       defaultOptions: [{ | ||||
|         label: '是', | ||||
|         value: 1 | ||||
|       }, { | ||||
|         label: '否', | ||||
|         value: 2 | ||||
|       }], | ||||
|       memberRenwalConfigList: [], | ||||
|       statusOptions: [], | ||||
|       // 关系表类型 | ||||
|  | ||||
|             // 查询参数 | ||||
|             queryParams: { | ||||
|                 pageIndex: 1, | ||||
|                 pageSize: 10, | ||||
|                 packageName: undefined, | ||||
|                 status: undefined, | ||||
|                 sortOrder: "asc", | ||||
|             }, | ||||
|             // 表单参数 | ||||
|             form: { | ||||
|             }, | ||||
|             // 表单校验 | ||||
|             rules: { | ||||
|                 packageName: [{ required: true, message: '套餐名称不能为空', trigger: 'blur' }], | ||||
|                 packageNameEn:[{required:true,message:'套餐英文名称不能为空',trigger:'blur'}], | ||||
|                 status: [{ required: true, message: '套餐状态不能为空', trigger: 'blur' }], | ||||
|                 durationDay: [{ required: true, message: '套餐时长不能为空', trigger: 'blur' }], | ||||
|                 originalPrice: [{ required: true, message: '原价不能为空', trigger: 'blur' }], | ||||
|             } | ||||
|         } | ||||
|     }, | ||||
|     created() { | ||||
|         this.getList() | ||||
|         this.getDicts('member_renwal_config_status').then(response => { | ||||
|             this.statusOptions = response.data | ||||
|         }) | ||||
|     }, | ||||
|     methods: { | ||||
|         /** 查询参数列表 */ | ||||
|         getList() { | ||||
|             this.loading = true | ||||
|             listMemberRenwalConfig(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|                 this.memberRenwalConfigList = response.data.list | ||||
|                 this.total = response.data.count | ||||
|                 this.loading = false | ||||
|             } | ||||
|             ) | ||||
|         }, | ||||
|         // 取消按钮 | ||||
|         cancel() { | ||||
|             this.open = false | ||||
|             this.reset() | ||||
|         }, | ||||
|         // 表单重置 | ||||
|         reset() { | ||||
|             this.form = { | ||||
|  | ||||
|                 id: undefined, | ||||
|                 packageName: undefined, | ||||
|                 durationDay: undefined, | ||||
|                 originalPrice: undefined, | ||||
|                 discountPrice: undefined, | ||||
|                 isDefault: 1, | ||||
|                 isVisible: 1, | ||||
|                 sort: 0, | ||||
|                 status: 'enable', | ||||
|             } | ||||
|             this.resetForm('form') | ||||
|         }, | ||||
|         getImgList: function () { | ||||
|             this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl | ||||
|         }, | ||||
|         fileClose: function () { | ||||
|             this.fileOpen = false | ||||
|         }, | ||||
|         statusFormat(row) { | ||||
|             return this.selectDictLabel(this.statusOptions, row.status) | ||||
|         }, | ||||
|         defaultFormat(val) { | ||||
|             var label = "" | ||||
|  | ||||
|             this.defaultOptions.forEach(element => { | ||||
|                 if (element.value === val) { | ||||
|                     label = element.label | ||||
|                 } | ||||
|             }); | ||||
|  | ||||
|             return label | ||||
|         }, | ||||
|         // 关系 | ||||
|         // 文件 | ||||
|         /** 搜索按钮操作 */ | ||||
|         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 | ||||
|             getMemberRenwalConfig(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.originalPrice = Number(this.form.originalPrice) | ||||
|                     this.form.durationDay = Number(this.form.durationDay) | ||||
|                     this.form.sort = Number(this.form.sort) | ||||
|  | ||||
|                     if (this.form.id !== undefined) { | ||||
|                         updateMemberRenwalConfig(this.form).then(response => { | ||||
|                             if (response.code === 200) { | ||||
|                                 this.msgSuccess(response.msg) | ||||
|                                 this.open = false | ||||
|                                 this.getList() | ||||
|                             } else { | ||||
|                                 this.msgError(response.msg) | ||||
|                             } | ||||
|                         }) | ||||
|                     } else { | ||||
|                         addMemberRenwalConfig(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 delMemberRenwalConfig({ 'ids': Ids }) | ||||
|             }).then((response) => { | ||||
|                 if (response.code === 200) { | ||||
|                     this.msgSuccess(response.msg) | ||||
|                     this.open = false | ||||
|                     this.getList() | ||||
|                 } else { | ||||
|                     this.msgError(response.msg) | ||||
|                 } | ||||
|             }).catch(function () { | ||||
|             }) | ||||
|         } | ||||
|       // 查询参数 | ||||
|       queryParams: { | ||||
|         pageIndex: 1, | ||||
|         pageSize: 10, | ||||
|         packageName: undefined, | ||||
|         status: undefined, | ||||
|         sortOrder: 'asc' | ||||
|       }, | ||||
|       // 表单参数 | ||||
|       form: { | ||||
|       }, | ||||
|       // 表单校验 | ||||
|       rules: { | ||||
|         packageName: [{ required: true, message: '套餐名称不能为空', trigger: 'blur' }], | ||||
|         packageNameEn: [{ required: true, message: '套餐英文名称不能为空', trigger: 'blur' }], | ||||
|         status: [{ required: true, message: '套餐状态不能为空', trigger: 'blur' }], | ||||
|         durationDay: [{ required: true, message: '套餐时长不能为空', trigger: 'blur' }], | ||||
|         originalPrice: [{ required: true, message: '原价不能为空', trigger: 'blur' }] | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   created() { | ||||
|     this.getList() | ||||
|     this.getDicts('member_renwal_config_status').then(response => { | ||||
|       this.statusOptions = response.data | ||||
|     }) | ||||
|   }, | ||||
|   methods: { | ||||
|     /** 查询参数列表 */ | ||||
|     getList() { | ||||
|       this.loading = true | ||||
|       listMemberRenwalConfig(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|         this.memberRenwalConfigList = response.data.list | ||||
|         this.total = response.data.count | ||||
|         this.loading = false | ||||
|       } | ||||
|       ) | ||||
|     }, | ||||
|     // 取消按钮 | ||||
|     cancel() { | ||||
|       this.open = false | ||||
|       this.reset() | ||||
|     }, | ||||
|     // 表单重置 | ||||
|     reset() { | ||||
|       this.form = { | ||||
|  | ||||
|         id: undefined, | ||||
|         packageName: undefined, | ||||
|         durationDay: undefined, | ||||
|         originalPrice: undefined, | ||||
|         discountPrice: undefined, | ||||
|         isDefault: 1, | ||||
|         isVisible: 1, | ||||
|         sort: 0, | ||||
|         status: 'enable' | ||||
|       } | ||||
|       this.resetForm('form') | ||||
|     }, | ||||
|     getImgList: function() { | ||||
|       this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl | ||||
|     }, | ||||
|     fileClose: function() { | ||||
|       this.fileOpen = false | ||||
|     }, | ||||
|     statusFormat(row) { | ||||
|       return this.selectDictLabel(this.statusOptions, row.status) | ||||
|     }, | ||||
|     defaultFormat(val) { | ||||
|       var label = '' | ||||
|  | ||||
|       this.defaultOptions.forEach(element => { | ||||
|         if (element.value === val) { | ||||
|           label = element.label | ||||
|         } | ||||
|       }) | ||||
|  | ||||
|       return label | ||||
|     }, | ||||
|     // 关系 | ||||
|     // 文件 | ||||
|     /** 搜索按钮操作 */ | ||||
|     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 | ||||
|       getMemberRenwalConfig(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.originalPrice = Number(this.form.originalPrice) | ||||
|           this.form.durationDay = Number(this.form.durationDay) | ||||
|           this.form.sort = Number(this.form.sort) | ||||
|  | ||||
|           if (this.form.id !== undefined) { | ||||
|             updateMemberRenwalConfig(this.form).then(response => { | ||||
|               if (response.code === 200) { | ||||
|                 this.msgSuccess(response.msg) | ||||
|                 this.open = false | ||||
|                 this.getList() | ||||
|               } else { | ||||
|                 this.msgError(response.msg) | ||||
|               } | ||||
|             }) | ||||
|           } else { | ||||
|             addMemberRenwalConfig(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 delMemberRenwalConfig({ '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> | ||||
|  | ||||
| @ -1,148 +1,159 @@ | ||||
| <template> | ||||
|     <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 }} | ||||
|             </el-form-item> | ||||
|             <el-form-item label="用户" prop="userName"> | ||||
|                 {{ form.userName }} | ||||
|             </el-form-item> | ||||
|             <el-form-item label="提现金额(U)" prop="amount"> | ||||
|                 {{ form.amount }} | ||||
|             </el-form-item> | ||||
|             <el-form-item label="提现状态" prop="statusName"> | ||||
|                 {{ form.statusName }} | ||||
|             </el-form-item> | ||||
|             <!-- <el-form-item label="确认时间" prop="confirmTime"> | ||||
|   <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 }} | ||||
|       </el-form-item> | ||||
|       <el-form-item label="用户" prop="userName"> | ||||
|         {{ form.userName }} | ||||
|       </el-form-item> | ||||
|       <el-form-item label="提现金额(U)" prop="amount"> | ||||
|         {{ form.amount }} | ||||
|       </el-form-item> | ||||
|       <el-form-item label="提现状态" prop="statusName"> | ||||
|         {{ form.statusName }} | ||||
|       </el-form-item> | ||||
|       <!-- <el-form-item label="确认时间" prop="confirmTime"> | ||||
|                 <el-date-picker v-model="form.confirmTime" type="datetime" placeholder="选择日期"> | ||||
|                 </el-date-picker> | ||||
|             </el-form-item> --> | ||||
|             <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-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">{{ | ||||
|                                 item.label }}</el-radio> | ||||
|                     </template> | ||||
|                 </el-radio-group> | ||||
|             </el-form-item> | ||||
|             <el-form-item v-if="form.status==='approved'" label="交易Hash" prop="hash"> | ||||
|                 <el-input v-model="form.hash" placeholder="交易Hash" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="备注" prop="remark"> | ||||
|                 <el-input v-model="form.remark" type="textarea" maxlength="200" show-word-limit placeholder="备注" /> | ||||
|             </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> | ||||
|       <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-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" | ||||
|             >{{ | ||||
|               item.label }}</el-radio> | ||||
|           </template> | ||||
|         </el-radio-group> | ||||
|       </el-form-item> | ||||
|       <el-form-item v-if="form.status==='approved'" label="交易Hash" prop="hash"> | ||||
|         <el-input v-model="form.hash" placeholder="交易Hash" /> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="备注" prop="remark"> | ||||
|         <el-input v-model="form.remark" type="textarea" maxlength="200" show-word-limit placeholder="备注" /> | ||||
|       </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 { approve, confirm } from '@/api/admin/member-withdrawal-log' | ||||
|  | ||||
| export default { | ||||
|     name: 'approve', | ||||
|     props: { | ||||
|         open: { | ||||
|             type: Boolean, | ||||
|             default: false | ||||
|         }, | ||||
|         title: { | ||||
|             type: String, | ||||
|             default: "提现审核" | ||||
|         }, | ||||
|         data: { | ||||
|             type: Object, | ||||
|             default: () => { } | ||||
|         } | ||||
|   name: 'Approve', | ||||
|   props: { | ||||
|     open: { | ||||
|       type: Boolean, | ||||
|       default: false | ||||
|     }, | ||||
|     watch: { | ||||
|         open(val) { | ||||
|             this.dialogVisible = val | ||||
|         }, | ||||
|         data(val) { | ||||
|             this.form = { approveStatus: 1, ...val } | ||||
|         } | ||||
|     title: { | ||||
|       type: String, | ||||
|       default: '提现审核' | ||||
|     }, | ||||
|     data() { | ||||
|         return { | ||||
|             dialogVisible: this.open, | ||||
|             form: { | ||||
|  | ||||
|             }, | ||||
|             loading: false, | ||||
|             // approveStatus:1, | ||||
|             rules: { | ||||
|                 approveStatus: [{ required: true, message: '请选择审核状态', trigger: 'trigger' }] | ||||
|             }, | ||||
|             options: [{ | ||||
|                 label: '通过', | ||||
|                 value: 1 | ||||
|             }, { | ||||
|                 label: '拒绝', | ||||
|                 value: 2 | ||||
|             }], | ||||
|             confirmOptions: [ | ||||
|                 { | ||||
|                     label: "已转账", | ||||
|                     value: 1 | ||||
|                 }, | ||||
|                 { | ||||
|                     label: "转账失败", | ||||
|                     value: 2 | ||||
|                 } | ||||
|             ] | ||||
|         } | ||||
|     }, | ||||
|     methods: { | ||||
|         submitForm() { | ||||
|             this.loading = true | ||||
|             //审核 | ||||
|             if (this.form.status === 'pending') { | ||||
|                 approve({ id: this.form.id, approval: this.form.approveStatus, remark: this.form.remark }).then(res => { | ||||
|                     if (res.code === 200) { | ||||
|                         this.msgSuccess(res.msg) | ||||
|                         this.cancel() | ||||
|                     } | ||||
|                 }) | ||||
|                     .finally(f => { | ||||
|                         this.loading = false | ||||
|                     }) | ||||
|             } 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) | ||||
|                     if (res.code === 200) { | ||||
|                         this.msgSuccess(res.msg) | ||||
|                         this.cancel() | ||||
|                     } | ||||
|                 }) | ||||
|                     .finally(f => { | ||||
|                         this.loading = false | ||||
|                     }) | ||||
|             } else { | ||||
|                 this.loading = false | ||||
|             } | ||||
|         }, | ||||
|         closeDialog() { | ||||
|             this.form = {} | ||||
|             this.loading = false | ||||
|             this.$emit('update:open', false) | ||||
|         }, | ||||
|         cancel() { | ||||
|             this.dialogVisible = false | ||||
|         } | ||||
|     data: { | ||||
|       type: Object, | ||||
|       default: () => { } | ||||
|     } | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       dialogVisible: this.open, | ||||
|       form: { | ||||
|  | ||||
|       }, | ||||
|       loading: false, | ||||
|       // approveStatus:1, | ||||
|       rules: { | ||||
|         approveStatus: [{ required: true, message: '请选择审核状态', trigger: 'trigger' }] | ||||
|       }, | ||||
|       options: [{ | ||||
|         label: '通过', | ||||
|         value: 1 | ||||
|       }, { | ||||
|         label: '拒绝', | ||||
|         value: 2 | ||||
|       }], | ||||
|       confirmOptions: [ | ||||
|         { | ||||
|           label: '已转账', | ||||
|           value: 1 | ||||
|         }, | ||||
|         { | ||||
|           label: '转账失败', | ||||
|           value: 2 | ||||
|         } | ||||
|       ] | ||||
|     } | ||||
|   }, | ||||
|   watch: { | ||||
|     open(val) { | ||||
|       this.dialogVisible = val | ||||
|     }, | ||||
|     data(val) { | ||||
|       this.form = { approveStatus: 1, ...val } | ||||
|     } | ||||
|   }, | ||||
|   methods: { | ||||
|     submitForm() { | ||||
|       this.loading = true | ||||
|       // 审核 | ||||
|       if (this.form.status === 'pending') { | ||||
|         approve({ id: this.form.id, approval: this.form.approveStatus, remark: this.form.remark }).then(res => { | ||||
|           if (res.code === 200) { | ||||
|             this.msgSuccess(res.msg) | ||||
|             this.cancel() | ||||
|           } | ||||
|         }) | ||||
|           .finally(f => { | ||||
|             this.loading = false | ||||
|           }) | ||||
|       } 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) | ||||
|           if (res.code === 200) { | ||||
|             this.msgSuccess(res.msg) | ||||
|             this.cancel() | ||||
|           } | ||||
|         }) | ||||
|           .finally(f => { | ||||
|             this.loading = false | ||||
|           }) | ||||
|       } else { | ||||
|         this.loading = false | ||||
|       } | ||||
|     }, | ||||
|     closeDialog() { | ||||
|       this.form = {} | ||||
|       this.loading = false | ||||
|       this.$emit('update:open', false) | ||||
|     }, | ||||
|     cancel() { | ||||
|       this.dialogVisible = false | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </script> | ||||
| </script> | ||||
|  | ||||
| @ -1,27 +1,40 @@ | ||||
| <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="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-select> | ||||
|                     </el-form-item> | ||||
|   <BasicLayout> | ||||
|     <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> | ||||
|           <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> | ||||
|  | ||||
|                     <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-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  | ||||
|         <el-row :gutter="10" class="mb8"> | ||||
|           <!-- <el-col :span="1.5"> | ||||
|                         <el-button | ||||
|                                 v-permisaction="['admin:memberWithdrawalLog:add']" | ||||
|                                 type="primary" | ||||
|                                 icon="el-icon-plus" | ||||
| @ -41,302 +54,337 @@ | ||||
|                         >修改 | ||||
|                         </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> | ||||
|                     </el-col> | ||||
|                 </el-row> | ||||
|           <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> | ||||
|           </el-col> | ||||
|         </el-row> | ||||
|  | ||||
|                 <el-table v-loading="loading" :data="memberWithdrawalLogList" @selection-change="handleSelectionChange"> | ||||
|                     <el-table-column type="selection" width="55" align="center" /> | ||||
|                     <el-table-column label="网络名称" align="center" prop="networkName" :show-overflow-tooltip="true" /> | ||||
|                     <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 v-loading="loading" :data="memberWithdrawalLogList" @selection-change="handleSelectionChange"> | ||||
|           <el-table-column type="selection" width="55" align="center" /> | ||||
|           <el-table-column label="网络名称" align="center" prop="networkName" :show-overflow-tooltip="true" /> | ||||
|           <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"> | ||||
|                             {{ statusFormat(scope.row.status) }} | ||||
|                         </template> | ||||
|                     </el-table-column> | ||||
|                     <el-table-column label="提交时间" align="center" prop="createdTime" width="160px"> | ||||
|                         <template slot-scope="scope"> | ||||
|                             <span>{{ parseTime(scope.row.createdAt) }}</span> | ||||
|                         </template> | ||||
|                     </el-table-column> | ||||
|                     <el-table-column label="确认时间" align="center" prop="confirmTime" width="160px"> | ||||
|                         <template slot-scope="scope"> | ||||
|                             <span>{{ parseTime(scope.row.confirmTime) }}</span> | ||||
|                         </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="修改" | ||||
|           <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="createdTime" width="160px"> | ||||
|             <template slot-scope="scope"> | ||||
|               <span>{{ parseTime(scope.row.createdAt) }}</span> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column label="确认时间" align="center" prop="confirmTime" width="160px"> | ||||
|             <template slot-scope="scope"> | ||||
|               <span>{{ parseTime(scope.row.confirmTime) }}</span> | ||||
|             </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:memberWithdrawalLog:edit']" | ||||
|                                     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> | ||||
|                             <el-button v-permisaction="['admin:memberWithdrawalLog:confirm']" | ||||
|                                 v-if="scope.row.status == 'approved'" @click="handleApprove(scope.row, '确认到账')" | ||||
|                                 size="mini" type="text">确认到账 | ||||
|                             </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-button> | ||||
|                             </el-popconfirm> | ||||
|                         </template> | ||||
|                     </el-table-column> | ||||
|                 </el-table> | ||||
|               <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-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-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"> | ||||
|                     <el-form ref="form" :model="form" :rules="rules" label-width="80px"> | ||||
|         <!-- 添加或修改对话框 --> | ||||
|         <el-dialog :title="title" :visible.sync="open" width="500px"> | ||||
|           <el-form ref="form" :model="form" :rules="rules" label-width="80px"> | ||||
|  | ||||
|                         <el-form-item label="网络id" prop="networkId"> | ||||
|                             <el-input v-model="form.networkId" placeholder="网络id" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="网络名称" prop="networkName"> | ||||
|                             <el-input v-model="form.networkName" placeholder="网络名称" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="用户id" prop="userId"> | ||||
|                             <el-input v-model="form.userId" placeholder="用户id" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="提现金额(U)" prop="amount"> | ||||
|                             <el-input v-model="form.amount" placeholder="提现金额(U)" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="提现状态(member_withdrawal_status)" prop="status"> | ||||
|                             <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-form-item> | ||||
|                         <el-form-item label="手续费比例" prop="fee"> | ||||
|                             <el-input v-model="form.fee" placeholder="手续费比例" /> | ||||
|                         </el-form-item> | ||||
|                         <el-form-item label="备注" prop="remark"> | ||||
|                             <el-input v-model="form.remark" 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> | ||||
|             <approve :open.sync="showApprove" :title="showApproveTitle" :data="approveData"  @update:open="handleClose"></approve> | ||||
|         </template> | ||||
|     </BasicLayout> | ||||
|             <el-form-item label="网络id" prop="networkId"> | ||||
|               <el-input v-model="form.networkId" placeholder="网络id" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="网络名称" prop="networkName"> | ||||
|               <el-input v-model="form.networkName" placeholder="网络名称" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="用户id" prop="userId"> | ||||
|               <el-input v-model="form.userId" placeholder="用户id" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="提现金额(U)" prop="amount"> | ||||
|               <el-input v-model="form.amount" placeholder="提现金额(U)" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="提现状态(member_withdrawal_status)" prop="status"> | ||||
|               <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-form-item> | ||||
|             <el-form-item label="手续费比例" prop="fee"> | ||||
|               <el-input v-model="form.fee" placeholder="手续费比例" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="备注" prop="remark"> | ||||
|               <el-input v-model="form.remark" 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> | ||||
|       <approve :open.sync="showApprove" :title="showApproveTitle" :data="approveData" @update:open="handleClose" /> | ||||
|     </template> | ||||
|   </BasicLayout> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { addMemberWithdrawalLog, delMemberWithdrawalLog, getMemberWithdrawalLog, listMemberWithdrawalLog, updateMemberWithdrawalLog } from '@/api/admin/member-withdrawal-log' | ||||
| import approve from './approve.vue' | ||||
| export default { | ||||
|     name: 'MemberWithdrawalLog', | ||||
|     components: { | ||||
|         approve | ||||
|     }, | ||||
|     data() { | ||||
|         return { | ||||
|             // 遮罩层 | ||||
|             loading: true, | ||||
|             // 选中数组 | ||||
|             ids: [], | ||||
|             // 非单个禁用 | ||||
|             single: true, | ||||
|             // 非多个禁用 | ||||
|             multiple: true, | ||||
|             // 总条数 | ||||
|             total: 0, | ||||
|             // 弹出层标题 | ||||
|             title: '', | ||||
|             // 是否显示弹出层 | ||||
|             open: false, | ||||
|             isEdit: false, | ||||
|             // 类型数据字典 | ||||
|             typeOptions: [], | ||||
|             memberWithdrawalLogList: [], | ||||
|             statusOptions: [], | ||||
|             // 关系表类型 | ||||
|   name: 'MemberWithdrawalLog', | ||||
|   components: { | ||||
|     approve | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       // 遮罩层 | ||||
|       loading: true, | ||||
|       // 选中数组 | ||||
|       ids: [], | ||||
|       // 非单个禁用 | ||||
|       single: true, | ||||
|       // 非多个禁用 | ||||
|       multiple: true, | ||||
|       // 总条数 | ||||
|       total: 0, | ||||
|       // 弹出层标题 | ||||
|       title: '', | ||||
|       // 是否显示弹出层 | ||||
|       open: false, | ||||
|       isEdit: false, | ||||
|       // 类型数据字典 | ||||
|       typeOptions: [], | ||||
|       memberWithdrawalLogList: [], | ||||
|       statusOptions: [], | ||||
|       // 关系表类型 | ||||
|  | ||||
|             // 查询参数 | ||||
|             queryParams: { | ||||
|                 pageIndex: 1, | ||||
|                 pageSize: 10, | ||||
|                 networkName: undefined, | ||||
|                 status: undefined, | ||||
|                 idOrder: "desc" | ||||
|             }, | ||||
|             showApprove: false, | ||||
|             showApproveTitle: "", | ||||
|             approveData: {}, | ||||
|             // 表单参数 | ||||
|             form: { | ||||
|             }, | ||||
|             // 表单校验 | ||||
|             rules: { | ||||
|                 networkName: [{ required: true, message: '网络名称不能为空', trigger: 'blur' }], | ||||
|                 status: [{ required: true, message: '提现状态(member_withdrawal_status)不能为空', trigger: 'blur' }], | ||||
|             } | ||||
|         } | ||||
|     }, | ||||
|     created() { | ||||
|         this.getList() | ||||
|         this.getDicts('member_withdrawal_status').then(response => { | ||||
|             this.statusOptions = response.data | ||||
|         }) | ||||
|     }, | ||||
|     methods: { | ||||
|         /** 查询参数列表 */ | ||||
|         getList() { | ||||
|             this.loading = true | ||||
|             listMemberWithdrawalLog(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|                 this.memberWithdrawalLogList = response.data.list | ||||
|                 this.total = response.data.count | ||||
|                 this.loading = false | ||||
|             } | ||||
|             ) | ||||
|         }, | ||||
|         // 取消按钮 | ||||
|         cancel() { | ||||
|             this.open = false | ||||
|             this.reset() | ||||
|         }, | ||||
|         // 表单重置 | ||||
|         reset() { | ||||
|             this.form = { | ||||
|  | ||||
|                 id: undefined, | ||||
|                 networkId: undefined, | ||||
|                 networkName: undefined, | ||||
|                 userId: undefined, | ||||
|                 amount: undefined, | ||||
|                 status: undefined, | ||||
|                 confirmTime: undefined, | ||||
|                 fee: undefined, | ||||
|                 remark: undefined, | ||||
|             } | ||||
|             this.resetForm('form') | ||||
|         }, | ||||
|         getImgList: function () { | ||||
|             this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl | ||||
|         }, | ||||
|         fileClose: function () { | ||||
|             this.fileOpen = false | ||||
|         }, | ||||
|         statusFormat(status) { | ||||
|             return this.selectDictLabel(this.statusOptions, status) | ||||
|         }, | ||||
|         handleApprove(row, title) { | ||||
|             this.showApprove = true | ||||
|             this.showApproveTitle = title | ||||
|             this.approveData = {statusName:this.statusFormat(row.status),...row} | ||||
|         }, | ||||
|         // 关系 | ||||
|         // 文件 | ||||
|         /** 搜索按钮操作 */ | ||||
|         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 | ||||
|             getMemberWithdrawalLog(id).then(response => { | ||||
|                 this.form = response.data | ||||
|                 this.open = true | ||||
|                 this.title = '修改用户提现记录' | ||||
|                 this.isEdit = true | ||||
|             }) | ||||
|         }, | ||||
|         handleClose(){ | ||||
|             this.getList() | ||||
|         }, | ||||
|         /** 提交按钮 */ | ||||
|         submitForm: function () { | ||||
|             this.$refs['form'].validate(valid => { | ||||
|                 if (valid) { | ||||
|                     if (this.form.id !== undefined) { | ||||
|                         updateMemberWithdrawalLog(this.form).then(response => { | ||||
|                             if (response.code === 200) { | ||||
|                                 this.msgSuccess(response.msg) | ||||
|                                 this.open = false | ||||
|                                 this.getList() | ||||
|                             } else { | ||||
|                                 this.msgError(response.msg) | ||||
|                             } | ||||
|                         }) | ||||
|                     } else { | ||||
|                         addMemberWithdrawalLog(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 delMemberWithdrawalLog({ 'ids': Ids }) | ||||
|             }).then((response) => { | ||||
|                 if (response.code === 200) { | ||||
|                     this.msgSuccess(response.msg) | ||||
|                     this.open = false | ||||
|                     this.getList() | ||||
|                 } else { | ||||
|                     this.msgError(response.msg) | ||||
|                 } | ||||
|             }).catch(function () { | ||||
|             }) | ||||
|         } | ||||
|       // 查询参数 | ||||
|       queryParams: { | ||||
|         pageIndex: 1, | ||||
|         pageSize: 10, | ||||
|         networkName: undefined, | ||||
|         status: undefined, | ||||
|         idOrder: 'desc' | ||||
|       }, | ||||
|       showApprove: false, | ||||
|       showApproveTitle: '', | ||||
|       approveData: {}, | ||||
|       // 表单参数 | ||||
|       form: { | ||||
|       }, | ||||
|       // 表单校验 | ||||
|       rules: { | ||||
|         networkName: [{ required: true, message: '网络名称不能为空', trigger: 'blur' }], | ||||
|         status: [{ required: true, message: '提现状态(member_withdrawal_status)不能为空', trigger: 'blur' }] | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   created() { | ||||
|     this.getList() | ||||
|     this.getDicts('member_withdrawal_status').then(response => { | ||||
|       this.statusOptions = response.data | ||||
|     }) | ||||
|   }, | ||||
|   methods: { | ||||
|     /** 查询参数列表 */ | ||||
|     getList() { | ||||
|       this.loading = true | ||||
|       listMemberWithdrawalLog(this.addDateRange(this.queryParams, this.dateRange)).then(response => { | ||||
|         this.memberWithdrawalLogList = response.data.list | ||||
|         this.total = response.data.count | ||||
|         this.loading = false | ||||
|       } | ||||
|       ) | ||||
|     }, | ||||
|     // 取消按钮 | ||||
|     cancel() { | ||||
|       this.open = false | ||||
|       this.reset() | ||||
|     }, | ||||
|     // 表单重置 | ||||
|     reset() { | ||||
|       this.form = { | ||||
|  | ||||
|         id: undefined, | ||||
|         networkId: undefined, | ||||
|         networkName: undefined, | ||||
|         userId: undefined, | ||||
|         amount: undefined, | ||||
|         status: undefined, | ||||
|         confirmTime: undefined, | ||||
|         fee: undefined, | ||||
|         remark: undefined | ||||
|       } | ||||
|       this.resetForm('form') | ||||
|     }, | ||||
|     getImgList: function() { | ||||
|       this.form[this.fileIndex] = this.$refs['fileChoose'].resultList[0].fullUrl | ||||
|     }, | ||||
|     fileClose: function() { | ||||
|       this.fileOpen = false | ||||
|     }, | ||||
|     statusFormat(status) { | ||||
|       return this.selectDictLabel(this.statusOptions, status) | ||||
|     }, | ||||
|     handleApprove(row, title) { | ||||
|       this.showApprove = true | ||||
|       this.showApproveTitle = title | ||||
|       this.approveData = { statusName: this.statusFormat(row.status), ...row } | ||||
|     }, | ||||
|     // 关系 | ||||
|     // 文件 | ||||
|     /** 搜索按钮操作 */ | ||||
|     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 | ||||
|       getMemberWithdrawalLog(id).then(response => { | ||||
|         this.form = response.data | ||||
|         this.open = true | ||||
|         this.title = '修改用户提现记录' | ||||
|         this.isEdit = true | ||||
|       }) | ||||
|     }, | ||||
|     handleClose() { | ||||
|       this.getList() | ||||
|     }, | ||||
|     /** 提交按钮 */ | ||||
|     submitForm: function() { | ||||
|       this.$refs['form'].validate(valid => { | ||||
|         if (valid) { | ||||
|           if (this.form.id !== undefined) { | ||||
|             updateMemberWithdrawalLog(this.form).then(response => { | ||||
|               if (response.code === 200) { | ||||
|                 this.msgSuccess(response.msg) | ||||
|                 this.open = false | ||||
|                 this.getList() | ||||
|               } else { | ||||
|                 this.msgError(response.msg) | ||||
|               } | ||||
|             }) | ||||
|           } else { | ||||
|             addMemberWithdrawalLog(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 delMemberWithdrawalLog({ '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> | ||||
|  | ||||
| @ -315,7 +315,8 @@ export default { | ||||
|         paths: undefined, | ||||
|         action: undefined, | ||||
|         parentId: undefined, | ||||
|         sort: undefined | ||||
|         sort: undefined, | ||||
|         type: 'BUS' | ||||
|       } | ||||
|       this.resetForm('form') | ||||
|     }, | ||||
|  | ||||
		Reference in New Issue
	
	Block a user