Compare commits
	
		
			86 Commits
		
	
	
		
			order
			...
			roomBackgr
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 836fb732c8 | ||
|   | 9a151fbe05 | ||
|   | 07e9a1e8b2 | ||
|   | d3c14383f8 | ||
|   | 5bba43c189 | ||
|   | 74939056ce | ||
|   | 004bf0e03a | ||
|   | b467577792 | ||
|   | 99a1c89643 | ||
|   | b043d8c06e | ||
|   | fb007e763c | ||
|   | 2fddf66a5d | ||
|   | 75bcd232a4 | ||
|   | ae0a3507a6 | ||
|   | 31d6efd60e | ||
|   | 70993f1b4d | ||
|   | e4fb991a98 | ||
|   | b84438c19d | ||
|   | ed9178a1d0 | ||
|   | 78b3a70d5f | ||
|   | baad132403 | ||
|   | c865eae77b | ||
|   | 5d296f8086 | ||
|   | 3f905c2b1e | ||
|   | 7add80a5ae | ||
|   | 0d6019e9f1 | ||
|   | 11ceac5d4f | ||
|   | 289aa70af3 | ||
|   | c8b283b0d8 | ||
|   | 9bec1ba472 | ||
|   | 2c64fc1443 | ||
|   | 097dea0693 | ||
|   | 6abde0b9ec | ||
|   | c99ee00ca8 | ||
|   | c3f70e3c9b | ||
|   | 1e4002a4fa | ||
|   | 090447e1ce | ||
|   | c847b94994 | ||
|   | f91dc1cf62 | ||
|   | 4d5fb57ddf | ||
|   | b174c9818e | ||
|   | c6f979c094 | ||
|   | 475ee45a44 | ||
|   | c4209d6c24 | ||
|   | e77165a1d7 | ||
|   | 8a2c1381e9 | ||
|   | e062c2afa3 | ||
|   | 591495edcc | ||
|   | 25e828f7e4 | ||
|   | 1ab319d372 | ||
|   | 9b6ee433d7 | ||
|   | 9c4aa4efb9 | ||
|   | f228aad967 | ||
|   | e47b57f760 | ||
|   | 4e3bbd9209 | ||
|   | 9f9e7ca81c | ||
|   | 493ad80d1c | ||
|   | a71144b735 | ||
|   | ebf22c8012 | ||
|   | 69dc2de281 | ||
|   | 520e4e4c58 | ||
|   | faa779555c | ||
|   | a62f2a5eca | ||
|   | 65cf443cb4 | ||
|   | 9f2b89d0be | ||
|   | b362a25028 | ||
|   | 3c909bdb97 | ||
|   | d79917ecca | ||
|   | b5de5e5125 | ||
|   | 8cf9dfa2bc | ||
|   | fa41f55a23 | ||
|   | c6487e78bb | ||
|   | de76dc8f56 | ||
|   | 1e67efafe7 | ||
|   | f31dcae058 | ||
|   | aa74f2ed36 | ||
|   | e4cbd9cc35 | ||
|   | 775b8abc93 | ||
|   | e1fb48d900 | ||
|   | 93aded746e | ||
|   | af1d94c1f2 | ||
|   | 89c27b28e7 | ||
|   | f34a7b9430 | ||
|   | fbd4fdcbd1 | ||
|   | 7ea73622cd | ||
|   | 6e66ca4864 | 
| @@ -17,5 +17,6 @@ module.exports = { | ||||
|     'no-unused-vars': 'off', | ||||
|     'no-useless-escape': 'off', | ||||
|     'no-control-regex': 'off', | ||||
|     'no-extra-semi': 'off', | ||||
|   } | ||||
| } | ||||
|   | ||||
							
								
								
									
										110
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										110
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -14,6 +14,7 @@ | ||||
|         "bootstrap": "^3.3.5", | ||||
|         "core-js": "^3.8.3", | ||||
|         "element-plus": "^2.3.14", | ||||
|         "file-saver": "^2.0.5", | ||||
|         "font-awesome": "^4.6.3", | ||||
|         "ionicons": "^2.0.1", | ||||
|         "jquery": "^2.2.0", | ||||
| @@ -21,11 +22,14 @@ | ||||
|         "knockout": "^3.5.1", | ||||
|         "less": "^4.2.0", | ||||
|         "less-loader": "^11.1.3", | ||||
|         "moment-timezone": "^0.5.45", | ||||
|         "node-sass": "^9.0.0", | ||||
|         "popper.js": "^1.16.1", | ||||
|         "sass": "^1.67.0", | ||||
|         "sass-loader": "^13.3.2", | ||||
|         "svgaplayerweb": "^2.3.2", | ||||
|         "unplugin-element-plus": "^0.8.0", | ||||
|         "vue-clipboard2": "^0.3.3", | ||||
|         "vue-router": "^4.0.3", | ||||
|         "vuex": "^4.0.0", | ||||
|         "xlsx": "^0.18.5" | ||||
| @@ -40,6 +44,7 @@ | ||||
|         "@vue/cli-service": "~5.0.0", | ||||
|         "eslint": "^7.32.0", | ||||
|         "eslint-plugin-vue": "^8.0.3", | ||||
|         "script-loader": "^0.7.2", | ||||
|         "unplugin-auto-import": "^0.16.7", | ||||
|         "unplugin-vue-components": "^0.25.2", | ||||
|         "vue": "^3.2.13", | ||||
| @@ -4435,9 +4440,23 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/caniuse-lite": { | ||||
|       "version": "1.0.30001546", | ||||
|       "resolved": "https://registry.npmmirror.com/caniuse-lite/-/caniuse-lite-1.0.30001546.tgz", | ||||
|       "integrity": "sha512-zvtSJwuQFpewSyRrI3AsftF6rM0X80mZkChIt1spBGEvRglCrjTniXvinc8JKRoqTwXAgvqTImaN9igfSMtUBw==" | ||||
|       "version": "1.0.30001651", | ||||
|       "resolved": "https://registry.npmmirror.com/caniuse-lite/-/caniuse-lite-1.0.30001651.tgz", | ||||
|       "integrity": "sha512-9Cf+Xv1jJNe1xPZLGuUXLNkE1BoDkqRqYyFJ9TDYSqhduqA4hu4oR9HluGoWYQC/aj8WHjsGVV+bwkh0+tegRg==", | ||||
|       "funding": [ | ||||
|         { | ||||
|           "type": "opencollective", | ||||
|           "url": "https://opencollective.com/browserslist" | ||||
|         }, | ||||
|         { | ||||
|           "type": "tidelift", | ||||
|           "url": "https://tidelift.com/funding/github/npm/caniuse-lite" | ||||
|         }, | ||||
|         { | ||||
|           "type": "github", | ||||
|           "url": "https://github.com/sponsors/ai" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     "node_modules/case-sensitive-paths-webpack-plugin": { | ||||
|       "version": "2.4.0", | ||||
| @@ -4652,6 +4671,16 @@ | ||||
|         "node": ">=6" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/clipboard": { | ||||
|       "version": "2.0.11", | ||||
|       "resolved": "https://registry.npmmirror.com/clipboard/-/clipboard-2.0.11.tgz", | ||||
|       "integrity": "sha512-C+0bbOqkezLIsmWSvlsXS0Q0bmkugu7jcfMIACB+RDEntIzQIkdr148we28AfSloQLRdZlYL/QYyrq05j/3Faw==", | ||||
|       "dependencies": { | ||||
|         "good-listener": "^1.2.2", | ||||
|         "select": "^1.1.2", | ||||
|         "tiny-emitter": "^2.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/clipboardy": { | ||||
|       "version": "2.3.0", | ||||
|       "resolved": "https://registry.npmmirror.com/clipboardy/-/clipboardy-2.3.0.tgz", | ||||
| @@ -5547,6 +5576,11 @@ | ||||
|         "node": ">=0.4.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/delegate": { | ||||
|       "version": "3.2.0", | ||||
|       "resolved": "https://registry.npmmirror.com/delegate/-/delegate-3.2.0.tgz", | ||||
|       "integrity": "sha512-IofjkYBZaZivn0V8nnsMJGBr4jVLxHDheKSW88PyxS5QC4Vo9ZbZVvhzlSxY87fVq3STR6r+4cGepyHkcWOQSw==" | ||||
|     }, | ||||
|     "node_modules/delegates": { | ||||
|       "version": "1.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/delegates/-/delegates-1.0.0.tgz", | ||||
| @@ -6685,6 +6719,11 @@ | ||||
|         "node": "^10.12.0 || >=12.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/file-saver": { | ||||
|       "version": "2.0.5", | ||||
|       "resolved": "https://registry.npmmirror.com/file-saver/-/file-saver-2.0.5.tgz", | ||||
|       "integrity": "sha512-P9bmyZ3h/PRG+Nzga+rbdI4OEpNDzAVyy74uVO9ATgzLK6VtAsYybF/+TOCvrc0MO793d6+42lLyZTw7/ArVzA==" | ||||
|     }, | ||||
|     "node_modules/fill-range": { | ||||
|       "version": "7.0.1", | ||||
|       "resolved": "https://registry.npmmirror.com/fill-range/-/fill-range-7.0.1.tgz", | ||||
| @@ -7082,6 +7121,14 @@ | ||||
|         "node": "*" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/good-listener": { | ||||
|       "version": "1.2.2", | ||||
|       "resolved": "https://registry.npmmirror.com/good-listener/-/good-listener-1.2.2.tgz", | ||||
|       "integrity": "sha512-goW1b+d9q/HIwbVYZzZ6SsTr4IgE+WA44A0GmPIQstuOrgsFcT7VEJ48nmr9GaRtNu0XTKacFLGnBPAM6Afouw==", | ||||
|       "dependencies": { | ||||
|         "delegate": "^3.1.2" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/gopd": { | ||||
|       "version": "1.0.1", | ||||
|       "resolved": "https://registry.npmmirror.com/gopd/-/gopd-1.0.1.tgz", | ||||
| @@ -8929,6 +8976,25 @@ | ||||
|       "integrity": "sha512-23g5BFj4zdQL/b6tor7Ji+QY4pEfNH784BMslY9Qb0UnJWRAt+lQGLYmRaM0KDBwIG23ffEBELhZDP2rhi9f/Q==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/moment": { | ||||
|       "version": "2.30.1", | ||||
|       "resolved": "https://registry.npmmirror.com/moment/-/moment-2.30.1.tgz", | ||||
|       "integrity": "sha512-uEmtNhbDOrWPFS+hdjFCBfy9f2YoyzRpwcl+DqpC6taX21FzsTLQVbMV/W7PzNSX6x/bhC1zA3c2UQ5NzH6how==", | ||||
|       "engines": { | ||||
|         "node": "*" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/moment-timezone": { | ||||
|       "version": "0.5.45", | ||||
|       "resolved": "https://registry.npmmirror.com/moment-timezone/-/moment-timezone-0.5.45.tgz", | ||||
|       "integrity": "sha512-HIWmqA86KcmCAhnMAN0wuDOARV/525R2+lOLotuGFzn4HO+FH+/645z2wx0Dt3iDv6/p61SIvKnDstISainhLQ==", | ||||
|       "dependencies": { | ||||
|         "moment": "^2.29.4" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": "*" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/mrmime": { | ||||
|       "version": "1.0.1", | ||||
|       "resolved": "https://registry.npmmirror.com/mrmime/-/mrmime-1.0.1.tgz", | ||||
| @@ -10790,6 +10856,12 @@ | ||||
|         "node": ">= 0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/raw-loader": { | ||||
|       "version": "0.5.1", | ||||
|       "resolved": "https://registry.npmmirror.com/raw-loader/-/raw-loader-0.5.1.tgz", | ||||
|       "integrity": "sha512-sf7oGoLuaYAScB4VGr0tzetsYlS8EJH6qnTCfQ/WVEa89hALQ4RQfCKt5xCyPQKPDUbVUAIP1QsxAwfAjlDp7Q==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/read-pkg": { | ||||
|       "version": "5.2.0", | ||||
|       "resolved": "https://registry.npmmirror.com/read-pkg/-/read-pkg-5.2.0.tgz", | ||||
| @@ -11238,6 +11310,15 @@ | ||||
|         "node": ">= 8.9.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/script-loader": { | ||||
|       "version": "0.7.2", | ||||
|       "resolved": "https://registry.npmmirror.com/script-loader/-/script-loader-0.7.2.tgz", | ||||
|       "integrity": "sha512-UMNLEvgOAQuzK8ji8qIscM3GIrRCWN6MmMXGD4SD5l6cSycgGsCo0tX5xRnfQcoghqct0tjHjcykgI1PyBE2aA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "raw-loader": "~0.5.1" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/scss-tokenizer": { | ||||
|       "version": "0.4.3", | ||||
|       "resolved": "https://registry.npmmirror.com/scss-tokenizer/-/scss-tokenizer-0.4.3.tgz", | ||||
| @@ -11261,6 +11342,11 @@ | ||||
|       "integrity": "sha512-4AsO/FrViE/iDNEPaAQlb77tf0csuq27EsVpy6ett584EcRTp6pTDLoGWVxCD77y5iU5FauOvhsI4o1APwPoSQ==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/select": { | ||||
|       "version": "1.1.2", | ||||
|       "resolved": "https://registry.npmmirror.com/select/-/select-1.1.2.tgz", | ||||
|       "integrity": "sha512-OwpTSOfy6xSs1+pwcNrv0RBMOzI39Lp3qQKUTPVVPRjCdNa5JH/oPRiqsesIskK8TVgmRiHwO4KXlV2Li9dANA==" | ||||
|     }, | ||||
|     "node_modules/select-hose": { | ||||
|       "version": "2.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/select-hose/-/select-hose-2.0.0.tgz", | ||||
| @@ -11905,6 +11991,11 @@ | ||||
|       "integrity": "sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/svgaplayerweb": { | ||||
|       "version": "2.3.2", | ||||
|       "resolved": "https://registry.npmmirror.com/svgaplayerweb/-/svgaplayerweb-2.3.2.tgz", | ||||
|       "integrity": "sha512-QuTvNIgy3W6Mi4h74SczEHUtAwb8m3ax7Ai7xRLUuN6hjJh49RGtWOWq1IuF2I7ECcl0HAYn8FcTn99UDz9UiQ==" | ||||
|     }, | ||||
|     "node_modules/svgo": { | ||||
|       "version": "2.8.0", | ||||
|       "resolved": "https://registry.npmmirror.com/svgo/-/svgo-2.8.0.tgz", | ||||
| @@ -12142,6 +12233,11 @@ | ||||
|       "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/tiny-emitter": { | ||||
|       "version": "2.1.0", | ||||
|       "resolved": "https://registry.npmmirror.com/tiny-emitter/-/tiny-emitter-2.1.0.tgz", | ||||
|       "integrity": "sha512-NB6Dk1A9xgQPMoGqC5CVXn123gWyte215ONT5Pp5a0yt4nlEoO1ZWeCwpncaekPHXO60i47ihFnZPiRPjRMq4Q==" | ||||
|     }, | ||||
|     "node_modules/to-fast-properties": { | ||||
|       "version": "2.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz", | ||||
| @@ -12638,6 +12734,14 @@ | ||||
|         "@vue/shared": "3.2.13" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/vue-clipboard2": { | ||||
|       "version": "0.3.3", | ||||
|       "resolved": "https://registry.npmmirror.com/vue-clipboard2/-/vue-clipboard2-0.3.3.tgz", | ||||
|       "integrity": "sha512-aNWXIL2DKgJyY/1OOeITwAQz1fHaCIGvUFHf9h8UcoQBG5a74MkdhS/xqoYe7DNZdQmZRL+TAdIbtUs9OyVjbw==", | ||||
|       "dependencies": { | ||||
|         "clipboard": "^2.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/vue-eslint-parser": { | ||||
|       "version": "8.3.0", | ||||
|       "resolved": "https://registry.npmmirror.com/vue-eslint-parser/-/vue-eslint-parser-8.3.0.tgz", | ||||
|   | ||||
| @@ -14,6 +14,7 @@ | ||||
|     "bootstrap": "^3.3.5", | ||||
|     "core-js": "^3.8.3", | ||||
|     "element-plus": "^2.3.14", | ||||
|     "file-saver": "^2.0.5", | ||||
|     "font-awesome": "^4.6.3", | ||||
|     "ionicons": "^2.0.1", | ||||
|     "jquery": "^2.2.0", | ||||
| @@ -21,11 +22,14 @@ | ||||
|     "knockout": "^3.5.1", | ||||
|     "less": "^4.2.0", | ||||
|     "less-loader": "^11.1.3", | ||||
|     "moment-timezone": "^0.5.45", | ||||
|     "node-sass": "^9.0.0", | ||||
|     "popper.js": "^1.16.1", | ||||
|     "sass": "^1.67.0", | ||||
|     "sass-loader": "^13.3.2", | ||||
|     "svgaplayerweb": "^2.3.2", | ||||
|     "unplugin-element-plus": "^0.8.0", | ||||
|     "vue-clipboard2": "^0.3.3", | ||||
|     "vue-router": "^4.0.3", | ||||
|     "vuex": "^4.0.0", | ||||
|     "xlsx": "^0.18.5" | ||||
| @@ -40,6 +44,7 @@ | ||||
|     "@vue/cli-service": "~5.0.0", | ||||
|     "eslint": "^7.32.0", | ||||
|     "eslint-plugin-vue": "^8.0.3", | ||||
|     "script-loader": "^0.7.2", | ||||
|     "unplugin-auto-import": "^0.16.7", | ||||
|     "unplugin-vue-components": "^0.25.2", | ||||
|     "vue": "^3.2.13", | ||||
|   | ||||
							
								
								
									
										19
									
								
								src/api/GiftPanelManagement/GiftPanelManagement.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								src/api/GiftPanelManagement/GiftPanelManagement.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| // 列表 | ||||
| export const list = query => { | ||||
|     return request({ | ||||
|         url: '/giftPanelTab/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 保存 | ||||
| export const update = query => { | ||||
|     return request({ | ||||
|         url: '/giftPanelTab/update', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										42
									
								
								src/api/SsGuild/SsGuild.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								src/api/SsGuild/SsGuild.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 周期选项下拉框 | ||||
| export const cycleDateList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ssGuild/cycleDateList', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // SS公会列表 | ||||
| export const list = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ssGuild/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 发送金币&批量发送 | ||||
| export const sendGold = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ssGuild/sendGold', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 导出 | ||||
| // export const ssGuildExport = query => { | ||||
| //     return request({ | ||||
| //         url: `/admin/ssGuild/export`, | ||||
| //         method: 'post', | ||||
| //         params: query, | ||||
| //         responseType: 'blob' | ||||
| //     }); | ||||
| // }; | ||||
| // 导出-公会信息 | ||||
| export const ssGuildExport = query => { | ||||
|     window.location.href = `/admin/ssGuild/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
							
								
								
									
										34
									
								
								src/api/VipGive/VipGive.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								src/api/VipGive/VipGive.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| // 查询用户接口 | ||||
| export const getByErbanNo = query => { | ||||
|     return request({ | ||||
|         url: '/admin/user/getByErbanNo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 获取VIP列表接口 | ||||
| export const listAll = query => { | ||||
|     return request({ | ||||
|         url: '/admin/vip/listAll', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 获取列表接口 | ||||
| export const pageRecord = query => { | ||||
|     return request({ | ||||
|         url: '/vipSend/pageRecord', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 赠送VIP接口 | ||||
| export const vipSendSend = query => { | ||||
|     return request({ | ||||
|         url: '/vipSend/send', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										38
									
								
								src/api/lingSmallGames/lingSmallGames.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								src/api/lingSmallGames/lingSmallGames.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 获取游戏列表 | ||||
| export const sysConfKey = query => { | ||||
|     return request({ | ||||
|         url: '/admin/sysConf/key', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 获取列表 | ||||
| export const statisPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/miniGame/leadercc/statis/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 获取详情列表 | ||||
| export const detailPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/miniGame/leadercc/statis/detailPage', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 导出 | ||||
| export const exportForMiniGame = query => { | ||||
|     window.location.href = `/admin/miniGame/leadercc/statis/exportForMiniGame?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 导出弹窗 | ||||
| export const statisExport = query => { | ||||
|     window.location.href = `/admin/miniGame/leadercc/statis/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
							
								
								
									
										70
									
								
								src/api/luckGift/luckGift.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								src/api/luckGift/luckGift.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 奖池拉框 | ||||
| export const listType = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/pool/listType', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 池子列表 | ||||
| export const list = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/pool/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 基础配置 | ||||
| export const getConfig = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/config/getConfig', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 基础配置-修改 | ||||
| export const updateSet = query => { | ||||
|     return request({ | ||||
|         headers: { "Content-Type": 'application/json;charset=UTF-8' }, | ||||
|         url: '/admin/lucky24/config/update', | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // 个人数据 | ||||
| export const personal = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/record/personal', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 汇总 | ||||
| export const platform = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/record/platform', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 保存池子 | ||||
| export const save = query => { | ||||
|     return request({ | ||||
|         headers: { "Content-Type": 'application/json;charset=UTF-8' }, | ||||
|         url: '/admin/lucky24/pool/save', | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // 赠送用户 | ||||
| export const updateUserMulti = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/config/updateUserMulti', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										58
									
								
								src/api/medal/medal.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								src/api/medal/medal.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| // 地区接口 | ||||
| export const listPartitionInfo = query => { | ||||
|     return request({ | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章信息-列表 | ||||
| export const medalPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medal/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章信息-新增&保存 | ||||
| export const medalSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medal/save', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章信息-发放 | ||||
| export const medalSend = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medal/send', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章记录-撤销 | ||||
| export const rollback = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medalRecord/rollback', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章记录-列表 | ||||
| export const medalRecordPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medalRecord/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章记录-勋章列表 | ||||
| export const listAll = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medal/listAll', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| @@ -102,6 +102,14 @@ export const addRecord = query => { | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 保存收款账户 | ||||
| export const savePayAccount = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/savePayAccount', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 违规类查询 | ||||
| export const listRecord = query => { | ||||
|     return request({ | ||||
| @@ -115,3 +123,132 @@ export const exportFamilyMember = query => { | ||||
|     window.location.href = `/admin/family/manage/exportFamilyMember?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 导出-公会信息 | ||||
| export const exportInfo = query => { | ||||
|     window.location.href = `/admin/family/manage/exportFamily?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
|  | ||||
|  | ||||
| // 工资梯度-列表 | ||||
| export const manageList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工资梯度-新增 | ||||
| export const manageAdd = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/add', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工资梯度-删除 | ||||
| export const manageDelete = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/delete', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工会统计-列表 | ||||
| export const statPageFamily = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/wage/stat/pageFamily', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工会统计-单个工会详情 | ||||
| export const listFamilyMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/wage/stat/listFamilyMember', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工会统计-单个工会导出 | ||||
| export const statExportFamilyMember = query => { | ||||
|     window.location.href = `/admin/family/wage/stat/exportFamilyMember?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 工会统计-每日工会详情 | ||||
| export const listFamilyMemberDaily = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/wage/stat/listFamilyMemberDaily', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工会统计-单每日会导出 | ||||
| export const exportFamilyMemberDaily = query => { | ||||
|     window.location.href = `/admin/family/wage/stat/exportFamilyMemberDaily?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 工会统计-导出公会工资统计 | ||||
| export const statExportFamily = query => { | ||||
|     window.location.href = `/admin/family/wage/stat/exportFamily?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 工会统计-导出家族流水 | ||||
| export const incomeExportFamilys = query => { | ||||
|     window.location.href = `/admin/family/income/exportFamily?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 金币流水-列表 | ||||
| export const incomePageFamily = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/income/pageFamily', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 金币流水-详情 | ||||
| export const incomeListFamilyMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/income/listFamilyMember', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 金币流水-导出成员流水信息 | ||||
| export const incomeExportFamily = query => { | ||||
|     window.location.href = `/admin/family/income/exportFamilyMember?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 成员信息-弹窗详情 | ||||
| export const manageListFamilyMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/listFamilyMember', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 成员信息-新增成员 | ||||
| export const addMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/addMember', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 成员信息-设置管理员 | ||||
| export const setManager = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/setManager', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 成员信息-删除管理员 | ||||
| export const removeMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/removeMember', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										94
									
								
								src/api/noblemanNew/noblemanNew.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								src/api/noblemanNew/noblemanNew.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,94 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| // 邀请移除记录 | ||||
| export const pageOperateRecord = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/pageOperateRecord', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 查询公会信息 | ||||
| export const pageFamily = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/pageGuild', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 公会成员信息 | ||||
| export const pageFamilyMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/pageFamilyMember', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 创建公会信息 | ||||
| export const create = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/create', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 删除公会信息 | ||||
| export const dismiss = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/dismiss', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 幸运礼物详情导出  | ||||
| export const luckyGiftRewardRecordExport = query => { | ||||
|     window.location.href = `/admin/luckyGiftRewardRecord/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 公会信息编辑接口 | ||||
| export const update = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/update', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 导出-公会信息 | ||||
| export const exportInfo = query => { | ||||
|     window.location.href = `/admin/guild/manage/exportGuild?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 成员信息-弹窗详情 | ||||
| export const manageListFamilyMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/listGuildMember', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 成员信息-新增成员 | ||||
| export const addMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/addMember', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 成员信息-设置管理员 | ||||
| export const setManager = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/setManager', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 成员信息-删除管理员 | ||||
| export const removeMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/removeMember', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										176
									
								
								src/api/relAgency/relAgency.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										176
									
								
								src/api/relAgency/relAgency.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,176 @@ | ||||
|  | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| // 活动配置 相关接口(一级菜单:活动配置) | ||||
|  | ||||
| // 获取 周期列表 | ||||
| export const getDateCycleList = query => { | ||||
|     return request({ | ||||
|         url: '/anchorSalaryBill/dateCycle/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 获取 公会钻石薪资流水统计 列表 | ||||
| export const getAgencyDiamondFlow = query => { | ||||
|     return request({ | ||||
|         url: '/agency/diamond/flow/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 公会钻石薪资流水统计 导出 | ||||
| // export const agencyDiamondFlowExport = query => { | ||||
| //     return request({ | ||||
| //         url: `/agency/diamond/flow/export`, | ||||
| //         method: 'post', | ||||
| //         params: query, | ||||
| //         responseType: 'blob' | ||||
| //     }); | ||||
| // }; | ||||
| export const agencyDiamondFlowExport = query => { | ||||
|     window.location.href = `/agency/diamond/flow/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 主播薪资操作(不用分区) | ||||
| export const getAnchorSalaryBill = query => { | ||||
|     return request({ | ||||
|         url: '/anchorSalaryBill/anchorSummary/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // salaryType 1钻石兑换薪资明细 2 薪资转赠充值代理 明细 3薪资转增公会长明细 4官方提现 6 薪资兑换金币明细 | ||||
| export const anchorSalaryBillDetail = query => { | ||||
|     return request({ | ||||
|         url: '/anchorSalaryBill/detail/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 充值代理转增薪资  | ||||
| export const chargeAgentList = query => { | ||||
|     return request({ | ||||
|         url: '/anchorSalaryBill/chargeAgent/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 充值代理转增薪资 总值 | ||||
| export const chargeAgentSum = query => { | ||||
|     return request({ | ||||
|         url: '/anchorSalaryBill/chargeAgent/sum', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 官方提现记录 列表 | ||||
| export const agencyWithdrawList = query => { | ||||
|     return request({ | ||||
|         url: '/agencyWithdrawExamine/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 官方提现记录 导出 | ||||
| export const agencyWithdrawExamineExport = query => { | ||||
|     return request({ | ||||
|         url: `/agencyWithdrawExamine/export`, | ||||
|         method: 'post', | ||||
|         params: query, | ||||
|         responseType: 'blob' | ||||
|     }); | ||||
| }; | ||||
| // 官方提现记录 结算 | ||||
| // export const agencyWithdrawSet = query => { | ||||
| //     return request({ | ||||
| //         url: '/agencyWithdrawExamine/settle', | ||||
| //         method: 'post', | ||||
| //         params: query | ||||
| //     }); | ||||
| // }; | ||||
| export const agencyWithdrawSet = query => { | ||||
|     return request({ | ||||
|         url: '/agencyWithdrawExamine/batchSettle', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 官方提现记录 批量结算 | ||||
| export const agencyWithdrawBatchSet = query => { | ||||
|     return request({ | ||||
|         url: '/agencyWithdrawExamine/batchSettle', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 官方提现记录 批量驳回 | ||||
| export const batchReject = query => { | ||||
|     return request({ | ||||
|         url: '/agencyWithdrawExamine/batchReject', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 公会开业数据统计 | ||||
| export const agencyOpenList = query => { | ||||
|     return request({ | ||||
|         url: '/agency/open/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 公会开业数据 详情 | ||||
| export const agencyOpenDetail = query => { | ||||
|     return request({ | ||||
|         url: '/agency/open/detail/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 公会优秀主播数据统计 | ||||
| export const excellentAnchorList = query => { | ||||
|     return request({ | ||||
|         url: '/agency/open/excellentAnchor/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 公会优秀主播数据统计 | ||||
| export const excellentAnchorDetail = query => { | ||||
|     return request({ | ||||
|         url: '/agency/open/excellentAnchor/detail/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 官方提现-国家 | ||||
| export const adminCountry = query => { | ||||
|     return request({ | ||||
|         url: '/admin/country/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // =====================================钻石充值流水======================================= | ||||
| // 查询 | ||||
| export const diamondStatistics = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/diamondStatistics', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| //  导出 | ||||
| export const diamondStatisticsExport = query => { | ||||
|     window.location.href = `/admin/guild/diamondStatistics/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
							
								
								
									
										43
									
								
								src/api/relPrivilegeManage/relPrivilegeManage.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								src/api/relPrivilegeManage/relPrivilegeManage.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
| // 靓号申请管理 列表 | ||||
| export const getPrettyNumberExamineList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/prettyNumber/examine/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 靓号申请管理 通过 | ||||
| export const prettyNumberExaminePass = query => { | ||||
|     return request({ | ||||
|         url: '/admin/prettyNumber/examine/pass', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     });  | ||||
| }; | ||||
| // 靓号申请管理 删除 | ||||
| export const prettyNumberExamineDelete = query => { | ||||
|     return request({ | ||||
|         url: '/admin/prettyNumber/examine/delete', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 靓号申请管理 拒绝 | ||||
| export const prettyNumberExamineReject = query => { | ||||
|     return request({ | ||||
|         url: '/admin/prettyNumber/examine/reject', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 靓号导入 | ||||
| export const erbanUpload = query => { | ||||
|     return request({ | ||||
|         url: '/admin/prettyNumber/upload', | ||||
|         method: 'post', | ||||
|         headers: { 'Content-Type': 'multipart/form-data' }, | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										104
									
								
								src/api/relUserBelongings/relUserBelongings.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								src/api/relUserBelongings/relUserBelongings.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,104 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 用户财产 相关接口(一级菜单:用户财产管理) | ||||
|  | ||||
| // 获取 金币转赠历史列表 | ||||
| export const getGoldCoinTransferList = query => { | ||||
|     return request({ | ||||
|         url: '/gold/give/history', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 获取 金币转赠历史 金币汇总 | ||||
| export const getGoldCoinSumGold = query => { | ||||
|     return request({ | ||||
|         url: '/gold/give/history/sumGold', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
|  | ||||
| // 用户资产排行 列表 | ||||
| export const getUserAssetsList = query => { | ||||
|     return request({ | ||||
|         url: '/userAssets/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 用户资产排行 导出 | ||||
| export const userAssetsExport = query => { | ||||
|     return request({ | ||||
|         url: '/userAssets/export', | ||||
|         method: 'get', | ||||
|         params: query, | ||||
|         responseType: 'blob' | ||||
|     }); | ||||
| }; | ||||
| // 金币钻石操作记录 列表 | ||||
| export const officalGoldSearch = query => { | ||||
|     return request({ | ||||
|         url: '/offical/gold/search', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 金币钻石操作记录 导出 | ||||
| export const officalGoldExport = query => { | ||||
|     return request({ | ||||
|         url: '/offical/gold/export', | ||||
|         method: 'get', | ||||
|         params: query, | ||||
|         responseType: 'blob' | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 操作货币增加/减少 列表  | ||||
| export const officalGoldGive= query => { | ||||
|     return request({ | ||||
|         url: '/offical/gold/give', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|         // data: qs.stringify(query) | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 操作货币增加/减少 查看用户 | ||||
| export const getofficalGoldUserInfo = query => { | ||||
|     return request({ | ||||
|         url: '/offical/gold/userInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 冻结用户资产管理 列表 | ||||
| export const getFrozenRecordList = query => { | ||||
|     return request({ | ||||
|         url: '/frozenRecord/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 冻结用户资产管理 冻结 | ||||
| export const userRecordFrozen= query => { | ||||
|     return request({ | ||||
|         url: '/frozenRecord/frozen', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 冻结用户资产管理 解冻 | ||||
| export const frozenRecordFree= query => { | ||||
|     return request({ | ||||
|         url: '/frozenRecord/free', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										87
									
								
								src/api/roomBackground/roomBackground.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								src/api/roomBackground/roomBackground.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 地区接口 | ||||
| export const listPartitionInfo = query => { | ||||
|     return request({ | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // ==============================================首页ui配置============================================== | ||||
| // 配置 | ||||
| export const appUiSetting = query => { | ||||
|     return request({ | ||||
|         url: '/appUiSetting', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 保存 | ||||
| export const appUiSettingSave = query => { | ||||
|     return request({ | ||||
|         url: '/appUiSetting/save', | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // ==============================================自定义背景============================================== | ||||
| // 列表 | ||||
| export const page = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 新增 | ||||
| export const roomBackgroundAdd = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/add', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 编辑 | ||||
| export const roomBackgroundUpdate = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/update', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // ==============================================自定义背景============================================== | ||||
| // 列表 | ||||
| export const customPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/custom/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 通过 | ||||
| export const customPass = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/custom/pass', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 拒绝 | ||||
| export const customReject = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/custom/reject', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 删除 | ||||
| export const customDel = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/custom/del', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										98
									
								
								src/components/common/TablePagination.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								src/components/common/TablePagination.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,98 @@ | ||||
| <template> | ||||
|     <div class="pagination"> | ||||
|         <el-pagination | ||||
|             background | ||||
|             :layout="paginationLayout" | ||||
|             :current-page="pageParams.pageNo" | ||||
|             :page-size="pageParams.pageSize" | ||||
|             :page-sizes="pageSizes" | ||||
|             :total="pageTotal" | ||||
|             :pager-count="pagerCount" | ||||
|             @size-change="handleSizeChange" | ||||
|             @current-change="handlePageChange" | ||||
|         ></el-pagination> | ||||
|     </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     props: { | ||||
|         pageParams: { | ||||
|             type: Object, | ||||
|             default: () => {} | ||||
|         }, | ||||
|         pageSizes: { | ||||
|             type: Array, | ||||
|             default: function () { | ||||
|                 return [5, 10, 20, 30, 40, 50, 100]; | ||||
|             } | ||||
|         }, | ||||
|         // pagerCount: { | ||||
|         //     type: Number, | ||||
|         //     default: 5 | ||||
|         // }, | ||||
|         pageTotal: { | ||||
|             type: Number, | ||||
|             default: 0 | ||||
|         }, | ||||
|         ifShowTotal: { | ||||
|             type: Boolean, | ||||
|             default: true | ||||
|         }, | ||||
|         ifShowSizes: { | ||||
|             type: Boolean, | ||||
|             default: true | ||||
|         }, | ||||
|         ifShowPrev: { | ||||
|             type: Boolean, | ||||
|             default: true | ||||
|         }, | ||||
|         ifShowPager: { | ||||
|             type: Boolean, | ||||
|             default: true | ||||
|         }, | ||||
|         ifShowNext: { | ||||
|             type: Boolean, | ||||
|             default: true | ||||
|         }, | ||||
|         ifShowJumper: { | ||||
|             type: Boolean, | ||||
|             default: false | ||||
|         } | ||||
|     }, | ||||
|     data() { | ||||
|         return { | ||||
|             pagerCount: 5 | ||||
|         }; | ||||
|     }, | ||||
|     methods: { | ||||
|         handleSizeChange(val) { | ||||
|             this.$emit('handleSizeChange', val); | ||||
|         }, | ||||
|         handlePageChange(val) { | ||||
|             this.$emit('handlePageChange', val); | ||||
|         }, | ||||
|         handleResize() { | ||||
|             if (window.innerWidth > 768) { | ||||
|                 this.pagerCount = 5; | ||||
|             } else { | ||||
|                 this.pagerCount = 2; | ||||
|             } | ||||
|         } | ||||
|     }, | ||||
|     mounted() { | ||||
|         this.handleResize(); // 初始化宽度 | ||||
|     }, | ||||
|     computed: { | ||||
|         paginationLayout() { | ||||
|             const layoutStr = ['total', 'sizes', 'prev', 'pager', 'next', 'jumper']; | ||||
|             const { ifShowTotal, ifShowSizes, ifShowPrev, ifShowPager, ifShowNext, ifShowJumper } = this; | ||||
|             let layoutWantedToBeShowed = []; | ||||
|             [ifShowTotal, ifShowSizes, ifShowPrev, ifShowPager, ifShowNext, ifShowJumper].forEach((item, index) => { | ||||
|                 if (item) layoutWantedToBeShowed.push(index); | ||||
|             }); | ||||
|             return layoutWantedToBeShowed.map((item) => layoutStr[item]).join(','); | ||||
|         } | ||||
|     } | ||||
| }; | ||||
| </script> | ||||
							
								
								
									
										12
									
								
								src/main.js
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								src/main.js
									
									
									
									
									
								
							| @@ -49,11 +49,17 @@ import '@/assets/plugins/bootstrap-treeview/js/bootstrap-treeview.min.js' | ||||
|  | ||||
| // @ts-ignore | ||||
| import components from '@/utils/components.js' | ||||
|  | ||||
| import Vue from 'vue'; | ||||
| // import ElementPlus from 'element-plus' | ||||
| // import 'element-plus/dist/index.css' | ||||
| import '@/css/public.css' | ||||
|  | ||||
| import VueClipboard from 'vue-clipboard2' | ||||
| // import 'vue-clipboard2/dist/vue-clipboard.min.css' | ||||
| import { copy } from './utils/copy.js'; | ||||
| const app = createApp(App) | ||||
| app.config.globalProperties.$copy = function (text) { | ||||
|     copy(text, this); | ||||
| }; | ||||
|  | ||||
| app.config.warnHandler = () => null; | ||||
| app.use(store).use(router).use(components).mount('#app') | ||||
| app.use(store).use(router).use(components).use(VueClipboard).mount('#app') | ||||
|   | ||||
							
								
								
									
										81
									
								
								src/mixin/mixRegion.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								src/mixin/mixRegion.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,81 @@ | ||||
|  | ||||
| // 公共混入 用户区服处理  | ||||
| /** | ||||
|  * 注意: 使用混入,在选择区服切换的时候会添加搜索的区服, | ||||
|  *       所以页面data如果没有searchForm: { region: null }, 需要加上,否则查询searchForm为空 | ||||
|  */ | ||||
| export default { | ||||
|     data() { | ||||
|         return { | ||||
|             userRegion: JSON.parse(localStorage.getItem('user_region')), | ||||
|             regionEnum: [ | ||||
|                 { value: 1, name: 'A区' }, | ||||
|                 { value: 2, name: 'B区' }, | ||||
|                 { value: 3, name: 'C区' }, | ||||
|                 { value: 4, name: 'D区' }, | ||||
|                 { value: 5, name: 'E区' }, | ||||
|                 { value: 6, name: 'F区' } | ||||
|             ], | ||||
|             userAreaRegion: [], //拥有权限的区域列表 | ||||
|             region: null, //展示的区域 | ||||
|         } | ||||
|     }, | ||||
|     created() { | ||||
|         this.handleUserRegion() | ||||
|     }, | ||||
|     methods: { | ||||
|         handleUserRegion() { | ||||
|             if (this.userRegion.length == 0) { | ||||
|                 this.$message.error({ | ||||
|                     message: '请先联系管理员设置你的区服权限!', | ||||
|                     duration: 5000 | ||||
|                 }); | ||||
|                 return | ||||
|             } | ||||
|             this.userAreaRegion = this.regionEnum.filter(item => this.userRegion.includes(item.value)); | ||||
|             this.region = this.userAreaRegion[0].value; | ||||
|             this.searchForm.region = this.region; | ||||
|             console.log('当前查看区服:', this.region); | ||||
|         }, | ||||
|         handSearchRegion() { | ||||
|             if (this.$refs['searchForm']) { // 检查 this.$refs['searchForm'] 是否存在 | ||||
|                 this.$refs['searchForm'].validate((valid) => { | ||||
|                     if (valid) { | ||||
|                         this.pageParams.pageNo = 1; | ||||
|                         this.getData(); | ||||
|                     } | ||||
|                 }); | ||||
|             } else { | ||||
|                 this.pageParams.pageNo = 1; | ||||
|                 this.getData(); | ||||
|             } | ||||
|         }, | ||||
|     }, | ||||
|     computed: { | ||||
|         regionType() { | ||||
|             const { regionEnum } = this; | ||||
|             return function (value) { | ||||
|                 for (let item of regionEnum) { | ||||
|                     if (item.value === value) { | ||||
|                         return item.name; | ||||
|                     } | ||||
|                 } | ||||
|                 return ''; | ||||
|             }; | ||||
|         } | ||||
|     }, | ||||
|     watch: { | ||||
|         region: { | ||||
|             handler(newVal, oldVal) { | ||||
|                 this.searchForm.region = newVal; | ||||
|                 // 防止初始化重复调用查询表单接口 | ||||
|                 if (oldVal != null) { | ||||
|                     this.handSearchRegion() | ||||
|                 } | ||||
|             }, | ||||
|             // immediate: true,  //立即监听 | ||||
|         }, | ||||
|  | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -51,6 +51,7 @@ export default { | ||||
|         }, | ||||
|         getViewComponent(context, path) { | ||||
|             let component = path; | ||||
|             console.log(component) | ||||
|             if (path && path.endsWith('.html')) { | ||||
|                 const pathArray = path.split('/'); | ||||
|                 const routeName = toCamelCase(pathArray[pathArray.length - 1].replace('.html', '')); | ||||
|   | ||||
							
								
								
									
										11
									
								
								src/utils/copy.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								src/utils/copy.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
|  | ||||
| // copy.js | ||||
| export function copy(text, vueInstance) { | ||||
|   vueInstance.$copyText(text) | ||||
|     .then(() => { | ||||
|       vueInstance.$message.success('已复制'); | ||||
|     }) | ||||
|     .catch(() => { | ||||
|       vueInstance.$message.warning('复制失败'); | ||||
|     }); | ||||
| } | ||||
							
								
								
									
										684
									
								
								src/utils/excel/Blob.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										684
									
								
								src/utils/excel/Blob.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,684 @@ | ||||
| // /* Blob.js | ||||
| //  * A Blob, File, FileReader & URL implementation. | ||||
| //  * 2019-04-19 | ||||
| //  * | ||||
| //  * By Eli Grey, http://eligrey.com | ||||
| //  * By Jimmy Wärting, https://github.com/jimmywarting | ||||
| //  * License: MIT | ||||
| //  *   See https://github.com/eligrey/Blob.js/blob/master/LICENSE.md | ||||
| //  */ | ||||
|  | ||||
| // ; (function () { | ||||
| //     var global = typeof window === 'object' | ||||
| //         ? window : typeof self === 'object' | ||||
| //             ? self : this | ||||
|  | ||||
| //     var BlobBuilder = global.BlobBuilder | ||||
| //         || global.WebKitBlobBuilder | ||||
| //         || global.MSBlobBuilder | ||||
| //         || global.MozBlobBuilder | ||||
|  | ||||
| //     global.URL = global.URL || global.webkitURL || function (href, a) { | ||||
| //         a = document.createElement('a') | ||||
| //         a.href = href | ||||
| //         return a | ||||
| //     } | ||||
|  | ||||
| //     var origBlob = global.Blob | ||||
| //     var createObjectURL = URL.createObjectURL | ||||
| //     var revokeObjectURL = URL.revokeObjectURL | ||||
| //     var strTag = global.Symbol && global.Symbol.toStringTag | ||||
| //     var blobSupported = false | ||||
| //     var blobSupportsArrayBufferView = false | ||||
| //     var arrayBufferSupported = !!global.ArrayBuffer | ||||
| //     var blobBuilderSupported = BlobBuilder | ||||
| //         && BlobBuilder.prototype.append | ||||
| //         && BlobBuilder.prototype.getBlob | ||||
|  | ||||
| //     try { | ||||
| //         // Check if Blob constructor is supported | ||||
| //         blobSupported = new Blob(['ä']).size === 2 | ||||
|  | ||||
| //         // Check if Blob constructor supports ArrayBufferViews | ||||
| //         // Fails in Safari 6, so we need to map to ArrayBuffers there. | ||||
| //         blobSupportsArrayBufferView = new Blob([new Uint8Array([1, 2])]).size === 2 | ||||
| //     } catch (e) { } | ||||
|  | ||||
| //     /** | ||||
| //      * Helper function that maps ArrayBufferViews to ArrayBuffers | ||||
| //      * Used by BlobBuilder constructor and old browsers that didn't | ||||
| //      * support it in the Blob constructor. | ||||
| //      */ | ||||
| //     function mapArrayBufferViews(ary) { | ||||
| //         return ary.map(function (chunk) { | ||||
| //             if (chunk.buffer instanceof ArrayBuffer) { | ||||
| //                 var buf = chunk.buffer | ||||
|  | ||||
| //                 // if this is a subarray, make a copy so we only | ||||
| //                 // include the subarray region from the underlying buffer | ||||
| //                 if (chunk.byteLength !== buf.byteLength) { | ||||
| //                     var copy = new Uint8Array(chunk.byteLength) | ||||
| //                     copy.set(new Uint8Array(buf, chunk.byteOffset, chunk.byteLength)) | ||||
| //                     buf = copy.buffer | ||||
| //                 } | ||||
|  | ||||
| //                 return buf | ||||
| //             } | ||||
|  | ||||
| //             return chunk | ||||
| //         }) | ||||
| //     } | ||||
|  | ||||
| //     function BlobBuilderConstructor(ary, options) { | ||||
| //         options = options || {} | ||||
|  | ||||
| //         var bb = new BlobBuilder() | ||||
| //         mapArrayBufferViews(ary).forEach(function (part) { | ||||
| //             bb.append(part) | ||||
| //         }) | ||||
|  | ||||
| //         return options.type ? bb.getBlob(options.type) : bb.getBlob() | ||||
| //     } | ||||
|  | ||||
| //     function BlobConstructor(ary, options) { | ||||
| //         return new origBlob(mapArrayBufferViews(ary), options || {}) | ||||
| //     } | ||||
|  | ||||
| //     if (global.Blob) { | ||||
| //         BlobBuilderConstructor.prototype = Blob.prototype | ||||
| //         BlobConstructor.prototype = Blob.prototype | ||||
| //     } | ||||
|  | ||||
|  | ||||
|  | ||||
| //     /********************************************************/ | ||||
| //     /*               String Encoder fallback                */ | ||||
| //     /********************************************************/ | ||||
| //     function stringEncode(string) { | ||||
| //         var pos = 0 | ||||
| //         var len = string.length | ||||
| //         var Arr = global.Uint8Array || Array // Use byte array when possible | ||||
|  | ||||
| //         var at = 0  // output position | ||||
| //         var tlen = Math.max(32, len + (len >> 1) + 7)  // 1.5x size | ||||
| //         var target = new Arr((tlen >> 3) << 3)  // ... but at 8 byte offset | ||||
|  | ||||
| //         while (pos < len) { | ||||
| //             var value = string.charCodeAt(pos++) | ||||
| //             if (value >= 0xd800 && value <= 0xdbff) { | ||||
| //                 // high surrogate | ||||
| //                 if (pos < len) { | ||||
| //                     var extra = string.charCodeAt(pos) | ||||
| //                     if ((extra & 0xfc00) === 0xdc00) { | ||||
| //                         ++pos | ||||
| //                         value = ((value & 0x3ff) << 10) + (extra & 0x3ff) + 0x10000 | ||||
| //                     } | ||||
| //                 } | ||||
| //                 if (value >= 0xd800 && value <= 0xdbff) { | ||||
| //                     continue  // drop lone surrogate | ||||
| //                 } | ||||
| //             } | ||||
|  | ||||
| //             // expand the buffer if we couldn't write 4 bytes | ||||
| //             if (at + 4 > target.length) { | ||||
| //                 tlen += 8  // minimum extra | ||||
| //                 tlen *= (1.0 + (pos / string.length) * 2)  // take 2x the remaining | ||||
| //                 tlen = (tlen >> 3) << 3  // 8 byte offset | ||||
|  | ||||
| //                 var update = new Uint8Array(tlen) | ||||
| //                 update.set(target) | ||||
| //                 target = update | ||||
| //             } | ||||
|  | ||||
| //             if ((value & 0xffffff80) === 0) {  // 1-byte | ||||
| //                 target[at++] = value  // ASCII | ||||
| //                 continue | ||||
| //             } else if ((value & 0xfffff800) === 0) {  // 2-byte | ||||
| //                 target[at++] = ((value >> 6) & 0x1f) | 0xc0 | ||||
| //             } else if ((value & 0xffff0000) === 0) {  // 3-byte | ||||
| //                 target[at++] = ((value >> 12) & 0x0f) | 0xe0 | ||||
| //                 target[at++] = ((value >> 6) & 0x3f) | 0x80 | ||||
| //             } else if ((value & 0xffe00000) === 0) {  // 4-byte | ||||
| //                 target[at++] = ((value >> 18) & 0x07) | 0xf0 | ||||
| //                 target[at++] = ((value >> 12) & 0x3f) | 0x80 | ||||
| //                 target[at++] = ((value >> 6) & 0x3f) | 0x80 | ||||
| //             } else { | ||||
| //                 // FIXME: do we care | ||||
| //                 continue | ||||
| //             } | ||||
|  | ||||
| //             target[at++] = (value & 0x3f) | 0x80 | ||||
| //         } | ||||
|  | ||||
| //         return target.slice(0, at) | ||||
| //     } | ||||
|  | ||||
| //     /********************************************************/ | ||||
| //     /*               String Decoder fallback                */ | ||||
| //     /********************************************************/ | ||||
| //     function stringDecode(buf) { | ||||
| //         var end = buf.length | ||||
| //         var res = [] | ||||
|  | ||||
| //         var i = 0 | ||||
| //         while (i < end) { | ||||
| //             var firstByte = buf[i] | ||||
| //             var codePoint = null | ||||
| //             var bytesPerSequence = (firstByte > 0xEF) ? 4 | ||||
| //                 : (firstByte > 0xDF) ? 3 | ||||
| //                     : (firstByte > 0xBF) ? 2 | ||||
| //                         : 1 | ||||
|  | ||||
| //             if (i + bytesPerSequence <= end) { | ||||
| //                 var secondByte, thirdByte, fourthByte, tempCodePoint | ||||
|  | ||||
| //                 switch (bytesPerSequence) { | ||||
| //                     case 1: | ||||
| //                         if (firstByte < 0x80) { | ||||
| //                             codePoint = firstByte | ||||
| //                         } | ||||
| //                         break | ||||
| //                     case 2: | ||||
| //                         secondByte = buf[i + 1] | ||||
| //                         if ((secondByte & 0xC0) === 0x80) { | ||||
| //                             tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F) | ||||
| //                             if (tempCodePoint > 0x7F) { | ||||
| //                                 codePoint = tempCodePoint | ||||
| //                             } | ||||
| //                         } | ||||
| //                         break | ||||
| //                     case 3: | ||||
| //                         secondByte = buf[i + 1] | ||||
| //                         thirdByte = buf[i + 2] | ||||
| //                         if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) { | ||||
| //                             tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F) | ||||
| //                             if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) { | ||||
| //                                 codePoint = tempCodePoint | ||||
| //                             } | ||||
| //                         } | ||||
| //                         break | ||||
| //                     case 4: | ||||
| //                         secondByte = buf[i + 1] | ||||
| //                         thirdByte = buf[i + 2] | ||||
| //                         fourthByte = buf[i + 3] | ||||
| //                         if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) { | ||||
| //                             tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F) | ||||
| //                             if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) { | ||||
| //                                 codePoint = tempCodePoint | ||||
| //                             } | ||||
| //                         } | ||||
| //                 } | ||||
| //             } | ||||
|  | ||||
| //             if (codePoint === null) { | ||||
| //                 // we did not generate a valid codePoint so insert a | ||||
| //                 // replacement char (U+FFFD) and advance only 1 byte | ||||
| //                 codePoint = 0xFFFD | ||||
| //                 bytesPerSequence = 1 | ||||
| //             } else if (codePoint > 0xFFFF) { | ||||
| //                 // encode to utf16 (surrogate pair dance) | ||||
| //                 codePoint -= 0x10000 | ||||
| //                 res.push(codePoint >>> 10 & 0x3FF | 0xD800) | ||||
| //                 codePoint = 0xDC00 | codePoint & 0x3FF | ||||
| //             } | ||||
|  | ||||
| //             res.push(codePoint) | ||||
| //             i += bytesPerSequence | ||||
| //         } | ||||
|  | ||||
| //         var len = res.length | ||||
| //         var str = '' | ||||
| //         var i = 0 | ||||
|  | ||||
| //         while (i < len) { | ||||
| //             str += String.fromCharCode.apply(String, res.slice(i, i += 0x1000)) | ||||
| //         } | ||||
|  | ||||
| //         return str | ||||
| //     } | ||||
|  | ||||
| //     // string -> buffer | ||||
| //     var textEncode = typeof TextEncoder === 'function' | ||||
| //         ? TextEncoder.prototype.encode.bind(new TextEncoder()) | ||||
| //         : stringEncode | ||||
|  | ||||
| //     // buffer -> string | ||||
| //     var textDecode = typeof TextDecoder === 'function' | ||||
| //         ? TextDecoder.prototype.decode.bind(new TextDecoder()) | ||||
| //         : stringDecode | ||||
|  | ||||
| //     function FakeBlobBuilder() { | ||||
| //         function isDataView(obj) { | ||||
| //             return obj && DataView.prototype.isPrototypeOf(obj) | ||||
| //         } | ||||
| //         function bufferClone(buf) { | ||||
| //             var view = new Array(buf.byteLength) | ||||
| //             var array = new Uint8Array(buf) | ||||
| //             var i = view.length | ||||
| //             while (i--) { | ||||
| //                 view[i] = array[i] | ||||
| //             } | ||||
| //             return view | ||||
| //         } | ||||
| //         function array2base64(input) { | ||||
| //             var byteToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=' | ||||
|  | ||||
| //             var output = [] | ||||
|  | ||||
| //             for (var i = 0; i < input.length; i += 3) { | ||||
| //                 var byte1 = input[i] | ||||
| //                 var haveByte2 = i + 1 < input.length | ||||
| //                 var byte2 = haveByte2 ? input[i + 1] : 0 | ||||
| //                 var haveByte3 = i + 2 < input.length | ||||
| //                 var byte3 = haveByte3 ? input[i + 2] : 0 | ||||
|  | ||||
| //                 var outByte1 = byte1 >> 2 | ||||
| //                 var outByte2 = ((byte1 & 0x03) << 4) | (byte2 >> 4) | ||||
| //                 var outByte3 = ((byte2 & 0x0F) << 2) | (byte3 >> 6) | ||||
| //                 var outByte4 = byte3 & 0x3F | ||||
|  | ||||
| //                 if (!haveByte3) { | ||||
| //                     outByte4 = 64 | ||||
|  | ||||
| //                     if (!haveByte2) { | ||||
| //                         outByte3 = 64 | ||||
| //                     } | ||||
| //                 } | ||||
|  | ||||
| //                 output.push( | ||||
| //                     byteToCharMap[outByte1], byteToCharMap[outByte2], | ||||
| //                     byteToCharMap[outByte3], byteToCharMap[outByte4] | ||||
| //                 ) | ||||
| //             } | ||||
|  | ||||
| //             return output.join('') | ||||
| //         } | ||||
|  | ||||
| //         var create = Object.create || function (a) { | ||||
| //             function c() { } | ||||
| //             c.prototype = a | ||||
| //             return new c() | ||||
| //         } | ||||
|  | ||||
| //         if (arrayBufferSupported) { | ||||
| //             var viewClasses = [ | ||||
| //                 '[object Int8Array]', | ||||
| //                 '[object Uint8Array]', | ||||
| //                 '[object Uint8ClampedArray]', | ||||
| //                 '[object Int16Array]', | ||||
| //                 '[object Uint16Array]', | ||||
| //                 '[object Int32Array]', | ||||
| //                 '[object Uint32Array]', | ||||
| //                 '[object Float32Array]', | ||||
| //                 '[object Float64Array]' | ||||
| //             ] | ||||
|  | ||||
| //             var isArrayBufferView = ArrayBuffer.isView || function (obj) { | ||||
| //                 return obj && viewClasses.indexOf(Object.prototype.toString.call(obj)) > -1 | ||||
| //             } | ||||
| //         } | ||||
|  | ||||
| //         function concatTypedarrays(chunks) { | ||||
| //             var size = 0 | ||||
| //             var i = chunks.length | ||||
| //             while (i--) { size += chunks[i].length } | ||||
| //             var b = new Uint8Array(size) | ||||
| //             var offset = 0 | ||||
| //             for (i = 0, l = chunks.length; i < l; i++) { | ||||
| //                 var chunk = chunks[i] | ||||
| //                 b.set(chunk, offset) | ||||
| //                 offset += chunk.byteLength || chunk.length | ||||
| //             } | ||||
|  | ||||
| //             return b | ||||
| //         } | ||||
|  | ||||
| //         /********************************************************/ | ||||
| //         /*                   Blob constructor                   */ | ||||
| //         /********************************************************/ | ||||
| //         function Blob(chunks, opts) { | ||||
| //             chunks = chunks || [] | ||||
| //             opts = opts == null ? {} : opts | ||||
| //             for (var i = 0, len = chunks.length; i < len; i++) { | ||||
| //                 var chunk = chunks[i] | ||||
| //                 if (chunk instanceof Blob) { | ||||
| //                     chunks[i] = chunk._buffer | ||||
| //                 } else if (typeof chunk === 'string') { | ||||
| //                     chunks[i] = textEncode(chunk) | ||||
| //                 } else if (arrayBufferSupported && (ArrayBuffer.prototype.isPrototypeOf(chunk) || isArrayBufferView(chunk))) { | ||||
| //                     chunks[i] = bufferClone(chunk) | ||||
| //                 } else if (arrayBufferSupported && isDataView(chunk)) { | ||||
| //                     chunks[i] = bufferClone(chunk.buffer) | ||||
| //                 } else { | ||||
| //                     chunks[i] = textEncode(String(chunk)) | ||||
| //                 } | ||||
| //             } | ||||
|  | ||||
| //             this._buffer = global.Uint8Array | ||||
| //                 ? concatTypedarrays(chunks) | ||||
| //                 : [].concat.apply([], chunks) | ||||
| //             this.size = this._buffer.length | ||||
|  | ||||
| //             this.type = opts.type || '' | ||||
| //             if (/[^\u0020-\u007E]/.test(this.type)) { | ||||
| //                 this.type = '' | ||||
| //             } else { | ||||
| //                 this.type = this.type.toLowerCase() | ||||
| //             } | ||||
| //         } | ||||
|  | ||||
| //         Blob.prototype.arrayBuffer = function () { | ||||
| //             return Promise.resolve(this._buffer) | ||||
| //         } | ||||
|  | ||||
| //         Blob.prototype.text = function () { | ||||
| //             return Promise.resolve(textDecode(this._buffer)) | ||||
| //         } | ||||
|  | ||||
| //         Blob.prototype.slice = function (start, end, type) { | ||||
| //             var slice = this._buffer.slice(start || 0, end || this._buffer.length) | ||||
| //             return new Blob([slice], { type: type }) | ||||
| //         } | ||||
|  | ||||
| //         Blob.prototype.toString = function () { | ||||
| //             return '[object Blob]' | ||||
| //         } | ||||
|  | ||||
| //         /********************************************************/ | ||||
| //         /*                   File constructor                   */ | ||||
| //         /********************************************************/ | ||||
| //         function File(chunks, name, opts) { | ||||
| //             opts = opts || {} | ||||
| //             var a = Blob.call(this, chunks, opts) || this | ||||
| //             a.name = name.replace(/\//g, ':') | ||||
| //             a.lastModifiedDate = opts.lastModified ? new Date(opts.lastModified) : new Date() | ||||
| //             a.lastModified = +a.lastModifiedDate | ||||
|  | ||||
| //             return a | ||||
| //         } | ||||
|  | ||||
| //         File.prototype = create(Blob.prototype) | ||||
| //         File.prototype.constructor = File | ||||
|  | ||||
| //         if (Object.setPrototypeOf) { | ||||
| //             Object.setPrototypeOf(File, Blob) | ||||
| //         } else { | ||||
| //             try { File.__proto__ = Blob } catch (e) { } | ||||
| //         } | ||||
|  | ||||
| //         File.prototype.toString = function () { | ||||
| //             return '[object File]' | ||||
| //         } | ||||
|  | ||||
| //         /********************************************************/ | ||||
| //         /*                FileReader constructor                */ | ||||
| //         /********************************************************/ | ||||
| //         function FileReader() { | ||||
| //             if (!(this instanceof FileReader)) { | ||||
| //                 throw new TypeError("Failed to construct 'FileReader': Please use the 'new' operator, this DOM object constructor cannot be called as a function.") | ||||
| //             } | ||||
|  | ||||
| //             var delegate = document.createDocumentFragment() | ||||
| //             this.addEventListener = delegate.addEventListener | ||||
| //             this.dispatchEvent = function (evt) { | ||||
| //                 var local = this['on' + evt.type] | ||||
| //                 if (typeof local === 'function') local(evt) | ||||
| //                 delegate.dispatchEvent(evt) | ||||
| //             } | ||||
| //             this.removeEventListener = delegate.removeEventListener | ||||
| //         } | ||||
|  | ||||
| //         function _read(fr, blob, kind) { | ||||
| //             if (!(blob instanceof Blob)) { | ||||
| //                 throw new TypeError("Failed to execute '" + kind + "' on 'FileReader': parameter 1 is not of type 'Blob'.") | ||||
| //             } | ||||
|  | ||||
| //             fr.result = '' | ||||
|  | ||||
| //             setTimeout(function () { | ||||
| //                 this.readyState = FileReader.LOADING | ||||
| //                 fr.dispatchEvent(new Event('load')) | ||||
| //                 fr.dispatchEvent(new Event('loadend')) | ||||
| //             }) | ||||
| //         } | ||||
|  | ||||
| //         FileReader.EMPTY = 0 | ||||
| //         FileReader.LOADING = 1 | ||||
| //         FileReader.DONE = 2 | ||||
| //         FileReader.prototype.error = null | ||||
| //         FileReader.prototype.onabort = null | ||||
| //         FileReader.prototype.onerror = null | ||||
| //         FileReader.prototype.onload = null | ||||
| //         FileReader.prototype.onloadend = null | ||||
| //         FileReader.prototype.onloadstart = null | ||||
| //         FileReader.prototype.onprogress = null | ||||
|  | ||||
| //         FileReader.prototype.readAsDataURL = function (blob) { | ||||
| //             _read(this, blob, 'readAsDataURL') | ||||
| //             this.result = 'data:' + blob.type + ';base64,' + array2base64(blob._buffer) | ||||
| //         } | ||||
|  | ||||
| //         FileReader.prototype.readAsText = function (blob) { | ||||
| //             _read(this, blob, 'readAsText') | ||||
| //             this.result = textDecode(blob._buffer) | ||||
| //         } | ||||
|  | ||||
| //         FileReader.prototype.readAsArrayBuffer = function (blob) { | ||||
| //             _read(this, blob, 'readAsText') | ||||
| //             // return ArrayBuffer when possible | ||||
| //             this.result = (blob._buffer.buffer || blob._buffer).slice() | ||||
| //         } | ||||
|  | ||||
| //         FileReader.prototype.abort = function () { } | ||||
|  | ||||
| //         /********************************************************/ | ||||
| //         /*                         URL                          */ | ||||
| //         /********************************************************/ | ||||
| //         URL.createObjectURL = function (blob) { | ||||
| //             return blob instanceof Blob | ||||
| //                 ? 'data:' + blob.type + ';base64,' + array2base64(blob._buffer) | ||||
| //                 : createObjectURL.call(URL, blob) | ||||
| //         } | ||||
|  | ||||
| //         URL.revokeObjectURL = function (url) { | ||||
| //             revokeObjectURL && revokeObjectURL.call(URL, url) | ||||
| //         } | ||||
|  | ||||
| //         /********************************************************/ | ||||
| //         /*                         XHR                          */ | ||||
| //         /********************************************************/ | ||||
| //         var _send = global.XMLHttpRequest && global.XMLHttpRequest.prototype.send | ||||
| //         if (_send) { | ||||
| //             XMLHttpRequest.prototype.send = function (data) { | ||||
| //                 if (data instanceof Blob) { | ||||
| //                     this.setRequestHeader('Content-Type', data.type) | ||||
| //                     _send.call(this, textDecode(data._buffer)) | ||||
| //                 } else { | ||||
| //                     _send.call(this, data) | ||||
| //                 } | ||||
| //             } | ||||
| //         } | ||||
|  | ||||
| //         global.FileReader = FileReader | ||||
| //         global.File = File | ||||
| //         global.Blob = Blob | ||||
| //     } | ||||
|  | ||||
| //     function fixFileAndXHR() { | ||||
| //         var isIE = !!global.ActiveXObject || ( | ||||
| //             '-ms-scroll-limit' in document.documentElement.style && | ||||
| //             '-ms-ime-align' in document.documentElement.style | ||||
| //         ) | ||||
|  | ||||
| //         // Monkey patched | ||||
| //         // IE don't set Content-Type header on XHR whose body is a typed Blob | ||||
| //         // https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/6047383 | ||||
| //         var _send = global.XMLHttpRequest && global.XMLHttpRequest.prototype.send | ||||
| //         if (isIE && _send) { | ||||
| //             XMLHttpRequest.prototype.send = function (data) { | ||||
| //                 if (data instanceof Blob) { | ||||
| //                     this.setRequestHeader('Content-Type', data.type) | ||||
| //                     _send.call(this, data) | ||||
| //                 } else { | ||||
| //                     _send.call(this, data) | ||||
| //                 } | ||||
| //             } | ||||
| //         } | ||||
|  | ||||
| //         try { | ||||
| //             new File([], '') | ||||
| //         } catch (e) { | ||||
| //             try { | ||||
| //                 var klass = new Function('class File extends Blob {' + | ||||
| //                     'constructor(chunks, name, opts) {' + | ||||
| //                     'opts = opts || {};' + | ||||
| //                     'super(chunks, opts || {});' + | ||||
| //                     'this.name = name.replace(/\//g, ":");' + | ||||
| //                     'this.lastModifiedDate = opts.lastModified ? new Date(opts.lastModified) : new Date();' + | ||||
| //                     'this.lastModified = +this.lastModifiedDate;' + | ||||
| //                     '}};' + | ||||
| //                     'return new File([], ""), File' | ||||
| //                 )() | ||||
| //                 global.File = klass | ||||
| //             } catch (e) { | ||||
| //                 var klass = function (b, d, c) { | ||||
| //                     var blob = new Blob(b, c) | ||||
| //                     var t = c && void 0 !== c.lastModified ? new Date(c.lastModified) : new Date() | ||||
|  | ||||
| //                     blob.name = d.replace(/\//g, ':') | ||||
| //                     blob.lastModifiedDate = t | ||||
| //                     blob.lastModified = +t | ||||
| //                     blob.toString = function () { | ||||
| //                         return '[object File]' | ||||
| //                     } | ||||
|  | ||||
| //                     if (strTag) { | ||||
| //                         blob[strTag] = 'File' | ||||
| //                     } | ||||
|  | ||||
| //                     return blob | ||||
| //                 } | ||||
| //                 global.File = klass | ||||
| //             } | ||||
| //         } | ||||
| //     } | ||||
|  | ||||
| //     if (blobSupported) { | ||||
| //         fixFileAndXHR() | ||||
| //         global.Blob = blobSupportsArrayBufferView ? global.Blob : BlobConstructor | ||||
| //     } else if (blobBuilderSupported) { | ||||
| //         fixFileAndXHR() | ||||
| //         global.Blob = BlobBuilderConstructor | ||||
| //     } else { | ||||
| //         FakeBlobBuilder() | ||||
| //     } | ||||
|  | ||||
| //     if (strTag) { | ||||
| //         File.prototype[strTag] = 'File' | ||||
| //         Blob.prototype[strTag] = 'Blob' | ||||
| //         FileReader.prototype[strTag] = 'FileReader' | ||||
| //     } | ||||
|  | ||||
| //     var blob = global.Blob.prototype | ||||
| //     var stream | ||||
|  | ||||
| //     function promisify(obj) { | ||||
| //         return new Promise(function (resolve, reject) { | ||||
| //             obj.onload = | ||||
| //                 obj.onerror = function (evt) { | ||||
| //                     obj.onload = | ||||
| //                         obj.onerror = null | ||||
|  | ||||
| //                     evt.type === 'load' | ||||
| //                         ? resolve(obj.result || obj) | ||||
| //                         : reject(new Error('Failed to read the blob/file')) | ||||
| //                 } | ||||
| //         }) | ||||
| //     } | ||||
|  | ||||
|  | ||||
| //     try { | ||||
| //         new ReadableStream({ type: 'bytes' }) | ||||
| //         stream = function stream() { | ||||
| //             var position = 0 | ||||
| //             var blob = this | ||||
|  | ||||
| //             return new ReadableStream({ | ||||
| //                 type: 'bytes', | ||||
| //                 autoAllocateChunkSize: 524288, | ||||
|  | ||||
| //                 pull: function (controller) { | ||||
| //                     var v = controller.byobRequest.view | ||||
| //                     var chunk = blob.slice(position, position + v.byteLength) | ||||
| //                     return chunk.arrayBuffer() | ||||
| //                         .then(function (buffer) { | ||||
| //                             var uint8array = new Uint8Array(buffer) | ||||
| //                             var bytesRead = uint8array.byteLength | ||||
|  | ||||
| //                             position += bytesRead | ||||
| //                             v.set(uint8array) | ||||
| //                             controller.byobRequest.respond(bytesRead) | ||||
|  | ||||
| //                             if (position >= blob.size) | ||||
| //                                 controller.close() | ||||
| //                         }) | ||||
| //                 } | ||||
| //             }) | ||||
| //         } | ||||
| //     } catch (e) { | ||||
| //         try { | ||||
| //             new ReadableStream({}) | ||||
| //             stream = function stream(blob) { | ||||
| //                 var position = 0 | ||||
| //                 var blob = this | ||||
|  | ||||
| //                 return new ReadableStream({ | ||||
| //                     pull: function (controller) { | ||||
| //                         var chunk = blob.slice(position, position + 524288) | ||||
|  | ||||
| //                         return chunk.arrayBuffer().then(function (buffer) { | ||||
| //                             position += buffer.byteLength | ||||
| //                             var uint8array = new Uint8Array(buffer) | ||||
| //                             controller.enqueue(uint8array) | ||||
|  | ||||
| //                             if (position == blob.size) | ||||
| //                                 controller.close() | ||||
| //                         }) | ||||
| //                     } | ||||
| //                 }) | ||||
| //             } | ||||
| //         } catch (e) { | ||||
| //             try { | ||||
| //                 new Response('').body.getReader().read() | ||||
| //                 stream = function stream() { | ||||
| //                     return (new Response(this)).body | ||||
| //                 } | ||||
| //             } catch (e) { | ||||
| //                 stream = function stream() { | ||||
| //                     throw new Error('Include https://github.com/MattiasBuelens/web-streams-polyfill') | ||||
| //                 } | ||||
| //             } | ||||
| //         } | ||||
| //     } | ||||
|  | ||||
|  | ||||
| //     if (!blob.arrayBuffer) { | ||||
| //         blob.arrayBuffer = function arrayBuffer() { | ||||
| //             var fr = new FileReader() | ||||
| //             fr.readAsArrayBuffer(this) | ||||
| //             return promisify(fr) | ||||
| //         } | ||||
| //     } | ||||
|  | ||||
| //     if (!blob.text) { | ||||
| //         blob.text = function text() { | ||||
| //             var fr = new FileReader() | ||||
| //             fr.readAsText(this) | ||||
| //             return promisify(fr) | ||||
| //         } | ||||
| //     } | ||||
|  | ||||
| //     if (!blob.stream) { | ||||
| //         blob.stream = stream | ||||
| //     } | ||||
| // })() | ||||
							
								
								
									
										141
									
								
								src/utils/excel/Export2Excel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								src/utils/excel/Export2Excel.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,141 @@ | ||||
| /* eslint-disable */ | ||||
| require('script-loader!file-saver'); | ||||
| // require('script-loader!./Blob.js'); | ||||
| require('script-loader!xlsx/dist/xlsx.core.min'); | ||||
| function generateArray(table) { | ||||
|     var out = []; | ||||
|     var rows = table.querySelectorAll('tr'); | ||||
|     var ranges = []; | ||||
|     for (var R = 0; R < rows.length; ++R) { | ||||
|         var outRow = []; | ||||
|         var row = rows[R]; | ||||
|         var columns = row.querySelectorAll('td'); | ||||
|         for (var C = 0; C < columns.length; ++C) { | ||||
|             var cell = columns[C]; | ||||
|             var colspan = cell.getAttribute('colspan'); | ||||
|             var rowspan = cell.getAttribute('rowspan'); | ||||
|             var cellValue = cell.innerText; | ||||
|             if (cellValue !== "" && cellValue == +cellValue) cellValue = +cellValue; | ||||
|  | ||||
|             //Skip ranges | ||||
|             ranges.forEach(function (range) { | ||||
|                 if (R >= range.s.r && R <= range.e.r && outRow.length >= range.s.c && outRow.length <= range.e.c) { | ||||
|                     for (var i = 0; i <= range.e.c - range.s.c; ++i) outRow.push(null); | ||||
|                 } | ||||
|             }); | ||||
|  | ||||
|             //Handle Row Span | ||||
|             if (rowspan || colspan) { | ||||
|                 rowspan = rowspan || 1; | ||||
|                 colspan = colspan || 1; | ||||
|                 ranges.push({s: {r: R, c: outRow.length}, e: {r: R + rowspan - 1, c: outRow.length + colspan - 1}}); | ||||
|             } | ||||
|             ; | ||||
|  | ||||
|             //Handle Value | ||||
|             outRow.push(cellValue !== "" ? cellValue : null); | ||||
|  | ||||
|             //Handle Colspan | ||||
|             if (colspan) for (var k = 0; k < colspan - 1; ++k) outRow.push(null); | ||||
|         } | ||||
|         out.push(outRow); | ||||
|     } | ||||
|     return [out, ranges]; | ||||
| }; | ||||
|  | ||||
| function datenum(v, date1904) { | ||||
|     if (date1904) v += 1462; | ||||
|     var epoch = Date.parse(v); | ||||
|     return (epoch - new Date(Date.UTC(1899, 11, 30))) / (24 * 60 * 60 * 1000); | ||||
| } | ||||
|  | ||||
| function sheet_from_array_of_arrays(data, opts) { | ||||
|     var ws = {}; | ||||
|     var range = {s: {c: 10000000, r: 10000000}, e: {c: 0, r: 0}}; | ||||
|     for (var R = 0; R != data.length; ++R) { | ||||
|         for (var C = 0; C != data[R].length; ++C) { | ||||
|             if (range.s.r > R) range.s.r = R; | ||||
|             if (range.s.c > C) range.s.c = C; | ||||
|             if (range.e.r < R) range.e.r = R; | ||||
|             if (range.e.c < C) range.e.c = C; | ||||
|             var cell = {v: data[R][C]}; | ||||
|             if (cell.v == null) continue; | ||||
|             var cell_ref = XLSX.utils.encode_cell({c: C, r: R}); | ||||
|  | ||||
|             if (typeof cell.v === 'number') cell.t = 'n'; | ||||
|             else if (typeof cell.v === 'boolean') cell.t = 'b'; | ||||
|             else if (cell.v instanceof Date) { | ||||
|                 cell.t = 'n'; | ||||
|                 cell.z = XLSX.SSF._table[14]; | ||||
|                 cell.v = datenum(cell.v); | ||||
|             } | ||||
|             else cell.t = 's'; | ||||
|  | ||||
|             ws[cell_ref] = cell; | ||||
|         } | ||||
|     } | ||||
|     if (range.s.c < 10000000) ws['!ref'] = XLSX.utils.encode_range(range); | ||||
|     return ws; | ||||
| } | ||||
|  | ||||
| function Workbook() { | ||||
|     if (!(this instanceof Workbook)) return new Workbook(); | ||||
|     this.SheetNames = []; | ||||
|     this.Sheets = {}; | ||||
| } | ||||
|  | ||||
| function s2ab(s) { | ||||
|     var buf = new ArrayBuffer(s.length); | ||||
|     var view = new Uint8Array(buf); | ||||
|     for (var i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF; | ||||
|     return buf; | ||||
| } | ||||
|  | ||||
| export function export_table_to_excel(id) { | ||||
|     var theTable = document.getElementById(id); | ||||
|     console.log('a') | ||||
|     var oo = generateArray(theTable); | ||||
|     var ranges = oo[1]; | ||||
|  | ||||
|     /* original data */ | ||||
|     var data = oo[0]; | ||||
|     var ws_name = "SheetJS"; | ||||
|     console.log(data); | ||||
|  | ||||
|     var wb = new Workbook(), ws = sheet_from_array_of_arrays(data); | ||||
|  | ||||
|     /* add ranges to worksheet */ | ||||
|     // ws['!cols'] = ['apple', 'banan']; | ||||
|     ws['!merges'] = ranges; | ||||
|  | ||||
|     /* add worksheet to workbook */ | ||||
|     wb.SheetNames.push(ws_name); | ||||
|     wb.Sheets[ws_name] = ws; | ||||
|  | ||||
|     var wbout = XLSX.write(wb, {bookType: 'xlsx', bookSST: false, type: 'binary'}); | ||||
|  | ||||
|     saveAs(new Blob([s2ab(wbout)], {type: "application/octet-stream"}), "test.xlsx") | ||||
| } | ||||
|  | ||||
| function formatJson(jsonData) { | ||||
|     console.log(jsonData) | ||||
| } | ||||
| export function export_json_to_excel(th, jsonData, defaultTitle) { | ||||
|  | ||||
|     /* original data */ | ||||
|  | ||||
|     var data = jsonData; | ||||
|     data.unshift(th); | ||||
|     var ws_name = "SheetJS"; | ||||
|  | ||||
|     var wb = new Workbook(), ws = sheet_from_array_of_arrays(data); | ||||
|  | ||||
|  | ||||
|     /* add worksheet to workbook */ | ||||
|     wb.SheetNames.push(ws_name); | ||||
|     wb.Sheets[ws_name] = ws; | ||||
|  | ||||
|     var wbout = XLSX.write(wb, {bookType: 'xlsx', bookSST: false, type: 'binary'}); | ||||
|     var title = defaultTitle || '列表' | ||||
|     saveAs(new Blob([s2ab(wbout)], {type: "application/octet-stream"}), title + ".xlsx") | ||||
| } | ||||
							
								
								
									
										11
									
								
								src/utils/exportExcel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								src/utils/exportExcel.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| function formatJson(filterVal, jsonData) { | ||||
| 	return jsonData.map(v => filterVal.map(j => v[j])); | ||||
| } | ||||
|  | ||||
| export const exportExcel = (tHeader, filterVal, data, excelName) => { | ||||
| 	require.ensure([], () => { | ||||
| 		const { export_json_to_excel } = require('./excel/Export2Excel.js'); | ||||
| 		const combineData = formatJson(filterVal, data); | ||||
| 		export_json_to_excel(tHeader, combineData, excelName); | ||||
| 	}); | ||||
| } | ||||
							
								
								
									
										107
									
								
								src/utils/relDate.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								src/utils/relDate.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| export const formatDate = (value) => { | ||||
|     let timezone = 3; //目标时区时间,东3区(东时区正数 西时区负数) | ||||
|     let offset_GMT = new Date(value).getTimezoneOffset(); // 本地时间和格林威治的时间差,单位为分钟 | ||||
|     let nowDate = new Date(value).getTime(); // 本地时间距 1970 年 1 月 1 日午夜(GMT 时间)之间的毫秒数 | ||||
|     let date = new Date(nowDate + offset_GMT * 60 * 1000 + timezone * 60 * 60 * 1000); | ||||
|  | ||||
|     // 提取年、月、日、小时、分钟和秒 | ||||
|     let y = date.getFullYear(); | ||||
|     let MM = date.getMonth() + 1; | ||||
|     MM = MM < 10 ? ('0' + MM) : MM; | ||||
|     let d = date.getDate(); | ||||
|     d = d < 10 ? ('0' + d) : d; | ||||
|     let h = date.getHours(); | ||||
|     h = h < 10 ? ('0' + h) : h; | ||||
|     let m = date.getMinutes(); | ||||
|     m = m < 10 ? ('0' + m) : m; | ||||
|     let s = date.getSeconds(); | ||||
|     s = s < 10 ? ('0' + s) : s; | ||||
|     return `${y}-${MM}-${d} ${h}:${m}:${s}`; | ||||
| } | ||||
|  | ||||
| export const formatDate2 = (value) => { | ||||
|     let timezone = 3; //目标时区时间,东3区(东时区正数 西时区负数) | ||||
|     let offset_GMT = new Date(value).getTimezoneOffset(); // 本地时间和格林威治的时间差,单位为分钟 | ||||
|     let nowDate = new Date(value).getTime(); // 本地时间距 1970 年 1 月 1 日午夜(GMT 时间)之间的毫秒数 | ||||
|     let date = new Date(nowDate + offset_GMT * 60 * 1000 + timezone * 60 * 60 * 1000); | ||||
|  | ||||
|     let y = date.getFullYear(); | ||||
|     let MM = date.getMonth() + 1; | ||||
|     MM = MM < 10 ? ('0' + MM) : MM; | ||||
|     let d = date.getDate(); | ||||
|     d = d < 10 ? ('0' + d) : d; | ||||
|     let h = date.getHours(); | ||||
|     h = h < 10 ? ('0' + h) : h; | ||||
|     let m = date.getMinutes(); | ||||
|     m = m < 10 ? ('0' + m) : m; | ||||
|     let s = date.getSeconds(); | ||||
|     s = s < 10 ? ('0' + s) : s; | ||||
|     return `${y}/${MM}/${d} ${h}:${m}:${s}`; | ||||
| } | ||||
|  | ||||
| export const formatDateYMD = (value) => { | ||||
|     let timezone = 3; //目标时区时间,东3区(东时区正数 西时区负数) | ||||
|     let offset_GMT = new Date(value).getTimezoneOffset(); // 本地时间和格林威治的时间差,单位为分钟 | ||||
|     let nowDate = new Date(value).getTime(); // 本地时间距 1970 年 1 月 1 日午夜(GMT 时间)之间的毫秒数 | ||||
|     let date = new Date(nowDate + offset_GMT * 60 * 1000 + timezone * 60 * 60 * 1000); | ||||
|  | ||||
|     let y = date.getFullYear(); | ||||
|     let MM = date.getMonth() + 1; | ||||
|     MM = MM < 10 ? ('0' + MM) : MM; | ||||
|     let d = date.getDate(); | ||||
|     d = d < 10 ? ('0' + d) : d; | ||||
|     let h = date.getHours(); | ||||
|     h = h < 10 ? ('0' + h) : h; | ||||
|     let m = date.getMinutes(); | ||||
|     m = m < 10 ? ('0' + m) : m; | ||||
|     let s = date.getSeconds(); | ||||
|     s = s < 10 ? ('0' + s) : s; | ||||
|     return `${y}/${MM}/${d}`; | ||||
| } | ||||
|  | ||||
| export const formatDateYYYYMMDD = (value) => { | ||||
|     let date = new Date(value); | ||||
|     // 将时区设置为GMT+3 | ||||
|     let gmtOffset = 3; // GMT+3时区偏移量为3小时 | ||||
|     let localOffset = date.getTimezoneOffset() / 60; // 获取本地时区偏移量(以小时为单位) | ||||
|     let targetOffset = gmtOffset - localOffset; // 计算目标时区偏移量 | ||||
|     date.setHours(date.getHours() + targetOffset); // 根据偏移量调整小时 | ||||
|  | ||||
|     const y = date.getFullYear(); | ||||
|     let MM = date.getMonth() + 1; | ||||
|     MM = MM < 10 ? ('0' + MM) : MM; | ||||
|     let d = date.getDate(); | ||||
|     d = d < 10 ? ('0' + d) : d; | ||||
|     let h = date.getHours(); | ||||
|     h = h < 10 ? ('0' + h) : h; | ||||
|     let m = date.getMinutes(); | ||||
|     m = m < 10 ? ('0' + m) : m; | ||||
|     let s = date.getSeconds(); | ||||
|     s = s < 10 ? ('0' + s) : s; | ||||
|  | ||||
|     return `${y}-${MM}-${d}`; | ||||
| } | ||||
|  | ||||
|  | ||||
| export const formatDateYYYYMM = (value) => { | ||||
|     let date = new Date(value); | ||||
|     // 将时区设置为GMT+3 | ||||
|     let gmtOffset = 3; // GMT+3时区偏移量为3小时 | ||||
|     let localOffset = date.getTimezoneOffset() / 60; // 获取本地时区偏移量(以小时为单位) | ||||
|     let targetOffset = gmtOffset - localOffset; // 计算目标时区偏移量 | ||||
|     date.setHours(date.getHours() + targetOffset); // 根据偏移量调整小时 | ||||
|  | ||||
|     let y = date.getFullYear(); | ||||
|     let MM = date.getMonth() + 1; | ||||
|     MM = MM < 10 ? ('0' + MM) : MM; | ||||
|     let d = date.getDate(); | ||||
|     d = d < 10 ? ('0' + d) : d; | ||||
|     let h = date.getHours(); | ||||
|     h = h < 10 ? ('0' + h) : h; | ||||
|     let m = date.getMinutes(); | ||||
|     m = m < 10 ? ('0' + m) : m; | ||||
|     let s = date.getSeconds(); | ||||
|     s = s < 10 ? ('0' + s) : s; | ||||
|     console.log(y, MM, d, h, s); | ||||
|     return `${y}-${MM}`; | ||||
| } | ||||
							
								
								
									
										238
									
								
								src/views/GiftPanelManagement/GiftPanelManagement.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										238
									
								
								src/views/GiftPanelManagement/GiftPanelManagement.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,238 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 选择分区 --> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">选择分区</span> | ||||
|         <el-select | ||||
|           v-model="inquire.partitionId" | ||||
|           style="width: 75%" | ||||
|           placeholder="请选择" | ||||
|           @change="handleChange" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in inquire.inquireonInfos" | ||||
|             :key="item.id" | ||||
|             :label="item.desc" | ||||
|             :value="item.id" | ||||
|           ></el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="seq" align="center" label="排序" /> | ||||
|       <el-table-column prop="name" align="center" label="礼物面板类型" /> | ||||
|       <el-table-column prop="enable" align="center" label="是否生效"> | ||||
|         <template v-slot="scope">{{ scope.row.enable ? "是" : "否" }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="操作"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="ediClick(scope.row)" | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             size="default" | ||||
|             >编辑</el-button | ||||
|           > | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|     <!-- 编辑弹窗 --> | ||||
|     <el-dialog v-model="eidDialog" :title="eidDialogTitle" width="30%" center> | ||||
|       <!-- 礼物面板类型 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; white-space: nowrap; margin-right: 70px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >礼物面板类型</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="eidObj.type" | ||||
|           style="width: 60%" | ||||
|           class="input" | ||||
|           placeholder="请输入" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <!-- 面板排序 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; white-space: nowrap; margin-right: 70px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >面板排序-{{ eidText }}</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="eidObj.seq" | ||||
|           style="width: 60%" | ||||
|           class="input" | ||||
|           placeholder="请输入" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <!-- 是否生效 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; white-space: nowrap; margin-right: 70px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >是否生效</span | ||||
|         > | ||||
|         <el-select | ||||
|           v-model="eidObj.value" | ||||
|           style="width: 60%" | ||||
|           placeholder="请选择" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in eidObj.option" | ||||
|             :key="item.id" | ||||
|             :label="item.desc" | ||||
|             :value="item.id" | ||||
|           ></el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="eidDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="eidDialogClick()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { list, update } from "@/api/GiftPanelManagement/GiftPanelManagement"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "GiftPanelManagement", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         partitionId: 4, | ||||
|         inquireonInfos: [ | ||||
|           { desc: "英语区", id: 1 }, | ||||
|           { desc: "阿拉伯区", id: 2 }, | ||||
|           { desc: "华语区", id: 4 }, | ||||
|         ], | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 编辑 | ||||
|       eidDialog: false, | ||||
|       eidDialogTitle: "", | ||||
|       eidText: "", | ||||
|       eidObjNew: {}, | ||||
|       eidObj: { | ||||
|         type: "", | ||||
|         clientName: "", | ||||
|         seq: "", | ||||
|         value: "", | ||||
|         option: [ | ||||
|           { | ||||
|             desc: "是", | ||||
|             id: true, | ||||
|           }, | ||||
|           { | ||||
|             desc: "否", | ||||
|             id: false, | ||||
|           }, | ||||
|         ], | ||||
|       }, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.eidDialogTitle = `编辑礼物面板信息-华语区`; | ||||
|     this.eidText = `华语区`; | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       list({ | ||||
|         partitionId: this.inquire.partitionId, | ||||
|       }).then((res) => { | ||||
|         this.tableData = res.data; | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     ediClick(val) { | ||||
|       this.eidDialog = true; | ||||
|       this.eidObj.type = val.name; | ||||
|       this.eidObj.seq = val.seq; | ||||
|       this.eidObj.value = val.enable; | ||||
|       this.eidObjNew = val; | ||||
|     }, | ||||
|     eidDialogClick() { | ||||
|       update({ | ||||
|         enable: this.eidObj.value, | ||||
|         id: this.eidObjNew.id, | ||||
|         seq: this.eidObj.seq, | ||||
|         partitionId: this.inquire.partitionId, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "编辑成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.eidDialog = false; | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     handleChange(val) { | ||||
|       console.log(val); | ||||
|       if (val == 1) { | ||||
|         this.eidDialogTitle = `编辑礼物面板信息-英语区`; | ||||
|         this.eidText = `英语区`; | ||||
|       } else if (val == 2) { | ||||
|         this.eidDialogTitle = `编辑礼物面板信息-阿拉伯区`; | ||||
|         this.eidText = `阿拉伯区`; | ||||
|       } else if (val == 4) { | ||||
|         this.eidDialogTitle = `编辑礼物面板信息-华语区`; | ||||
|         this.eidText = `华语区`; | ||||
|       } | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 70px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										457
									
								
								src/views/accountApplyManage/accountApplyManage.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										457
									
								
								src/views/accountApplyManage/accountApplyManage.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,457 @@ | ||||
| <template> | ||||
|   <div class="account-apply-manage"> | ||||
|     <div class="container"> | ||||
|       <div class="region-box"> | ||||
|         <el-radio-group v-model="region"> | ||||
|           <el-radio v-for="(item, index) in userAreaRegion" | ||||
|                     :key="index" | ||||
|                     :label="item.value">{{ item.name }}</el-radio> | ||||
|         </el-radio-group> | ||||
|       </div> | ||||
|       <div class="handle-box"> | ||||
|         <el-form ref="searchForm" | ||||
|                  :model="searchForm" | ||||
|                  label-width="90px" | ||||
|                  :disabled="tableLoading"> | ||||
|           <div class="search-line"> | ||||
|             <el-form-item label="MoliStar ID" | ||||
|                           prop="erbanNo"> | ||||
|               <el-input v-model.trim="searchForm.erbanNo" | ||||
|                         placeholder="Please enter"></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="UID" | ||||
|                           prop="uid"> | ||||
|               <el-input v-model.trim="searchForm.uid" | ||||
|                         placeholder="Please enter"></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="SID" | ||||
|                           prop="sid"> | ||||
|               <el-input v-model.trim="searchForm.sid" | ||||
|                         placeholder="Please enter"></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="Region" | ||||
|                           prop="partitionId"> | ||||
|               <el-select v-model="searchForm.partitionId"> | ||||
|                 <el-option label="全部" | ||||
|                            value=""></el-option> | ||||
|                 <el-option v-for="item in partitionInfoList" | ||||
|                            :key="item.id" | ||||
|                            :label="item.desc" | ||||
|                            :value="item.id"></el-option> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|             <el-form-item label-width="40px"> | ||||
|               <el-button type="primary" | ||||
|                          @click="handSearch">Search</el-button> | ||||
|               <el-button plain | ||||
|                          @click="resetSearchForm">Reset Search</el-button> | ||||
|               <el-upload class="file-uploader" | ||||
|                          action="#" | ||||
|                          list-type="picture-card" | ||||
|                          :show-file-list="false" | ||||
|                          :on-change="handleExcel" | ||||
|                          accept=".xls, .xlsx" | ||||
|                          :auto-upload="false"> | ||||
|                 <el-button type="primary">Import</el-button> | ||||
|               </el-upload> | ||||
|             </el-form-item> | ||||
|           </div> | ||||
|         </el-form> | ||||
|         <!-- <el-upload | ||||
|           class="file-uploader" | ||||
|           action="#" | ||||
|           list-type="picture-card" | ||||
|           :show-file-list="false" | ||||
|           :on-change="handleExcel" | ||||
|           accept=".xls, .xlsx" | ||||
|           :auto-upload="false" | ||||
|         > | ||||
|           <el-button type="primary" class="el-icon-upload">Import</el-button> | ||||
|         </el-upload> --> | ||||
|       </div> | ||||
|       <div class="table"> | ||||
|         <el-table :data="tableData" | ||||
|                   border | ||||
|                   v-loading="tableLoading" | ||||
|                   @header-click="headerCopy" | ||||
|                   style="width: 100%"> | ||||
|           <el-table-column align="center" | ||||
|                            prop="id" | ||||
|                            label="No."> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="erbanNo" | ||||
|                            label="MoliStar ID"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="uid" | ||||
|                            label="UID"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="level" | ||||
|                            label="SID Level"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="nick" | ||||
|                            label="Nickname"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="partitionInfo" | ||||
|                            label="Region"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="createTime" | ||||
|                            label="Apply time"> | ||||
|             <template v-slot="scope">{{ | ||||
|               convertTimestamp(scope.row.createTime) | ||||
|             }}</template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="prettyNo" | ||||
|                            label="SID"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="status" | ||||
|                            label="State"> | ||||
|             <template v-slot="scope"> | ||||
|               <el-tag :type="applyStateTag(scope.row.status)">{{ | ||||
|                 applyStateText(scope.row.status) | ||||
|               }}</el-tag> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="updateTime" | ||||
|                            label="Review time"> | ||||
|             <template v-slot="scope">{{ | ||||
|               convertTimestamp(scope.row.updateTime) | ||||
|             }}</template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="operater" | ||||
|                            label="Operator"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            label="Operate"> | ||||
|             <template v-slot="scope"> | ||||
|               <el-button type="text" | ||||
|                          v-if="scope.row.status == 0" | ||||
|                          @click="handlePass(scope.$index, scope.row)"> | ||||
|                 Pass | ||||
|               </el-button> | ||||
|               <el-button type="text" | ||||
|                          v-if="scope.row.status == 0" | ||||
|                          @click="handleReject(scope.$index, scope.row)"> | ||||
|                 Reject | ||||
|               </el-button> | ||||
|               <el-button type="text" | ||||
|                          v-if="scope.row.status == 1" | ||||
|                          class="red" | ||||
|                          @click="handleDelete(scope.$index, scope.row)"> | ||||
|                 Delete | ||||
|               </el-button> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|         </el-table> | ||||
|         <table-pagination :pageParams="pageParams" | ||||
|                           :pageTotal="pageTotal" | ||||
|                           :ifShowSizes="true" | ||||
|                           @handleSizeChange="handleSizeChange" | ||||
|                           @handlePageChange="handlePageChange"></table-pagination> | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { | ||||
|   getPrettyNumberExamineList, | ||||
|   prettyNumberExaminePass, | ||||
|   prettyNumberExamineDelete, | ||||
|   prettyNumberExamineReject, | ||||
|   erbanUpload, | ||||
| } from "@/api/relPrivilegeManage/relPrivilegeManage.js"; | ||||
| import { getPartitionInfoList } from '@/api/partition/partitionInfo'; | ||||
| import TablePagination from "@/components/common/TablePagination"; | ||||
| import { formatDate } from "@/utils/relDate"; | ||||
| import { ElMessageBox, ElMessage } from "element-plus"; // 正确引入 ElM | ||||
| // 混入 | ||||
| // import Mixin from '../../mixin/mixRegion.js'; | ||||
|  | ||||
| export default { | ||||
|   name: "accountApplyManage", | ||||
|   // mixins: [Mixin], | ||||
|   components: { TablePagination }, | ||||
|   data () { | ||||
|     return { | ||||
|       partitionInfoList: [], | ||||
|       tableLoading: false, // 表格是否加载中 | ||||
|       tableData: [], // 接口返回的表格数据 | ||||
|       // 搜索表单相关 | ||||
|       searchForm: { | ||||
|         erbanNo: null, | ||||
|         uid: null, | ||||
|         sid: null, | ||||
|         partitionId: null, | ||||
|       }, | ||||
|       pageTotal: 0, // 接口返回的表格总条数 | ||||
|       pageParams: { | ||||
|         pageNo: 1, | ||||
|         pageSize: 10, | ||||
|       }, | ||||
|     }; | ||||
|   }, | ||||
|   created () { | ||||
|     this.initPartition(); | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     getData () { | ||||
|       this.tableLoading = true; | ||||
|  | ||||
|       let { pageParams, searchForm } = this; | ||||
|       searchForm = JSON.parse(JSON.stringify(searchForm)); | ||||
|       pageParams = JSON.parse(JSON.stringify(pageParams)); | ||||
|       Object.keys(searchForm).forEach((item) => { | ||||
|         if ( | ||||
|           !searchForm[item] || | ||||
|           (searchForm[item] !== undefined && searchForm[item] === "") | ||||
|         ) { | ||||
|           delete searchForm[item]; | ||||
|         } | ||||
|       }); | ||||
|       Object.assign(pageParams, searchForm); | ||||
|  | ||||
|       getPrettyNumberExamineList(pageParams).then((res) => { | ||||
|         this.tableLoading = false; | ||||
|         if (res.code == 200) { | ||||
|           let data = res.data; | ||||
|           console.log(data); | ||||
|           this.tableData = data.rows; | ||||
|           this.pageTotal = data.total; | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     //导入表格 | ||||
|     handleExcel (file) { | ||||
|       let formData = new FormData(); //声明一个FormDate对象 | ||||
|       formData.append("file", file.raw); //把文件信息放入对象中 | ||||
|       console.log(file.raw); | ||||
|       erbanUpload(formData) | ||||
|         .then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             this.getData(); | ||||
|             this.$message.success("Operation successful"); | ||||
|           } | ||||
|         }) | ||||
|         .catch((err) => { | ||||
|           // that.$message({ | ||||
|           //     type: 'error', | ||||
|           //     message: 'Operation failed' | ||||
|           // }); | ||||
|         }); | ||||
|     }, | ||||
|     // 通过 | ||||
|     handlePass (index, row) { | ||||
|       ElMessageBox.confirm("Are you sure you want to pass?", "Prompt", { | ||||
|         type: "warning", | ||||
|         confirmButtonText: "Sure", | ||||
|         cancelButtonText: "Cancel", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           prettyNumberExaminePass({ id: row.id }).then((res) => { | ||||
|             if (res.code == 200) { | ||||
|               this.getData(); | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: "Operation successful", | ||||
|                 type: "success", | ||||
|               }); | ||||
|             } else { | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: res.message, | ||||
|                 type: "error", | ||||
|               }); | ||||
|             } | ||||
|           }); | ||||
|         }) | ||||
|         .catch(() => { }); | ||||
|     }, | ||||
|     // 拒绝 | ||||
|     handleReject (index, row) { | ||||
|       ElMessageBox.confirm("Are you sure you want to refuse?", "Prompt", { | ||||
|         type: "warning", | ||||
|         confirmButtonText: "Sure", | ||||
|         cancelButtonText: "Cancel", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           prettyNumberExamineReject({ id: row.id }).then((res) => { | ||||
|             if (res.code == 200) { | ||||
|               this.getData(); | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: "Operation successful", | ||||
|                 type: "success", | ||||
|               }); | ||||
|             } else { | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: res.message, | ||||
|                 type: "error", | ||||
|               }); | ||||
|             } | ||||
|           }); | ||||
|         }) | ||||
|         .catch(() => { }); | ||||
|     }, | ||||
|     // 删除操作 | ||||
|     handleDelete (index, row) { | ||||
|       // 二次确认删除 | ||||
|       ElMessageBox.confirm("Are you sure you want to delete?", "Prompt", { | ||||
|         type: "warning", | ||||
|         confirmButtonText: "Sure", | ||||
|         cancelButtonText: "Cancel", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           prettyNumberExamineDelete({ id: row.id }).then((res) => { | ||||
|             if (res.code == 200) { | ||||
|               this.getData(); | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: "Operation successful", | ||||
|                 type: "success", | ||||
|               }); | ||||
|             } else { | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: res.message, | ||||
|                 type: "error", | ||||
|               }); | ||||
|             } | ||||
|           }); | ||||
|         }) | ||||
|         .catch(() => { }); | ||||
|     }, | ||||
|     // 点击搜索 | ||||
|     handSearch () { | ||||
|       this.$refs["searchForm"].validate((valid) => { | ||||
|         if (valid) { | ||||
|           this.pageParams.pageNo = 1; | ||||
|           this.getData(); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 重置搜索表单 | ||||
|     resetSearchForm () { | ||||
|       this.$refs["searchForm"].resetFields(); | ||||
|       this.pageParams.pageNo = 1; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange (val) { | ||||
|       this.pageParams.pageNo = val; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handlePageChange (val) { | ||||
|       this.pageParams.pageNo = val; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     headerCopy (column, e) { | ||||
|       this.$copy(column.label); | ||||
|     }, | ||||
|     initPartition () { | ||||
|       getPartitionInfoList().then(res => { | ||||
|         let data = res.data; | ||||
|         this.partitionInfoList = data; | ||||
|       }); | ||||
|     }, | ||||
|   }, | ||||
|   computed: { | ||||
|     applyStateTag () { | ||||
|       return function (val) { | ||||
|         let text = ""; | ||||
|         switch (val) { | ||||
|           case 0: | ||||
|             text = "warning"; | ||||
|             break; | ||||
|           case 1: | ||||
|             text = "success"; | ||||
|             break; | ||||
|           case 2: | ||||
|             text = "info"; | ||||
|             break; | ||||
|           case 3: | ||||
|             text = "danger"; | ||||
|             break; | ||||
|         } | ||||
|         return text; | ||||
|       }; | ||||
|     }, | ||||
|     applyStateText () { | ||||
|       return function (val) { | ||||
|         let text = ""; | ||||
|         switch (val) { | ||||
|           case 0: | ||||
|             text = "In Review"; | ||||
|             break; | ||||
|           case 1: | ||||
|             text = "Passed"; | ||||
|             break; | ||||
|           case 2: | ||||
|             text = "Rejected"; | ||||
|             break; | ||||
|           case 3: | ||||
|             text = "Deleted"; | ||||
|             break; | ||||
|         } | ||||
|         return text; | ||||
|       }; | ||||
|     }, | ||||
|     convertTimestamp () { | ||||
|       return function (time) { | ||||
|         let date = new Date(time); | ||||
|         return formatDate(date); | ||||
|       }; | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style lang="scss"> | ||||
| .red { | ||||
|   color: rgb(241, 19, 19); | ||||
| } | ||||
|  | ||||
| // ::v-deep { | ||||
| //   .el-upload--picture-card { | ||||
| //     background-color: transparent; | ||||
| //     border: 0; | ||||
| //     border-radius: 0; | ||||
| //     box-sizing: border-box; | ||||
| //     width: 0; | ||||
| //     height: 45px; | ||||
| //     line-height: 0; | ||||
| //     vertical-align: top; | ||||
| //   } | ||||
| // } | ||||
| .file-uploader { | ||||
|   display: block; | ||||
|   margin-left: 51px; | ||||
|   input { | ||||
|     display: none; | ||||
|   } | ||||
|   .el-upload { | ||||
|     background-color: transparent; | ||||
|     border: 0; | ||||
|     border-radius: 0; | ||||
|     box-sizing: border-box; | ||||
|     width: 0; | ||||
|     height: 45px; | ||||
|     line-height: 0; | ||||
|     vertical-align: top; | ||||
|   } | ||||
|   span { | ||||
|     display: block; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1046,11 +1046,11 @@ export default { | ||||
|                             $("#tipModal").modal('show'); | ||||
|                             return; | ||||
|                         } | ||||
|                         if (!effect) { | ||||
|                             $("#tipMsg").text("请上传动画图片"); | ||||
|                             $("#tipModal").modal('show'); | ||||
|                             return; | ||||
|                         } | ||||
|                         // if (!effect) { | ||||
|                         //     $("#tipMsg").text("请上传动画图片"); | ||||
|                         //     $("#tipModal").modal('show'); | ||||
|                         //     return; | ||||
|                         // }  | ||||
|                         if (!days || days <= 0) { | ||||
|                             $("#tipMsg").text("请输入合理的购买天数"); | ||||
|                             $("#tipModal").modal('show'); | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1528
									
								
								src/views/firstpage/towPageBannerView.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1528
									
								
								src/views/firstpage/towPageBannerView.vue
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -48,7 +48,7 @@ | ||||
|           :src="scope.row.logo" | ||||
|           :zoom-rate="1.1" | ||||
|           :preview-src-list="scope.row.logo" | ||||
|           fit="cover" | ||||
|           fit="scale-down" | ||||
|           preview-teleported="true" | ||||
|           hide-on-click-modal="true" | ||||
|         /> | ||||
| @@ -63,7 +63,7 @@ | ||||
|           :src="scope.row.background" | ||||
|           :zoom-rate="1.1" | ||||
|           :preview-src-list="scope.row.background" | ||||
|           fit="cover" | ||||
|           fit="scale-down" | ||||
|           preview-teleported="true" | ||||
|           hide-on-click-modal="true" | ||||
|         /> | ||||
| @@ -78,7 +78,7 @@ | ||||
|           :src="scope.row.pic" | ||||
|           :zoom-rate="1.1" | ||||
|           :preview-src-list="scope.row.pic" | ||||
|           fit="cover" | ||||
|           fit="scale-down" | ||||
|           preview-teleported="true" | ||||
|           hide-on-click-modal="true" | ||||
|         /> | ||||
|   | ||||
| @@ -390,7 +390,7 @@ export default { | ||||
|       function setUserModal (data) { | ||||
|         modalData = { | ||||
|           uid: data.uid, erbanNo: data.erbanNo, | ||||
|           games: Object.assign([], data.games.map(game => { return { gameId: game.gameId, price: game.price, proficiency: game.proficiency, tags: Object.assign([], game.tags) } })) | ||||
|           games: Object.assign([], data.games ? data.games.map(game => { return { gameId: game.gameId, price: game.price, proficiency: game.proficiency, tags: Object.assign([], game.tags) } }) : []) | ||||
|         }; | ||||
|         freshUserModal(); | ||||
|       } | ||||
| @@ -463,7 +463,7 @@ function freshUserModal () { | ||||
|   } else { | ||||
|     $("#modalAddBtn").hide(); | ||||
|   } | ||||
|   const gameStr = modalData.games.map((game, index) => | ||||
|   const gameStr = !modalData.games ? '' : modalData.games.map((game, index) => | ||||
|     '<div class="form-group">' + | ||||
|     '<label for="modalGameId" class="col-sm-3 control-label">游戏:</label>' + | ||||
|     '<div class="col-sm-9">' + | ||||
|   | ||||
							
								
								
									
										376
									
								
								src/views/games/lingSmallGames.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										376
									
								
								src/views/games/lingSmallGames.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,376 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>游戏</span> | ||||
|       <el-select v-model="inquire.gameArrVal" placeholder="请选择"> | ||||
|         <el-option | ||||
|           v-for="item in inquire.gamesArr" | ||||
|           :key="item.gameId" | ||||
|           :label="item.gameName" | ||||
|           :value="item.gameId" | ||||
|         > | ||||
|         </el-option> | ||||
|       </el-select> | ||||
|     </div> | ||||
|     <!-- 时间选择器 --> | ||||
|     <div class="inquire"> | ||||
|       <span class="demonstration">日期</span> | ||||
|       <el-date-picker | ||||
|         v-model="inquire.time" | ||||
|         type="daterange" | ||||
|         range-separator="至" | ||||
|         start-placeholder="开始日期" | ||||
|         end-placeholder="结束日期" | ||||
|       > | ||||
|       </el-date-picker> | ||||
|     </div> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button | ||||
|       class="primary" | ||||
|       type="primary" | ||||
|       @click=" | ||||
|         tableData = []; | ||||
|         currentPage = 1; | ||||
|         isFinished = false; | ||||
|         getData(); | ||||
|       " | ||||
|       >查询</el-button | ||||
|     > | ||||
|     <el-button class="primary" type="primary" @click="confirmExport2Excel()" | ||||
|       >导出</el-button | ||||
|     > | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       ref="multipleTable" | ||||
|       @selection-change="handleSelectionChange" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="dateTime" align="center" label="日期" /> | ||||
|       <el-table-column prop="userCount" align="center" label="人数" /> | ||||
|       <el-table-column prop="consumeNum" align="center" label="货币消耗" /> | ||||
|       <el-table-column prop="settleNum" align="center" label="结算总量" /> | ||||
|       <el-table-column prop="platformNum" align="center" label="平台收入" /> | ||||
|       <el-table-column align="center" label="操作" width="300"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             @click=" | ||||
|               detailPageFunArr = scope.row; | ||||
|               tableDataDetails = []; | ||||
|               currentPage2 = 1; | ||||
|               isFinished2 = false; | ||||
|               detailPageFun(); | ||||
|             " | ||||
|             size="default" | ||||
|             >查看详情</el-button | ||||
|           > | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|  | ||||
|     <!-- 分页 --> | ||||
|     <!-- <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[1, 10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> --> | ||||
|     <!-- 加载更多按钮 --> | ||||
|     <div v-if="!isFinished" class="pagination"> | ||||
|       <el-button | ||||
|         class="pagination_in" | ||||
|         @click="loadMore" | ||||
|         type="primary" | ||||
|         :loading="isLoading" | ||||
|         >加载更多</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div v-else class="pagination"> | ||||
|       <span class="pagination_in">没有更多数据了</span> | ||||
|     </div> | ||||
|   </div> | ||||
|  | ||||
|   <!-- 内嵌单个工会详情 --> | ||||
|   <el-dialog :title="detailsTitle" v-model="detailsDialog"> | ||||
|     <el-table | ||||
|       v-loading="loading2" | ||||
|       :data="tableDataDetails" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="erbanNo" align="center" label="用户平台ID" /> | ||||
|       <el-table-column prop="nick" align="center" label="昵称" /> | ||||
|       <el-table-column prop="consumeNum" align="center" label="货币消耗" /> | ||||
|       <el-table-column prop="settleNum" align="center" label="结算总量" /> | ||||
|       <el-table-column prop="platformNum" align="center" label="平台收入" /> | ||||
|     </el-table> | ||||
|     <!-- 分页 --> | ||||
|     <!-- <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage2" | ||||
|       v-model:page-size="pageSize2" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total2" | ||||
|       @size-change="handleSizeChange2" | ||||
|       @current-change="handleCurrentChange2" | ||||
|     /> --> | ||||
|     <!-- 加载更多按钮 --> | ||||
|     <div v-if="!isFinished2" class="pagination"> | ||||
|       <el-button | ||||
|         class="pagination_in" | ||||
|         @click="loadMore2" | ||||
|         type="primary" | ||||
|         :loading="isLoading2" | ||||
|         >加载更多</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div v-else class="pagination"> | ||||
|       <span class="pagination_in">没有更多数据了</span> | ||||
|     </div> | ||||
|     <template #footer> | ||||
|       <div class="dialog-footer"> | ||||
|         <el-button @click="detailsDialog = false">关闭</el-button> | ||||
|         <el-button type="primary" @click="confirmExport2Excel2()" | ||||
|           >导出</el-button | ||||
|         > | ||||
|       </div></template | ||||
|     > | ||||
|   </el-dialog> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   statisPage, | ||||
|   sysConfKey, | ||||
|   detailPage, | ||||
|   exportForMiniGame, | ||||
|   statisExport, | ||||
| } from "@/api/lingSmallGames/lingSmallGames"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage, ElTable } from "element-plus"; | ||||
| import { ref } from "vue"; | ||||
| import { ElMessageBox } from "element-plus"; // 正确引入 ElM | ||||
| export default { | ||||
|   name: "lingSmallGames", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       loading2: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         time: "", | ||||
|         gameArrVal: "", | ||||
|         gamesArr: [], | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 分页 | ||||
|       total: 0, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|       isLoading: false, // 加载状态 | ||||
|       isFinished: false, // 是否加载完成 | ||||
|       //   弹窗 | ||||
|       detailsDialog: false, | ||||
|       detailsTitle: "", | ||||
|       tableDataDetails: [], | ||||
|       dateTimePub: null, | ||||
|       detailPageFunArr: {}, | ||||
|       // 分页 | ||||
|       total2: 0, //总页数 | ||||
|       currentPage2: 1, //页码 | ||||
|       pageSize2: 10, //条数 | ||||
|       isLoading2: false, // 加载状态 | ||||
|       isFinished2: false, // 是否加载完成 | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     sysConfKey({ configId: "leadercc_game" }).then((res) => { | ||||
|       this.inquire.gamesArr = JSON.parse(res.data.configValue); | ||||
|       this.getData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.isLoading = true; | ||||
|       this.loading = true; | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       statisPage({ | ||||
|         gameId: this.inquire.gameArrVal, | ||||
|         startTime: startTime, | ||||
|         endTime: endTime, | ||||
|         pageNum: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           // 判断返回的记录是否为空数组 | ||||
|           const records = res.data.records; | ||||
|           if (records.length > 0) { | ||||
|             // 如果有数据,追加到表格数据中 | ||||
|             this.tableData = [...this.tableData, ...records]; | ||||
|             this.currentPage++; // 更新当前页码 | ||||
|           } else { | ||||
|             // 如果数据长度为 0,停止加载 | ||||
|             this.isFinished = true; | ||||
|           } | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.loading = false; | ||||
|         this.isLoading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 加载下一页数据 | ||||
|     loadMore() { | ||||
|       if (!this.isFinished) { | ||||
|         this.currentPage = this.currentPage++; | ||||
|         this.getData(this.currentPage); | ||||
|       } | ||||
|     }, | ||||
|     // 加载下一页数据 | ||||
|     loadMore2() { | ||||
|       if (!this.isFinished2) { | ||||
|         this.currentPage2 = this.currentPage2++; | ||||
|         this.detailPageFun(this.currentPage2); | ||||
|       } | ||||
|     }, | ||||
|     // 导出 | ||||
|     confirmExport2Excel() { | ||||
|       this.loading = true; | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       exportForMiniGame({ | ||||
|         gameId: this.inquire.gameArrVal, | ||||
|         startTime: startTime, | ||||
|         endTime: endTime, | ||||
|       }).then(); | ||||
|     }, | ||||
|     // 导出弹窗 | ||||
|     confirmExport2Excel2() { | ||||
|       statisExport({ | ||||
|         dateTime: this.dateTimePub, | ||||
|         gameId: this.inquire.gameArrVal, | ||||
|       }).then(); | ||||
|     }, | ||||
|     // 详情接口 | ||||
|     detailPageFun() { | ||||
|       this.isLoading2 = true; | ||||
|       this.detailsDialog = true; | ||||
|       this.loading2 = true; | ||||
|       this.detailsTitle = this.dateTimePub = this.detailPageFunArr.dateTime; | ||||
|       detailPage({ | ||||
|         gameId: this.detailPageFunArr.gameId, | ||||
|         dateTime: this.detailPageFunArr.dateTime, | ||||
|         pageNum: this.currentPage2, | ||||
|         pageSize: this.pageSize2, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           // 判断返回的记录是否为空数组 | ||||
|           const records2 = res.data.records; | ||||
|           if (records2.length > 0) { | ||||
|             // 如果有数据,追加到表格数据中 | ||||
|             this.tableDataDetails = [...this.tableDataDetails, ...records2]; | ||||
|             this.currentPage2++; // 更新当前页码 | ||||
|           } else { | ||||
|             // 如果数据长度为 0,停止加载 | ||||
|             this.isFinished2 = true; | ||||
|           } | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.loading2 = false; | ||||
|         this.isLoading2 = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleSizeChange2() { | ||||
|       this.detailPageFun(); | ||||
|     }, | ||||
|     handleCurrentChange2() { | ||||
|       this.detailPageFun(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| .selectBox { | ||||
|   display: flex; | ||||
|   height: 35px; | ||||
|   line-height: 35px; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| .selectBoxImg { | ||||
|   height: 150px; | ||||
| } | ||||
| .pagination { | ||||
|   margin: 10px auto 10px; | ||||
|   position: relative; | ||||
|   left: 50%; | ||||
|   transform: translateX(-50%); | ||||
| } | ||||
| .pagination_in { | ||||
|   text-align: center; | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										413
									
								
								src/views/goldCoinGiftingHistory/GoldCoinGiftingHistory.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										413
									
								
								src/views/goldCoinGiftingHistory/GoldCoinGiftingHistory.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,413 @@ | ||||
| <template> | ||||
|   <div class="list-gold-coin-transfer"> | ||||
|     <div class="container"> | ||||
|       <div class="handle-box"> | ||||
|         <el-form | ||||
|           ref="searchForm" | ||||
|           :model="searchForm" | ||||
|           :rules="searchRule" | ||||
|           label-width="120px" | ||||
|           :disabled="tableLoading" | ||||
|         > | ||||
|           <div class="search-line"> | ||||
|             <el-form-item label="转赠用户平台号" prop="sendUserPlatformNo"> | ||||
|               <el-input | ||||
|                 v-model.number="searchForm.sendUserPlatformNo" | ||||
|                 placeholder="请输入" | ||||
|               ></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="接收用户平台号" prop="receiveUserPlatformNo"> | ||||
|               <el-input | ||||
|                 v-model.number="searchForm.receiveUserPlatformNo" | ||||
|                 placeholder="请输入" | ||||
|               ></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="创建时间" class="large"> | ||||
|               <el-form-item prop="startTime"> | ||||
|                 <el-date-picker | ||||
|                   type="datetime" | ||||
|                   placeholder="选择开始时间" | ||||
|                   v-model="searchForm.startTime" | ||||
|                   value-format="yyyy/MM/dd HH:mm:ss" | ||||
|                 ></el-date-picker> | ||||
|               </el-form-item> | ||||
|               <el-col :span="2" align="center">-</el-col> | ||||
|               <el-form-item prop="endTime"> | ||||
|                 <el-date-picker | ||||
|                   type="datetime" | ||||
|                   placeholder="选择结束时间" | ||||
|                   v-model="searchForm.endTime" | ||||
|                   value-format="yyyy/MM/dd HH:mm:ss" | ||||
|                 ></el-date-picker> | ||||
|               </el-form-item> | ||||
|             </el-form-item> | ||||
|             <el-form-item label-width="40px"> | ||||
|               <el-button type="primary" @click="handSearch">搜索</el-button> | ||||
|               <el-button plain @click="resetSearchForm">重置搜索</el-button> | ||||
|               <el-button | ||||
|                 type="primary" | ||||
|                 class="mr10" | ||||
|                 @click="exportVisible = true" | ||||
|                 >导出</el-button | ||||
|               > | ||||
|             </el-form-item> | ||||
|           </div> | ||||
|         </el-form> | ||||
|  | ||||
|         <p style="color: #00d1b2">当前汇总值:{{ totalCoins }}</p> | ||||
|       </div> | ||||
|       <el-table | ||||
|         :data="tableData" | ||||
|         border | ||||
|         class="table" | ||||
|         ref="multipleTable" | ||||
|         header-cell-class-name="table-header" | ||||
|         @header-click="headerCopy" | ||||
|         v-loading="tableLoading" | ||||
|       > | ||||
|         <el-table-column | ||||
|           prop="id" | ||||
|           width="90" | ||||
|           label="ID" | ||||
|           align="center" | ||||
|           fixed="left" | ||||
|         ></el-table-column> | ||||
|         <el-table-column | ||||
|           prop="fromUserNick" | ||||
|           label="转赠用户昵称" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <el-table-column | ||||
|           prop="fromUserPlatformNo" | ||||
|           width="120" | ||||
|           label="转赠用户平台号" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <el-table-column | ||||
|           prop="toUserNick" | ||||
|           label="接收用户昵称" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <el-table-column | ||||
|           prop="toUserPlatformNo" | ||||
|           width="120" | ||||
|           label="接收用户平台号" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <el-table-column | ||||
|           prop="abbr" | ||||
|           label="接收用户国家" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <el-table-column | ||||
|           prop="goldNum" | ||||
|           width="110" | ||||
|           label="金币数量" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <el-table-column width="160" label="创建时间" align="center"> | ||||
|           <template v-slot="scope">{{ | ||||
|             convertTimestamp(scope.row.createTime) | ||||
|           }}</template> | ||||
|         </el-table-column> | ||||
|         <el-table-column width="160" label="更新时间" align="center"> | ||||
|           <template v-slot="scope">{{ | ||||
|             convertTimestamp(scope.row.updateTime) | ||||
|           }}</template> | ||||
|         </el-table-column> | ||||
|       </el-table> | ||||
|       <table-pagination | ||||
|         :pageParams="pageParams" | ||||
|         :pageTotal="pageTotal" | ||||
|         @handleSizeChange="handleSizeChange" | ||||
|         @handlePageChange="handlePageChange" | ||||
|       ></table-pagination> | ||||
|     </div> | ||||
|     <!-- 确认导出弹出框 --> | ||||
|     <el-dialog | ||||
|       v-model="exportVisible" | ||||
|       width="30%" | ||||
|       :before-close="handlDialogClose" | ||||
|     > | ||||
|       <!-- 使用 v-slot 指令提供 'title' 插槽的内容 --> | ||||
|       <template v-slot:title> | ||||
|         <div style="display: flex; align-items: center">提示</div> | ||||
|       </template> | ||||
|  | ||||
|       <!-- 默认插槽的内容 --> | ||||
|       <div style="font-size: 16px">确定以当前筛选条件导出Excel吗?</div> | ||||
|  | ||||
|       <!-- 使用 v-slot 指令提供 'footer' 插槽的内容 --> | ||||
|       <template v-slot:footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="exportVisible = false" :disabled="dialogDisabled" | ||||
|             >取 消</el-button | ||||
|           > | ||||
|           <el-button | ||||
|             type="primary" | ||||
|             @click="confirmExport2Excel" | ||||
|             :loading="btnLoading" | ||||
|             :disabled="dialogDisabled" | ||||
|             >确 定</el-button | ||||
|           > | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { | ||||
|   getGoldCoinTransferList, | ||||
|   getGoldCoinSumGold, | ||||
| } from "@/api/relUserBelongings/relUserBelongings.js"; | ||||
| import { formatDate } from "@/utils/relDate.js"; | ||||
| import { exportExcel } from "@/utils/exportExcel.js"; | ||||
| import TablePagination from "@/components/common/TablePagination.vue"; | ||||
| export default { | ||||
|   name: "GoldCoinGiftingHistory", | ||||
|   components: { TablePagination }, | ||||
|   data() { | ||||
|     return { | ||||
|       clickedLineId: null, // 记录被点击的某行数据的id | ||||
|       clickedLineText: "GIFT_IN_ROOM", // 记录红包类型 | ||||
|       tableData: [], // 接口返回的表格数据 | ||||
|       pageTotal: 0, // 接口返回的表格总条数 | ||||
|       pageParams: { | ||||
|         pageNo: 1, | ||||
|         pageSize: 10, | ||||
|       }, | ||||
|       exportVisible: false, | ||||
|       tableLoading: false, // 表格是否加载中 | ||||
|  | ||||
|       // 搜索表单相关 | ||||
|       searchForm: { | ||||
|         sendUserPlatformNo: null, // 接收者平台号 | ||||
|         receiveUserPlatformNo: null, // 发送者平台号 | ||||
|         startTime: null, | ||||
|         endTime: null, | ||||
|       }, | ||||
|       searchRule: { | ||||
|         startTime: [ | ||||
|           { | ||||
|             validator: (rule, value, callback) => { | ||||
|               this.$refs["searchForm"].validateField("endTime"); | ||||
|               callback(); | ||||
|             }, | ||||
|             trigger: "change", | ||||
|           }, | ||||
|         ], | ||||
|         endTime: [ | ||||
|           { | ||||
|             validator: (rule, value, callback) => { | ||||
|               const { startTime } = this.searchForm; | ||||
|               if (startTime !== null && startTime !== "" && value) { | ||||
|                 if (value <= startTime) { | ||||
|                   callback(new Error("须晚于开始时间")); | ||||
|                 } else { | ||||
|                   callback(); | ||||
|                 } | ||||
|               } else { | ||||
|                 callback(); | ||||
|               } | ||||
|             }, | ||||
|             trigger: "change", | ||||
|           }, | ||||
|         ], | ||||
|       }, | ||||
|  | ||||
|       dialogDisabled: false, // 是否禁用弹出框(dialog)表单元素 | ||||
|       btnLoading: false, // 弹出框(dialog)的确认按钮 | ||||
|       totalCoins: null, //当前金币汇总值 | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     // this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     getData() { | ||||
|       this.tableLoading = true; | ||||
|  | ||||
|       let { pageParams, searchForm } = this; | ||||
|       searchForm = JSON.parse(JSON.stringify(searchForm)); | ||||
|       pageParams = JSON.parse(JSON.stringify(pageParams)); | ||||
|       Object.keys(searchForm).forEach((item) => { | ||||
|         if ( | ||||
|           !searchForm[item] || | ||||
|           (searchForm[item] !== undefined && searchForm[item] === "") | ||||
|         ) { | ||||
|           delete searchForm[item]; | ||||
|         } | ||||
|       }); | ||||
|       Object.assign(pageParams, searchForm); | ||||
|  | ||||
|       getGoldCoinSumGold(pageParams).then((res) => { | ||||
|         if (res.data.success === true) { | ||||
|           let data = res.data.data; | ||||
|           this.totalCoins = data; | ||||
|         } | ||||
|       }); | ||||
|       getGoldCoinTransferList(pageParams).then((res) => { | ||||
|         this.tableLoading = false; | ||||
|         if (res.data.success === true) { | ||||
|           let data = res.data.data; | ||||
|           this.tableData = data.list; | ||||
|           this.pageTotal = data.total; | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 点击搜索 | ||||
|     handSearch() { | ||||
|       this.$refs["searchForm"].validate((valid) => { | ||||
|         if (valid) { | ||||
|           this.pageParams.pageNo = 1; | ||||
|           this.getData(); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 重置搜索表单 | ||||
|     resetSearchForm() { | ||||
|       this.$refs["searchForm"].resetFields(); | ||||
|       this.pageParams.pageNo = 1; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // 弹窗关闭前控制 | ||||
|     handlDialogClose(done) { | ||||
|       const { dialogDisabled } = this; | ||||
|       if (dialogDisabled) return; | ||||
|       done(); | ||||
|     }, | ||||
|     // 重置表单状态 | ||||
|     resetDialog() { | ||||
|       this.btnLoading = false; | ||||
|       this.dialogDisabled = false; | ||||
|     }, | ||||
|  | ||||
|     // 分页导航 | ||||
|     handleSizeChange(val) { | ||||
|       this.$set(this.pageParams, "pageSize", val); | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handlePageChange(val) { | ||||
|       this.$set(this.pageParams, "pageNo", val); | ||||
|       this.getData(); | ||||
|     }, | ||||
|     headerCopy(column, e) { | ||||
|       this.$copy(column.label); | ||||
|     }, | ||||
|  | ||||
|     // 确认导出 | ||||
|     confirmExport2Excel() { | ||||
|       this.btnLoading = true; | ||||
|       this.dialogDisabled = true; | ||||
|  | ||||
|       let { searchForm } = this; | ||||
|       searchForm = JSON.parse(JSON.stringify(searchForm)); | ||||
|       Object.keys(searchForm).forEach((item) => { | ||||
|         if ( | ||||
|           !searchForm[item] || | ||||
|           (searchForm[item] !== undefined && searchForm[item] === "") | ||||
|         ) { | ||||
|           delete searchForm[item]; | ||||
|         } | ||||
|       }); | ||||
|       Object.assign(searchForm, { pageSize: 10000, pageNo: 1 }); | ||||
|  | ||||
|       getGoldCoinTransferList(searchForm).then((res) => { | ||||
|         this.resetDialog(); | ||||
|         if (res.data.success === true) { | ||||
|           this.exportVisible = false; | ||||
|  | ||||
|           const list = res.data.data.list; | ||||
|           list.forEach((item) => { | ||||
|             item.createTime = formatDate(item.createTime); | ||||
|             item.updateTime = formatDate(item.updateTime); | ||||
|           }); | ||||
|           const tHeader = [ | ||||
|             "ID", | ||||
|             "转赠用户昵称", | ||||
|             "转赠用户平台号", | ||||
|             "接收用户昵称", | ||||
|             "接收用户平台号", | ||||
|             "接收用户国家", | ||||
|             "金币数量", | ||||
|             "创建时间", | ||||
|             "更新时间", | ||||
|           ]; | ||||
|           const filterVal = [ | ||||
|             "id", | ||||
|             "fromUserNick", | ||||
|             "fromUserPlatformNo", | ||||
|             "toUserNick", | ||||
|             "toUserPlatformNo", | ||||
|             "abbr", | ||||
|             "goldNum", | ||||
|             "createTime", | ||||
|             "updateTime", | ||||
|           ]; | ||||
|           const exportName = `金币转赠历史${formatDate(new Date())}`; | ||||
|  | ||||
|           exportExcel(tHeader, filterVal, list, exportName); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|   }, | ||||
|   computed: { | ||||
|     convertTimestamp() { | ||||
|       return function (time) { | ||||
|         let date = new Date(time); | ||||
|         return formatDate(date); | ||||
|       }; | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| .handle-box { | ||||
|   overflow: hidden; | ||||
|   .search-line { | ||||
|     display: flex; | ||||
|     flex-wrap: wrap; | ||||
|     .el-form-item { | ||||
|       width: 320px; | ||||
|       .el-input, | ||||
|       .el-select { | ||||
|         width: 200px; | ||||
|       } | ||||
|       .el-form-item--small { | ||||
|         margin-bottom: 0; | ||||
|       } | ||||
|       .el-form-item { | ||||
|         float: left; | ||||
|       } | ||||
|       &.large { | ||||
|         width: 580px; | ||||
|         .el-form-item { | ||||
|           width: 200px; | ||||
|         } | ||||
|       } | ||||
|       &.small { | ||||
|         .el-form-item { | ||||
|           width: 90px; | ||||
|           .el-input { | ||||
|             width: 100%; | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .table { | ||||
|   width: 100%; | ||||
|   font-size: 14px; | ||||
| } | ||||
|  | ||||
| .table-td-thumb { | ||||
|   display: block; | ||||
|   margin: auto; | ||||
|   width: 40px; | ||||
|   height: 40px; | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										314
									
								
								src/views/guildOperationManagement/agencyDiamondFlow.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										314
									
								
								src/views/guildOperationManagement/agencyDiamondFlow.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,314 @@ | ||||
| <template> | ||||
|   <div class="agency-diamond-flow"> | ||||
|     <div class="container"> | ||||
|       <div class="region-box"> | ||||
|         <el-radio-group v-model="region"> | ||||
|           <el-radio | ||||
|             v-for="(item, index) in userAreaRegion" | ||||
|             :key="index" | ||||
|             :label="item.value" | ||||
|             >{{ item.name }}</el-radio | ||||
|           > | ||||
|         </el-radio-group> | ||||
|       </div> | ||||
|       <div class="handle-box"> | ||||
|         <el-form | ||||
|           ref="searchForm" | ||||
|           :model="searchForm" | ||||
|           :rules="searchRule" | ||||
|           label-width="90px" | ||||
|           :disabled="tableLoading" | ||||
|         > | ||||
|           <div class="search-line"> | ||||
|             <el-form-item label="公会ID" prop="agencyId"> | ||||
|               <el-input | ||||
|                 v-model.trim="searchForm.agencyId" | ||||
|                 placeholder="请输入" | ||||
|               ></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="公会长ID" prop="agencyOwnerId"> | ||||
|               <el-input | ||||
|                 v-model.trim="searchForm.agencyOwnerId" | ||||
|                 placeholder="请输入" | ||||
|               ></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="周期" prop="dateCycle"> | ||||
|               <el-select placeholder="请选择" v-model="searchForm.dateCycle"> | ||||
|                 <el-option | ||||
|                   v-for="(item, i) in dateCycleList" | ||||
|                   :key="i" | ||||
|                   :label="item.startDateStr + '~' + item.endDateStr" | ||||
|                   :value="item.dateCycle" | ||||
|                 ></el-option> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|  | ||||
|             <el-form-item label-width="40px"> | ||||
|               <el-button type="primary" @click="handSearch">搜索</el-button> | ||||
|               <el-button plain @click="resetSearchForm">重置搜索</el-button> | ||||
|             </el-form-item> | ||||
|           </div> | ||||
|         </el-form> | ||||
|         <el-button type="primary" class="exportBtn" @click="confirmExport2Excel" | ||||
|           >导出</el-button | ||||
|         > | ||||
|       </div> | ||||
|       <div class="table"> | ||||
|         <el-table | ||||
|           :data="tableData" | ||||
|           border | ||||
|           v-loading="tableLoading" | ||||
|           @header-click="headerCopy" | ||||
|           style="width: 100%" | ||||
|         > | ||||
|           <!-- <el-table-column align="center" prop="region" label="区服"> | ||||
|                         <template v-slot="scope"> | ||||
|                             {{ regionType(scope.row.region) }} | ||||
|                         </template> | ||||
|                     </el-table-column> --> | ||||
|           <el-table-column align="center" prop="agencyId" label="公会ID"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="agencyName" label="公会名称"> | ||||
|           </el-table-column> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="hallMemberCount" | ||||
|             label="主播人数" | ||||
|           > | ||||
|           </el-table-column> | ||||
|           <!-- <el-table-column align="center" prop="agencyAbbr" label="公会国家"> </el-table-column> --> | ||||
|           <el-table-column align="center" prop="agencyErbanNo" label="公会长ID"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="energyValue" label="总钻石流水"> | ||||
|             <template v-slot="scope"> | ||||
|               {{ scope.row.energyValue ? scope.row.energyValue.toLocaleString() : "null"}} | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="salaryRate" | ||||
|             label="公会长薪资比例" | ||||
|           > | ||||
|             <template v-slot="scope"> | ||||
|               {{ scope.row.salaryRate ? scope.row.salaryRate + "%" : "0%" }} | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="hallSalary" label="公会长薪资"> | ||||
|           </el-table-column> | ||||
|         </el-table> | ||||
|       </div> | ||||
|       <table-pagination | ||||
|         :pageParams="pageParams" | ||||
|         :pageTotal="pageTotal" | ||||
|         :page-sizes="[10, 20, 100, 200]" | ||||
|         @handleSizeChange="handleSizeChange" | ||||
|         @handlePageChange="handlePageChange" | ||||
|       ></table-pagination> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script lang=js> | ||||
| import { getDateCycleList, getAgencyDiamondFlow, agencyDiamondFlowExport } from '@/api/relAgency/relAgency.js'; | ||||
| import TablePagination from '@/components/common/TablePagination'; | ||||
| import { formatDate, formatDateYMD } from '@/utils/relDate'; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| import { ref } from 'vue'; // 引入 ref | ||||
| import { ElMessageBox } from 'element-plus'; // 正确引入 ElM | ||||
| // 混入 | ||||
| // import Mixin from '../../mixin/mixRegion.js'; | ||||
|  | ||||
| export default { | ||||
|     name: "agencyDiamondFlow", | ||||
|     // mixins: [Mixin], | ||||
|     components: { TablePagination }, | ||||
|     data() { | ||||
|         return { | ||||
|             dateCycleList: [], | ||||
|             btnLoading: false, // 导出弹出框(dialog)的确认按钮 | ||||
|             tableLoading: false, // 表格是否加载中 | ||||
|  | ||||
|             tableData: [], // 接口返回的表格数据 | ||||
|             pageTotal: 0, // 接口返回的表格总条数 | ||||
|             pageParams: { | ||||
|                 pageNo: 1, | ||||
|                 pageSize: 20 | ||||
|             }, | ||||
|             // 搜索表单相关 | ||||
|             searchForm: { | ||||
|                 agencyOwnerId: null, | ||||
|                 agencyId: null, | ||||
|                 dateCycle: null, | ||||
|                 region: null | ||||
|             }, | ||||
|             searchRule: { | ||||
|                 startTime: [ | ||||
|                     { | ||||
|                         validator: (rule, value, callback) => { | ||||
|                             this.$refs['searchForm'].validateField('endTime'); | ||||
|                             callback(); | ||||
|                         }, | ||||
|                         trigger: 'change' | ||||
|                     } | ||||
|                 ], | ||||
|                 endTime: [ | ||||
|                     { | ||||
|                         validator: (rule, value, callback) => { | ||||
|                             const { startTime } = this.searchForm; | ||||
|                             if (startTime !== null && startTime !== '' && value) { | ||||
|                                 if (value <= startTime) { | ||||
|                                     callback(new Error('须晚于开始时间')); | ||||
|                                 } else { | ||||
|                                     callback(); | ||||
|                                 } | ||||
|                             } else { | ||||
|                                 callback(); | ||||
|                             } | ||||
|                         }, | ||||
|                         trigger: 'change' | ||||
|                     } | ||||
|                 ] | ||||
|             } | ||||
|         }; | ||||
|     }, | ||||
|     created() { | ||||
|         this.getDateCycleList(); | ||||
|     }, | ||||
|     methods: { | ||||
|         getDateCycleList() { | ||||
|             getDateCycleList({ month: 3 }).then((res) => { | ||||
|                 this.dateCycleList = res.data || []; | ||||
|             }); | ||||
|         }, | ||||
|         getData() { | ||||
|             this.tableLoading = true; | ||||
|  | ||||
|             let { pageParams, searchForm } = this; | ||||
|             searchForm = JSON.parse(JSON.stringify(searchForm)); | ||||
|             pageParams = JSON.parse(JSON.stringify(pageParams)); | ||||
|             Object.keys(searchForm).forEach((item) => { | ||||
|                 if (!searchForm[item] || (searchForm[item] !== undefined && searchForm[item] === '')) { | ||||
|                     delete searchForm[item]; | ||||
|                 } | ||||
|             }); | ||||
|             Object.assign(pageParams, searchForm); | ||||
|  | ||||
|             getAgencyDiamondFlow(pageParams).then((res) => { | ||||
|                 this.tableLoading = false; | ||||
|                 if (res.code == 200) { | ||||
|                     let data = res.data; | ||||
|                     this.tableData = data.records; | ||||
|                     this.pageTotal = data.total; | ||||
|                 }else{ | ||||
|                     ElMessage({ | ||||
|                     showClose: true, | ||||
|                     message: res.message, | ||||
|                     type: "error", | ||||
|                     }); | ||||
|             } | ||||
|             }); | ||||
|         }, | ||||
|         // 点击搜索 | ||||
|         handSearch() { | ||||
|             this.$refs['searchForm'].validate((valid) => { | ||||
|                 if (valid) { | ||||
|                     this.pageParams.pageNo = 1; | ||||
|                     this.getData(); | ||||
|                 } | ||||
|             }); | ||||
|         }, | ||||
|         // 重置搜索表单 | ||||
|         resetSearchForm() { | ||||
|             this.$refs['searchForm'].resetFields(); | ||||
|             this.pageParams.pageNo = 1; | ||||
|             this.getData(); | ||||
|         }, | ||||
|         // 确认导出 | ||||
|         confirmExport2Excel() { | ||||
|            ElMessageBox.confirm('确定以当前筛选条件导出Excel吗?', '提示', { | ||||
|                 confirmButtonText: '确定', | ||||
|                 cancelButtonText: '取消', | ||||
|                 type: 'warning' | ||||
|             }) | ||||
|                 .then(() => { | ||||
|                     this.btnLoading = true; | ||||
|                     let { searchForm } = this; | ||||
|                     searchForm = JSON.parse(JSON.stringify(searchForm)); | ||||
|                     Object.keys(searchForm).forEach((item) => { | ||||
|                         if (!searchForm[item] || (searchForm[item] !== undefined && searchForm[item] === '')) { | ||||
|                             delete searchForm[item]; | ||||
|                         } | ||||
|                     }); | ||||
|                     Object.assign(searchForm, { pageSize: 10000, pageNo: 1 }); | ||||
|  | ||||
|                     agencyDiamondFlowExport(searchForm) | ||||
|                         .then((res) => { | ||||
|                             if (res) { | ||||
|                                 this.exportVisible = false; | ||||
|                                 this.btnLoading = false; | ||||
|                                 let time = formatDate(new Date()); | ||||
|                                 let alink = document.createElement('a'); | ||||
|                                 alink.download = `公会钻石薪资流水统计${time}.xls`; | ||||
|                                 alink.style.display = 'none'; | ||||
|                                 const blob = new Blob([res.data]); | ||||
|                                 alink.href = URL.createObjectURL(blob); | ||||
|                                 document.body.appendChild(alink); | ||||
|                                 alink.click(); | ||||
|                                 URL.revokeObjectURL(alink.href); | ||||
|                             } | ||||
|                         }) | ||||
|                         .catch((err) => { | ||||
|                             console.error(err); // 打印错误信息 | ||||
|                            ElMessage({ | ||||
|                                 showClose: true, | ||||
|                                 message:"导出失败", | ||||
|                                 type: "error", | ||||
|                             }); | ||||
|                         }); | ||||
|                 }) | ||||
|                 .catch(() => { | ||||
|                 }); | ||||
|         }, | ||||
|         // 分页导航 | ||||
|         handleSizeChange(val) { | ||||
|            this.pageParams.pageSize = val; | ||||
|             this.getData(); | ||||
|         }, | ||||
|         handlePageChange(val) { | ||||
|           this.pageParams.pageSize = val; | ||||
|             this.getData(); | ||||
|         }, | ||||
|         headerCopy(column, e) { | ||||
|             this.$copy(column.label); | ||||
|         } | ||||
|     }, | ||||
|     computed: { | ||||
|         convertTimestamp1() { | ||||
|             return function (time) { | ||||
|                 let date = new Date(time); | ||||
|                 return formatDateYMD(date); | ||||
|             }; | ||||
|         }, | ||||
|         convertTimestamp() { | ||||
|             return function (time) { | ||||
|                 let date = new Date(time); | ||||
|                 return formatDate(date); | ||||
|             }; | ||||
|         } | ||||
|     } | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style scope> | ||||
| .exportBtn { | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
|  | ||||
| .container { | ||||
|   width: 100%; | ||||
| } | ||||
| .search-line { | ||||
|   width: 38%; | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										287
									
								
								src/views/guildOperationManagement/agentSendSalary.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										287
									
								
								src/views/guildOperationManagement/agentSendSalary.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,287 @@ | ||||
| <template> | ||||
|   <div class="agent-send-salary"> | ||||
|     <div class="container"> | ||||
|       <div class="handle-box"> | ||||
|         <el-form | ||||
|           ref="searchForm" | ||||
|           :model="searchForm" | ||||
|           :rules="searchRule" | ||||
|           label-width="90px" | ||||
|           :disabled="tableLoading" | ||||
|         > | ||||
|           <div class="search-line"> | ||||
|             <el-form-item label="充值代理ID" prop="chargeAgentErbanNo"> | ||||
|               <el-input | ||||
|                 v-model.trim="searchForm.chargeAgentErbanNo" | ||||
|                 placeholder="请输入" | ||||
|               ></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="主播ID" prop="erbanNo"> | ||||
|               <el-input | ||||
|                 v-model.trim="searchForm.erbanNo" | ||||
|                 placeholder="请输入" | ||||
|               ></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="时间" class="large"> | ||||
|               <el-form-item prop="startTime"> | ||||
|                 <el-date-picker | ||||
|                   type="datetime" | ||||
|                   placeholder="选择开始时间" | ||||
|                   v-model="searchForm.startTime" | ||||
|                 ></el-date-picker> | ||||
|               </el-form-item> | ||||
|               <el-col :span="2" align="center">-</el-col> | ||||
|               <el-form-item prop="endTime"> | ||||
|                 <el-date-picker | ||||
|                   type="datetime" | ||||
|                   placeholder="选择结束时间" | ||||
|                   v-model="searchForm.endTime" | ||||
|                 ></el-date-picker> | ||||
|               </el-form-item> | ||||
|             </el-form-item> | ||||
|  | ||||
|             <el-form-item label-width="40px"> | ||||
|               <el-button type="primary" @click="handSearch">搜索</el-button> | ||||
|               <el-button plain @click="resetSearchForm">重置搜索</el-button> | ||||
|             </el-form-item> | ||||
|           </div> | ||||
|         </el-form> | ||||
|         <el-button type="text" class="total" | ||||
|           >转增薪资总额:{{ total ? total.toLocaleString() : "0" }}</el-button | ||||
|         > | ||||
|       </div> | ||||
|       <div class="table"> | ||||
|         <el-table | ||||
|           :data="tableData" | ||||
|           border | ||||
|           v-loading="tableLoading" | ||||
|           @header-click="headerCopy" | ||||
|           style="width: 100%" | ||||
|         > | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="receiveErbano" | ||||
|             label="充值代理ID" | ||||
|           > | ||||
|           </el-table-column> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="receiveNick" | ||||
|             label="充值代理昵称" | ||||
|           > | ||||
|           </el-table-column> | ||||
|           <!-- <el-table-column | ||||
|             align="center" | ||||
|             prop="receiveAbbr" | ||||
|             label="充值代理国家" | ||||
|           > | ||||
|           </el-table-column> --> | ||||
|           <el-table-column align="center" prop="erbano" label="主播ID"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="nick" label="主播昵称"> | ||||
|           </el-table-column> | ||||
|           <!-- <el-table-column align="center" prop="abbr" label="主播国家"> | ||||
|           </el-table-column> --> | ||||
|           <el-table-column align="center" prop="tradeUsb" label="转增薪资"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="gold" label="对应金币数"> | ||||
|           </el-table-column> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="createTime" | ||||
|             label="创建时间" | ||||
|             width="160" | ||||
|           > | ||||
|             <template v-slot="scope"> | ||||
|               {{ convertTimestamp(scope.row.createTime) }} | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|         </el-table> | ||||
|       </div> | ||||
|       <table-pagination | ||||
|         :pageParams="pageParams" | ||||
|         :pageTotal="pageTotal" | ||||
|         :page-sizes="[10, 20, 100, 200]" | ||||
|         @handleSizeChange="handleSizeChange" | ||||
|         @handlePageChange="handlePageChange" | ||||
|       ></table-pagination> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { chargeAgentList, chargeAgentSum } from "@/api/relAgency/relAgency.js"; | ||||
| import TablePagination from "@/components/common/TablePagination"; | ||||
| import { formatDate, formatDateYMD } from "@/utils/relDate"; | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| import { ref } from "vue"; | ||||
| export default { | ||||
|   name: "agentSendSalary", | ||||
|   components: { TablePagination }, | ||||
|   data() { | ||||
|     return { | ||||
|       total: 0, | ||||
|       btnLoading: false, // 导出弹出框(dialog)的确认按钮 | ||||
|       tableLoading: false, // 表格是否加载中 | ||||
|  | ||||
|       tableData: [], // 接口返回的表格数据 | ||||
|       pageTotal: 0, // 接口返回的表格总条数 | ||||
|       pageParams: { | ||||
|         pageNo: 1, | ||||
|         pageSize: 20, | ||||
|       }, | ||||
|       // 搜索表单相关 | ||||
|       searchForm: { | ||||
|         erbanNo: null, | ||||
|         chargeAgentErbanNo: null, | ||||
|         startTime: null, | ||||
|         endTime: null, | ||||
|       }, | ||||
|       searchRule: { | ||||
|         startTime: [ | ||||
|           { | ||||
|             validator: (rule, value, callback) => { | ||||
|               this.$refs["searchForm"].validateField("endTime"); | ||||
|               callback(); | ||||
|             }, | ||||
|             trigger: "change", | ||||
|           }, | ||||
|         ], | ||||
|         endTime: [ | ||||
|           { | ||||
|             validator: (rule, value, callback) => { | ||||
|               const { startTime } = this.searchForm; | ||||
|               if (startTime !== null && startTime !== "" && value) { | ||||
|                 if (value <= startTime) { | ||||
|                   callback(new Error("须晚于开始时间")); | ||||
|                 } else { | ||||
|                   callback(); | ||||
|                 } | ||||
|               } else { | ||||
|                 callback(); | ||||
|               } | ||||
|             }, | ||||
|             trigger: "change", | ||||
|           }, | ||||
|         ], | ||||
|       }, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     // this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     getData() { | ||||
|       this.tableLoading = true; | ||||
|  | ||||
|       let { pageParams, searchForm } = this; | ||||
|       console.log(searchForm); | ||||
|       searchForm.startTime = searchForm.startTime | ||||
|         ? dateFormat(searchForm.startTime, "yyyy-MM-dd hh:mm:ss") | ||||
|         : null; | ||||
|       searchForm.endTime = searchForm.endTime | ||||
|         ? dateFormat(searchForm.endTime, "yyyy-MM-dd hh:mm:ss") | ||||
|         : null; | ||||
|       searchForm = JSON.parse(JSON.stringify(searchForm)); | ||||
|       pageParams = JSON.parse(JSON.stringify(pageParams)); | ||||
|       Object.keys(searchForm).forEach((item) => { | ||||
|         if ( | ||||
|           !searchForm[item] || | ||||
|           (searchForm[item] !== undefined && searchForm[item] === "") | ||||
|         ) { | ||||
|           delete searchForm[item]; | ||||
|         } | ||||
|       }); | ||||
|       Object.assign(pageParams, searchForm); | ||||
|       console.log(pageParams); | ||||
|  | ||||
|       chargeAgentList(pageParams).then((res) => { | ||||
|         this.tableLoading = false; | ||||
|         if (res.code == 200) { | ||||
|           let data = res.data; | ||||
|           this.tableData = data.records; | ||||
|           this.pageTotal = data.total; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|       chargeAgentSum(pageParams).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           this.total = res.data; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 点击搜索 | ||||
|     handSearch() { | ||||
|       this.$refs["searchForm"].validate((valid) => { | ||||
|         if (valid) { | ||||
|           this.pageParams.pageNo = 1; | ||||
|           this.getData(); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 重置搜索表单 | ||||
|     resetSearchForm() { | ||||
|       this.$refs["searchForm"].resetFields(); | ||||
|       this.pageParams.pageNo = 1; | ||||
|       this.getData(); | ||||
|     }, | ||||
|  | ||||
|     // 分页导航 | ||||
|     handleSizeChange(val) { | ||||
|       // this.$set(this.pageParams, 'pageSize', val); | ||||
|       this.pageParams.pageSize = val; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handlePageChange(val) { | ||||
|       // this.$set(this.pageParams, 'pageNo', val); | ||||
|       this.pageParams.pageSize = val; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     headerCopy(column, e) { | ||||
|       this.$copy(column.label); | ||||
|     }, | ||||
|   }, | ||||
|   computed: { | ||||
|     convertTimestamp1() { | ||||
|       return function (time) { | ||||
|         let date = new Date(time); | ||||
|         return formatDateYMD(date); | ||||
|       }; | ||||
|     }, | ||||
|     convertTimestamp() { | ||||
|       return function (time) { | ||||
|         let date = new Date(time); | ||||
|         return formatDate(date); | ||||
|       }; | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style scope> | ||||
| .exportBtn { | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| .total { | ||||
|   font-size: 18px; | ||||
| } | ||||
| .container { | ||||
|   width: 100%; | ||||
| } | ||||
| .search-line { | ||||
|   width: 38%; | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										572
									
								
								src/views/guildOperationManagement/anchorSalaryOperate.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										572
									
								
								src/views/guildOperationManagement/anchorSalaryOperate.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,572 @@ | ||||
| <template> | ||||
|   <div class="anchor-salary-operate"> | ||||
|     <div class="container"> | ||||
|       <div class="handle-box"> | ||||
|         <el-form | ||||
|           ref="searchForm" | ||||
|           :model="searchForm" | ||||
|           :rules="searchRule" | ||||
|           label-width="90px" | ||||
|           :disabled="tableLoading" | ||||
|         > | ||||
|           <div class="search-line"> | ||||
|             <el-form-item label="主播ID" prop="erbanNo"> | ||||
|               <el-input | ||||
|                 v-model.trim="searchForm.erbanNo" | ||||
|                 placeholder="请输入" | ||||
|               ></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="公会ID" prop="agencyId"> | ||||
|               <el-input | ||||
|                 v-model.trim="searchForm.agencyId" | ||||
|                 placeholder="请输入" | ||||
|               ></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="公会长ID" prop="agencyOwnerId"> | ||||
|               <el-input | ||||
|                 v-model.trim="searchForm.agencyOwnerId" | ||||
|                 placeholder="请输入" | ||||
|               ></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="周期" prop="dateCycle"> | ||||
|               <el-select placeholder="请选择" v-model="searchForm.dateCycle"> | ||||
|                 <el-option | ||||
|                   v-for="(item, i) in dateCycleList" | ||||
|                   :key="i" | ||||
|                   :label="item.startDateStr + '~' + item.endDateStr" | ||||
|                   :value="item.dateCycle" | ||||
|                 ></el-option> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|  | ||||
|             <el-form-item label-width="40px"> | ||||
|               <el-button type="primary" @click="handSearch">搜索</el-button> | ||||
|               <el-button plain @click="resetSearchForm">重置搜索</el-button> | ||||
|             </el-form-item> | ||||
|           </div> | ||||
|         </el-form> | ||||
|       </div> | ||||
|       <div class="table"> | ||||
|         <el-table | ||||
|           :data="tableData" | ||||
|           border | ||||
|           v-loading="tableLoading" | ||||
|           @header-click="headerCopy" | ||||
|           style="width: 100%" | ||||
|         > | ||||
|           <!-- <el-table-column align="center" prop="dateCycle" label="周期" width="105"> | ||||
|                         <template v-slot="scope"> | ||||
|                             {{ dateCycleType(scope.row.dateCycle) }} | ||||
|                         </template> | ||||
|                     </el-table-column> --> | ||||
|           <el-table-column align="center" prop="erbano" label="主播ID"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="nick" label="主播昵称"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="agencyId" label="公会ID"> | ||||
|           </el-table-column> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="agencyOwnerErbanNo" | ||||
|             label="公会长ID" | ||||
|           > | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="diamondFlow" label="钻石流水"> | ||||
|             <template v-slot="scope"> | ||||
|               {{ | ||||
|                 scope.row.diamondFlow | ||||
|                   ? scope.row.diamondFlow.toLocaleString() | ||||
|                   : "0" | ||||
|               }} | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="diamondToUsb" | ||||
|             label="钻石兑换薪资" | ||||
|           > | ||||
|             <template v-slot="scope"> | ||||
|               <el-button type="text" @click="handleOpen(1, scope.row)"> | ||||
|                 {{ scope.row.diamondToUsb + "us" }} | ||||
|               </el-button> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="usbToGold" label="薪资兑换金币"> | ||||
|             <template v-slot="scope"> | ||||
|               <el-button type="text" @click="handleOpen(2, scope.row)"> | ||||
|                 {{ scope.row.usbToGold + "us" }} | ||||
|               </el-button> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="usbToAgent" | ||||
|             label="薪资转增代理" | ||||
|           > | ||||
|             <template v-slot="scope"> | ||||
|               <el-button type="text" @click="handleOpen(3, scope.row)"> | ||||
|                 {{ scope.row.usbToAgent + "us" }} | ||||
|               </el-button> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="usbToOwner" | ||||
|             label="薪资转增公会长" | ||||
|           > | ||||
|             <template v-slot="scope"> | ||||
|               <el-button type="text" @click="handleOpen(4, scope.row)"> | ||||
|                 {{ scope.row.usbToOwner + "us" }} | ||||
|               </el-button> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="officialWithdram" | ||||
|             label="官方提现" | ||||
|           > | ||||
|             <template v-slot="scope"> | ||||
|               <el-button type="text" @click="handleOpen(5, scope.row)"> | ||||
|                 {{ scope.row.officialWithdram + "us" }} | ||||
|               </el-button> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="usb" label="剩余薪资"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="diamond" label="钻石余额(当前)"> | ||||
|             <template v-slot="scope"> | ||||
|               {{ | ||||
|                 scope.row.diamond ? scope.row.diamond.toLocaleString() : "null" | ||||
|               }} | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|         </el-table> | ||||
|       </div> | ||||
|       <table-pagination | ||||
|         :pageParams="pageParams" | ||||
|         :pageTotal="pageTotal" | ||||
|         :page-sizes="[10, 20, 100, 200]" | ||||
|         @handleSizeChange="handleSizeChange" | ||||
|         @handlePageChange="handlePageChange" | ||||
|       ></table-pagination> | ||||
|     </div> | ||||
|  | ||||
|     <!-- 弹出框 --> | ||||
|     <el-dialog :title="dialogTitle" v-model="dialogVisible" width="60%"> | ||||
|       <el-table | ||||
|         :data="dialogData" | ||||
|         border | ||||
|         class="received-table" | ||||
|         v-loading="dialogLoading" | ||||
|       > | ||||
|         <el-table-column prop="createTime" label="日期" align="center"> | ||||
|           <template v-slot="scope">{{ | ||||
|             convertTimestamp(scope.row.createTime) | ||||
|           }}</template> | ||||
|         </el-table-column> | ||||
|         <el-table-column | ||||
|           prop="nick" | ||||
|           label="主播昵称" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <el-table-column | ||||
|           prop="erbano" | ||||
|           label="主播ID" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <!-- 薪资兑换金币6 --> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 6" | ||||
|           prop="gold" | ||||
|           label="兑换金币数量" | ||||
|           align="center" | ||||
|         > | ||||
|           <template v-slot="scope"> | ||||
|             {{ scope.row.gold ? scope.row.gold.toLocaleString() : "0" }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <!-- 钻石兑换薪资1 --> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 1" | ||||
|           prop="exDiamond" | ||||
|           label="兑换钻石数量" | ||||
|           align="center" | ||||
|         > | ||||
|           <template v-slot="scope"> | ||||
|             {{ | ||||
|               scope.row.exDiamond ? scope.row.exDiamond.toLocaleString() : "0" | ||||
|             }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 1 || dialogType == 6" | ||||
|           prop="tradeUsb" | ||||
|           label="兑换薪资数" | ||||
|           align="center" | ||||
|         > | ||||
|           <template v-slot="scope"> | ||||
|             {{ scope.row.tradeUsb + "us" }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 1" | ||||
|           prop="afterDiamond" | ||||
|           label="钻石余额" | ||||
|           align="center" | ||||
|         > | ||||
|           <template v-slot="scope"> | ||||
|             {{ | ||||
|               scope.row.afterDiamond | ||||
|                 ? scope.row.afterDiamond.toLocaleString() | ||||
|                 : "0" | ||||
|             }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <!-- 薪资转增代理2 --> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 2" | ||||
|           prop="receiveErbano" | ||||
|           label="充值代理ID" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 2" | ||||
|           prop="receiveNick" | ||||
|           label="充值代理名称" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 2" | ||||
|           prop="beforeUsb" | ||||
|           label="当前薪资" | ||||
|           align="center" | ||||
|         > | ||||
|           <template v-slot="scope"> | ||||
|             {{ scope.row.beforeUsb + "us" }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 2" | ||||
|           prop="tradeUsb" | ||||
|           label="转增代理" | ||||
|           align="center" | ||||
|         > | ||||
|           <template v-slot="scope"> | ||||
|             {{ scope.row.tradeUsb + "us" }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <!-- 薪资转增公会长3 --> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 3 || dialogType == 4" | ||||
|           prop="receiveNick" | ||||
|           label="公会长昵称" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 3 || dialogType == 4" | ||||
|           prop="receiveErbano" | ||||
|           label="公会长ID" | ||||
|           align="center" | ||||
|         ></el-table-column> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 3" | ||||
|           prop="tradeUsb" | ||||
|           label="转增公会长" | ||||
|           align="center" | ||||
|         > | ||||
|           <template v-slot="scope"> | ||||
|             {{ scope.row.tradeUsb + "us" }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <!-- 官方提现4 --> | ||||
|         <el-table-column | ||||
|           v-if="dialogType == 4" | ||||
|           prop="tradeUsb" | ||||
|           label="官方提现" | ||||
|           align="center" | ||||
|         > | ||||
|           <template v-slot="scope"> | ||||
|             {{ scope.row.tradeUsb + "us" }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|  | ||||
|         <el-table-column align="center" prop="afterUsb" label="剩余薪资"> | ||||
|           <template v-slot="scope"> | ||||
|             {{ scope.row.afterUsb + "us" }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|       </el-table> | ||||
|  | ||||
|       <table-pagination | ||||
|         :pageParams="pageParams1" | ||||
|         :pageTotal="pageTotal1" | ||||
|         :page-sizes="[5, 10, 20]" | ||||
|         @handleSizeChange="handleSizeChange1" | ||||
|         @handlePageChange="handlePageChange1" | ||||
|       ></table-pagination> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { | ||||
|   getDateCycleList, | ||||
|   getAnchorSalaryBill, | ||||
|   anchorSalaryBillDetail, | ||||
| } from "@/api/relAgency/relAgency.js"; | ||||
| import TablePagination from "@/components/common/TablePagination"; | ||||
| import { formatDate, formatDateYMD } from "@/utils/relDate"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
|  | ||||
| export default { | ||||
|   name: "anchorSalaryOperate", | ||||
|   components: { TablePagination }, | ||||
|   data() { | ||||
|     return { | ||||
|       dateCycleList: [], | ||||
|       btnLoading: false, // 导出弹出框(dialog)的确认按钮 | ||||
|       tableLoading: false, // 表格是否加载中 | ||||
|  | ||||
|       tableData: [], // 接口返回的表格数据 | ||||
|       pageTotal: 0, // 接口返回的表格总条数 | ||||
|       pageParams: { | ||||
|         pageNo: 1, | ||||
|         pageSize: 20, | ||||
|       }, | ||||
|       // 搜索表单相关 | ||||
|       searchForm: { | ||||
|         agencyOwnerId: null, | ||||
|         agencyId: null, | ||||
|         dateCycle: null, | ||||
|         erbanNo: null, | ||||
|       }, | ||||
|       searchRule: { | ||||
|         startTime: [ | ||||
|           { | ||||
|             validator: (rule, value, callback) => { | ||||
|               this.$refs["searchForm"].validateField("endTime"); | ||||
|               callback(); | ||||
|             }, | ||||
|             trigger: "change", | ||||
|           }, | ||||
|         ], | ||||
|         endTime: [ | ||||
|           { | ||||
|             validator: (rule, value, callback) => { | ||||
|               const { startTime } = this.searchForm; | ||||
|               if (startTime !== null && startTime !== "" && value) { | ||||
|                 if (value <= startTime) { | ||||
|                   callback(new Error("须晚于开始时间")); | ||||
|                 } else { | ||||
|                   callback(); | ||||
|                 } | ||||
|               } else { | ||||
|                 callback(); | ||||
|               } | ||||
|             }, | ||||
|             trigger: "change", | ||||
|           }, | ||||
|         ], | ||||
|       }, | ||||
|       dialogData: [], //弹窗表格数据 | ||||
|       dialogVisible: false, | ||||
|       dialogLoading: false, | ||||
|       pageTotal1: 0, // 接口返回的表格总条数 | ||||
|       pageParams1: { | ||||
|         pageNo: 1, | ||||
|         pageSize: 10, | ||||
|       }, | ||||
|       dialogParams: {}, | ||||
|       dialogTitle: "钻石兑换薪资", | ||||
|       dialogType: 1, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getDateCycleList(); | ||||
|   }, | ||||
|   methods: { | ||||
|     getDateCycleList() { | ||||
|       getDateCycleList({ month: 3 }).then((res) => { | ||||
|         this.dateCycleList = res.data || []; | ||||
|       }); | ||||
|     }, | ||||
|     getData() { | ||||
|       this.tableLoading = true; | ||||
|  | ||||
|       let { pageParams, searchForm } = this; | ||||
|       searchForm = JSON.parse(JSON.stringify(searchForm)); | ||||
|       pageParams = JSON.parse(JSON.stringify(pageParams)); | ||||
|       Object.keys(searchForm).forEach((item) => { | ||||
|         if ( | ||||
|           !searchForm[item] || | ||||
|           (searchForm[item] !== undefined && searchForm[item] === "") | ||||
|         ) { | ||||
|           delete searchForm[item]; | ||||
|         } | ||||
|       }); | ||||
|       Object.assign(pageParams, searchForm); | ||||
|  | ||||
|       getAnchorSalaryBill(pageParams).then((res) => { | ||||
|         this.tableLoading = false; | ||||
|         if (res.code == 200) { | ||||
|           let data = res.data; | ||||
|           this.tableData = data.records; | ||||
|           this.pageTotal = data.total; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 弹窗 | ||||
|     handleOpen(index, row) { | ||||
|       switch (index) { | ||||
|         case 1: | ||||
|           this.dialogTitle = "钻石兑换薪资"; | ||||
|           this.dialogType = 1; | ||||
|           break; | ||||
|         case 2: | ||||
|           this.dialogTitle = "薪资转增代理"; | ||||
|           this.dialogType = 2; | ||||
|           break; | ||||
|         case 3: | ||||
|           this.dialogTitle = "薪资转增公会长"; | ||||
|           this.dialogType = 3; | ||||
|           break; | ||||
|         case 4: | ||||
|           this.dialogTitle = "官方提现"; | ||||
|           this.dialogType = 4; | ||||
|           break; | ||||
|         case 6: | ||||
|           this.dialogTitle = "薪资兑换金币"; | ||||
|           this.dialogType = 6; | ||||
|           break; | ||||
|         default: | ||||
|           break; | ||||
|       } | ||||
|       this.dialogParams = { | ||||
|         salaryType: index, | ||||
|         dateCycle: this.searchForm.dateCycle, | ||||
|         uid: row.uid, | ||||
|         hallId: row.hallId, | ||||
|       }; | ||||
|       this.pageParams1 = { | ||||
|         pageNo: 1, | ||||
|         pageSize: 10, | ||||
|       }; | ||||
|       console.log(this.dialogParams); | ||||
|  | ||||
|       this.getDetail(); | ||||
|     }, | ||||
|     getDetail() { | ||||
|       let { pageParams1, dialogParams } = this; | ||||
|       pageParams1 = JSON.parse(JSON.stringify(pageParams1)); | ||||
|       dialogParams = JSON.parse(JSON.stringify(dialogParams)); | ||||
|       Object.keys(dialogParams).forEach((item) => { | ||||
|         if ( | ||||
|           !dialogParams[item] || | ||||
|           (dialogParams[item] !== undefined && dialogParams[item] === "") | ||||
|         ) { | ||||
|           delete dialogParams[item]; | ||||
|         } | ||||
|       }); | ||||
|       Object.assign(pageParams1, dialogParams); | ||||
|       this.dialogVisible = true; | ||||
|       this.dialogLoading = true; | ||||
|       anchorSalaryBillDetail(pageParams1).then((res) => { | ||||
|         if (res.success === true) { | ||||
|           let data = res.data; | ||||
|           this.dialogData = data.records; | ||||
|           this.pageTotal1 = data.total; | ||||
|         } | ||||
|         this.dialogLoading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 点击搜索 | ||||
|     handSearch() { | ||||
|       this.$refs["searchForm"].validate((valid) => { | ||||
|         if (valid) { | ||||
|           this.pageParams.pageNo = 1; | ||||
|           this.getData(); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 重置搜索表单 | ||||
|     resetSearchForm() { | ||||
|       this.$refs["searchForm"].resetFields(); | ||||
|       this.pageParams.pageNo = 1; | ||||
|       this.tableData = []; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange(val) { | ||||
|       this.pageParams.pageSize = val; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handlePageChange(val) { | ||||
|       this.pageParams.pageSize = val; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // 弹窗分页导航 | ||||
|     handleSizeChange1(val) { | ||||
|       this.$set(this.pageParams1, "pageSize", val); | ||||
|       this.getDetail(); | ||||
|     }, | ||||
|     handlePageChange1(val) { | ||||
|       this.$set(this.pageParams1, "pageNo", val); | ||||
|       this.getDetail(); | ||||
|     }, | ||||
|  | ||||
|     headerCopy(column, e) { | ||||
|       this.$copy(column.label); | ||||
|     }, | ||||
|   }, | ||||
|   computed: { | ||||
|     convertTimestamp1() { | ||||
|       return function (time) { | ||||
|         let date = new Date(time); | ||||
|         return formatDateYMD(date); | ||||
|       }; | ||||
|     }, | ||||
|     convertTimestamp() { | ||||
|       return function (time) { | ||||
|         let date = new Date(time); | ||||
|         return formatDate(date); | ||||
|       }; | ||||
|     }, | ||||
|     dateCycleType() { | ||||
|       const { dateCycleList } = this; | ||||
|       return function (value) { | ||||
|         for (let item of dateCycleList) { | ||||
|           if (item.dateCycle === value) { | ||||
|             return ( | ||||
|               this.convertTimestamp1(item.startDate) + | ||||
|               "~" + | ||||
|               this.convertTimestamp1(item.endDate) | ||||
|             ); | ||||
|           } | ||||
|         } | ||||
|         return ""; | ||||
|       }; | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style scope> | ||||
| .el-button--text { | ||||
|   font-size: 16px; | ||||
|   text-decoration: underline; | ||||
| } | ||||
|  | ||||
| .container { | ||||
|   width: 100%; | ||||
| } | ||||
| .search-line { | ||||
|   width: 38%; | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										237
									
								
								src/views/guildOperationManagement/diamondFlow.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										237
									
								
								src/views/guildOperationManagement/diamondFlow.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,237 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>公会ID</span> | ||||
|       <el-input | ||||
|         v-model="inquire.guildId" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <span>公会长ID</span> | ||||
|       <el-input | ||||
|         v-model="inquire.guildBoosId" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <!-- 时间选择器 --> | ||||
|     <!-- <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">日期</span> | ||||
|         <el-date-picker | ||||
|           v-model="inquire.time" | ||||
|           type="datetimerange" | ||||
|           range-separator="至" | ||||
|           start-placeholder="开始日期" | ||||
|           end-placeholder="结束日期" | ||||
|         > | ||||
|         </el-date-picker> | ||||
|       </div> | ||||
|     </div> --> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">开始时间</span> | ||||
|         <el-date-picker | ||||
|           v-model="inquire.time[0]" | ||||
|           type="date" | ||||
|           placeholder="开始时间" | ||||
|           format="YYYY-MM-DD 00:00:00" | ||||
|         > | ||||
|         </el-date-picker> | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">结束时间</span> | ||||
|         <el-date-picker | ||||
|           v-model="inquire.time[1]" | ||||
|           type="date" | ||||
|           placeholder="结束时间" | ||||
|           format="YYYY-MM-DD 23:59:59" | ||||
|         > | ||||
|         </el-date-picker> | ||||
|       </div> | ||||
|     </div> | ||||
|  | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary but" type="primary" @click="getData()" | ||||
|       >查询</el-button | ||||
|     > | ||||
|     <el-button | ||||
|       class="primary" | ||||
|       type="primary" | ||||
|       @click=" | ||||
|         inquire.guildId = ''; | ||||
|         inquire.guildBoosId = ''; | ||||
|         inquire.time = []; | ||||
|         getData(); | ||||
|       " | ||||
|       >重置查询</el-button | ||||
|     > | ||||
|     <el-button | ||||
|       class="primary" | ||||
|       type="primary" | ||||
|       @click="diamondStatisticsExportFun()" | ||||
|       >导出</el-button | ||||
|     > | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column type="index" width="100" align="center" label="序号" /> | ||||
|       <el-table-column prop="guildId" align="center" label="公会ID" /> | ||||
|       <el-table-column prop="guildName" align="center" label="公会昵称" /> | ||||
|       <el-table-column prop="ownerErbanNo" align="center" label="公会长ID" /> | ||||
|       <el-table-column prop="memberNum" align="center" label="主播人数" /> | ||||
|       <el-table-column prop="diamondNum" align="center" label="钻石流水" /> | ||||
|     </el-table> | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   diamondStatistics, | ||||
|   diamondStatisticsExport, | ||||
| } from "@/api/relAgency/relAgency"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "diamondFlow", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         guildId: "", | ||||
|         guildBoosId: "", | ||||
|         time: [], | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       //   新增弹窗 | ||||
|       addDialog: false, | ||||
|       // 分页 | ||||
|       total: 0, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 5, //条数 | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     // this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = null; | ||||
|       let endTime = null; | ||||
|       if (time.length > 0) { | ||||
|         startTime = this.inquire.time[0] | ||||
|           ? dateFormat(this.inquire.time[0], "yyyy-MM-dd") | ||||
|           : null; | ||||
|         endTime = this.inquire.time[1] | ||||
|           ? dateFormat(this.inquire.time[1], "yyyy-MM-dd") | ||||
|           : null; | ||||
|       } | ||||
|       diamondStatistics({ | ||||
|         guildId: this.inquire.guildId, | ||||
|         ownerErbanNo: this.inquire.guildBoosId, | ||||
|         startTime: startTime, | ||||
|         endTime: endTime, | ||||
|         pageNo: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           this.total = res.data.total; | ||||
|           this.tableData = res.data.records; | ||||
|           this.loading = false; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 导出 | ||||
|     diamondStatisticsExportFun() { | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd"); | ||||
|       } | ||||
|       diamondStatisticsExport({ | ||||
|         guildId: this.inquire.guildId, | ||||
|         ownerErbanNo: this.inquire.guildBoosId, | ||||
|         startTime: startTime, | ||||
|         endTime: endTime, | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     margin-bottom: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| .selectBox { | ||||
|   display: flex; | ||||
|   height: 35px; | ||||
|   line-height: 35px; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| .selectBoxImg { | ||||
|   height: 150px; | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										867
									
								
								src/views/guildOperationManagement/guildInfo.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										867
									
								
								src/views/guildOperationManagement/guildInfo.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,867 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>ID</span> | ||||
|       <el-input v-model="inquire.userId" | ||||
|                 placeholder="" | ||||
|                 class="input"></el-input> | ||||
|     </div> | ||||
|     <!-- <div class="inquire"> | ||||
|       <span>推荐人</span> | ||||
|       <el-input | ||||
|         v-model="inquire.referrer" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> --> | ||||
|     <!-- 时间选择器 --> | ||||
|     <!-- <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">日期</span> | ||||
|         <el-date-picker | ||||
|           v-model="inquire.time" | ||||
|           type="datetimerange" | ||||
|           range-separator="至" | ||||
|           start-placeholder="开始日期" | ||||
|           end-placeholder="结束日期" | ||||
|         > | ||||
|         </el-date-picker> | ||||
|       </div> | ||||
|     </div> --> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" | ||||
|                type="primary" | ||||
|                @click="getData()">查询</el-button> | ||||
|     <el-button class="primary" | ||||
|                type="primary" | ||||
|                @click="addDialog = true">添加</el-button> | ||||
|     <el-button class="primary" | ||||
|                type="primary" | ||||
|                @click="exportInfoFun()">导出</el-button> | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table v-loading="loading" | ||||
|               :data="tableData" | ||||
|               border | ||||
|               style="width: 100%; margin-top: 25px"> | ||||
|       <el-table-column prop="id" | ||||
|                        align="center" | ||||
|                        label="公会ID" /> | ||||
|       <!-- <el-table-column prop="referrer" align="center" label="推荐人" /> --> | ||||
|       <el-table-column prop="ownerErbanNo" | ||||
|                        align="center" | ||||
|                        label="会长ID" /> | ||||
|       <el-table-column prop="ownerNick" | ||||
|                        align="center" | ||||
|                        label="会长昵称" /> | ||||
|       <el-table-column prop="ownerPartitionName" | ||||
|                        align="center" | ||||
|                        label="会长分区" /> | ||||
|       <el-table-column prop="name" | ||||
|                        align="center" | ||||
|                        label="公会昵称" /> | ||||
|       <el-table-column align="center" | ||||
|                        prop="giftInfo" | ||||
|                        label="公会头像"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-image style="width: 100px; height: 100px" | ||||
|                     :src="scope.row.avatar" | ||||
|                     :zoom-rate="1.1" | ||||
|                     :preview-src-list="[scope.row.avatar]" | ||||
|                     fit="scale-down" | ||||
|                     preview-teleported="true" | ||||
|                     hide-on-click-modal="true" /> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" | ||||
|                        prop="giftInfo" | ||||
|                        label="公会背景图"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-image style="width: 100px; height: 100px" | ||||
|                     :src="scope.row.backgroundUrl" | ||||
|                     :zoom-rate="1.1" | ||||
|                     :preview-src-list="[scope.row.backgroundUrl]" | ||||
|                     fit="scale-down" | ||||
|                     preview-teleported="true" | ||||
|                     hide-on-click-modal="true" /> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="createTime" | ||||
|                        align="center" | ||||
|                        label="创建日期" /> | ||||
|       <!-- <el-table-column prop="memberNum" align="center" label="成员数量" /> --> | ||||
|       <el-table-column align="center" | ||||
|                        label="成员数量/上限"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button @click="memberDialogFun(scope.row)" | ||||
|                      type="text" | ||||
|                      size="default">{{ scope.row.memberNum }}/{{ scope.row.memberNumLimit }}</el-button> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="adminName" | ||||
|                        align="center" | ||||
|                        label="操作人" /> | ||||
|       <!-- <el-table-column align="center" label="收款账户" width="300"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="payAccountDialogFun(scope.row)" | ||||
|             type="text" | ||||
|             size="medium " | ||||
|           > | ||||
|             payoneer:{{ | ||||
|               scope.row.payAccount.payoneer | ||||
|                 ? scope.row.payAccount.payoneer | ||||
|                 : "未添加" | ||||
|             }} </el-button | ||||
|           ><br /> | ||||
|           <el-button | ||||
|             @click="payAccountDialogFun(scope.row)" | ||||
|             type="text" | ||||
|             size="medium " | ||||
|           > | ||||
|             USDT-ERC20:{{ | ||||
|               scope.row.payAccount.usdt ? scope.row.payAccount.usdt : "未添加" | ||||
|             }} </el-button | ||||
|           ><br /> | ||||
|           <el-button | ||||
|             @click="payAccountDialogFun(scope.row)" | ||||
|             type="text" | ||||
|             size="medium " | ||||
|           > | ||||
|             PayPal:{{ | ||||
|               scope.row.payAccount.payPal | ||||
|                 ? scope.row.payAccount.payPal | ||||
|                 : "未添加" | ||||
|             }} </el-button | ||||
|           ><br /> | ||||
|         </template> | ||||
|       </el-table-column> --> | ||||
|       <!-- <el-table-column prop="goldIncome" align="center" label="金币总收入" /> | ||||
|       <el-table-column prop="diamondRemain" align="center" label="钻石总收入" /> --> | ||||
|  | ||||
|       <el-table-column align="center" | ||||
|                        label="操作" | ||||
|                        width="300"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button @click="ediClick(scope)" | ||||
|                      class="primary" | ||||
|                      type="primary" | ||||
|                      size="default" | ||||
|                      :disabled="!scope.row.enable">编辑</el-button> | ||||
|           <el-button @click=" | ||||
|               delDialog = true; | ||||
|               delDialogData = scope.row; | ||||
|             " | ||||
|                      :class="scope.row.enable ? 'danger' : 'info'" | ||||
|                      :type="scope.row.enable ? 'danger' : 'info'" | ||||
|                      size="default" | ||||
|                      :disabled="!scope.row.enable">{{ scope.row.enable ? "移除" : "已解散" }}</el-button> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|     <!-- 新增弹窗 --> | ||||
|     <el-dialog v-model="addDialog" | ||||
|                title="新增" | ||||
|                width="28%" | ||||
|                center> | ||||
|       <div style="margin-bottom: 25px"> | ||||
|         <span style="display: inline-block; margin-right: 20px; width: 100px" | ||||
|               class="col-sm-2 control-label">会长ID</span> | ||||
|         <el-input v-model="resource.id" | ||||
|                   style="width: 75%" | ||||
|                   class="input"></el-input> | ||||
|       </div> | ||||
|       <!-- <div style="margin-bottom: 25px"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px; width: 100px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >推荐人</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="resource.referrer" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> --> | ||||
|       <!-- <div style="margin-bottom: 25px"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px; width: 100px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >会长昵称</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="resource.nick" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> --> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="addDialog = false">取消</el-button> | ||||
|           <el-button type="primary" | ||||
|                      @click="add()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination style="margin-top: 10px" | ||||
|                    class="paginationClass" | ||||
|                    v-model:current-page="currentPage" | ||||
|                    v-model:page-size="pageSize" | ||||
|                    :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|                    layout="sizes, prev, pager, next" | ||||
|                    :total="total" | ||||
|                    @size-change="handleSizeChange" | ||||
|                    @current-change="handleCurrentChange" /> | ||||
|     <!-- 编辑弹窗 --> | ||||
|     <el-dialog v-model="editDialog" | ||||
|                title="编辑" | ||||
|                width="28%" | ||||
|                center> | ||||
|       <!-- 公会ID --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">公会ID</span> | ||||
|         <el-input v-model="ediObj.id" | ||||
|                   style="width: 75%" | ||||
|                   class="input" | ||||
|                   disabled></el-input> | ||||
|       </div> | ||||
|       <!-- 会长ID --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">会长ID</span> | ||||
|         <el-input v-model="ediObj.leaderId" | ||||
|                   style="width: 75%" | ||||
|                   class="input" | ||||
|                   disabled></el-input> | ||||
|       </div> | ||||
|       <!-- 会长昵称 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">会长昵称</span> | ||||
|         <el-input v-model="ediObj.leaderNick" | ||||
|                   style="width: 75%" | ||||
|                   class="input" | ||||
|                   disabled></el-input> | ||||
|       </div> | ||||
|       <!-- 公会昵称 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">公会昵称</span> | ||||
|         <el-input v-model="ediObj.guildNick" | ||||
|                   style="width: 75%" | ||||
|                   class="input"></el-input> | ||||
|       </div> | ||||
|       <!-- 公会头像 --> | ||||
|       <div class="selectBox selectBoxImg"> | ||||
|         <span class="left" style="margin-right: 20px">公会头像</span> | ||||
|         <!-- action="/admin/tencent/cos/upload/file" --> | ||||
|         <el-upload | ||||
|           class="avatar-uploader" | ||||
|           action="/admin/tencent/cos/upload/file" | ||||
|           :show-file-list="false" | ||||
|           :on-success="handleAvatarSuccess2" | ||||
|           :before-upload="beforeAvatarUpload" | ||||
|           :on-error="handleAvatarError" | ||||
|         > | ||||
|           <img v-if="ediObj.imageUrl2" :src="ediObj.imageUrl2" class="avatar" /> | ||||
|           <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|         </el-upload> | ||||
|       </div> | ||||
|       <!-- 公会背景图 --> | ||||
|       <div class="selectBox selectBoxImg"> | ||||
|         <span class="left" | ||||
|               style="margin-right: 20px">公会背景图</span> | ||||
|         <!-- action="/admin/tencent/cos/upload/file" --> | ||||
|         <el-upload class="avatar-uploader" | ||||
|                    action="/admin/tencent/cos/upload/file" | ||||
|                    :show-file-list="false" | ||||
|                    :on-success="handleAvatarSuccess" | ||||
|                    :before-upload="beforeAvatarUpload" | ||||
|                    :on-error="handleAvatarError"> | ||||
|           <img v-if="ediObj.imageUrl1" | ||||
|                :src="ediObj.imageUrl1" | ||||
|                class="avatar" /> | ||||
|           <el-icon v-else | ||||
|                    class="avatar-uploader-icon"> | ||||
|             <Plus /> | ||||
|           </el-icon> | ||||
|         </el-upload> | ||||
|       </div> | ||||
|       <!-- 成员数量上限 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">成员数量上限</span> | ||||
|         <el-input v-model="ediObj.guildNumber" | ||||
|                   style="width: 75%" | ||||
|                   class="input"></el-input> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="editDialog = false">取消</el-button> | ||||
|           <el-button type="primary" | ||||
|                      @click="editDialogClick()"> | ||||
|             确认 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 二次确认删除弹窗 --> | ||||
|     <el-dialog v-model="delDialog" | ||||
|                title="提示" | ||||
|                width="30%" | ||||
|                center> | ||||
|       <span> 确定要解散该公会吗?</span> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="delDialog = false">取消</el-button> | ||||
|           <el-button type="primary" | ||||
|                      @click="delClick()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 编辑收款账户弹窗 --> | ||||
|     <el-dialog v-model="payAccountDialog" | ||||
|                :title="payAccountTitle" | ||||
|                width="28%" | ||||
|                center> | ||||
|       <!-- Payoneer --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">Payoneer</span> | ||||
|         <el-input v-model="payAccount.payoneer" | ||||
|                   style="width: 75%" | ||||
|                   class="input"></el-input> | ||||
|       </div> | ||||
|       <!-- USDT-ERC20 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">USDT-ERC20</span> | ||||
|         <el-input v-model="payAccount.usdt" | ||||
|                   style="width: 75%" | ||||
|                   class="input"></el-input> | ||||
|       </div> | ||||
|       <!-- PayPal --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">PayPal</span> | ||||
|         <el-input v-model="payAccount.payPal" | ||||
|                   style="width: 75%" | ||||
|                   class="input"></el-input> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="payAccountDialog = false">取消</el-button> | ||||
|           <el-button type="primary" | ||||
|                      @click="payAccountClick()"> | ||||
|             保存 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 编辑成员弹窗 --> | ||||
|     <el-dialog v-model="memberDialog" | ||||
|                :title="memberTitle" | ||||
|                width="36%" | ||||
|                center> | ||||
|       <!-- 新增用户 --> | ||||
|       <div class="inquire"> | ||||
|         <span>平台ID</span> | ||||
|         <el-input v-model="member.userID" | ||||
|                   placeholder="请输入新增平台id" | ||||
|                   class="input"></el-input> | ||||
|         <el-button type="primary" | ||||
|                    @click="addMemberFun()"> 新增 </el-button> | ||||
|       </div> | ||||
|       <!-- 内嵌表格 --> | ||||
|       <el-table v-loading="loading" | ||||
|                 :data="member.tableData" | ||||
|                 border | ||||
|                 style="width: 100%; margin-top: 25px"> | ||||
|         <el-table-column align="center" | ||||
|                          label="用户平台ID"> | ||||
|           <template v-slot="scope"> | ||||
|             {{ scope.row.erbanNo | ||||
|             }}{{ | ||||
|               scope.row.roleType == 1 | ||||
|                 ? "(会长)" | ||||
|                 : scope.row.roleType == 2 | ||||
|                 ? "(管理员)" | ||||
|                 : "" | ||||
|             }} | ||||
|             {{ scope.row.enable == false ? "(已离开)" : "" }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column prop="nick" | ||||
|                          align="center" | ||||
|                          label="用户昵称" /> | ||||
|         <el-table-column prop="createTime" | ||||
|                          align="center" | ||||
|                          label="加入时间" /> | ||||
|         <el-table-column prop="adminName" | ||||
|                          align="center" | ||||
|                          label="操作人" /> | ||||
|         <el-table-column align="center" | ||||
|                          label="操作" | ||||
|                          width="300"> | ||||
|           <template v-slot="scope"> | ||||
|             <el-button @click="setMemberFun(scope.row)" | ||||
|                        :class="scope.row.roleType == 2 ? 'danger' : 'primary'" | ||||
|                        :type="scope.row.roleType == 2 ? 'danger' : 'primary'" | ||||
|                        size="default" | ||||
|                        :disabled="scope.row.roleType == 1 ? true : false">{{ | ||||
|                 scope.row.roleType == 1 | ||||
|                   ? "会长" | ||||
|                   : scope.row.roleType == 2 | ||||
|                   ? "取消管理员" | ||||
|                   : "设为管理员" | ||||
|               }}</el-button> | ||||
|             <el-button @click=" | ||||
|                 memberRemoveObj = scope.row; | ||||
|                 memberRemoveDialog = true; | ||||
|               " | ||||
|                        class="danger" | ||||
|                        type="danger" | ||||
|                        size="default" | ||||
|                        :disabled="scope.row.roleType == 1 ? true : false">删除</el-button> | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|       </el-table> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button type="primary" | ||||
|                      @click="memberDialog = false"> | ||||
|             关闭 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 二次确认删除弹窗 --> | ||||
|     <el-dialog v-model="memberRemoveDialog" | ||||
|                title="提示" | ||||
|                width="30%" | ||||
|                center> | ||||
|       <span> 确定要删除该成员吗?</span> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="memberRemoveDialog = false">取消</el-button> | ||||
|           <el-button type="primary" | ||||
|                      @click="delmemberRemoveClick()"> | ||||
|             确认 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   pageFamily, | ||||
|   exportInfo, | ||||
|   create, | ||||
|   update, | ||||
|   dismiss, | ||||
|   savePayAccount, | ||||
|   manageListFamilyMember, | ||||
|   addMember, | ||||
|   setManager, | ||||
|   removeMember, | ||||
| } from "@/api/noblemanNew/noblemanNew"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "GuildInfoNew", | ||||
|   data () { | ||||
|     return { | ||||
|       loading: false, | ||||
|       delDialog: false, | ||||
|       delDialogData: null, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         userId: "", | ||||
|         referrer: "", | ||||
|         time: "", | ||||
|       }, | ||||
|       //新增所需对象 | ||||
|       resource: { | ||||
|         id: "", | ||||
|         nick: "", | ||||
|         referrer: "", | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       //   新增弹窗 | ||||
|       addDialog: false, | ||||
|       // 分页 | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|       // 编辑弹窗 | ||||
|       editDialog: false, | ||||
|       ediObj: { | ||||
|         leaderId: "", | ||||
|         leaderNick: "", | ||||
|         guildNick: "", | ||||
|         guildNumber: "", | ||||
|         id: "", | ||||
|         imageUrl1: "", | ||||
|         imageUrl2: "", | ||||
|       }, | ||||
|       // 收款账户弹窗 | ||||
|       payAccountDialog: false, | ||||
|       payAccountTitle: "(会长昵称【ID:0】)的收款账户", | ||||
|       payAccountNew: {}, | ||||
|       payAccount: { | ||||
|         payoneer: "", | ||||
|         usdt: "", | ||||
|         payPal: "", | ||||
|       }, | ||||
|       // 新增成员弹窗 | ||||
|       memberDialog: false, | ||||
|       memberTitle: "【公会名称】成员信息", | ||||
|       memberNew: {}, | ||||
|       member: { | ||||
|         userID: "", | ||||
|         tableData: [], | ||||
|       }, | ||||
|       // 删除成员弹窗 | ||||
|       memberRemoveDialog: false, | ||||
|       memberRemoveObj: {}, | ||||
|     }; | ||||
|   }, | ||||
|   created () { | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData () { | ||||
|       this.loading = true; | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       pageFamily({ | ||||
|         erbanNo: this.inquire.userId, | ||||
|         referrer: this.inquire.referrer, | ||||
|         familyName: this.inquire.nick, | ||||
|         // startDate: startTime, | ||||
|         // endDate: endTime, | ||||
|         pageNum: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         this.total = res.data.total; | ||||
|         this.tableData = res.data.rows; | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 打开成员信息弹窗 | ||||
|     memberDialogFun (val) { | ||||
|       var than = this; | ||||
|       than.memberTitle = `【${val.name}】成员信息`; | ||||
|       than.memberNew = val; | ||||
|       manageListFamilyMember({ | ||||
|         guildId: val.id, | ||||
|       }).then((res) => { | ||||
|         this.member.tableData = res.data; | ||||
|         than.memberDialog = true; | ||||
|       }); | ||||
|     }, | ||||
|     // 二次确认删除成员 | ||||
|     delmemberRemoveClick () { | ||||
|       removeMember({ | ||||
|         guildMemberId: this.memberRemoveObj.guildMemberId, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "删除成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           manageListFamilyMember({ | ||||
|             guildId: this.memberNew.id, | ||||
|           }).then((res) => { | ||||
|             this.member.tableData = res.data; | ||||
|           }); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.memberRemoveDialog = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 设置管理员 | ||||
|     setMemberFun (val) { | ||||
|       setManager({ | ||||
|         guildMemberId: val.guildMemberId, | ||||
|         status: val.roleType == 3 ? true : val.roleType == 2 ? false : null, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "设置成功!", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.member.userID = ""; | ||||
|           manageListFamilyMember({ | ||||
|             guildId: this.memberNew.id, | ||||
|           }).then((res) => { | ||||
|             this.member.tableData = res.data; | ||||
|           }); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 新增成员 | ||||
|     addMemberFun () { | ||||
|       addMember({ | ||||
|         erbanNo: this.member.userID, | ||||
|         guildId: this.memberNew.id, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "保存成功!", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.member.userID = ""; | ||||
|           manageListFamilyMember({ | ||||
|             guildId: this.memberNew.id, | ||||
|           }).then((res) => { | ||||
|             this.member.tableData = res.data; | ||||
|           }); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "保存失败!", | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 打开收款账户弹窗 | ||||
|     payAccountDialogFun (val) { | ||||
|       this.payAccountTitle = `(${val.ownerNick}【ID:${val.ownerErbanNo}】)的收款账户`; | ||||
|       this.payAccount.payoneer = val.payAccount.payoneer; | ||||
|       this.payAccount.usdt = val.payAccount.usdt; | ||||
|       this.payAccount.payPal = val.payAccount.payPal; | ||||
|       this.payAccountDialog = true; | ||||
|       this.payAccountNew = val; | ||||
|     }, | ||||
|     // 保存收款账户 | ||||
|     payAccountClick () { | ||||
|       savePayAccount({ | ||||
|         id: this.payAccountNew.payAccount.familyId, | ||||
|         payPal: this.payAccount.payPal, | ||||
|         payoneer: this.payAccount.payoneer, | ||||
|         usdt: this.payAccount.usdt, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "保存成功!", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.payAccountDialog = false; | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "保存失败!", | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 导出 | ||||
|     exportInfoFun () { | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       exportInfo({ | ||||
|         erbanNo: this.inquire.userId, | ||||
|         referrer: this.inquire.referrer, | ||||
|         familyName: this.inquire.nick, | ||||
|         // startDate: startTime, | ||||
|         // endDate: endTime, | ||||
|       }).then((res) => { }); | ||||
|     }, | ||||
|     // 添加 | ||||
|     add () { | ||||
|       this.addDialog = false; | ||||
|       create({ | ||||
|         erbanNo: this.resource.id, | ||||
|         referrer: this.resource.referrer, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "添加成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 编辑按钮 | ||||
|     ediClick (res) { | ||||
|       var obj = res.row; | ||||
|       this.ediObj.leaderId = obj.ownerErbanNo; | ||||
|       this.ediObj.leaderNick = obj.ownerNick; | ||||
|       this.ediObj.guildNick = obj.name; | ||||
|       this.ediObj.guildNumber = obj.memberNumLimit; | ||||
|       this.ediObj.id = obj.id; | ||||
|       this.ediObj.imageUrl1 = obj.backgroundUrl; | ||||
|       this.ediObj.imageUrl2 = obj.avatar; | ||||
|       this.editDialog = true; | ||||
|     }, | ||||
|     // 二次确认弹窗 | ||||
|     editDialogClick () { | ||||
|       console.log(this.ediObj); | ||||
|       update({ | ||||
|         id: this.ediObj.id, | ||||
|         memberNumLimit: this.ediObj.guildNumber, | ||||
|         backgroundUrl: this.ediObj.imageUrl1, | ||||
|         avatar: this.ediObj.imageUrl2, | ||||
|         name: this.ediObj.guildNick, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|           this.editDialog = false; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.delDialog = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 解散按钮 | ||||
|     delClick () { | ||||
|       console.log(this.delDialogData.id); | ||||
|       var guildId = this.delDialogData.id; | ||||
|       dismiss({ guildId }).then((res) => { | ||||
|         console.log(); | ||||
|         if (res.code == 200) { | ||||
|           this.getData(); | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "解散成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.delDialog = false; | ||||
|       }); | ||||
|     }, | ||||
|     beforeAvatarUpload () { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传中~", | ||||
|         type: "warning", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarError () { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传失败!", | ||||
|         type: "error", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess (res, file) { | ||||
|       console.log(file); | ||||
|       this.ediObj.imageUrl1 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess2(res, file) { | ||||
|       console.log(file); | ||||
|       this.ediObj.imageUrl2 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange () { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange () { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| .selectBox { | ||||
|   display: flex; | ||||
|   height: 35px; | ||||
|   line-height: 35px; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| .selectBoxImg { | ||||
|   height: 150px; | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										181
									
								
								src/views/guildOperationManagement/guildMove.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										181
									
								
								src/views/guildOperationManagement/guildMove.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,181 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>ID</span> | ||||
|       <el-input | ||||
|         v-model="inquire.userId" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <!-- 时间选择器 --> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">移除日期</span> | ||||
|         <el-date-picker | ||||
|           v-model="inquire.time" | ||||
|           type="datetimerange" | ||||
|           range-separator="至" | ||||
|           start-placeholder="开始日期" | ||||
|           end-placeholder="结束日期" | ||||
|         > | ||||
|         </el-date-picker> | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" type="primary" @click="getData()" | ||||
|       >查询</el-button | ||||
|     > | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="familyName" align="center" label="家族昵称" /> | ||||
|       <el-table-column prop="erbanNo" align="center" label="成员ID" /> | ||||
|       <el-table-column prop="nick" align="center" label="成员昵称" /> | ||||
|       <el-table-column prop="targetErbanNo" align="center" label="目标成员ID" /> | ||||
|       <el-table-column prop="targetNick" align="center" label="目标成员昵称" /> | ||||
|       <el-table-column prop="type" align="center" label="操作类型"> | ||||
|         <template v-slot="scope"> | ||||
|           {{ | ||||
|             scope.row.type == 1 | ||||
|               ? "申请加入" | ||||
|               : scope.row.type == 2 | ||||
|               ? "申请退出" | ||||
|               : scope.row.type == 3 | ||||
|               ? "邀请加入" | ||||
|               : scope.row.type == 4 | ||||
|               ? "设置管理员" | ||||
|               : scope.row.type == 5 | ||||
|               ? "移除管理员" | ||||
|               : "移除成员" | ||||
|           }} | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="createTime" align="center" label="操作时间" /> | ||||
|       <el-table-column prop="updateTime" align="center" label="最后更新时间" /> | ||||
|       <el-table-column prop="status" align="center" label="状态"> | ||||
|         <template v-slot="scope"> | ||||
|           {{ | ||||
|             scope.row.status == 1 | ||||
|               ? "未处理" | ||||
|               : scope.row.status == 2 | ||||
|               ? "同意" | ||||
|               : scope.row.status == 2 | ||||
|               ? "拒绝" | ||||
|               : "过期" | ||||
|           }} | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { pageOperateRecord } from "@/api/noblemanNew/noblemanNew"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "GuildMoveNew", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         userId: "", | ||||
|         nick: "", | ||||
|         time: "", | ||||
|       }, | ||||
|       //新增所需对象 | ||||
|       resource: { | ||||
|         id: "", | ||||
|         nick: "", | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       //   新增弹窗 | ||||
|       addDialog: false, | ||||
|       // 分页 | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       pageOperateRecord({ | ||||
|         erbanNo: this.inquire.userId, | ||||
|         startDate: startTime, | ||||
|         endDate: endTime, | ||||
|         pageNum: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         this.total = res.data.total; | ||||
|         this.tableData = res.data.rows; | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										614
									
								
								src/views/guildOperationManagement/officialWithdrawRecord.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										614
									
								
								src/views/guildOperationManagement/officialWithdrawRecord.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,614 @@ | ||||
| <template> | ||||
|   <div class="official-withdraw-record"> | ||||
|     <div class="container"> | ||||
|       <div class="region-box"> | ||||
|         <el-radio-group v-model="region"> | ||||
|           <el-radio | ||||
|             v-for="(item, index) in userAreaRegion" | ||||
|             :key="index" | ||||
|             :label="item.value" | ||||
|             >{{ item.name }}</el-radio | ||||
|           > | ||||
|         </el-radio-group> | ||||
|       </div> | ||||
|       <div class="handle-box"> | ||||
|         <el-form | ||||
|           ref="searchForm" | ||||
|           :model="searchForm" | ||||
|           :rules="searchRule" | ||||
|           label-width="90px" | ||||
|           :disabled="tableLoading" | ||||
|         > | ||||
|           <div class="search-line"> | ||||
|             <el-form-item label="MoliStar ID" prop="agencyOwnerErbanNo"> | ||||
|               <el-input | ||||
|                 v-model.trim="searchForm.agencyOwnerErbanNo" | ||||
|                 placeholder="请输入" | ||||
|               ></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="提现状态" prop="status"> | ||||
|               <el-select v-model="searchForm.status"> | ||||
|                 <el-option label="审核中" value="0"></el-option> | ||||
|                 <el-option label="审核通过" value="1"></el-option> | ||||
|                 <el-option label="未通过" value="2"></el-option> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="提现账户" prop="accountType"> | ||||
|               <el-select v-model="searchForm.accountType"> | ||||
|                 <el-option label="Vodafone" value="VODAFONE"></el-option> | ||||
|                 <el-option label="Payonner" value="PAYONNER"></el-option> | ||||
|                 <el-option label="USD" value="USDT"></el-option> | ||||
|                 <el-option label="Bank" value="BANK"></el-option> | ||||
|                 <el-option label="Other" value="OTHER"></el-option> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="国家" prop="country"> | ||||
|               <el-select v-model="searchForm.country"> | ||||
|                 <el-option | ||||
|                   v-for="(item, index) in adminCountryArr" | ||||
|                   :key="index" | ||||
|                   :label="item.label" | ||||
|                   :value="item.value" | ||||
|                 ></el-option> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="时间" class="large"> | ||||
|               <el-form-item prop="startTime"> | ||||
|                 <el-date-picker | ||||
|                   type="datetime" | ||||
|                   placeholder="选择开始时间" | ||||
|                   v-model="searchForm.startTime" | ||||
|                 ></el-date-picker> | ||||
|               </el-form-item> | ||||
|               <el-col :span="2" align="center">-</el-col> | ||||
|               <el-form-item prop="endTime"> | ||||
|                 <el-date-picker | ||||
|                   type="datetime" | ||||
|                   placeholder="选择结束时间" | ||||
|                   v-model="searchForm.endTime" | ||||
|                 ></el-date-picker> | ||||
|               </el-form-item> | ||||
|             </el-form-item> | ||||
|  | ||||
|             <el-form-item label-width="40px"> | ||||
|               <el-button type="primary" @click="handSearch">搜索</el-button> | ||||
|               <el-button  type="primary" plain @click="resetSearchForm">重置搜索</el-button> | ||||
|               <el-button | ||||
|                 type="primary" | ||||
|                 class="exportBtn" | ||||
|                 @click="confirmExport2Excel" | ||||
|                 >导出</el-button | ||||
|               > | ||||
|               <el-button @click="handleChangeAll()" type="info" plain | ||||
|                 >批量发放</el-button | ||||
|               > | ||||
|               <el-button | ||||
|                 @click=" | ||||
|                   centerDialogVisible = true; | ||||
|                   centerDialogVisibleType = 1; | ||||
|                 " | ||||
|                 type="info" | ||||
|                 plain | ||||
|                 >批量驳回</el-button | ||||
|               > | ||||
|             </el-form-item> | ||||
|           </div> | ||||
|         </el-form> | ||||
|       </div> | ||||
|       <!-- 表格 --> | ||||
|       <div class="table"> | ||||
|         <el-table | ||||
|           :data="tableData" | ||||
|           border | ||||
|           v-loading="tableLoading" | ||||
|           @header-click="headerCopy" | ||||
|           @selection-change="handleSelectionChange" | ||||
|           style="width: 100%;overflow-x: auto;" | ||||
|         > | ||||
|           <el-table-column type="selection"> </el-table-column> | ||||
|           <el-table-column align="center" prop="erbanNo" label="MoliStar ID" /> | ||||
|           <el-table-column align="center" prop="nick" label="昵称" /> | ||||
|           <el-table-column align="center" prop="accountCountry" label="国家" /> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="blocked" | ||||
|             label="用户当前账户状态" | ||||
|           > | ||||
|             <template v-slot="scope"> | ||||
|               {{ scope.row.blocked ? "封禁" : "正常" }} | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="status" label="申请状态"> | ||||
|             <template v-slot="scope"> | ||||
|               {{ | ||||
|                 scope.row.status == 0 | ||||
|                   ? "审核中" | ||||
|                   : scope.row.status == 1 | ||||
|                   ? "通过" | ||||
|                   : "未通过" | ||||
|               }} | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="createTime" label="申请时间" /> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="accountType" | ||||
|             label="提现类型  " | ||||
|           /> | ||||
|           <el-table-column | ||||
|             align="center" | ||||
|             prop="guildUsdNum" | ||||
|             label="提现薪资US" | ||||
|           /> | ||||
|           <el-table-column align="center" prop="currency" label="发放币种" /> | ||||
|           <el-table-column align="center" prop="currencyNum" label="发放金额" /> | ||||
|           <el-table-column align="center" prop="withdrawRate" label="手续费" /> | ||||
|           <el-table-column align="center" prop="withdrawNum" label="核销薪资" /> | ||||
|           <el-table-column align="center" prop="remark" label="驳回理由"> | ||||
|             <template v-slot="scope"> | ||||
|               {{ scope.row.remark ? scope.row.remark : "/" }} | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" prop="hallSalary" label="操作" width="150"> | ||||
|             <template v-slot="scope"> | ||||
|               <div v-if="scope.row.status == 0"> | ||||
|                 <el-button | ||||
|                   @click="handleChange(scope.row)" | ||||
|                   type="text" | ||||
|                   size="mini" | ||||
|                 > | ||||
|                   发放 | ||||
|                 </el-button> | ||||
|                 <el-button | ||||
|                   @click=" | ||||
|                     centerDialogVisible = true; | ||||
|                     centerDialogVisibleType = 2; | ||||
|                     centerDialogVisibleID = scope.row.id; | ||||
|                   " | ||||
|                   type="text" | ||||
|                   size="mini" | ||||
|                 > | ||||
|                   驳回 | ||||
|                 </el-button> | ||||
|               </div> | ||||
|               <div> | ||||
|                 <el-button | ||||
|                   @click="accountInfosFun(scope.row)" | ||||
|                   type="text" | ||||
|                   size="mini" | ||||
|                 > | ||||
|                   查看详情 | ||||
|                 </el-button> | ||||
|               </div> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|         </el-table> | ||||
|       </div> | ||||
|       <!-- 分页 --> | ||||
|       <table-pagination | ||||
|         :pageParams="pageParams" | ||||
|         :pageTotal="pageTotal" | ||||
|         :page-sizes="[10, 20, 100, 200]" | ||||
|         @handleSizeChange="handleSizeChange" | ||||
|         @handlePageChange="handlePageChange" | ||||
|       ></table-pagination> | ||||
|       <!-- 驳回弹窗 --> | ||||
|       <el-dialog v-model="centerDialogVisible" title="提示" width="30%" center> | ||||
|         <span> 请选择驳回理由:</span> | ||||
|         <div class="boxs"> | ||||
|           <el-radio class="radios" v-model="radio" label="用户消息提供不足" | ||||
|             >用户消息提供不足</el-radio | ||||
|           > | ||||
|         </div> | ||||
|         <template #footer> | ||||
|           <span class="dialog-footer"> | ||||
|             <el-button @click="centerDialogVisible = false">取消</el-button> | ||||
|             <el-button type="primary" @click="dialogClick()"> 确认 </el-button> | ||||
|           </span> | ||||
|         </template> | ||||
|       </el-dialog> | ||||
|       <!-- 提现详情弹窗 --> | ||||
|       <el-dialog v-model="centerDialogVisible2" title="提现详情"> | ||||
|         <div class="boxs2"> | ||||
|           <div>申请提现时间:{{ accountDetails.createTime }}</div> | ||||
|           <div>申请ID:{{ accountDetails.erbanNo }}</div> | ||||
|           <div>country:{{ accountDetails.country }}</div> | ||||
|           <div>payeeAccount:{{ accountDetails.bank_account }}</div> | ||||
|           <div>Bank Name:{{ accountDetails.bank_name }}</div> | ||||
|           <div>SWIFT Code:{{ accountDetails.swift_code }}</div> | ||||
|           <div>payeeName::{{ accountDetails.full_name }}</div> | ||||
|           <div>address:{{ accountDetails.address }}</div> | ||||
|           <div>提现薪资US:{{ accountDetails.guildUsdNum }}</div> | ||||
|           <div> | ||||
|             发放金额:{{ accountDetails.currency }} | ||||
|             {{ accountDetails.currencyNum }} | ||||
|           </div> | ||||
|           <div>提现手续费:{{ accountDetails.withdrawRate }}</div> | ||||
|           <div>核销薪资:{{ accountDetails.withdrawNum }}</div> | ||||
|         </div> | ||||
|         <template #footer> | ||||
|           <span class="dialog-footer"> | ||||
|             <el-button @click="centerDialogVisible2 = false">确认</el-button> | ||||
|           </span> | ||||
|         </template> | ||||
|       </el-dialog> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { | ||||
|   agencyWithdrawList, | ||||
|   agencyWithdrawExamineExport, | ||||
|   agencyWithdrawSet, | ||||
|   agencyWithdrawBatchSet, | ||||
|   batchReject, | ||||
|   adminCountry, | ||||
| } from "@/api/relAgency/relAgency.js"; | ||||
| import TablePagination from "@/components/common/TablePagination"; | ||||
| import { formatDate, formatDateYMD } from "@/utils/relDate"; | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| import { ElMessage } from "element-plus"; | ||||
| import { ElMessageBox } from "element-plus"; // 正确引入 ElM | ||||
| // 混入 | ||||
| // import Mixin from '../../mixin/mixRegion.js'; | ||||
|  | ||||
| export default { | ||||
|   name: "officialWithdrawRecord", | ||||
|   // mixins: [Mixin], | ||||
|   components: { TablePagination }, | ||||
|   data() { | ||||
|     return { | ||||
|       dateCycleList: [], | ||||
|       btnLoading: false, // 导出弹出框(dialog)的确认按钮 | ||||
|       tableLoading: false, // 表格是否加载中 | ||||
|  | ||||
|       tableData: [], // 接口  返回的表格数据 | ||||
|       pageTotal: 0, // 接口返回的表格总条数 | ||||
|       pageParams: { | ||||
|         pageNo: 1, | ||||
|         pageSize: 20, | ||||
|       }, | ||||
|       centerDialogVisible: false, //驳回弹窗 | ||||
|       centerDialogVisibleType: null, //驳回弹窗 | ||||
|       centerDialogVisibleID: null, //驳回弹窗 | ||||
|       centerDialogVisible2: false, //操作弹窗 | ||||
|       radio: "用户消息提供不足", //驳回原因 | ||||
|       // 搜索表单相关 | ||||
|       searchForm: { | ||||
|         agencyOwnerErbanNo: null, | ||||
|         status: null, | ||||
|         startTime: null, | ||||
|         endTime: null, | ||||
|         adminCountry: null, | ||||
|         country: null, | ||||
|       }, | ||||
|       adminCountryArr: [], | ||||
|       searchRule: { | ||||
|         startTime: [ | ||||
|           { | ||||
|             validator: (rule, value, callback) => { | ||||
|               this.$refs["searchForm"].validateField("endTime"); | ||||
|               callback(); | ||||
|             }, | ||||
|             trigger: "change", | ||||
|           }, | ||||
|         ], | ||||
|         endTime: [ | ||||
|           { | ||||
|             validator: (rule, value, callback) => { | ||||
|               const { startTime } = this.searchForm; | ||||
|               if (startTime !== null && startTime !== "" && value) { | ||||
|                 if (value <= startTime) { | ||||
|                   callback(new Error("须晚于开始时间")); | ||||
|                 } else { | ||||
|                   callback(); | ||||
|                 } | ||||
|               } else { | ||||
|                 callback(); | ||||
|               } | ||||
|             }, | ||||
|             trigger: "change", | ||||
|           }, | ||||
|         ], | ||||
|       }, | ||||
|       idStr: [], //批量删除ID | ||||
|       // 查看薪资弹窗数据存储 | ||||
|       accountDetails: { | ||||
|         createTime: null, | ||||
|         erbanNo: null, | ||||
|         country: null, | ||||
|         bank_account: null, | ||||
|         bank_name: null, | ||||
|         swift_code: null, | ||||
|         full_name: null, | ||||
|         address: null, | ||||
|         guildUsdNum: null, | ||||
|         currency: null, | ||||
|         currencyNum: null, | ||||
|         withdrawRate: null, | ||||
|         withdrawNum: null, | ||||
|       }, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     adminCountry().then((res) => { | ||||
|       this.adminCountryArr = res.data; | ||||
|       this.getData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     getData() { | ||||
|       this.tableLoading = true; | ||||
|  | ||||
|       let { pageParams, searchForm } = this; | ||||
|       searchForm.startTime = searchForm.startTime | ||||
|         ? dateFormat(searchForm.startTime, "yyyy-MM-dd hh:mm:ss") | ||||
|         : ""; | ||||
|       searchForm.endTime = searchForm.endTime | ||||
|         ? dateFormat(searchForm.endTime, "yyyy-MM-dd hh:mm:ss") | ||||
|         : ""; | ||||
|       searchForm = JSON.parse(JSON.stringify(searchForm)); | ||||
|       pageParams = JSON.parse(JSON.stringify(pageParams)); | ||||
|       Object.keys(searchForm).forEach((item) => { | ||||
|         if ( | ||||
|           !searchForm[item] || | ||||
|           (searchForm[item] !== undefined && searchForm[item] === "") | ||||
|         ) { | ||||
|           delete searchForm[item]; | ||||
|         } | ||||
|       }); | ||||
|       Object.assign(pageParams, searchForm); | ||||
|       console.log(pageParams); | ||||
|       console.log(searchForm); | ||||
|       agencyWithdrawList(pageParams).then((res) => { | ||||
|         this.tableLoading = false; | ||||
|         if (res.code == 200) { | ||||
|           let data = res.data; | ||||
|           this.tableData = data.records; | ||||
|           this.pageTotal = data.total; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     handleSelectionChange(rows) { | ||||
|       this.idStr = null; | ||||
|       this.idStr = rows.map((obj) => obj.id).join(","); | ||||
|     }, | ||||
|     handleChangeAll() { | ||||
|       ElMessageBox.confirm("确定要结算吗", "提示", { | ||||
|         confirmButtonText: "确定", | ||||
|         cancelButtonText: "取消", | ||||
|         type: "warning", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           agencyWithdrawBatchSet({ ids: this.idStr }).then((res) => { | ||||
|             if (res.success === true) { | ||||
|               ElMessage({ | ||||
|                 type: "success", | ||||
|                 message: "操作成功!", | ||||
|               }); | ||||
|               this.getData(); | ||||
|               this.idStr = null; | ||||
|             } | ||||
|           }); | ||||
|         }) | ||||
|         .catch(() => { | ||||
|           ElMessage({ | ||||
|             type: "warning ", | ||||
|             message: "已取消", | ||||
|           }); | ||||
|         }); | ||||
|     }, | ||||
|     // 查看详情处理函数 | ||||
|     accountInfosFun(res) { | ||||
|       var obj = JSON.parse(res.accountInfos); | ||||
|       console.log(obj); | ||||
|       this.accountDetails.createTime = res.createTime ? res.createTime : "-"; | ||||
|       this.accountDetails.erbanNo = res.erbanNo ? res.erbanNo : "-"; | ||||
|       this.accountDetails.country = obj.country ? obj.country : "-"; | ||||
|       this.accountDetails.bank_account = obj.bank_account | ||||
|         ? obj.bank_account | ||||
|         : "-"; | ||||
|       this.accountDetails.bank_name = obj.bank_name ? obj.bank_name : "-"; | ||||
|       this.accountDetails.swift_code = obj.swift_code ? obj.swift_code : "-"; | ||||
|       this.accountDetails.full_name = obj.full_name ? obj.full_name : "-"; | ||||
|       this.accountDetails.address = obj.address ? obj.address : "-"; | ||||
|       this.accountDetails.guildUsdNum = res.guildUsdNum ? res.guildUsdNum : "-"; | ||||
|       this.accountDetails.currency = res.currency ? res.currency : "-"; | ||||
|       this.accountDetails.currencyNum = res.currencyNum ? res.currencyNum : "-"; | ||||
|       this.accountDetails.withdrawRate = res.withdrawRate | ||||
|         ? res.withdrawRate | ||||
|         : "-"; | ||||
|       this.accountDetails.withdrawNum = res.withdrawNum ? res.withdrawNum : "-"; | ||||
|       this.centerDialogVisible2 = true; | ||||
|     }, | ||||
|     // 批量驳回 | ||||
|     dialogClick() { | ||||
|       batchReject({ | ||||
|         ids: | ||||
|           this.centerDialogVisibleType == 1 | ||||
|             ? this.idStr | ||||
|             : this.centerDialogVisibleID, | ||||
|         remark: this.radio, | ||||
|       }) | ||||
|         .then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             ElMessage({ | ||||
|               type: "success", | ||||
|               message: "操作成功!", | ||||
|             }); | ||||
|             this.getData(); | ||||
|             this.centerDialogVisible = false; | ||||
|             this.idStr = null; | ||||
|           } else { | ||||
|             ElMessage({ | ||||
|               type: "error", | ||||
|               message: res.message, | ||||
|             }); | ||||
|           } | ||||
|         }) | ||||
|         .catch(() => { | ||||
|           ElMessage({ | ||||
|             type: "warning ", | ||||
|             message: "已取消", | ||||
|           }); | ||||
|         }); | ||||
|     }, | ||||
|     handleChange(row) { | ||||
|       ElMessageBox.confirm("确定要结算吗", "提示", { | ||||
|         confirmButtonText: "确定", | ||||
|         cancelButtonText: "取消", | ||||
|         type: "warning", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           agencyWithdrawSet({ ids: row.id }).then((res) => { | ||||
|             if (res.success === true) { | ||||
|               ElMessage({ | ||||
|                 type: "success", | ||||
|                 message: "操作成功!", | ||||
|               }); | ||||
|               this.getData(); | ||||
|               this.idStr = null; | ||||
|             } | ||||
|           }); | ||||
|         }) | ||||
|         .catch(() => { | ||||
|           ElMessage({ | ||||
|             type: "warning ", | ||||
|             message: "已取消", | ||||
|           }); | ||||
|         }); | ||||
|     }, | ||||
|     // 点击搜索 | ||||
|     handSearch() { | ||||
|       this.$refs["searchForm"].validate((valid) => { | ||||
|         if (valid) { | ||||
|           this.pageParams.pageNo = 1; | ||||
|           this.getData(); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 重置搜索表单 | ||||
|     resetSearchForm() { | ||||
|       this.$refs["searchForm"].resetFields(); | ||||
|       this.pageParams.pageNo = 1; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // 确认导出 | ||||
|     confirmExport2Excel() { | ||||
|       ElMessageBox.confirm("确定以当前筛选条件导出Excel吗?", "提示", { | ||||
|         confirmButtonText: "确定", | ||||
|         cancelButtonText: "取消", | ||||
|         type: "warning", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           this.btnLoading = true; | ||||
|           let { searchForm } = this; | ||||
|           searchForm = JSON.parse(JSON.stringify(searchForm)); | ||||
|           Object.keys(searchForm).forEach((item) => { | ||||
|             if ( | ||||
|               !searchForm[item] || | ||||
|               (searchForm[item] !== undefined && searchForm[item] === "") | ||||
|             ) { | ||||
|               delete searchForm[item]; | ||||
|             } | ||||
|           }); | ||||
|           Object.assign(searchForm, { pageSize: 10000, pageNo: 1 }); | ||||
|  | ||||
|           agencyWithdrawExamineExport(searchForm) | ||||
|             .then((res) => { | ||||
|               if (res) { | ||||
|                 this.exportVisible = false; | ||||
|                 this.btnLoading = false; | ||||
|                 let time = formatDate(new Date()); | ||||
|                 let alink = document.createElement("a"); | ||||
|                 alink.download = `官方提现记录${time}.xls`; | ||||
|                 alink.style.display = "none"; | ||||
|                 const blob = new Blob([res.data]); | ||||
|                 alink.href = URL.createObjectURL(blob); | ||||
|                 document.body.appendChild(alink); | ||||
|                 alink.click(); | ||||
|                 URL.revokeObjectURL(alink.href); | ||||
|               } | ||||
|             }) | ||||
|             .catch((err) => { | ||||
|               console.error(err); // 打印错误信息 | ||||
|               ElMessage.error("导出失败"); | ||||
|             }); | ||||
|         }) | ||||
|         .catch(() => { | ||||
|           ElMessage({ | ||||
|             type: "info", | ||||
|             message: "取消", | ||||
|           }); | ||||
|         }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange(val) { | ||||
|       this.pageParams.pageSize = val; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handlePageChange(val) { | ||||
|       this.pageParams.pageSize = val; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     headerCopy(column, e) { | ||||
|       this.$copy(column.label); | ||||
|     }, | ||||
|   }, | ||||
|   computed: { | ||||
|     convertTimestamp1() { | ||||
|       return function (time) { | ||||
|         let date = new Date(time); | ||||
|         return formatDateYMD(date); | ||||
|       }; | ||||
|     }, | ||||
|     convertTimestamp() { | ||||
|       return function (time) { | ||||
|         let date = new Date(time); | ||||
|         return formatDate(date); | ||||
|       }; | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style scope> | ||||
| .exportBtn { | ||||
|   margin-bottom: 0; | ||||
| } | ||||
| .text { | ||||
|   margin-left: 20px; | ||||
| } | ||||
| .container { | ||||
|   width: 100%; | ||||
| } | ||||
| .search-line { | ||||
|   width: 38%; | ||||
| } | ||||
| .boxs { | ||||
|   margin-top: 10px; | ||||
|   width: 100%; | ||||
|   word-wrap: break-word; /* 允许在单词内换行 */ | ||||
|   overflow-wrap: break-word; /* 同上,现代浏览器推荐使用 */ | ||||
|   white-space: normal; /* 允许换行 */ | ||||
| } | ||||
| .radios { | ||||
|   display: block !important; | ||||
|   width: 100% !important; | ||||
|   word-wrap: break-word !important; /* 允许在单词内换行 */ | ||||
|   overflow-wrap: break-word !important; /* 同上,现代浏览器推荐使用 */ | ||||
|   white-space: normal !important; /* 允许换行 */ | ||||
|   height: auto !important; | ||||
| } | ||||
| .boxs2 div { | ||||
|   margin-bottom: 10px; | ||||
|   font-size: 16px; | ||||
| } | ||||
| </style> | ||||
| @@ -72,7 +72,7 @@ export default { | ||||
|   name: "LoginView", | ||||
|   data () { | ||||
|     return { | ||||
|       smsSwitch: true, | ||||
|       smsSwitch: false, | ||||
|     }; | ||||
|   }, | ||||
|   setup () { | ||||
|   | ||||
							
								
								
									
										232
									
								
								src/views/luckGift/arrange.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										232
									
								
								src/views/luckGift/arrange.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,232 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <div class="condition"> | ||||
|       <!-- 分区 --> | ||||
|       <div class="inquire"> | ||||
|         <span>奖池</span> | ||||
|         <el-select | ||||
|           v-model="inquire.value" | ||||
|           placeholder="请选择" | ||||
|           @change="handleChange" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in inquire.options" | ||||
|             :key="item.type" | ||||
|             :label="item.name" | ||||
|             :value="item.type" | ||||
|           > | ||||
|           </el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|     </div> | ||||
|  | ||||
|     <!-- 总分组 --> | ||||
|     <div class="allArr"> | ||||
|       目前数组 <span>{{ allArr.length }} </span> 组: | ||||
|       <span class="span" v-for="(item, index) in allArr" :key="index"> | ||||
|         {{ item.expect }}, | ||||
|       </span> | ||||
|     </div> | ||||
|  | ||||
|     <!-- 数组设置 --> | ||||
|     <div class="arrSet">数组设置:</div> | ||||
|  | ||||
|     <!-- 数组内容 --> | ||||
|     <div class="boxs"> | ||||
|       <div class="arrContent" v-for="(item, index) in arr" :key="index"> | ||||
|         <div class="arrBox"> | ||||
|           <div class="left"> | ||||
|             <div class="left_in1"> | ||||
|               期望: <b class="b1">{{ item.expect }}</b> , | ||||
|             </div> | ||||
|             <div class="left_in2"> | ||||
|               得到率: <b class="b2">{{ (item.winRate * 100).toFixed(2) }}%</b> , | ||||
|             </div> | ||||
|           </div> | ||||
|           <div class="right" v-for="(arrInItem, i) in item.itemList" :key="i"> | ||||
|             <span>{{ arrInItem.multi }}</span> | ||||
|             <el-input | ||||
|               @input="handleInput(index, i, $event)" | ||||
|               v-model="arrInItem.num" | ||||
|               placeholder="" | ||||
|               class="input" | ||||
|             /> | ||||
|           </div> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|  | ||||
|     <!-- 按钮 --> | ||||
|     <div class="but"> | ||||
|       <el-button class="primary" type="primary" @click="saveFun()" | ||||
|         >保存 | ||||
|       </el-button> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { listType, list, save } from "@/api/luckGift/luckGift"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| import moment from "moment-timezone"; | ||||
| export default { | ||||
|   name: "luckGiftArrange", | ||||
|   data() { | ||||
|     return { | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         value: "", | ||||
|         options: [], | ||||
|       }, | ||||
|       allArr: [], //总数组 | ||||
|       arr: [], //处理下面总数组 | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     listType().then((res) => { | ||||
|       this.inquire.options = res.data; | ||||
|       this.inquire.value = res.data[0].type; | ||||
|       this.getData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       list({ type: this.inquire.value }).then((res) => { | ||||
|         this.allArr = res.data; | ||||
|         this.arr = res.data; | ||||
|       }); | ||||
|     }, | ||||
|     handleInput(index, i, val) { | ||||
|       // 期望值 expectedvalue = 倍数 * 5 * num / 2500 | ||||
|       // 中奖率 winRate =不为θ的倍数的num / 500 | ||||
|       this.arr[index].expect = this.calculationFun(index, i, val).expect; | ||||
|       this.arr[index].winRate = this.calculationFun(index, i, val).winRate; | ||||
|     }, | ||||
|     // 计算函数 | ||||
|     calculationFun(index, i, val) { | ||||
|       var expectNum = 0; | ||||
|       var winRate = 0; | ||||
|       this.arr[index].itemList.forEach((res) => { | ||||
|         expectNum += res.multi * res.num; | ||||
|         winRate += Number(res.num); | ||||
|       }); | ||||
|       console.log(winRate); | ||||
|       return { | ||||
|         expect: (expectNum / 500).toFixed(2), | ||||
|         winRate: (winRate / 500).toFixed(4), | ||||
|       }; | ||||
|     }, | ||||
|     // 保存 | ||||
|     saveFun() { | ||||
|       // | ||||
|       save( | ||||
|         JSON.stringify({ poolList: this.arr, type: this.inquire.value }) | ||||
|       ).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "保存成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 监听类型 | ||||
|     handleChange(value) { | ||||
|       this.inquire.value = value; | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   font-size: 18px; | ||||
|   .condition { | ||||
|     margin-bottom: 20px; | ||||
|     .inquire { | ||||
|       display: inline-block; | ||||
|       margin-right: 20px; | ||||
|       span { | ||||
|         margin-right: 10px; | ||||
|       } | ||||
|       .input { | ||||
|         width: 180px; | ||||
|         margin-right: 10px; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   .but { | ||||
|     margin-bottom: 20px; | ||||
|   } | ||||
|   .allArr { | ||||
|     margin: 20px 0 10px 0; | ||||
|     span { | ||||
|       color: red; | ||||
|     } | ||||
|     .span { | ||||
|       margin: 0 10px; | ||||
|     } | ||||
|   } | ||||
|   .arrSet { | ||||
|     margin-bottom: 0px; | ||||
|   } | ||||
|   .boxs { | ||||
|     display: flex; | ||||
|     // justify-content: space-between; | ||||
|     flex-wrap: wrap; | ||||
|     .arrContent { | ||||
|       // margin-bottom: 20px; | ||||
|       width: 190px; | ||||
|       height: 395px; | ||||
|       line-height: 30px; | ||||
|       margin-bottom: 20px; | ||||
|       .arrBox { | ||||
|         .left { | ||||
|           // float: left; | ||||
|           div { | ||||
|             min-width: 100px; | ||||
|             display: block; | ||||
|             // margin-bottom: -25px; | ||||
|             .b1 { | ||||
|               color: red; | ||||
|             } | ||||
|             .b2 { | ||||
|               color: blue; | ||||
|             } | ||||
|           } | ||||
|           .left_in2 { | ||||
|             margin-bottom: 10px | ||||
|           } | ||||
|         } | ||||
|         .right { | ||||
|           float: left; | ||||
|           margin-bottom: 15px; | ||||
|           span { | ||||
|             display: inline-block; | ||||
|             width: 45px; | ||||
|           } | ||||
|           .input { | ||||
|             display: inline-block; | ||||
|             width: 100px; | ||||
|             margin-right: 10px; | ||||
|             font-size: 16px; | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										265
									
								
								src/views/luckGift/luckGiftData.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										265
									
								
								src/views/luckGift/luckGiftData.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,265 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- ID --> | ||||
|     <div class="condition"> | ||||
|       <!-- 分区 --> | ||||
|       <div class="inquire"> | ||||
|         <span>分区</span> | ||||
|         <el-select | ||||
|           v-model="inquire.value" | ||||
|           placeholder="请选择" | ||||
|           @change="handleChange" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in inquire.options" | ||||
|             :key="item.type" | ||||
|             :label="item.name" | ||||
|             :value="item.type" | ||||
|           > | ||||
|           </el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|       <div class="inquire"> | ||||
|         <span>MoliStar ID</span> | ||||
|         <el-input v-model="inquire.userId" placeholder="" class="input"> | ||||
|         </el-input> | ||||
|       </div> | ||||
|       <!-- 送出时间 --> | ||||
|       <div class="inquire"> | ||||
|         <span>送出时间</span> | ||||
|         <el-date-picker v-model="inquire.time" type="date" placeholder="请选择"> | ||||
|         </el-date-picker> | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 按钮 --> | ||||
|     <div class="but"> | ||||
|       <el-button class="primary" type="primary" @click="getData()" | ||||
|         >查询 | ||||
|       </el-button> | ||||
|       <el-button | ||||
|         @click=" | ||||
|           inquire.userId = ''; | ||||
|           inquire.time = ''; | ||||
|         " | ||||
|         >重置筛选 | ||||
|       </el-button> | ||||
|       <el-button | ||||
|         class="primary" | ||||
|         type="primary" | ||||
|         style="margin-left=20px;" | ||||
|         :disabled="butClick" | ||||
|         @click=" | ||||
|           editDialog = true; | ||||
|           type = 12; | ||||
|           editDialogTitle = '赠送1000倍奖励'; | ||||
|           value = inquire.x; | ||||
|         " | ||||
|       > | ||||
|         赠送</el-button | ||||
|       > | ||||
|     </div> | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="date" align="center" label="日期" /> | ||||
|       <el-table-column prop="uid" align="center" label="uid" /> | ||||
|       <el-table-column prop="erbanNo" align="center" label="平台id" /> | ||||
|       <el-table-column prop="totalInput" align="center" label="进入" /> | ||||
|       <el-table-column prop="totalOutput" align="center" label="退出" /> | ||||
|       <el-table-column prop="production" align="center" label="剩余" /> | ||||
|       <el-table-column | ||||
|         prop="productionRatio" | ||||
|         align="center" | ||||
|         label="退出/进入" | ||||
|       /> | ||||
|       <el-table-column prop="avgInput" align="center" label="每次进入" /> | ||||
|       <el-table-column prop="num" align="center" label="总次数" /> | ||||
|       <el-table-column prop="winNum" align="center" label="得到次数" /> | ||||
|       <el-table-column prop="winRate" align="center" label="得到率" /> | ||||
|     </el-table> | ||||
|  | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|  | ||||
|     <!-- 编辑弹窗 --> | ||||
|     <el-dialog v-model="editDialog" :title="editDialogTitle" width="36%" center> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >{{ editDialogTitle }}</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="value" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|           placeholder="请输入用户ID" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button | ||||
|             @click=" | ||||
|               editDialog = false; | ||||
|               butClick = false; | ||||
|             " | ||||
|             >取消</el-button | ||||
|           > | ||||
|           <el-button | ||||
|             type="primary" | ||||
|             :disabled="butClick" | ||||
|             @click="editDialogClick()" | ||||
|           > | ||||
|             保存 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { personal, updateUserMulti } from "@/api/luckGift/luckGift"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| import moment from "moment-timezone"; | ||||
| export default { | ||||
|   name: "luckGiftData", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         userId: "", | ||||
|         time: "", | ||||
|         value: 2, | ||||
|         options: [ | ||||
|           { | ||||
|             name: "阿拉伯区", | ||||
|             type: 2, | ||||
|           }, | ||||
|           { | ||||
|             name: "英语区", | ||||
|             type: 1, | ||||
|           }, | ||||
|           { | ||||
|             name: "华语区", | ||||
|             type: 4, | ||||
|           }, | ||||
|         ], | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 分页 | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|       editDialog: false, | ||||
|       editDialogTitle: "", | ||||
|       value: "", | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     // this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       console.log(dateFormat(this.inquire.time, "yyyy-MM-dd")); | ||||
|       if (!this.inquire.time) { | ||||
|         ElMessage({ | ||||
|           showClose: true, | ||||
|           message: "请选择时间", | ||||
|           type: "error", | ||||
|         }); | ||||
|         return; | ||||
|       } | ||||
|       this.loading = true; | ||||
|       personal({ | ||||
|         erbanNo: this.inquire.userId, | ||||
|         pageNo: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|         startDate: dateFormat(this.inquire.time, "yyyy-MM-dd"), | ||||
|         endDate: dateFormat(this.inquire.time, "yyyy-MM-dd"), | ||||
|         partitionId: this.inquire.value, | ||||
|       }).then((res) => { | ||||
|         this.total = res.data.total; | ||||
|         this.tableData = res.data.rows; | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 确认保存 | ||||
|     editDialogClick() { | ||||
|       this.butClick = true; | ||||
|       updateUserMulti({ erbanNo: this.value }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "赠送成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           setTimeout(() => { | ||||
|             this.butClick = false; | ||||
|           }, 3000); | ||||
|           this.editDialog = false; | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           this.butClick = false; | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .condition { | ||||
|     margin-bottom: 20px; | ||||
|     .inquire { | ||||
|       display: inline-block; | ||||
|       margin-right: 20px; | ||||
|       span { | ||||
|         margin-right: 10px; | ||||
|       } | ||||
|       .input { | ||||
|         width: 180px; | ||||
|         margin-right: 10px; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   .but { | ||||
|     margin-bottom: 20px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										158
									
								
								src/views/luckGift/luckGiftDataAll.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								src/views/luckGift/luckGiftDataAll.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,158 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <div class="condition"> | ||||
|       <!-- 分区 --> | ||||
|       <div class="inquire"> | ||||
|         <span>分区</span> | ||||
|         <el-select v-model="inquire.value" placeholder="请选择"> | ||||
|           <el-option | ||||
|             v-for="item in inquire.options" | ||||
|             :key="item.value" | ||||
|             :label="item.label" | ||||
|             :value="item.value" | ||||
|           > | ||||
|           </el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|       <!-- 时间 --> | ||||
|       <div class="inquire"> | ||||
|         <span>时间</span> | ||||
|         <el-date-picker v-model="inquire.time" type="date" placeholder="请选择"> | ||||
|         </el-date-picker> | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 按钮 --> | ||||
|     <div class="but"> | ||||
|       <el-button class="primary" type="primary" @click="getData()" | ||||
|         >查询 | ||||
|       </el-button> | ||||
|     </div> | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="date" align="center" label="日期" /> | ||||
|       <el-table-column prop="totalInput" align="center" label="进入" /> | ||||
|       <el-table-column prop="totalOutput" align="center" label="退出" /> | ||||
|       <el-table-column prop="x" align="center" label="退出/进入比例" | ||||
|         ><template v-slot="scope"> | ||||
|           {{ (scope.row.totalOutput / scope.row.totalInput).toFixed(4) }} | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="num" align="center" label="参与次数" /> | ||||
|       <el-table-column prop="count" align="center" label="参与人数" /> | ||||
|       <el-table-column prop="winCount" align="center" label="得到人数" /> | ||||
|       <el-table-column prop="winNum" align="center" label="得到次数" /> | ||||
|       <el-table-column prop="winRate" align="center" label="得到率" | ||||
|         ><template v-slot="scope"> | ||||
|           {{ scope.row.winRate ? scope.row.winRate : "-" }} | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="stock" align="center" label="数组库存" /> | ||||
|     </el-table> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { platform } from "@/api/luckGift/luckGift"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| import moment from "moment-timezone"; | ||||
| export default { | ||||
|   name: "luckGiftDataAll", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         value: 2, | ||||
|         options: [ | ||||
|           { | ||||
|             value: 2, | ||||
|             label: "阿拉伯区", | ||||
|           }, | ||||
|           { | ||||
|             value: 1, | ||||
|             label: "英语区", | ||||
|           }, | ||||
|           { | ||||
|             value: 4, | ||||
|             label: "华语区", | ||||
|           }, | ||||
|         ], | ||||
|         time: "", | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 分页 | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     // this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       console.log(dateFormat(this.inquire.time, "yyyy-MM-dd")); | ||||
|       if (!this.inquire.time) { | ||||
|         ElMessage({ | ||||
|           showClose: true, | ||||
|           message: "请选择时间", | ||||
|           type: "error", | ||||
|         }); | ||||
|         return; | ||||
|       } | ||||
|       this.loading = true; | ||||
|       platform({ | ||||
|         erbanNo: this.inquire.userId, | ||||
|         startDate: dateFormat(this.inquire.time, "yyyy-MM-dd"), | ||||
|         endDate: dateFormat(this.inquire.time, "yyyy-MM-dd"), | ||||
|         partitionId: this.inquire.value, | ||||
|       }).then((res) => { | ||||
|         this.total = res.data.total; | ||||
|         this.tableData = res.data; | ||||
|         this.loading = false; | ||||
|         console.log(this.tableData, 123); | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .condition { | ||||
|     margin-bottom: 20px; | ||||
|     .inquire { | ||||
|       display: inline-block; | ||||
|       margin-right: 20px; | ||||
|       span { | ||||
|         margin-right: 10px; | ||||
|       } | ||||
|       .input { | ||||
|         width: 180px; | ||||
|         margin-right: 10px; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   .but { | ||||
|     margin-bottom: 20px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										500
									
								
								src/views/luckGift/luckGiftSet.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										500
									
								
								src/views/luckGift/luckGiftSet.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,500 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <div class="condition"> | ||||
|       <!-- 分区 --> | ||||
|       <div class="inquire"> | ||||
|         <span>分区</span> | ||||
|         <el-select | ||||
|           v-model="inquire.value" | ||||
|           placeholder="请选择" | ||||
|           @change="handleChange" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in inquire.options" | ||||
|             :key="item.type" | ||||
|             :label="item.name" | ||||
|             :value="item.type" | ||||
|           > | ||||
|           </el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|  | ||||
|       <div class="inquire"> | ||||
|         <span>对比值N</span> | ||||
|         <!-- @input="handleInput" --> | ||||
|         <el-input | ||||
|           v-model="inquire.comparisonValue" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             butClick = false; | ||||
|             type = 1; | ||||
|             editDialogTitle = '对比值N'; | ||||
|             value = inquire.comparisonValue; | ||||
|           " | ||||
|         > | ||||
|           编辑</el-button | ||||
|         > | ||||
|       </div> | ||||
|  | ||||
|       <div class="inquire"> | ||||
|         <span>对比值M</span> | ||||
|         <el-input | ||||
|           v-model="inquire.supplement.supplementRatio" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             butClick = false; | ||||
|             type = 5; | ||||
|             editDialogTitle = '对比值M'; | ||||
|             value = inquire.supplement.supplementRatio; | ||||
|           " | ||||
|         > | ||||
|           编辑</el-button | ||||
|         > | ||||
|       </div> | ||||
|  | ||||
|       <div class="inquire"> | ||||
|         <span>金币对比值A</span> | ||||
|         <!-- @input="handleInput" --> | ||||
|         <el-input | ||||
|           v-model="inquire.supplement.conditionInput" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             butClick = false; | ||||
|             type = 6; | ||||
|             editDialogTitle = '金币对比值A'; | ||||
|             value = inquire.supplement.conditionInput; | ||||
|           " | ||||
|         > | ||||
|           编辑</el-button | ||||
|         > | ||||
|       </div> | ||||
|  | ||||
|       <div class="inquire"> | ||||
|         <span>奖励金币倍数</span> | ||||
|         <!-- @input="handleInput" --> | ||||
|         <el-input | ||||
|           v-model="inquire.supplement.supplementMulti" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             butClick = false; | ||||
|             type = 7; | ||||
|             editDialogTitle = '奖励金币倍数'; | ||||
|             value = inquire.supplement.supplementMulti; | ||||
|           " | ||||
|         > | ||||
|           编辑</el-button | ||||
|         > | ||||
|       </div> | ||||
|  | ||||
|       <div class="inquire"> | ||||
|         <span>幸运24金币库存</span> | ||||
|         <el-input | ||||
|           v-model="inquire.goldInventory" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             butClick = false; | ||||
|             type = 2; | ||||
|             editDialogTitle = '幸运24金币库存'; | ||||
|             value = inquire.goldInventory; | ||||
|           " | ||||
|           >编辑</el-button | ||||
|         > | ||||
|       </div> | ||||
|  | ||||
|       <!-- <div class="inquire">   | ||||
|         <span>幸运礼物ID</span> | ||||
|         <el-input | ||||
|           v-model="inquire.x" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             butClick = false; | ||||
|             type = 8; | ||||
|             editDialogTitle = '幸运礼物ID'; | ||||
|             value = inquire.x; | ||||
|           " | ||||
|         > | ||||
|           编辑</el-button | ||||
|         > | ||||
|       </div> --> | ||||
|  | ||||
|       <div class="inquire"> | ||||
|         <span>平台抽成</span> | ||||
|         <el-input | ||||
|           v-model="inquire.platformCommission" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             butClick = false; | ||||
|             type = 3; | ||||
|             editDialogTitle = '平台抽成'; | ||||
|             value = inquire.platformCommission; | ||||
|           " | ||||
|           >编辑</el-button | ||||
|         > | ||||
|       </div> | ||||
|  | ||||
|       <div class="inquire"> | ||||
|         <span>用户收益比例</span> | ||||
|         <el-input | ||||
|           v-model="inquire.userRevenueRatio" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             butClick = false; | ||||
|             type = 4; | ||||
|             editDialogTitle = '用户收益比例'; | ||||
|             value = inquire.userRevenueRatio; | ||||
|           " | ||||
|           >编辑</el-button | ||||
|         > | ||||
|       </div> | ||||
|  | ||||
|       <div class="inquire"> | ||||
|         <span>通知制定金额</span> | ||||
|         <!-- @input="handleInput" --> | ||||
|         <el-input | ||||
|           v-model="inquire.warnMulti" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             butClick = false; | ||||
|             type = 9; | ||||
|             editDialogTitle = '通知制定金额'; | ||||
|             value = inquire.warnMulti; | ||||
|           " | ||||
|         > | ||||
|           编辑</el-button | ||||
|         > | ||||
|       </div> | ||||
|  | ||||
|       <!-- <div class="inquire"> | ||||
|         <span>库存告急通知</span> | ||||
|         <el-input | ||||
|           v-model="inquire.x" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             butClick = false; | ||||
|             type = 10; | ||||
|             editDialogTitle = '库存告急通知'; | ||||
|             value = inquire.x; | ||||
|           " | ||||
|         > | ||||
|           编辑</el-button | ||||
|         > | ||||
|       </div> --> | ||||
|  | ||||
|       <div class="inquire"> | ||||
|         <span>用户上线列表</span> | ||||
|         <!-- @input="handleInput" --> | ||||
|         <el-input | ||||
|           v-model="inquire.followErbanNoList" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             butClick = false; | ||||
|             type = 11; | ||||
|             editDialogTitle = '用户上线列表'; | ||||
|             value = inquire.followErbanNoList; | ||||
|           " | ||||
|         > | ||||
|           编辑</el-button | ||||
|         > | ||||
|       </div> | ||||
|       <div class="inquire"> | ||||
|         <span>赠送1000倍奖励</span> | ||||
|         <el-button | ||||
|           class="primary" | ||||
|           type="primary" | ||||
|           :disabled="butClick" | ||||
|           @click=" | ||||
|             editDialog = true; | ||||
|             type = 12; | ||||
|             editDialogTitle = '赠送1000倍奖励'; | ||||
|             value = inquire.x; | ||||
|           " | ||||
|         > | ||||
|           赠送</el-button | ||||
|         > | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 编辑弹窗 --> | ||||
|     <el-dialog v-model="editDialog" :title="editDialogTitle" width="36%" center> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >{{ editDialogTitle }}</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="value" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|           placeholder="请输入" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button | ||||
|             @click=" | ||||
|               editDialog = false; | ||||
|               butClick = false; | ||||
|             " | ||||
|             >取消</el-button | ||||
|           > | ||||
|           <el-button | ||||
|             type="primary" | ||||
|             :disabled="butClick" | ||||
|             @click="editDialogClick()" | ||||
|           > | ||||
|             保存 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { getConfig, updateSet, updateUserMulti } from "@/api/luckGift/luckGift"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| import moment from "moment-timezone"; | ||||
| export default { | ||||
|   name: "luckGiftSet", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       butClick: false, | ||||
|       butClickTime: null, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         value: 2, | ||||
|         options: [ | ||||
|           { | ||||
|             name: "阿拉伯区", | ||||
|             type: 2, | ||||
|           }, | ||||
|           { | ||||
|             name: "英语区", | ||||
|             type: 1, | ||||
|           }, | ||||
|           { | ||||
|             name: "华语区", | ||||
|             type: 4, | ||||
|           }, | ||||
|         ], | ||||
|         comparisonValue: "", | ||||
|         goldInventory: "", | ||||
|         giftId: "", | ||||
|         platformCommission: "", | ||||
|         userRevenueRatio: "", | ||||
|         supplement: { | ||||
|           conditionInput: "", | ||||
|           conditionNum: "", | ||||
|           supplementMulti: "", | ||||
|           supplementNum: "", | ||||
|           supplementRatio: "", | ||||
|         }, | ||||
|         warnMulti: "", | ||||
|         followErbanNoList: "", | ||||
|       }, | ||||
|       editDialog: false, | ||||
|       editDialogTitle: "", | ||||
|       value: "", | ||||
|       type: null, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       getConfig({ partitionId: this.inquire.value }).then((res) => { | ||||
|         this.inquire.comparisonValue = res.data.productionRatio; | ||||
|         this.inquire.goldInventory = res.data.stock; | ||||
|         this.inquire.platformCommission = res.data.platformRatio; | ||||
|         this.inquire.userRevenueRatio = res.data.receiverRatio; | ||||
|         this.inquire.supplement = res.data.supplement; | ||||
|         this.inquire.warnMulti = res.data.warnMulti; | ||||
|         this.inquire.followErbanNoList = res.data.followErbanNoList.join(); | ||||
|       }); | ||||
|     }, | ||||
|     // 确认保存 | ||||
|     editDialogClick() { | ||||
|       var obj = {}; | ||||
|       obj.partitionId = this.inquire.value; | ||||
|       if (this.type == 12) { | ||||
|         this.butClick = true; | ||||
|         updateUserMulti({ erbanNo: this.value }).then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message:'赠送成功', | ||||
|               type: "success", | ||||
|             }); | ||||
|             setTimeout(() => { | ||||
|               this.butClick = false; | ||||
|             }, 3000); | ||||
|             this.editDialog = false; | ||||
|             this.getData(); | ||||
|           } else { | ||||
|             this.butClick = false; | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "error", | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       } else { | ||||
|         if (this.type == 1) { | ||||
|           obj.productionRatio = this.value; | ||||
|         } else if (this.type == 2) { | ||||
|           obj.stock = this.value; | ||||
|         } else if (this.type == 3) { | ||||
|           obj.platformRatio = this.value; | ||||
|         } else if (this.type == 4) { | ||||
|           obj.receiverRatio = this.value; | ||||
|         }else if (this.type == 5) { | ||||
|           obj.supplement = this.inquire.supplement; | ||||
|           obj.supplement.supplementRatio = this.value; | ||||
|         } else if (this.type == 6) { | ||||
|           obj.supplement = this.inquire.supplement; | ||||
|           obj.supplement.conditionInput = this.value; | ||||
|         } else if (this.type == 7) { | ||||
|           obj.supplement = this.inquire.supplement; | ||||
|           obj.supplement.supplementMulti = this.value; | ||||
|         } else if (this.type == 9) { | ||||
|           obj.warnMulti = this.value; | ||||
|         } else if (this.type == 11) { | ||||
|           obj.followErbanNoList = this.value.split(","); | ||||
|         } | ||||
|         updateSet(obj).then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: "保存成功", | ||||
|               type: "success", | ||||
|             }); | ||||
|             this.editDialog = false; | ||||
|             this.getData(); | ||||
|           } else { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "error", | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
|     // 监听类型 | ||||
|     handleChange(value) { | ||||
|       this.inquire.value = value; | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .condition { | ||||
|     margin-bottom: 20px; | ||||
|     .inquire { | ||||
|       margin-right: 20px; | ||||
|       margin-bottom: 20px; | ||||
|       span { | ||||
|         display: inline-block; | ||||
|         width: 110px; | ||||
|         margin-right: 10px; | ||||
|         // text-align: right; | ||||
|       } | ||||
|       .input { | ||||
|         width: 180px; | ||||
|         margin-right: 10px; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   .but { | ||||
|     margin-bottom: 20px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
| @@ -306,7 +306,8 @@ export default { | ||||
|       this.inquire.value1 = e; | ||||
|       luckyGiftRangeConfigList({ giftId: this.inquire.value1 }).then((res) => { | ||||
|         this.inquire.giftsNum = res.data; | ||||
|         // this.inquire.value2 = res.data[0].id; | ||||
|       // this.inquire.value2 = ""; | ||||
|         this.inquire.value2 = res.data[0].id; | ||||
|         // this.loading = true; | ||||
|         // luckyGiftRewardList({ | ||||
|         //   giftId: e, | ||||
|   | ||||
| @@ -72,7 +72,7 @@ | ||||
|           :src="imgFun(JsonFunc(scope.row.rewardJson))[0]" | ||||
|           :zoom-rate="1.1" | ||||
|           :preview-src-list="imgFun(JsonFunc(scope.row.rewardJson))" | ||||
|           fit="cover" | ||||
|           fit="scale-down" | ||||
|           preview-teleported="true" | ||||
|           hide-on-click-modal="true" | ||||
|         /> | ||||
|   | ||||
| @@ -26,7 +26,7 @@ | ||||
|           :src="scope.row.luckyBagPic" | ||||
|           :zoom-rate="1.1" | ||||
|           :preview-src-list="[scope.row.luckyBagPic]" | ||||
|           fit="cover" | ||||
|           fit="scale-down" | ||||
|           preview-teleported="true" | ||||
|           hide-on-click-modal="true" | ||||
|         /> | ||||
| @@ -46,7 +46,7 @@ | ||||
|           :src="scope.row.destGiftPic" | ||||
|           :zoom-rate="1.1" | ||||
|           :preview-src-list="[scope.row.destGiftPic]" | ||||
|           fit="cover" | ||||
|           fit="scale-down" | ||||
|           preview-teleported="true" | ||||
|           hide-on-click-modal="true" | ||||
|         /> | ||||
| @@ -70,7 +70,7 @@ | ||||
|           :src="scope.row.rewardGiftPic" | ||||
|           :zoom-rate="1.1" | ||||
|           :preview-src-list="[scope.row.rewardGiftPic]" | ||||
|           fit="cover" | ||||
|           fit="scale-down" | ||||
|           preview-teleported="true" | ||||
|           hide-on-click-modal="true" | ||||
|         /> | ||||
|   | ||||
							
								
								
									
										624
									
								
								src/views/medal/MedalInfo.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										624
									
								
								src/views/medal/MedalInfo.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,624 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>勋章ID</span> | ||||
|       <el-input v-model="inquire.id" placeholder="" class="input"></el-input> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <span>勋章昵称</span> | ||||
|       <el-input v-model="inquire.nick" placeholder="" class="input"></el-input> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <span class="demonstration">地区</span> | ||||
|       <el-select filterable v-model="inquire.partitionId" placeholder="请选择"> | ||||
|         <el-option | ||||
|           v-for="item in inquire.options" | ||||
|           :key="item.id" | ||||
|           :label="item.desc" | ||||
|           :value="item.id" | ||||
|         ></el-option> | ||||
|       </el-select> | ||||
|     </div> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" type="primary" @click="getData()"> | ||||
|       查询 | ||||
|     </el-button> | ||||
|     <el-button class="primary" type="primary" @click="add()"> 新增 </el-button> | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="id" align="center" label="勋章ID" /> | ||||
|       <el-table-column prop="partitionFlag" align="center" label="地区"> | ||||
|         <template v-slot="scope">{{ | ||||
|           partitionFlagFun(scope.row.partitionFlag, 1) | ||||
|         }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="name" align="center" label="勋章名称-华语区"> | ||||
|         <template v-slot="scope">{{ JSON.parse(scope.row.name).zh }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="name" align="center" label="勋章名称-英语区"> | ||||
|         <template v-slot="scope">{{ JSON.parse(scope.row.name).en }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="name" align="center" label="勋章名称-阿语区"> | ||||
|         <template v-slot="scope">{{ JSON.parse(scope.row.name).ar }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column | ||||
|         align="center" | ||||
|         prop="picUrl" | ||||
|         label="勋章图片" | ||||
|         width="120" | ||||
|       > | ||||
|         <template v-slot="scope"> | ||||
|           <el-image | ||||
|             style="width: 100px; height: 100px" | ||||
|             :src="scope.row.picUrl" | ||||
|             :zoom-rate="1.1" | ||||
|             :preview-src-list="scope.row.picUrl" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|           /> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="enable" align="center" label="状态"> | ||||
|         <template v-slot="scope">{{ | ||||
|           scope.row.enable ? "生效" : "不生效" | ||||
|         }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="createTime" align="center" label="添加时间" /> | ||||
|       <el-table-column align="center" label="操作" width="220"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="eidFun(scope.row)" | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             size="default" | ||||
|           > | ||||
|             编辑 | ||||
|           </el-button> | ||||
|           <el-button | ||||
|             @click="grantFun(scope.row)" | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             size="default" | ||||
|             :disabled="!scope.row.enable" | ||||
|           > | ||||
|             发放 | ||||
|           </el-button> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|  | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|  | ||||
|     <!-- 新增&编辑弹窗 --> | ||||
|     <el-dialog | ||||
|       destroy-on-close | ||||
|       class="pub" | ||||
|       v-model="controlsDialog" | ||||
|       :title="controlsTitle" | ||||
|       width="32%" | ||||
|       center | ||||
|     > | ||||
|       <!-- 地区 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >地区</span | ||||
|         > | ||||
|         <el-select | ||||
|           multiple | ||||
|           filterable | ||||
|           v-model="controlsObj.value" | ||||
|           placeholder="请选择" | ||||
|           style="width: 100%" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in controlsObj.options" | ||||
|             :key="item.id" | ||||
|             :label="item.desc" | ||||
|             :value="item.id" | ||||
|           > | ||||
|           </el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 勋章名称-华语 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >勋章名称-华语</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="controlsObj.nickZh" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 勋章名称-英语 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >勋章名称-英语</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="controlsObj.nickEn" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 勋章名称-阿语 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >勋章名称-阿语</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="controlsObj.nickAr" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 勋章图片 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >勋章图片</span | ||||
|         > | ||||
|         <el-upload | ||||
|           class="avatar-uploader" | ||||
|           action="/admin/tencent/cos/upload/file" | ||||
|           :show-file-list="false" | ||||
|           :on-success="handleAvatarSuccess" | ||||
|           :before-upload="beforeAvatarUpload" | ||||
|           :on-error="handleAvatarError" | ||||
|         > | ||||
|           <img | ||||
|             :src="controlsObj.imageUrl1" | ||||
|             class="avatar" | ||||
|           /> | ||||
|         </el-upload> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 状态 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >状态</span | ||||
|         > | ||||
|         <el-select filterable v-model="controlsObj.value2" placeholder="请选择"> | ||||
|           <el-option | ||||
|             v-for="item in controlsObj.options2" | ||||
|             :key="item.id" | ||||
|             :label="item.desc" | ||||
|             :value="item.id" | ||||
|           ></el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 弹窗按钮 --> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="controlsDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="controlsDialogOut()"> | ||||
|             确认 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|  | ||||
|     <!-- 发放勋章弹窗 --> | ||||
|     <el-dialog | ||||
|       destroy-on-close | ||||
|       class="pub" | ||||
|       v-model="grantDialog" | ||||
|       title="发放勋章" | ||||
|       width="32%" | ||||
|       center | ||||
|     > | ||||
|       <!-- 勋章名称 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >勋章名称</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="grantObj.nick" | ||||
|           placeholder="默认展示的是中文勋章名称" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 发放对象平台号 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >发放对象平台号</span | ||||
|         > | ||||
|         <el-input | ||||
|           type="textarea" | ||||
|           :rows="2" | ||||
|           v-model="grantObj.userId" | ||||
|           placeholder="多个平台号用英文“,”号分开分隔" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 发放天数 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >发放天数</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="grantObj.days" | ||||
|           placeholder="输入天数,不输入则视为无限制" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 备注 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >备注</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="grantObj.desc" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 弹窗按钮 --> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="grantDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="grantOut()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   listPartitionInfo, | ||||
|   medalPage, | ||||
|   medalSave, | ||||
|   medalSend, | ||||
| } from "@/api/medal/medal"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "MedalInfo", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         id: "", | ||||
|         nick: "", | ||||
|         partitionId: "", | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 分页 | ||||
|       total: 10, | ||||
|       currentPage: 1, | ||||
|       pageSize: 10, | ||||
|       // 操作弹窗 | ||||
|       controlsDialog: false, | ||||
|       controlsTitle: "新增&编辑", | ||||
|       controlsType: 1, | ||||
|       controlsObj: { | ||||
|         value: [], | ||||
|         options: [], | ||||
|         nickZh: "", | ||||
|         nickEn: "", | ||||
|         nickAr: "", | ||||
|         imageUrl1: "", | ||||
|         value2: "", | ||||
|         options2: [ | ||||
|           { | ||||
|             desc: "生效", | ||||
|             id: true, | ||||
|           }, | ||||
|           { | ||||
|             desc: "不生效", | ||||
|             id: false, | ||||
|           }, | ||||
|         ], | ||||
|         id: "", | ||||
|       }, | ||||
|       // 发放弹窗 | ||||
|       grantDialog: false, | ||||
|       grantObj: { | ||||
|         nick: "", | ||||
|         userId: "", | ||||
|         days: "", | ||||
|         desc: "", | ||||
|       }, | ||||
|       grantObjNew: {}, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     listPartitionInfo().then((res) => { | ||||
|       this.inquire.options = res.data; | ||||
|       this.inquire.options.push({ | ||||
|         desc: "全部", | ||||
|         id: "", | ||||
|       }); | ||||
|       listPartitionInfo().then((res) => { | ||||
|         this.controlsObj.options = res.data; | ||||
|         this.getData(); | ||||
|       }); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       medalPage({ | ||||
|         id: this.inquire.id, | ||||
|         name: this.inquire.nick, | ||||
|         partitionId: this.inquire.partitionId, | ||||
|         page: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           this.total = res.data.total; | ||||
|           this.tableData = res.data.records; | ||||
|           this.loading = false; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 添加 | ||||
|     add() { | ||||
|       this.controlsTitle = "新增"; | ||||
|       this.controlsType = 1; | ||||
|       this.controlsObj.value = []; | ||||
|       this.controlsObj.nickZh = ""; | ||||
|       this.controlsObj.nickEn = ""; | ||||
|       this.controlsObj.nickAr = ""; | ||||
|       this.controlsObj.imageUrl1 = ""; | ||||
|       this.controlsObj.value2 = ""; | ||||
|       this.controlsDialog = true; | ||||
|     }, | ||||
|     // 编辑 | ||||
|     eidFun(val) { | ||||
|       this.controlsTitle = "编辑"; | ||||
|       this.controlsType = 2; | ||||
|       this.controlsObj.value = this.partitionFlagFun(val.partitionFlag, 2); | ||||
|       this.controlsObj.nickZh = JSON.parse(val.name).zh; | ||||
|       this.controlsObj.nickEn = JSON.parse(val.name).en; | ||||
|       this.controlsObj.nickAr = JSON.parse(val.name).ar; | ||||
|       this.controlsObj.imageUrl1 = val.picUrl; | ||||
|       this.controlsObj.value2 = val.enable; | ||||
|       this.controlsObj.id = val.id; | ||||
|       this.controlsDialog = true; | ||||
|     }, | ||||
|     // 确认保存按钮 | ||||
|     controlsDialogOut() { | ||||
|       if (this.controlsType == 1) { | ||||
|         // 新增 | ||||
|         var obj = {}; | ||||
|         var partitionFlagVal = 0; | ||||
|         console.log(this.controlsObj.value); | ||||
|         console.log(this.controlsObj.options); | ||||
|         this.controlsObj.value.forEach((res, i) => { | ||||
|           partitionFlagVal |= this.controlsObj.options[i].id; | ||||
|         }); | ||||
|         obj.partitionFlag = partitionFlagVal; | ||||
|         obj.name = JSON.stringify({ | ||||
|           zh: this.controlsObj.nickZh, | ||||
|           en: this.controlsObj.nickEn, | ||||
|           ar: this.controlsObj.nickAr, | ||||
|         }); | ||||
|         obj.picUrl = this.controlsObj.imageUrl1; | ||||
|         obj.enable = this.controlsObj.value2; | ||||
|         console.log(obj); | ||||
|         medalSave(obj).then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             this.getData(); | ||||
|             this.controlsDialog = false; | ||||
|           } else { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "error", | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       } else { | ||||
|         // 编辑 | ||||
|         var obj1 = {}; | ||||
|         var partitionFlagVal1 = 0; | ||||
|         this.controlsObj.value.forEach((res, i) => { | ||||
|           partitionFlagVal1 += res; | ||||
|         }); | ||||
|         obj1.partitionFlag = partitionFlagVal1; | ||||
|         obj1.name = JSON.stringify({ | ||||
|           zh: this.controlsObj.nickZh, | ||||
|           en: this.controlsObj.nickEn, | ||||
|           ar: this.controlsObj.nickAr, | ||||
|         }); | ||||
|         obj1.picUrl = this.controlsObj.imageUrl1; | ||||
|         obj1.enable = this.controlsObj.value2; | ||||
|         obj1.id = this.controlsObj.id; | ||||
|         console.log(1111111111, this.controlsObj.value); | ||||
|         console.log(this.controlsObj.options); | ||||
|         console.log(obj1); | ||||
|         medalSave(obj1).then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             this.getData(); | ||||
|             this.controlsDialog = false; | ||||
|           } else { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "error", | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
|     //发放按钮 | ||||
|     grantFun(val) { | ||||
|       this.grantObjNew = val; | ||||
|       this.grantObj.nick = JSON.parse(val.name).zh; | ||||
|       this.grantDialog = true; | ||||
|     }, | ||||
|     // 确认发放 | ||||
|     grantOut() { | ||||
|       medalSend({ | ||||
|         days: this.grantObj.days, | ||||
|         erbanNoStr: this.grantObj.userId, | ||||
|         medalId: this.grantObjNew.id, | ||||
|         remark: this.grantObj.desc, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message || "发放成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.grantDialog = false; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     partitionFlagFun(num, type) { | ||||
|       //1 2 4 | ||||
|       var val = 0; | ||||
|       if (type == 2) { | ||||
|         if (num == 0 || num == 7) { | ||||
|           val = [4, 1, 2]; | ||||
|         } else if (num == 1) { | ||||
|           val = [1]; | ||||
|         } else if (num == 3) { | ||||
|           val = [1, 2]; | ||||
|         } else if (num == 2) { | ||||
|           val = [2]; | ||||
|         } else if (num == 6) { | ||||
|           val = [2, 4]; | ||||
|         } else if (num == 4) { | ||||
|           val = [4]; | ||||
|         } | ||||
|       } else { | ||||
|         if (num == 0 || num == 7) { | ||||
|           val = "华语区、英语区、阿语区"; | ||||
|         } else if (num == 1) { | ||||
|           val = "英语区"; | ||||
|         } else if (num == 3) { | ||||
|           val = "英语区、阿语区"; | ||||
|         } else if (num == 2) { | ||||
|           val = "阿语区"; | ||||
|         } else if (num == 6) { | ||||
|           val = "阿语区、华语区"; | ||||
|         } else if (num == 4) { | ||||
|           val = "华语区"; | ||||
|         } | ||||
|       } | ||||
|       return val; | ||||
|     }, | ||||
|     beforeAvatarUpload() { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传中~", | ||||
|         type: "warning", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarError() { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传失败!", | ||||
|         type: "error", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess(res, file) { | ||||
|       console.log(file); | ||||
|       this.controlsObj.imageUrl1 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										363
									
								
								src/views/medal/MedalRecord.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										363
									
								
								src/views/medal/MedalRecord.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,363 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>勋章ID</span> | ||||
|       <el-input v-model="inquire.id" placeholder="" class="input"></el-input> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <span>用户平台ID</span> | ||||
|       <el-input | ||||
|         v-model="inquire.userId" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" type="primary" @click="getData()"> | ||||
|       查询 | ||||
|     </el-button> | ||||
|     <el-button class="primary" type="primary" @click="grantDialog = true"> | ||||
|       发放勋章 | ||||
|     </el-button> | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="createTime" align="center" label="发放时间" /> | ||||
|       <el-table-column prop="source" align="center" label="发放渠道"> | ||||
|         <template v-slot="scope">{{ | ||||
|           scope.row.source == 1 ? "管理后台" : scope.row.source | ||||
|         }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="id" align="center" label="发放勋章ID" /> | ||||
|       <el-table-column prop="medalName" align="center" label="勋章名称" /> | ||||
|       <el-table-column align="center" prop="x" label="勋章图片" width="120"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-image | ||||
|             style="width: 100px; height: 100px" | ||||
|             :src="scope.row.picUrl" | ||||
|             :zoom-rate="1.1" | ||||
|             :preview-src-list="scope.row.picUrl" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|           /> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="x" align="center" label="生效天数"> | ||||
|         <template v-slot="scope">{{ scope.row.days }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="x" align="center" label="备注"> | ||||
|         <template v-slot="scope">{{ | ||||
|           scope.row.remark == "" ? "-" : scope.row.remark | ||||
|         }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="x" align="center" label="状态"> | ||||
|         <template v-slot="scope">{{ | ||||
|           scope.row.status == 1 | ||||
|             ? "生效中" | ||||
|             : scope.row.status == 0 | ||||
|             ? "已失效" | ||||
|             : "撤销" | ||||
|         }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="erbanNo" align="center" label="发放对象平台号" /> | ||||
|       <el-table-column prop="nick" align="center" label="发放对象昵称" /> | ||||
|       <el-table-column | ||||
|         prop="partitionName" | ||||
|         align="center" | ||||
|         label="发放对象分区" | ||||
|       /> | ||||
|       <el-table-column align="center" label="操作" width="220"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="eidFun(scope.row)" | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             size="default" | ||||
|             :disabled="scope.row.status <= 0 ? true : false" | ||||
|           > | ||||
|             撤销 | ||||
|           </el-button> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|  | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|  | ||||
|     <!-- 发放勋章弹窗 --> | ||||
|     <el-dialog | ||||
|       destroy-on-close | ||||
|       class="pub" | ||||
|       v-model="grantDialog" | ||||
|       title="发放勋章" | ||||
|       width="32%" | ||||
|       center | ||||
|     > | ||||
|       <!-- 勋章昵称 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >勋章昵称</span | ||||
|         > | ||||
|         <el-select filterable v-model="grantObj.value" placeholder="请选择"> | ||||
|           <el-option | ||||
|             v-for="item in grantObj.options" | ||||
|             :key="item.id" | ||||
|             :label="item.name" | ||||
|             :value="item.id" | ||||
|           ></el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 发放对象平台号 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >发放对象平台号</span | ||||
|         > | ||||
|         <el-input | ||||
|           type="textarea" | ||||
|           :rows="2" | ||||
|           v-model="grantObj.userId" | ||||
|           placeholder="多个平台号用英文“,”号分开分隔" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 发放天数 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >发放天数</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="grantObj.days" | ||||
|           placeholder="输入天数,不输入则视为无限制" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 备注 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px; display: flex"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >备注</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="grantObj.desc" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 弹窗按钮 --> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="grantDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="grantOut()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|  | ||||
|     <!-- 二次确认弹窗 --> | ||||
|     <el-dialog | ||||
|       destroy-on-close | ||||
|       v-model="delDialog" | ||||
|       title="提示" | ||||
|       width="30%" | ||||
|       center | ||||
|     > | ||||
|       <span> 确定要撤销吗?</span> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="delDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="delClick()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   medalRecordPage, | ||||
|   listAll, | ||||
|   medalSend, | ||||
|   rollback, | ||||
| } from "@/api/medal/medal"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "MedalRecord", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         id: "", | ||||
|         userId: "", | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 分页 | ||||
|       total: 10, | ||||
|       currentPage: 1, | ||||
|       pageSize: 10, | ||||
|       // 发放弹窗 | ||||
|       grantDialog: false, | ||||
|       grantObj: { | ||||
|         value: "", | ||||
|         options: [], | ||||
|         userId: "", | ||||
|         days: "", | ||||
|         desc: "", | ||||
|       }, | ||||
|       // 撤销 | ||||
|       delDialog: false, | ||||
|       delObj: {}, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     listAll().then((res) => { | ||||
|       if (res.code == 200) { | ||||
|         this.grantObj.options = res.data; | ||||
|         this.getData(); | ||||
|       } else { | ||||
|         ElMessage({ | ||||
|           showClose: true, | ||||
|           message: res.message, | ||||
|           type: "error", | ||||
|         }); | ||||
|       } | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       medalRecordPage({ | ||||
|         medalId: this.inquire.id, | ||||
|         erbanNo: this.inquire.userId, | ||||
|         page: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           this.total = res.data.total; | ||||
|           this.tableData = res.data.records; | ||||
|           this.loading = false; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 确认发放 | ||||
|     grantOut() { | ||||
|       medalSend({ | ||||
|         days: this.grantObj.days, | ||||
|         erbanNoStr: this.grantObj.userId, | ||||
|         medalId: this.grantObj.value, | ||||
|         remark: this.grantObj.desc, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message || "发放成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.grantDialog = false; | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 撤销按钮 | ||||
|     eidFun(val) { | ||||
|       this.delObj = val; | ||||
|       this.delDialog = true; | ||||
|     }, | ||||
|     // 确认撤销按钮 | ||||
|     delClick() { | ||||
|       console.log(this.delObj); | ||||
|       rollback({ recordId: this.delObj.id }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message || "撤销成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|           this.delDialog = false; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										325
									
								
								src/views/nobleman/GoldWater.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										325
									
								
								src/views/nobleman/GoldWater.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,325 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 时间选择器 --> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">日期</span> | ||||
|         <el-date-picker | ||||
|           v-model="inquire.time" | ||||
|           type="daterange" | ||||
|           range-separator="至" | ||||
|           start-placeholder="开始日期" | ||||
|           end-placeholder="结束日期" | ||||
|         > | ||||
|         </el-date-picker> | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">会长分区</span> | ||||
|         <el-select | ||||
|           v-model="inquire.partitionId" | ||||
|           style="width: 75%" | ||||
|           placeholder="请选择" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in inquire.inquireonInfos" | ||||
|             :key="item.id" | ||||
|             :label="item.desc" | ||||
|             :value="item.id" | ||||
|           ></el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 公会ID --> | ||||
|     <div class="inquire"> | ||||
|       <span>会长ID</span> | ||||
|       <el-input v-model="inquire.id" placeholder="" class="input"></el-input> | ||||
|     </div> | ||||
|     <!-- 公会 --> | ||||
|     <div class="inquire"> | ||||
|       <span>公会名称</span> | ||||
|       <el-input | ||||
|         v-model="inquire.nick" | ||||
|         placeholder="支持模糊查询" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" type="primary" @click="getData()" | ||||
|       >查询</el-button | ||||
|     > | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" type="primary" @click="deriveFun()" | ||||
|       >导出</el-button | ||||
|     > | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="ownerErbanNo" align="center" label="会长ID" /> | ||||
|       <el-table-column prop="name" align="center" label="公会名称" /> | ||||
|       <el-table-column | ||||
|         prop="ownerPartitionName" | ||||
|         align="center" | ||||
|         label="会长分区" | ||||
|       /> | ||||
|       <el-table-column prop="memberNum" align="center" label="成员数" /> | ||||
|       <el-table-column | ||||
|         prop="goldIncome" | ||||
|         align="center" | ||||
|         label="月金币收入(流水)" | ||||
|       /> | ||||
|       <el-table-column | ||||
|         prop="hasGoldIncomeMemberNum" | ||||
|         align="center" | ||||
|         label="有流水成员数" | ||||
|       /> | ||||
|       <el-table-column prop="sendGiftUserNum" align="center" label="送礼人数" /> | ||||
|       <el-table-column align="center" label="操作"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button @click="ediClick(scope.row)" type="text" size="default" | ||||
|             >查看详情</el-button | ||||
|           > | ||||
|           <el-button @click="deriveFun2(scope.row)" type="text" size="default" | ||||
|             >导出</el-button | ||||
|           > | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|  | ||||
|     <!-- 内嵌单个工会详情 --> | ||||
|     <el-dialog :title="detailsTitle" v-model="detailsDialog"> | ||||
|       <el-table | ||||
|         v-loading="loading" | ||||
|         :data="tableDataDetails" | ||||
|         border | ||||
|         style="width: 100%; margin-top: 25px" | ||||
|       > | ||||
|         <el-table-column prop="erbanNo" align="center" label="用户平台ID" | ||||
|           ><template v-slot="scope"> | ||||
|             {{ | ||||
|               scope.row.enable ? scope.row.erbanNo : scope.row.erbanNo + "离开" | ||||
|             }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column prop="nick" align="center" label="用户昵称" /> | ||||
|         <el-table-column prop="micRemainTime" align="center" label="直播时长" /> | ||||
|         <el-table-column | ||||
|           prop="goldIncome" | ||||
|           align="center" | ||||
|           label="金币收入(流水)" | ||||
|         /> | ||||
|         <el-table-column | ||||
|           prop="sendGiftUserNum" | ||||
|           align="center" | ||||
|           label="送礼人数" | ||||
|         /> | ||||
|       </el-table> | ||||
|       <template #footer> | ||||
|         <div class="dialog-footer"> | ||||
|           <el-button @click="detailsDialog = false">关闭</el-button> | ||||
|           <el-button type="primary" @click="incomeExportFamilyFun()" | ||||
|             >导出</el-button | ||||
|           > | ||||
|         </div></template | ||||
|       > | ||||
|     </el-dialog> | ||||
|  | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   incomePageFamily, | ||||
|   incomeListFamilyMember, | ||||
|   incomeExportFamily, | ||||
|   incomeExportFamilys, | ||||
| } from "@/api/nobleman/nobleman"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "GoldWater", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         time: this.calculateLastSevenDays(), | ||||
|         id: "", | ||||
|         nick: "", | ||||
|         partitionId: 2, | ||||
|         inquireonInfos: [ | ||||
|           { desc: "英语区", id: 1 }, | ||||
|           { desc: "阿拉伯区", id: 2 }, | ||||
|           { desc: "华语区", id: 4 }, | ||||
|         ], | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 分页 | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|       // 内嵌单个公会详情 | ||||
|       detailsDialog: false, | ||||
|       detailsTitle: "", | ||||
|       tableDataDetails: [], | ||||
|       familyIdEx: "", | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       incomePageFamily({ | ||||
|         erbanNo: this.inquire.id, | ||||
|         familyName: this.inquire.nick, | ||||
|         partitionId: this.inquire.partitionId, | ||||
|         startDate: startTime, | ||||
|         endDate: endTime, | ||||
|         pageNum: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         this.total = res.data.total; | ||||
|         this.tableData = res.data.rows; | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 导出总外列表 | ||||
|     deriveFun(val) { | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       incomeExportFamilys({ | ||||
|         startDate: startTime, | ||||
|         endDate: endTime, | ||||
|         erbanNo: this.inquire.id, | ||||
|         familyName: this.inquire.nick, | ||||
|         partitionId: this.inquire.partitionId, | ||||
|       }).then((res) => {}); | ||||
|     }, | ||||
|     // 导出列表最外层 | ||||
|     deriveFun2(val) { | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       incomeExportFamily({ | ||||
|         familyId: val.id, | ||||
|         startDate: startTime, | ||||
|         endDate: endTime, | ||||
|       }).then((res) => {}); | ||||
|       this.detailsDialog = false; | ||||
|     }, | ||||
|     // 默认七天 | ||||
|     calculateLastSevenDays() { | ||||
|       const end = new Date(); | ||||
|       const start = new Date(); | ||||
|       start.setTime(start.getTime() - 3600 * 1000 * 24 * 6); | ||||
|       return [start, end]; | ||||
|     }, | ||||
|     // 查看详情按钮 | ||||
|     ediClick(val) { | ||||
|       this.detailsTitle = `公会昵称:【${val.name}】 时间:【${val.createTime}】—金币收入明细`; | ||||
|       let time = this.inquire.time; | ||||
|       let startDate = ""; | ||||
|       let endDate = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startDate = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endDate = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       this.familyIdEx = val.id; | ||||
|       incomeListFamilyMember({ | ||||
|         endDate, | ||||
|         startDate, | ||||
|         familyId: val.id, | ||||
|       }).then((res) => { | ||||
|         this.tableDataDetails = res.data; | ||||
|         this.detailsDialog = true; | ||||
|       }); | ||||
|     }, | ||||
|     // 导出按钮 | ||||
|     incomeExportFamilyFun() { | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       incomeExportFamily({ | ||||
|         familyId: this.familyIdEx, | ||||
|         startDate: startTime, | ||||
|         endDate: endTime, | ||||
|       }).then((res) => {}); | ||||
|       this.detailsDialog = false; | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
| @@ -3,120 +3,186 @@ | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>ID</span> | ||||
|       <el-input v-model="inquire.userId" | ||||
|                 placeholder="" | ||||
|                 class="input"></el-input> | ||||
|       <el-input | ||||
|         v-model="inquire.userId" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <span>推荐人</span> | ||||
|       <el-input v-model="inquire.referrer" | ||||
|                 placeholder="" | ||||
|                 class="input"></el-input> | ||||
|       <el-input | ||||
|         v-model="inquire.referrer" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <!-- 时间选择器 --> | ||||
|     <div class="inquire"> | ||||
|     <!-- <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">日期</span> | ||||
|         <el-date-picker v-model="inquire.time" | ||||
|                         type="datetimerange" | ||||
|                         range-separator="至" | ||||
|                         start-placeholder="开始日期" | ||||
|                         end-placeholder="结束日期"> | ||||
|         <el-date-picker | ||||
|           v-model="inquire.time" | ||||
|           type="datetimerange" | ||||
|           range-separator="至" | ||||
|           start-placeholder="开始日期" | ||||
|           end-placeholder="结束日期" | ||||
|         > | ||||
|         </el-date-picker> | ||||
|       </div> | ||||
|     </div> | ||||
|     </div> --> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" | ||||
|                type="primary" | ||||
|                @click="getData()">查询</el-button> | ||||
|     <el-button class="primary" | ||||
|                type="primary" | ||||
|                @click="addDialog = true">添加</el-button> | ||||
|     <el-button class="primary" type="primary" @click="getData()" | ||||
|       >查询</el-button | ||||
|     > | ||||
|     <el-button class="primary" type="primary" @click="addDialog = true" | ||||
|       >添加</el-button | ||||
|     > | ||||
|     <el-button class="primary" type="primary" @click="exportInfoFun()" | ||||
|       >导出</el-button | ||||
|     > | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table v-loading="loading" | ||||
|               :data="tableData" | ||||
|               border | ||||
|               style="width: 100%; margin-top: 25px"> | ||||
|       <el-table-column prop="referrer" | ||||
|                        align="center" | ||||
|                        label="推荐人" /> | ||||
|       <el-table-column prop="ownerErbanNo" | ||||
|                        align="center" | ||||
|                        label="会长ID" /> | ||||
|       <el-table-column prop="ownerNick" | ||||
|                        align="center" | ||||
|                        label="会长昵称" /> | ||||
|       <el-table-column prop="ownerPartitionName" | ||||
|                        align="center" | ||||
|                        label="会长分区" /> | ||||
|       <el-table-column prop="name" | ||||
|                        align="center" | ||||
|                        label="公会昵称" /> | ||||
|       <el-table-column align="center" | ||||
|                        prop="giftInfo" | ||||
|                        label="公会背景图"> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="referrer" align="center" label="推荐人" /> | ||||
|       <el-table-column prop="ownerErbanNo" align="center" label="会长ID" /> | ||||
|       <el-table-column prop="ownerNick" align="center" label="会长昵称" /> | ||||
|       <el-table-column | ||||
|         prop="ownerPartitionName" | ||||
|         align="center" | ||||
|         label="会长分区" | ||||
|       /> | ||||
|       <el-table-column prop="name" align="center" label="公会昵称" /> | ||||
|       <el-table-column align="center" prop="giftInfo" label="公会头像"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-image style="width: 100px; height: 100px" | ||||
|                     :src="scope.row.backgroundUrl" | ||||
|                     :zoom-rate="1.1" | ||||
|                     :preview-src-list="[scope.row.backgroundUrl]" | ||||
|                     fit="cover" | ||||
|                     preview-teleported="true" | ||||
|                     hide-on-click-modal="true" /> | ||||
|           <el-image | ||||
|             style="width: 100px; height: 100px" | ||||
|             :src="scope.row.avatar" | ||||
|             :zoom-rate="1.1" | ||||
|             :preview-src-list="[scope.row.avatar]" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|           /> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="createTime" | ||||
|                        align="center" | ||||
|                        label="创建日期" /> | ||||
|       <!-- <el-table-column prop="memberNum" align="center" label="成员数量" /> --> | ||||
|       <el-table-column align="center" | ||||
|                        label="成员数量/上限"><template v-slot="scope">{{ scope.row.memberNum }}/{{ scope.row.memberNumLimit }}</template></el-table-column> | ||||
|       <el-table-column prop="goldIncome" | ||||
|                        align="center" | ||||
|                        label="金币总收入" /> | ||||
|       <el-table-column prop="diamondRemain" | ||||
|                        align="center" | ||||
|                        label="钻石总收入" /> | ||||
|  | ||||
|       <el-table-column align="center" | ||||
|                        label="操作" | ||||
|                        width="300"> | ||||
|       <el-table-column align="center" prop="giftInfo" label="公会背景图"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button @click="ediClick(scope)" | ||||
|                      class="primary" | ||||
|                      type="primary" | ||||
|                      size="default" | ||||
|                      :disabled="!scope.row.enable">编辑</el-button> | ||||
|           <el-button @click=" | ||||
|           <el-image | ||||
|             style="width: 100px; height: 100px" | ||||
|             :src="scope.row.backgroundUrl" | ||||
|             :zoom-rate="1.1" | ||||
|             :preview-src-list="[scope.row.backgroundUrl]" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|           /> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="createTime" align="center" label="创建日期" /> | ||||
|       <!-- <el-table-column prop="memberNum" align="center" label="成员数量" /> --> | ||||
|       <el-table-column align="center" label="成员数量/上限"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="memberDialogFun(scope.row)" | ||||
|             type="text" | ||||
|             size="default" | ||||
|             >{{ scope.row.memberNum }}/{{ scope.row.memberNumLimit }}</el-button | ||||
|           > | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="收款账户" width="300"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="payAccountDialogFun(scope.row)" | ||||
|             type="text" | ||||
|             size="medium " | ||||
|           > | ||||
|             payoneer:{{ | ||||
|               scope.row.payAccount.payoneer | ||||
|                 ? scope.row.payAccount.payoneer | ||||
|                 : "未添加" | ||||
|             }} </el-button | ||||
|           ><br /> | ||||
|           <el-button | ||||
|             @click="payAccountDialogFun(scope.row)" | ||||
|             type="text" | ||||
|             size="medium " | ||||
|           > | ||||
|             USDT-ERC20:{{ | ||||
|               scope.row.payAccount.usdt ? scope.row.payAccount.usdt : "未添加" | ||||
|             }} </el-button | ||||
|           ><br /> | ||||
|           <el-button | ||||
|             @click="payAccountDialogFun(scope.row)" | ||||
|             type="text" | ||||
|             size="medium " | ||||
|           > | ||||
|             PayPal:{{ | ||||
|               scope.row.payAccount.payPal | ||||
|                 ? scope.row.payAccount.payPal | ||||
|                 : "未添加" | ||||
|             }} </el-button | ||||
|           ><br /> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <!-- <el-table-column prop="goldIncome" align="center" label="金币总收入" /> | ||||
|       <el-table-column prop="diamondRemain" align="center" label="钻石总收入" /> --> | ||||
|  | ||||
|       <el-table-column align="center" label="操作" width="300"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="ediClick(scope)" | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             size="default" | ||||
|             :disabled="!scope.row.enable" | ||||
|             >编辑</el-button | ||||
|           > | ||||
|           <el-button | ||||
|             @click=" | ||||
|               delDialog = true; | ||||
|               delDialogData = scope.row; | ||||
|             " | ||||
|                      :class="scope.row.enable ? 'danger' : 'info'" | ||||
|                      :type="scope.row.enable ? 'danger' : 'info'" | ||||
|                      size="default" | ||||
|                      :disabled="!scope.row.enable">{{ scope.row.enable ? "移除" : "已解散" }}</el-button> | ||||
|             :class="scope.row.enable ? 'danger' : 'info'" | ||||
|             :type="scope.row.enable ? 'danger' : 'info'" | ||||
|             size="default" | ||||
|             :disabled="!scope.row.enable" | ||||
|             >{{ scope.row.enable ? "移除" : "已解散" }}</el-button | ||||
|           > | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|     <!-- 新增弹窗 --> | ||||
|     <el-dialog v-model="addDialog" | ||||
|                title="新增" | ||||
|                width="28%" | ||||
|                center> | ||||
|     <el-dialog v-model="addDialog" title="新增" width="28%" center> | ||||
|       <div style="margin-bottom: 25px"> | ||||
|         <span style="display: inline-block; margin-right: 20px; width: 100px" | ||||
|               class="col-sm-2 control-label">会长ID</span> | ||||
|         <el-input v-model="resource.id" | ||||
|                   style="width: 75%" | ||||
|                   class="input"></el-input> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px; width: 100px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >会长ID</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="resource.id" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <div style="margin-bottom: 25px"> | ||||
|         <span style="display: inline-block; margin-right: 20px; width: 100px" | ||||
|               class="col-sm-2 control-label">推荐人</span> | ||||
|         <el-input v-model="resource.referrer" | ||||
|                   style="width: 75%" | ||||
|                   class="input"></el-input> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px; width: 100px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >推荐人</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="resource.referrer" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <!-- <div style="margin-bottom: 25px"> | ||||
|         <span | ||||
| @@ -133,96 +199,290 @@ | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="addDialog = false">取消</el-button> | ||||
|           <el-button type="primary" | ||||
|                      @click="add()"> 确认 </el-button> | ||||
|           <el-button type="primary" @click="add()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination style="margin-top: 10px" | ||||
|                    class="paginationClass" | ||||
|                    v-model:current-page="currentPage" | ||||
|                    v-model:page-size="pageSize" | ||||
|                    :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|                    layout="sizes, prev, pager, next" | ||||
|                    :total="total" | ||||
|                    @size-change="handleSizeChange" | ||||
|                    @current-change="handleCurrentChange" /> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|     <!-- 编辑弹窗 --> | ||||
|     <el-dialog v-model="editDialog" | ||||
|                title="编辑" | ||||
|                width="28%" | ||||
|                center> | ||||
|     <el-dialog v-model="editDialog" title="编辑" width="28%" center> | ||||
|       <!-- 会长ID --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">会长ID</span> | ||||
|         <el-input v-model="ediObj.leaderId" | ||||
|                   style="width: 75%" | ||||
|                   class="input" | ||||
|                   disabled></el-input> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >会长ID</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="ediObj.leaderId" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <!-- 会长昵称 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">会长昵称</span> | ||||
|         <el-input v-model="ediObj.leaderNick" | ||||
|                   style="width: 75%" | ||||
|                   class="input" | ||||
|                   disabled></el-input> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >会长昵称</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="ediObj.leaderNick" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <!-- 公会昵称 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">公会昵称</span> | ||||
|         <el-input v-model="ediObj.guildNick" | ||||
|                   style="width: 75%" | ||||
|                   class="input" | ||||
|                   disabled></el-input> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >公会昵称</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="ediObj.guildNick" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <!-- 公会头像 --> | ||||
|       <div class="selectBox selectBoxImg"> | ||||
|         <span class="left" style="margin-right: 20px">公会头像</span> | ||||
|         <!-- action="/admin/tencent/cos/upload/file" --> | ||||
|         <el-upload | ||||
|           class="avatar-uploader" | ||||
|           action="/admin/tencent/cos/upload/file" | ||||
|           :show-file-list="false" | ||||
|           :on-success="handleAvatarSuccess2" | ||||
|           :before-upload="beforeAvatarUpload" | ||||
|           :on-error="handleAvatarError" | ||||
|         > | ||||
|           <img v-if="ediObj.imageUrl2" :src="ediObj.imageUrl2" class="avatar" /> | ||||
|           <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|         </el-upload> | ||||
|       </div> | ||||
|       <!-- 公会背景图 --> | ||||
|       <div class="selectBox selectBoxImg"> | ||||
|         <span class="left" style="margin-right: 20px">公会背景图</span> | ||||
|         <!-- action="/admin/tencent/cos/upload/file" --> | ||||
|         <el-upload | ||||
|           class="avatar-uploader" | ||||
|           action="/admin/tencent/cos/upload/file" | ||||
|           :show-file-list="false" | ||||
|           :on-success="handleAvatarSuccess" | ||||
|           :before-upload="beforeAvatarUpload" | ||||
|           :on-error="handleAvatarError" | ||||
|         > | ||||
|           <img v-if="ediObj.imageUrl1" :src="ediObj.imageUrl1" class="avatar" /> | ||||
|           <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|         </el-upload> | ||||
|       </div> | ||||
|       <!-- 成员数量上限 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span style="display: inline-block; margin-right: 20px" | ||||
|               class="col-sm-2 control-label">成员数量上限</span> | ||||
|         <el-input v-model="ediObj.guildNumber" | ||||
|                   style="width: 75%" | ||||
|                   class="input"></el-input> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >成员数量上限</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="ediObj.guildNumber" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="editDialog = false">取消</el-button> | ||||
|           <el-button type="primary" | ||||
|                      @click="editDialogClick()"> | ||||
|           <el-button type="primary" @click="editDialogClick()"> | ||||
|             确认 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 二次确认删除弹窗 --> | ||||
|     <el-dialog v-model="delDialog" | ||||
|                title="提示" | ||||
|                width="30%" | ||||
|                center> | ||||
|     <el-dialog v-model="delDialog" title="提示" width="30%" center> | ||||
|       <span> 确定要解散该公会吗?</span> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="delDialog = false">取消</el-button> | ||||
|           <el-button type="primary" | ||||
|                      @click="delClick()"> 确认 </el-button> | ||||
|           <el-button type="primary" @click="delClick()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 编辑收款账户弹窗 --> | ||||
|     <el-dialog | ||||
|       v-model="payAccountDialog" | ||||
|       :title="payAccountTitle" | ||||
|       width="28%" | ||||
|       center | ||||
|     > | ||||
|       <!-- Payoneer --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >Payoneer</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="payAccount.payoneer" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <!-- USDT-ERC20 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >USDT-ERC20</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="payAccount.usdt" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <!-- PayPal --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >PayPal</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="payAccount.payPal" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="payAccountDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="payAccountClick()"> | ||||
|             保存 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 编辑成员弹窗 --> | ||||
|     <el-dialog v-model="memberDialog" :title="memberTitle" width="36%" center> | ||||
|       <!-- 新增用户 --> | ||||
|       <div class="inquire"> | ||||
|         <span>平台ID</span> | ||||
|         <el-input | ||||
|           v-model="member.userID" | ||||
|           placeholder="请输入新增平台id" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|         <el-button type="primary" @click="addMemberFun()"> 新增 </el-button> | ||||
|       </div> | ||||
|       <!-- 内嵌表格 --> | ||||
|       <el-table | ||||
|         v-loading="loading" | ||||
|         :data="member.tableData" | ||||
|         border | ||||
|         style="width: 100%; margin-top: 25px" | ||||
|       > | ||||
|         <el-table-column align="center" label="用户平台ID"> | ||||
|           <template v-slot="scope"> | ||||
|             {{ scope.row.erbanNo | ||||
|             }}{{ | ||||
|               scope.row.roleType == 1 | ||||
|                 ? "(会长)" | ||||
|                 : scope.row.roleType == 2 | ||||
|                 ? "(管理员)" | ||||
|                 : "" | ||||
|             }} | ||||
|             {{ scope.row.enable == false ? "(已离开)" : "" }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column prop="nick" align="center" label="用户昵称" /> | ||||
|         <el-table-column prop="createTime" align="center" label="加入时间" /> | ||||
|         <el-table-column align="center" label="操作" width="300"> | ||||
|           <template v-slot="scope"> | ||||
|             <el-button | ||||
|               @click="setMemberFun(scope.row)" | ||||
|               :class="scope.row.roleType == 2 ? 'danger' : 'primary'" | ||||
|               :type="scope.row.roleType == 2 ? 'danger' : 'primary'" | ||||
|               size="default" | ||||
|               :disabled="scope.row.roleType == 1 ? true : false" | ||||
|               >{{ | ||||
|                 scope.row.roleType == 1 | ||||
|                   ? "会长" | ||||
|                   : scope.row.roleType == 2 | ||||
|                   ? "取消管理员" | ||||
|                   : "设为管理员" | ||||
|               }}</el-button | ||||
|             > | ||||
|             <el-button | ||||
|               @click=" | ||||
|                 memberRemoveObj = scope.row; | ||||
|                 memberRemoveDialog = true; | ||||
|               " | ||||
|               class="danger" | ||||
|               type="danger" | ||||
|               size="default" | ||||
|               :disabled="scope.row.roleType == 1 ? true : false" | ||||
|               >删除</el-button | ||||
|             > | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|       </el-table> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button type="primary" @click="memberDialog = false"> | ||||
|             关闭 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 二次确认删除弹窗 --> | ||||
|     <el-dialog v-model="memberRemoveDialog" title="提示" width="30%" center> | ||||
|       <span> 确定要删除该成员吗?</span> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="memberRemoveDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="delmemberRemoveClick()"> | ||||
|             确认 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { pageFamily, create, update, dismiss } from "@/api/nobleman/nobleman"; | ||||
| import { | ||||
|   pageFamily, | ||||
|   exportInfo, | ||||
|   create, | ||||
|   update, | ||||
|   dismiss, | ||||
|   savePayAccount, | ||||
|   manageListFamilyMember, | ||||
|   addMember, | ||||
|   setManager, | ||||
|   removeMember, | ||||
| } from "@/api/nobleman/nobleman"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "GuildInfo", | ||||
|   data () { | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       delDialog: false, | ||||
| @@ -255,15 +515,37 @@ export default { | ||||
|         guildNick: "", | ||||
|         guildNumber: "", | ||||
|         id: "", | ||||
|         imageUrl1: "", | ||||
|         imageUrl2: "", | ||||
|       }, | ||||
|       // 收款账户弹窗 | ||||
|       payAccountDialog: false, | ||||
|       payAccountTitle: "(会长昵称【ID:0】)的收款账户", | ||||
|       payAccountNew: {}, | ||||
|       payAccount: { | ||||
|         payoneer: "", | ||||
|         usdt: "", | ||||
|         payPal: "", | ||||
|       }, | ||||
|       // 新增成员弹窗 | ||||
|       memberDialog: false, | ||||
|       memberTitle: "【公会名称】成员信息", | ||||
|       memberNew: {}, | ||||
|       member: { | ||||
|         userID: "", | ||||
|         tableData: [], | ||||
|       }, | ||||
|       // 删除成员弹窗 | ||||
|       memberRemoveDialog: false, | ||||
|       memberRemoveObj: {}, | ||||
|     }; | ||||
|   }, | ||||
|   created () { | ||||
|   created() { | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData () { | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
| @@ -276,8 +558,8 @@ export default { | ||||
|         erbanNo: this.inquire.userId, | ||||
|         referrer: this.inquire.referrer, | ||||
|         familyName: this.inquire.nick, | ||||
|         startDate: startTime, | ||||
|         endDate: endTime, | ||||
|         // startDate: startTime, | ||||
|         // endDate: endTime, | ||||
|         pageNum: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
| @@ -286,8 +568,151 @@ export default { | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 打开成员信息弹窗 | ||||
|     memberDialogFun(val) { | ||||
|       var than = this; | ||||
|       than.memberTitle = `【${val.name}】成员信息`; | ||||
|       than.memberNew = val; | ||||
|       manageListFamilyMember({ | ||||
|         familyId: val.id, | ||||
|       }).then((res) => { | ||||
|         this.member.tableData = res.data; | ||||
|         than.memberDialog = true; | ||||
|       }); | ||||
|     }, | ||||
|     // 二次确认删除成员 | ||||
|     delmemberRemoveClick() { | ||||
|       removeMember({ | ||||
|         familyMemberId: this.memberRemoveObj.familyMemberId, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "删除成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           manageListFamilyMember({ | ||||
|             familyId: this.memberNew.id, | ||||
|           }).then((res) => { | ||||
|             this.member.tableData = res.data; | ||||
|           }); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.memberRemoveDialog = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 设置管理员 | ||||
|     setMemberFun(val) { | ||||
|       setManager({ | ||||
|         familyMemberId: val.familyMemberId, | ||||
|         status: val.roleType == 3 ? true : val.roleType == 2 ? false : null, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "设置成功!", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.member.userID = ""; | ||||
|           manageListFamilyMember({ | ||||
|             familyId: this.memberNew.id, | ||||
|           }).then((res) => { | ||||
|             this.member.tableData = res.data; | ||||
|           }); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 新增成员 | ||||
|     addMemberFun() { | ||||
|       addMember({ | ||||
|         erbanNo: this.member.userID, | ||||
|         familyId: this.memberNew.id, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "保存成功!", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.member.userID = ""; | ||||
|           manageListFamilyMember({ | ||||
|             familyId: this.memberNew.id, | ||||
|           }).then((res) => { | ||||
|             this.member.tableData = res.data; | ||||
|           }); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "保存失败!", | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 打开收款账户弹窗 | ||||
|     payAccountDialogFun(val) { | ||||
|       this.payAccountTitle = `(${val.ownerNick}【ID:${val.ownerErbanNo}】)的收款账户`; | ||||
|       this.payAccount.payoneer = val.payAccount.payoneer; | ||||
|       this.payAccount.usdt = val.payAccount.usdt; | ||||
|       this.payAccount.payPal = val.payAccount.payPal; | ||||
|       this.payAccountDialog = true; | ||||
|       this.payAccountNew = val; | ||||
|     }, | ||||
|     // 保存收款账户 | ||||
|     payAccountClick() { | ||||
|       savePayAccount({ | ||||
|         id: this.payAccountNew.payAccount.familyId, | ||||
|         payPal: this.payAccount.payPal, | ||||
|         payoneer: this.payAccount.payoneer, | ||||
|         usdt: this.payAccount.usdt, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "保存成功!", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.payAccountDialog = false; | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "保存失败!", | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 导出 | ||||
|     exportInfoFun() { | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       exportInfo({ | ||||
|         erbanNo: this.inquire.userId, | ||||
|         referrer: this.inquire.referrer, | ||||
|         familyName: this.inquire.nick, | ||||
|         // startDate: startTime, | ||||
|         // endDate: endTime, | ||||
|       }).then((res) => {}); | ||||
|     }, | ||||
|     // 添加 | ||||
|     add () { | ||||
|     add() { | ||||
|       this.addDialog = false; | ||||
|       create({ | ||||
|         erbanNo: this.resource.id, | ||||
| @@ -297,21 +722,26 @@ export default { | ||||
|       }); | ||||
|     }, | ||||
|     // 编辑按钮 | ||||
|     ediClick (res) { | ||||
|     ediClick(res) { | ||||
|       var obj = res.row; | ||||
|       this.ediObj.leaderId = obj.ownerErbanNo; | ||||
|       this.ediObj.leaderNick = obj.ownerNick; | ||||
|       this.ediObj.guildNick = obj.name; | ||||
|       this.ediObj.guildNumber = obj.memberNumLimit; | ||||
|       this.ediObj.id = obj.id; | ||||
|       this.ediObj.imageUrl1 = obj.backgroundUrl; | ||||
|       this.ediObj.imageUrl2 = obj.avatar; | ||||
|       this.editDialog = true; | ||||
|     }, | ||||
|     // 二次确认弹窗 | ||||
|     editDialogClick () { | ||||
|     editDialogClick() { | ||||
|       console.log(this.ediObj); | ||||
|       update({ | ||||
|         id: this.ediObj.id, | ||||
|         memberNumLimit: this.ediObj.guildNumber, | ||||
|         backgroundUrl: this.ediObj.imageUrl1, | ||||
|         avatar: this.ediObj.imageUrl2, | ||||
|         name: this.ediObj.guildNick, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
| @@ -332,7 +762,7 @@ export default { | ||||
|       }); | ||||
|     }, | ||||
|     // 解散按钮 | ||||
|     delClick () { | ||||
|     delClick() { | ||||
|       console.log(this.delDialogData.id); | ||||
|       var familyId = this.delDialogData.id; | ||||
|       dismiss({ familyId }).then((res) => { | ||||
| @@ -354,11 +784,45 @@ export default { | ||||
|         this.delDialog = false; | ||||
|       }); | ||||
|     }, | ||||
|     beforeAvatarUpload() { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传中~", | ||||
|         type: "warning", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarError() { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传失败!", | ||||
|         type: "error", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess2(res, file) { | ||||
|       console.log(file); | ||||
|       // this.ediObj.imageUrl1 = URL.createObjectURL(); | ||||
|       this.ediObj.imageUrl2 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess(res, file) { | ||||
|       console.log(file); | ||||
|       // this.ediObj.imageUrl1 = URL.createObjectURL(); | ||||
|       this.ediObj.imageUrl1 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange () { | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange () { | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| @@ -387,4 +851,13 @@ export default { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| .selectBox { | ||||
|   display: flex; | ||||
|   height: 35px; | ||||
|   line-height: 35px; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| .selectBoxImg { | ||||
|   height: 150px; | ||||
| } | ||||
| </style> | ||||
|   | ||||
| @@ -50,6 +50,19 @@ | ||||
|       <el-table-column prop="ownerErbanNo" align="center" label="会长ID" /> | ||||
|       <el-table-column prop="ownerNick" align="center" label="会长昵称" /> | ||||
|       <el-table-column prop="name" align="center" label="公会昵称" /> | ||||
|       <el-table-column align="center" prop="giftInfo" label="公会头像"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-image | ||||
|             style="width: 100px; height: 100px" | ||||
|             :src="scope.row.avatar" | ||||
|             :zoom-rate="1.1" | ||||
|             :preview-src-list="[scope.row.avatar]" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|           /> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" prop="giftInfo" label="公会背景图"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-image | ||||
| @@ -57,7 +70,7 @@ | ||||
|             :src="scope.row.backgroundUrl" | ||||
|             :zoom-rate="1.1" | ||||
|             :preview-src-list="[scope.row.backgroundUrl]" | ||||
|             fit="cover" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|           /> | ||||
|   | ||||
							
								
								
									
										398
									
								
								src/views/nobleman/WagesCount.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										398
									
								
								src/views/nobleman/WagesCount.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,398 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 时间选择器 --> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">日期</span> | ||||
|         <el-config-provider :locale="zhCn"> | ||||
|           <el-date-picker v-model="inquire.time" | ||||
|                           type="month" | ||||
|                           placeholder="选择月"> | ||||
|           </el-date-picker></el-config-provider> | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">会长分区</span> | ||||
|         <el-select v-model="inquire.partitionId" | ||||
|                    style="width: 75%" | ||||
|                    placeholder="请选择"> | ||||
|           <el-option v-for="item in inquire.inquireonInfos" | ||||
|                      :key="item.id" | ||||
|                      :label="item.desc" | ||||
|                      :value="item.id"></el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|     </div> | ||||
|  | ||||
|     <!-- 公会 --> | ||||
|     <div class="inquire"> | ||||
|       <span>会长ID</span> | ||||
|       <el-input v-model="inquire.nick" | ||||
|                 placeholder="" | ||||
|                 class="input"></el-input> | ||||
|     </div> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" | ||||
|                type="primary" | ||||
|                @click="getData()">查询</el-button> | ||||
|     <!-- 导出 --> | ||||
|     <el-button class="primary" | ||||
|                type="primary" | ||||
|                @click="deriveFun()">导出</el-button> | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table v-loading="loading" | ||||
|               :data="tableData" | ||||
|               border | ||||
|               style="width: 100%; margin-top: 25px"> | ||||
|       <el-table-column prop="ownerErbanNo" | ||||
|                        align="center" | ||||
|                        label="会长ID" /> | ||||
|       <el-table-column prop="name" | ||||
|                        align="center" | ||||
|                        label="公会名称" /> | ||||
|       <el-table-column prop="ownerPartitionName" | ||||
|                        align="center" | ||||
|                        label="会长分区" /> | ||||
|       <el-table-column prop="enable" | ||||
|                        align="center" | ||||
|                        label="是否有效状态"> | ||||
|         <template v-slot="scope">{{ scope.row.enable? '是': '否' }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="memberNum" | ||||
|                        align="center" | ||||
|                        label="成员数" /> | ||||
|       <el-table-column prop="goldIncome" | ||||
|                        align="center" | ||||
|                        label="月金币收入(流水)" /> | ||||
|       <el-table-column prop="goldWage" | ||||
|                        align="center" | ||||
|                        label="金币工资" /> | ||||
|       <el-table-column prop="agentWage" | ||||
|                        align="center" | ||||
|                        label="代理工资" /> | ||||
|       <el-table-column prop="diamondRemain" | ||||
|                        align="center" | ||||
|                        label="当前钻石余额"> | ||||
|         <template v-slot="scope">{{ scope.row.diamondRemain }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" | ||||
|                        label="操作" | ||||
|                        width="260"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button @click="ediClick(scope.row)" | ||||
|                      class="primary" | ||||
|                      type="primary" | ||||
|                      size="default">查看详情</el-button> | ||||
|           <el-button @click="deriveFun2(scope.row)" | ||||
|                      class="primary" | ||||
|                      type="primary" | ||||
|                      size="default">导出</el-button> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|  | ||||
|     <!-- 内嵌单个工会详情 --> | ||||
|     <el-dialog :title="detailsTitle" | ||||
|                v-model="detailsDialog"> | ||||
|       <el-table v-loading="loading" | ||||
|                 :data="tableDataDetails" | ||||
|                 border | ||||
|                 style="width: 100%; margin-top: 25px"> | ||||
|         <el-table-column prop="erbanNo" | ||||
|                          align="center" | ||||
|                          label="用户平台ID"> | ||||
|           <template v-slot="scope"> | ||||
|             {{ | ||||
|               scope.row.erbanNo == scope.row.familyOwnerErbanNo | ||||
|                 ? scope.row.erbanNo + "(会长)" | ||||
|                 : scope.row.enable | ||||
|                 ? scope.row.erbanNo | ||||
|                 : scope.row.erbanNo + "离开" | ||||
|             }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column prop="nick" | ||||
|                          align="center" | ||||
|                          label="用户昵称" /> | ||||
|         <el-table-column prop="micRemainTime" | ||||
|                          align="center" | ||||
|                          label="本月直播时长" /> | ||||
|         <el-table-column prop="micVaildDays" | ||||
|                          align="center" | ||||
|                          label="本月有效天数" /> | ||||
|         <el-table-column prop="goldIncome" | ||||
|                          align="center" | ||||
|                          label="月金币收入(流水)" /> | ||||
|         <el-table-column prop="goldWage" | ||||
|                          align="center" | ||||
|                          label="金币工资" /> | ||||
|         <el-table-column prop="agentWage" | ||||
|                          align="center" | ||||
|                          label="代理工资" /> | ||||
|         <el-table-column prop="diamondRemain" | ||||
|                          align="center" | ||||
|                          label="当前钻石余额" /> | ||||
|         <el-table-column align="center" | ||||
|                          label="操作"> | ||||
|           <template v-slot="scope"> | ||||
|             <el-button @click="detailsClick(scope.row)" | ||||
|                        class="primary" | ||||
|                        type="primary" | ||||
|                        size="default">查看详情</el-button> | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|       </el-table> | ||||
|       <template #footer> | ||||
|         <div class="dialog-footer"> | ||||
|           <el-button @click="detailsDialog = false">关闭</el-button> | ||||
|           <el-button type="primary" | ||||
|                      @click="detailsClickOut()">导出</el-button> | ||||
|         </div> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|  | ||||
|     <!-- 内嵌单个成员明细 --> | ||||
|     <el-dialog :title="detailsTitle2" | ||||
|                v-model="detailsDialog2"> | ||||
|       <el-table v-loading="loading" | ||||
|                 :data="tableDataDetails2" | ||||
|                 border | ||||
|                 style="width: 100%; margin-top: 25px"> | ||||
|         <el-table-column prop="date" | ||||
|                          align="center" | ||||
|                          label="日期" /> | ||||
|         <el-table-column prop="micRemainTime" | ||||
|                          align="center" | ||||
|                          label="直播时长" /> | ||||
|         <el-table-column prop="micVaild" | ||||
|                          align="center" | ||||
|                          label="是否有效天"> | ||||
|           <template v-slot="scope"> | ||||
|             {{ scope.row.micVaild ? "是" : "否" }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column prop="goldIncome" | ||||
|                          align="center" | ||||
|                          label="当日金币收入" /> | ||||
|         <el-table-column prop="savedGoldIncome" | ||||
|                          align="center" | ||||
|                          label="月累计金币收入" /> | ||||
|         <el-table-column prop="saveedGoldWage" | ||||
|                          align="center" | ||||
|                          label="月金币工资" /> | ||||
|         <el-table-column prop="diamondRemain" | ||||
|                          align="center" | ||||
|                          label="当日钻石余额" /> | ||||
|         <!-- <el-table-column align="center" label="操作"> | ||||
|           <template v-slot="scope"> | ||||
|             <el-button | ||||
|               @click="detailsClick2(scope)" | ||||
|               class="primary" | ||||
|               type="text" | ||||
|               size="default" | ||||
|               :disabled="!scope.row.enable" | ||||
|               >查看详情</el-button | ||||
|             > | ||||
|           </template> | ||||
|         </el-table-column> --> | ||||
|       </el-table> | ||||
|       <template #footer> | ||||
|         <div class="dialog-footer"> | ||||
|           <el-button @click="detailsDialog2 = false">关闭</el-button> | ||||
|           <el-button type="primary" | ||||
|                      @click="detailsClickOut2()">导出</el-button> | ||||
|         </div> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination style="margin-top: 10px" | ||||
|                    class="paginationClass" | ||||
|                    v-model:current-page="currentPage" | ||||
|                    v-model:page-size="pageSize" | ||||
|                    :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|                    layout="sizes, prev, pager, next" | ||||
|                    :total="total" | ||||
|                    @size-change="handleSizeChange" | ||||
|                    @current-change="handleCurrentChange" /> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import zhCn from "element-plus/dist/locale/zh-cn.mjs"; | ||||
| import { | ||||
|   statPageFamily, | ||||
|   listFamilyMember, | ||||
|   statExportFamilyMember, | ||||
|   listFamilyMemberDaily, | ||||
|   exportFamilyMemberDaily, | ||||
|   statExportFamily, | ||||
| } from "@/api/nobleman/nobleman"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "WagesCount", | ||||
|   data () { | ||||
|     return { | ||||
|       zhCn, | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         time: "", | ||||
|         nick: "", | ||||
|         partitionId: 2, | ||||
|         inquireonInfos: [ | ||||
|           { desc: "英语区", id: 1 }, | ||||
|           { desc: "阿拉伯区", id: 2 }, | ||||
|           { desc: "华语区", id: 4 }, | ||||
|         ], | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 分页 | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|       // 内嵌单个公会详情 | ||||
|       detailsDialog: false, | ||||
|       detailsTitle: "工会昵称 时间段 结算明细", | ||||
|       tableDataDetails: [], | ||||
|       detailsClickOutObj: {}, | ||||
|       // 内嵌单个公会详情2 | ||||
|       detailsDialog2: false, | ||||
|       detailsTitle2: "工会昵称 用户昵称(ID:0) 时间段 结算明细", | ||||
|       tableDataDetails2: [], | ||||
|       detailsClickOutObj2: {}, | ||||
|     }; | ||||
|   }, | ||||
|   created () { | ||||
|     // this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData () { | ||||
|       // this.loading = true; | ||||
|       let time = this.inquire.time; | ||||
|       if (time) { | ||||
|         time = dateFormat(this.inquire.time, "yyyy-MM"); | ||||
|       } | ||||
|       statPageFamily({ | ||||
|         erbanNo: this.inquire.nick, | ||||
|         partitionId: this.inquire.partitionId, | ||||
|         month: time, | ||||
|         pageNum: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         this.total = res.data.total; | ||||
|         this.tableData = res.data.rows; | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 导出总外列表 | ||||
|     deriveFun (val) { | ||||
|       let time = this.inquire.time; | ||||
|       if (time) { | ||||
|         time = dateFormat(this.inquire.time, "yyyy-MM"); | ||||
|       } | ||||
|       statExportFamily({ | ||||
|         erbanNo: this.inquire.nick, | ||||
|         month: time, | ||||
|         partitionId: this.inquire.partitionId, | ||||
|       }).then((res) => { }); | ||||
|     }, | ||||
|     // 导出列表最外层 | ||||
|     deriveFun2 (val) { | ||||
|       statExportFamilyMember({ | ||||
|         familyId: val.id, | ||||
|         month: dateFormat(this.inquire.time, "yyyy-MM"), | ||||
|       }); | ||||
|       this.detailsDialog = false; | ||||
|     }, | ||||
|     // 1层查看详情按钮 | ||||
|     ediClick (val) { | ||||
|       console.log(val); | ||||
|       var than = this; | ||||
|       this.detailsClickOutObj = val; | ||||
|       than.detailsTitle = `[${val.name}] [${dateFormat( | ||||
|         than.inquire.time, | ||||
|         "yyyy-MM" | ||||
|       )}]结算明细`; | ||||
|       listFamilyMember({ | ||||
|         familyId: val.id, | ||||
|         month: dateFormat(than.inquire.time, "yyyy-MM"), | ||||
|       }).then((res) => { | ||||
|         this.tableDataDetails = res.data; | ||||
|         this.detailsDialog = true; | ||||
|       }); | ||||
|     }, | ||||
|     // 导出最外层数据按钮 | ||||
|     detailsClickOut () { | ||||
|       statExportFamilyMember({ | ||||
|         familyId: this.detailsClickOutObj.id, | ||||
|         month: dateFormat(this.inquire.time, "yyyy-MM"), | ||||
|       }); | ||||
|       this.detailsDialog = false; | ||||
|     }, | ||||
|     // 嵌套详情按钮 | ||||
|     detailsClick (val) { | ||||
|       var than = this; | ||||
|       this.detailsClickOutObj2 = val; | ||||
|       than.detailsTitle2 = `公会名称:${val.familyName} 成员名称:${val.nick | ||||
|         }(ID:${val.erbanNo}) ${dateFormat( | ||||
|           than.inquire.time, | ||||
|           "yyyy-MM" | ||||
|         )} 结算明细`; | ||||
|       listFamilyMemberDaily({ | ||||
|         familyId: val.familyId, | ||||
|         month: dateFormat(than.inquire.time, "yyyy-MM"), | ||||
|         uid: val.uid, | ||||
|       }).then((res) => { | ||||
|         than.tableDataDetails2 = res.data; | ||||
|         than.detailsDialog2 = true; | ||||
|       }); | ||||
|     }, | ||||
|     // 导出每日成员数据 | ||||
|     detailsClickOut2 () { | ||||
|       exportFamilyMemberDaily({ | ||||
|         familyId: this.detailsClickOutObj2.id, | ||||
|         month: dateFormat(this.inquire.time, "yyyy-MM"), | ||||
|         uid: this.detailsClickOutObj2.uid, | ||||
|       }); | ||||
|       this.detailsDialog2 = false; | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange () { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange () { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										188
									
								
								src/views/nobleman/WaterSettlement.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										188
									
								
								src/views/nobleman/WaterSettlement.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,188 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" type="primary" @click="addDialog = true" | ||||
|       >新增</el-button | ||||
|     > | ||||
|     <el-tabs v-model="roleType" @click="handleClick" style="margin-top: 20px"> | ||||
|       <el-tab-pane label="金币工资" name="3"></el-tab-pane> | ||||
|       <el-tab-pane label="代理工资" name="1"></el-tab-pane> | ||||
|     </el-tabs> | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column | ||||
|         prop="level" | ||||
|         align="center" | ||||
|         label="金币目标(金币流水)" | ||||
|       /> | ||||
|       <el-table-column prop="wage" align="center" label="金币工资(USD)" /> | ||||
|       <el-table-column align="center" label="操作"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="delClick(scope.row)" | ||||
|             class="danger" | ||||
|             type="danger" | ||||
|             size="default" | ||||
|             >删除</el-button | ||||
|           > | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|  | ||||
|     <!-- 新增弹窗 --> | ||||
|     <el-dialog title="新增档位" v-model="addDialog" width="35%"> | ||||
|       <div class="inquire"> | ||||
|         <span>金币目标(金币流水)</span> | ||||
|         <el-input v-model="add.gold" placeholder="" class="input"></el-input> | ||||
|       </div> | ||||
|       <div class="inquire"> | ||||
|         <span>金币工资(USD)</span> | ||||
|         <el-input v-model="add.usdt" placeholder="" class="input"></el-input> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <div class="dialog-footer"> | ||||
|           <el-button @click="addDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="addShour()">保存</el-button> | ||||
|         </div></template | ||||
|       > | ||||
|     </el-dialog> | ||||
|  | ||||
|     <!-- 二次确认删除弹窗 --> | ||||
|     <el-dialog v-model="delDialog" title="提示" width="30%" center> | ||||
|       <span> 确定要删除吗?</span> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="delDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="dle()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { manageList, manageAdd, manageDelete } from "@/api/nobleman/nobleman"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "WaterSettlement", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       // 切换 | ||||
|       roleType: "3", | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       arr1: [], | ||||
|       arr2: [], | ||||
|       // 新增弹窗 | ||||
|       addDialog: false, | ||||
|       add: { | ||||
|         gold: "", | ||||
|         usdt: "", | ||||
|       }, | ||||
|       delDialog: false, | ||||
|       delObj: {}, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       manageList({ | ||||
|         roleType: this.roleType, | ||||
|       }).then((res) => { | ||||
|         this.tableData = res.data; | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     handleClick(tab, event) { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // 确认新增按钮 | ||||
|     addShour() { | ||||
|       manageAdd({ | ||||
|         roleType: this.roleType, | ||||
|         level: this.add.gold, | ||||
|         wage: this.add.usdt, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "新增成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|           this.addDialog = false; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 删除 | ||||
|     delClick(val) { | ||||
|       this.delObj = val; | ||||
|       this.delDialog = true; | ||||
|     }, | ||||
|     // 确认删除 | ||||
|     dle() { | ||||
|       manageDelete({ id: this.delObj.id }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "删除成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|           this.delDialog = false; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     width: 60%; | ||||
|     display: flex; | ||||
|     justify-content: space-between; | ||||
|     margin-bottom: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,155 +1,163 @@ | ||||
| <template> | ||||
|     <section class="content"> | ||||
|         <div class="box box-primary"> | ||||
|             <div class="box-body"> | ||||
|                 <div class="content-header"> | ||||
|                     <h1 id="itemTitle"></h1> | ||||
|                 </div> | ||||
|                 <div class="content"> | ||||
|                     <div id="table"></div> | ||||
|                     <div id="toolbar"> | ||||
|                         <label for="prettyNo" class="control-label">目标平台号:</label> | ||||
|                         <input type="text" name="goodNum" id="targetPrettyNo"> | ||||
|                         <label for="prettyNo" class="control-label">原平台号:</label> | ||||
|                         <input type="text" id="currentPrettyNo"> | ||||
|                         <label for="operator" class="control-label">操作类型:</label> | ||||
|                         <select name="status" id="operator" class="input-m"> | ||||
|                             <option value="">全部</option> | ||||
|                             <option value="1">绑定</option> | ||||
|                             <option value="2">解绑</option> | ||||
|                         </select> | ||||
|                         <button id="btnSearch" class="btn btn-sm btn-primary">查询</button> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
|   <section class="content"> | ||||
|     <div class="box box-primary"> | ||||
|       <div class="box-body"> | ||||
|         <div class="content-header"> | ||||
|           <h1 id="itemTitle"></h1> | ||||
|         </div> | ||||
|     </section> | ||||
|         <div class="content"> | ||||
|           <div id="table"></div> | ||||
|           <div id="toolbar"> | ||||
|             <label for="prettyNo" | ||||
|                    class="control-label">目标平台号:</label> | ||||
|             <input type="text" | ||||
|                    name="goodNum" | ||||
|                    id="targetPrettyNo"> | ||||
|             <label for="prettyNo" | ||||
|                    class="control-label">原平台号:</label> | ||||
|             <input type="text" | ||||
|                    id="currentPrettyNo"> | ||||
|             <label for="operator" | ||||
|                    class="control-label">操作类型:</label> | ||||
|             <select name="status" | ||||
|                     id="operator" | ||||
|                     class="input-m"> | ||||
|               <option value="">全部</option> | ||||
|               <option value="1">绑定</option> | ||||
|               <option value="2">解绑</option> | ||||
|             </select> | ||||
|             <button id="btnSearch" | ||||
|                     class="btn btn-sm btn-primary">查询</button> | ||||
|           </div> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
|  | ||||
| export default { | ||||
|     name: "PrettyNoRecordAdminView", | ||||
|     setup() { | ||||
|         return {}; | ||||
|     }, | ||||
|     created() { | ||||
|         this.$nextTick(function () { | ||||
|             this.initData(); | ||||
|         }); | ||||
|     }, | ||||
|     methods: { | ||||
|         initData() { | ||||
|             $(function () { | ||||
|                 $('#table').bootstrapTable('destroy'); | ||||
|                 $('#table').bootstrapTable({ | ||||
|                     columns: [ | ||||
|                         { field: 'id', title: 'ID', align: 'center', valign: 'middle', width: '5%' }, | ||||
|                         { field: 'currentErbanNo', title: '原平台号', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                         { | ||||
|                             field: 'operator', | ||||
|                             title: '操作', | ||||
|                             align: 'center', | ||||
|                             width: '10%', | ||||
|                             valign: 'middle', | ||||
|                             formatter: function (val, row, index) { | ||||
|                                 switch (val) { | ||||
|                                     case 1: | ||||
|                                         return '绑定'; | ||||
|   name: "PrettyNoRecordAdminView", | ||||
|   setup () { | ||||
|     return {}; | ||||
|   }, | ||||
|   created () { | ||||
|     this.$nextTick(function () { | ||||
|       this.initData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     initData () { | ||||
|       $(function () { | ||||
|         $('#table').bootstrapTable('destroy'); | ||||
|         $('#table').bootstrapTable({ | ||||
|           columns: [ | ||||
|             { field: 'currentErbanNo', title: '原平台号', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { | ||||
|               field: 'operator', | ||||
|               title: '操作', | ||||
|               align: 'center', | ||||
|               width: '10%', | ||||
|               valign: 'middle', | ||||
|               formatter: function (val, row, index) { | ||||
|                 switch (val) { | ||||
|                   case 1: | ||||
|                     return '绑定'; | ||||
|  | ||||
|                                     case 2: | ||||
|                                         return '解绑'; | ||||
|                   case 2: | ||||
|                     return '解绑'; | ||||
|  | ||||
|                                 } | ||||
|                             } | ||||
|                         }, | ||||
|                         { field: 'targetErbanNo', title: '目标平台号', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                         { field: 'uid', title: 'uid', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                         { field: 'prettyRecordDesc', title: '备注', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                         { | ||||
|                             field: 'startTime', | ||||
|                             title: '开始时间(绑定时显示)', | ||||
|                             align: 'center', | ||||
|                             width: '10%', | ||||
|                             valign: 'middle', | ||||
|                             formatter: function (val, row, index) { | ||||
|                                 if (val) { | ||||
|                                     var date = new Date(val); | ||||
|                                     return date.format("yyyy-MM-dd hh:mm:ss"); | ||||
|                                 } else { | ||||
|                                     return '-'; | ||||
|                                 } | ||||
|                             } | ||||
|                         }, | ||||
|                         { | ||||
|                             field: 'endTime', | ||||
|                             title: '结束时间(绑定时显示)', | ||||
|                             align: 'center', | ||||
|                             width: '10%', | ||||
|                             valign: 'middle', | ||||
|                             formatter: function (val, row, index) { | ||||
|                                 if (val) { | ||||
|                                     var date = new Date(val); | ||||
|                                     return date.format("yyyy-MM-dd hh:mm:ss"); | ||||
|                                 } else { | ||||
|                                     return '-'; | ||||
|                                 } | ||||
|                             } | ||||
|                         }, | ||||
|                         { | ||||
|                             field: 'createTime', | ||||
|                             title: '创建时间', | ||||
|                             align: 'center', | ||||
|                             width: '10%', | ||||
|                             valign: 'middle', | ||||
|                             formatter: function (val, row, index) { | ||||
|                                 if (val) { | ||||
|                                     var date = new Date(val); | ||||
|                                     return date.format("yyyy-MM-dd hh:mm:ss"); | ||||
|                                 } else { | ||||
|                                     return '-'; | ||||
|                                 } | ||||
|                             } | ||||
|                         }, | ||||
|                         { field: 'createdBy', title: '操作者', align: 'center', width: '10%', valign: 'middle' } | ||||
|                 } | ||||
|               } | ||||
|             }, | ||||
|             { field: 'targetErbanNo', title: '目标平台号', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { field: 'uid', title: 'uid', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { field: 'prettyRecordDesc', title: '备注', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { | ||||
|               field: 'startTime', | ||||
|               title: '开始时间(绑定时显示)', | ||||
|               align: 'center', | ||||
|               width: '10%', | ||||
|               valign: 'middle', | ||||
|               formatter: function (val, row, index) { | ||||
|                 if (val) { | ||||
|                   var date = new Date(val); | ||||
|                   return date.format("yyyy-MM-dd hh:mm:ss"); | ||||
|                 } else { | ||||
|                   return '-'; | ||||
|                 } | ||||
|               } | ||||
|             }, | ||||
|             { | ||||
|               field: 'endTime', | ||||
|               title: '结束时间(绑定时显示)', | ||||
|               align: 'center', | ||||
|               width: '10%', | ||||
|               valign: 'middle', | ||||
|               formatter: function (val, row, index) { | ||||
|                 if (val) { | ||||
|                   var date = new Date(val); | ||||
|                   return date.format("yyyy-MM-dd hh:mm:ss"); | ||||
|                 } else { | ||||
|                   return '-'; | ||||
|                 } | ||||
|               } | ||||
|             }, | ||||
|             { | ||||
|               field: 'createTime', | ||||
|               title: '创建时间', | ||||
|               align: 'center', | ||||
|               width: '10%', | ||||
|               valign: 'middle', | ||||
|               formatter: function (val, row, index) { | ||||
|                 if (val) { | ||||
|                   var date = new Date(val); | ||||
|                   return date.format("yyyy-MM-dd hh:mm:ss"); | ||||
|                 } else { | ||||
|                   return '-'; | ||||
|                 } | ||||
|               } | ||||
|             }, | ||||
|             { field: 'createdBy', title: '操作者', align: 'center', width: '10%', valign: 'middle' } | ||||
|  | ||||
|                     ], | ||||
|                     cache: false, | ||||
|                     striped: true, | ||||
|                     showRefresh: false, | ||||
|                     pageSize: 10, | ||||
|                     pagination: true, | ||||
|                     pageList: [10, 20, 30, 50], | ||||
|                     sidePagination: "server", //表示服务端请求 | ||||
|                     queryParamsType: "undefined", | ||||
|                     queryParams: function queryParams(params) {   //设置查询参数 | ||||
|                         var param = { | ||||
|                             pageSize: params.pageSize, | ||||
|                             pageNumber: params.pageNumber, | ||||
|                             targetPrettyNo: $('#targetPrettyNo').val(), | ||||
|                             currentPrettyNo: $('#currentPrettyNo').val(), | ||||
|                             operator: $('#operator').val() | ||||
|                         }; | ||||
|                         return param; | ||||
|                     }, | ||||
|                     uniqueId: 'id', | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/pretty/record/getList', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
|                     onLoadError: function () {  //加载失败时执行 | ||||
|                         console.log("load fail"); | ||||
|                     } | ||||
|                 }) | ||||
|           ], | ||||
|           cache: false, | ||||
|           striped: true, | ||||
|           showRefresh: false, | ||||
|           pageSize: 10, | ||||
|           pagination: true, | ||||
|           pageList: [10, 20, 30, 50], | ||||
|           sidePagination: "server", //表示服务端请求 | ||||
|           queryParamsType: "undefined", | ||||
|           queryParams: function queryParams (params) {   //设置查询参数 | ||||
|             var param = { | ||||
|               pageSize: params.pageSize, | ||||
|               pageNumber: params.pageNumber, | ||||
|               targetPrettyNo: $('#targetPrettyNo').val(), | ||||
|               currentPrettyNo: $('#currentPrettyNo').val(), | ||||
|               operator: $('#operator').val() | ||||
|             }; | ||||
|             return param; | ||||
|           }, | ||||
|           uniqueId: 'id', | ||||
|           toolbar: '#toolbar', | ||||
|           url: '/admin/prettyNumber/record/getList', | ||||
|           onLoadSuccess: function () {  //加载成功时执行 | ||||
|             console.log("load success"); | ||||
|           }, | ||||
|           onLoadError: function () {  //加载失败时执行 | ||||
|             console.log("load fail"); | ||||
|           } | ||||
|         }) | ||||
|  | ||||
|                 $('#btnSearch').on('click', function () { | ||||
|                     TableHelper.doRefresh('#table'); | ||||
|                 }) | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|         $('#btnSearch').on('click', function () { | ||||
|           TableHelper.doRefresh('#table'); | ||||
|         }) | ||||
|       }) | ||||
|     } | ||||
|   }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|   | ||||
| @@ -1,84 +1,128 @@ | ||||
| <template> | ||||
|     <section class="content"> | ||||
|         <div class="box box-primary"> | ||||
|             <div class="box-body"> | ||||
|                 <!-- Content Header (Page header) --> | ||||
|                 <section class="content-header"> | ||||
|                     <h1 id="itemTitle"></h1> | ||||
|                 </section> | ||||
|                 <!-- .content --> | ||||
|                 <section class="content"> | ||||
|                     <div id="table"></div> | ||||
|                     <div id="toolbar"> | ||||
|                         <form action="" id="searchForm" method="POST"> | ||||
|                             <select name="search-type" id="search-type"> | ||||
|                                 <option value="0">请选择</option> | ||||
|                                 <option value="1">幸运许愿池偏差类型</option> | ||||
|                                 <option value="4">梦幻许愿池池偏差类型</option> | ||||
|                             </select> | ||||
|                         </form> | ||||
|                         <button class="btn btn-primary" id="searchBtn">搜索</button> | ||||
|                         <button id="add" class="btn btn-default"> | ||||
|                             <i class="glyphicon glyphicon-plus"></i>新增 | ||||
|                         </button> | ||||
|                     </div> | ||||
|                 </section> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|     <div class="modal fade" id="deviateRangeModal" tabindex="-1" role="dialog" aria-labelledby="modalLabel"> | ||||
|         <div class="modal-dialog" role="document"> | ||||
|             <div class="modal-content"> | ||||
|                 <div class="modal-header"> | ||||
|                     <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span | ||||
|                             aria-hidden="true">×</span></button> | ||||
|                     <h4 class="modal-title" id="modalLabel">偏差范围</h4> | ||||
|                 </div> | ||||
|                 <div class="modal-body"> | ||||
|                     <form class="form-horizontal" id="deviateRangeForm"> | ||||
|                         <input id="deviateRangeId" type="hidden" name="id" /> | ||||
|                         <div class="form-group"> | ||||
|                             <label class="col-sm-3 control-label">下限:</label> | ||||
|                             <div class="col-sm-8"> | ||||
|                                 <input type="number" id="deviateLowerLimit" name="lowerLimit" class=" validate[required]" | ||||
|                                     placeholder="单行输入"> | ||||
|                             </div> | ||||
|                         </div> | ||||
|  | ||||
|                         <div class="form-group"> | ||||
|                             <label class="col-sm-3 control-label">上限:</label> | ||||
|                             <div class="col-sm-8"> | ||||
|                                 <input type="number" id="deviateUpperLimit" name="upperLimit" class=" validate[required]" | ||||
|                                     placeholder="单行输入"> | ||||
|                             </div> | ||||
|                         </div> | ||||
|  | ||||
|                         <div class="form-group type"> | ||||
|                             <label for="type" class="col-sm-3 control-label">选择类型:</label> | ||||
|                             <div class="col-sm-8"> | ||||
|                                 <select name="type" id="type" data-btn-class="btn btn-warning"> | ||||
|                                     <option value="1">幸运许愿池偏差类型</option> | ||||
|                                     <option value="4">梦幻许愿池池偏差类型</option> | ||||
|                                 </select> | ||||
|                             </div> | ||||
|                         </div> | ||||
|  | ||||
|                         <div class="form-group"> | ||||
|                             <label class="col-sm-3 control-label">创建者:</label> | ||||
|  | ||||
|                             <div class="col-sm-8"> | ||||
|                                 <input type="text" id="creator" name="creator" class="validate[required]" placeholder="必填项"> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </form> | ||||
|                 </div> | ||||
|                 <div class="modal-footer"> | ||||
|                     <button type="button" class="btn btn-default" data-dismiss="modal">关闭</button> | ||||
|                     <button type="button" class="btn btn-primary" id="save">保存</button> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|   <section class="content"> | ||||
|     <div class="box box-primary"> | ||||
|       <div class="box-body"> | ||||
|         <!-- Content Header (Page header) --> | ||||
|         <section class="content-header"> | ||||
|           <h1 id="itemTitle"></h1> | ||||
|         </section> | ||||
|         <!-- .content --> | ||||
|         <section class="content"> | ||||
|           <div id="table"></div> | ||||
|           <div id="toolbar"> | ||||
|             <form action="" | ||||
|                   id="searchForm" | ||||
|                   method="POST"> | ||||
|               <select name="search-type" | ||||
|                       id="search-type"> | ||||
|                 <option value="1">幸运许愿池偏差类型</option> | ||||
|                 <option value="4">梦幻许愿池池偏差类型</option> | ||||
|               </select> | ||||
|               <select id="partitionId"></select> | ||||
|             </form> | ||||
|             <button class="btn btn-primary" | ||||
|                     id="searchBtn">搜索</button> | ||||
|             <button id="add" | ||||
|                     class="btn btn-default"> | ||||
|               <i class="glyphicon glyphicon-plus"></i>新增 | ||||
|             </button> | ||||
|           </div> | ||||
|         </section> | ||||
|       </div> | ||||
|     </div> | ||||
|   </section> | ||||
|   <div class="modal fade" | ||||
|        id="deviateRangeModal" | ||||
|        tabindex="-1" | ||||
|        role="dialog" | ||||
|        aria-labelledby="modalLabel"> | ||||
|     <div class="modal-dialog" | ||||
|          role="document"> | ||||
|       <div class="modal-content"> | ||||
|         <div class="modal-header"> | ||||
|           <button type="button" | ||||
|                   class="close" | ||||
|                   data-dismiss="modal" | ||||
|                   aria-label="Close"><span aria-hidden="true">×</span></button> | ||||
|           <h4 class="modal-title" | ||||
|               id="modalLabel">偏差范围</h4> | ||||
|         </div> | ||||
|         <div class="modal-body"> | ||||
|           <form class="form-horizontal" | ||||
|                 id="deviateRangeForm"> | ||||
|             <input id="deviateRangeId" | ||||
|                    type="hidden" | ||||
|                    name="id" /> | ||||
|             <div class="form-group"> | ||||
|               <label class="col-sm-3 control-label">下限:</label> | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="number" | ||||
|                        id="deviateLowerLimit" | ||||
|                        name="lowerLimit" | ||||
|                        class=" validate[required]" | ||||
|                        placeholder="单行输入"> | ||||
|               </div> | ||||
|             </div> | ||||
|  | ||||
|             <div class="form-group"> | ||||
|               <label class="col-sm-3 control-label">上限:</label> | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="number" | ||||
|                        id="deviateUpperLimit" | ||||
|                        name="upperLimit" | ||||
|                        class=" validate[required]" | ||||
|                        placeholder="单行输入"> | ||||
|               </div> | ||||
|             </div> | ||||
|  | ||||
|             <div class="form-group type"> | ||||
|               <label for="type" | ||||
|                      class="col-sm-3 control-label">选择类型:</label> | ||||
|               <div class="col-sm-8"> | ||||
|                 <select name="type" | ||||
|                         id="type" | ||||
|                         data-btn-class="btn btn-warning"> | ||||
|                   <option value="1">幸运许愿池偏差类型</option> | ||||
|                   <option value="4">梦幻许愿池池偏差类型</option> | ||||
|                 </select> | ||||
|               </div> | ||||
|             </div> | ||||
|  | ||||
|             <div class="form-group deviatePartitionId"> | ||||
|               <label for="type" | ||||
|                      class="col-sm-3 control-label">选择分区:</label> | ||||
|               <div class="col-sm-8"> | ||||
|                 <select name="partitionId" | ||||
|                         id="deviatePartitionId" | ||||
|                         data-btn-class="btn btn-warning"> | ||||
|                 </select> | ||||
|               </div> | ||||
|             </div> | ||||
|  | ||||
|             <div class="form-group"> | ||||
|               <label class="col-sm-3 control-label">创建者:</label> | ||||
|  | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="text" | ||||
|                        id="creator" | ||||
|                        name="creator" | ||||
|                        class="validate[required]" | ||||
|                        placeholder="必填项"> | ||||
|               </div> | ||||
|             </div> | ||||
|           </form> | ||||
|         </div> | ||||
|         <div class="modal-footer"> | ||||
|           <button type="button" | ||||
|                   class="btn btn-default" | ||||
|                   data-dismiss="modal">关闭</button> | ||||
|           <button type="button" | ||||
|                   class="btn btn-primary" | ||||
|                   id="save">保存</button> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| @@ -86,160 +130,190 @@ import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
| import ComboboxHelper from '@/assets/plugins/bootstrap-combobox/js/bootstrap-combobox-helper'; | ||||
|  | ||||
| export default { | ||||
|     name: "DeviateRangeManageAdminView", | ||||
|     setup() { | ||||
|         return {}; | ||||
|     }, | ||||
|     created() { | ||||
|         this.$nextTick(function () { | ||||
|             this.initData(); | ||||
|         }); | ||||
|     }, | ||||
|     methods: { | ||||
|         initData() { | ||||
|             $(function () { | ||||
|                 $('#table').bootstrapTable('destroy'); | ||||
|                 $('#table').bootstrapTable({ | ||||
|                     columns: [ | ||||
|                         { field: 'id', title: 'id', align: 'center', width: '15%' }, | ||||
|                         { field: 'lowerLimit', title: '下限', align: 'center', width: '15%' }, | ||||
|                         { field: 'upperLimit', title: '上限', width: '20%' }, | ||||
|                         { field: 'creator', title: '创建人', align: 'center', width: '5%' }, | ||||
|                         { | ||||
|                             field: 'tmp', title: '操作', align: 'center', width: '20%', formatter: function (val, row, index) { | ||||
|                                 var key = row.id; | ||||
|                                 return "<button class='btn btn-sm btn-success opt-edit' data-id=" + key + ">编辑</button>  " + | ||||
|                                     "<button class='btn btn-sm btn-danger opt-del' data-id=" + key + ">删除</button>"; | ||||
|                             } | ||||
|                         } | ||||
|                     ], | ||||
|                     cache: false, | ||||
|                     striped: true, | ||||
|                     showRefresh: true, | ||||
|                     pageSize: 10, | ||||
|                     pagination: true, | ||||
|                     pageList: [10, 20, 30, 50], | ||||
|                     sidePagination: "server", //表示服务端请求 | ||||
|                     //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder | ||||
|                     //设置为limit可以获取limit, offset, search, sort, order | ||||
|                     queryParamsType: "undefined", | ||||
|                     queryParams: function queryParams(params) {   //设置查询参数 | ||||
|                         var param = { | ||||
|                             pageNumber: params.pageNumber, | ||||
|                             pageSize: params.pageSize, | ||||
|                             type: parseInt($("#search-type").val()) | ||||
|                         }; | ||||
|                         return param; | ||||
|                     }, | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/deviateRange/list', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
|                     onLoadError: function () {  //加载失败时执行 | ||||
|                         console.log("load fail"); | ||||
|                     } | ||||
|                 }); | ||||
|   name: "DeviateRangeManageAdminView", | ||||
|   setup () { | ||||
|     return {}; | ||||
|   }, | ||||
|   created () { | ||||
|     this.$nextTick(function () { | ||||
|       this.initData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     initData () { | ||||
|       $.ajax({ | ||||
|         type: 'get', | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         dataType: 'json', | ||||
|         success: function (json) { | ||||
|           if (json.code == 200) { | ||||
|             var deviatePartitionId = $("#deviatePartitionId"); | ||||
|             deviatePartitionId.empty(); | ||||
|  | ||||
|             var partitionId = $("#partitionId"); | ||||
|             partitionId.empty(); | ||||
|  | ||||
|                 // 构建下拉组合框 | ||||
|                 ComboboxHelper.build(null, '#status'); | ||||
|                 ComboboxHelper.build(null, '#type'); | ||||
|                 $("#deviateRangeForm").validationEngine(); | ||||
|             // 遍历数据并添加 option | ||||
|             $.each(json.data, function (index, item) { | ||||
|               // 创建新的 option 元素 | ||||
|               var option = $('<option></option>') | ||||
|                 .attr('value', item.id)  // 设置 value 属性 | ||||
|                 .text(item.desc);           // 设置文本内容 | ||||
|  | ||||
|                 $("#add").click(function () { | ||||
|                     // 打开编辑弹窗 | ||||
|                     $('#deviateRangeId').val(''); | ||||
|                     $("#deviateRangeModal").modal('show'); | ||||
|                     $("#deviateRangeForm")[0].reset(); | ||||
|                 }); | ||||
|  | ||||
|                 $("#table").on("click", '.opt-del', function () { | ||||
|                     if (confirm("你确认删除该记录吗?" + | ||||
|                         "\r\n删除偏差范围,会一起删除偏差奖池对应的配置,请谨慎操作!")) { | ||||
|                         var id = $(this).attr("data-id"); | ||||
|                         $.ajax({ | ||||
|                             type: 'post', | ||||
|                             url: "/admin/deviateRange/del", | ||||
|                             data: { 'deviateRangeId': id }, | ||||
|                             dataType: "json", | ||||
|                             success: function (res) { | ||||
|                                 if (res.code == 200) { | ||||
|                                     $("#tipMsg").text("删除成功"); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                     TableHelper.doRefresh("#table"); | ||||
|                                 } else { | ||||
|                                     $("#tipMsg").text("删除失败,错误信息:" + res.message); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                 } | ||||
|                             } | ||||
|                         }); | ||||
|                     } | ||||
|                 }); | ||||
|  | ||||
|                 $("#table").on("click", '.opt-edit', function () { | ||||
|                     var id = $(this).attr("data-id"); | ||||
|                     $.ajax({ | ||||
|                         type: "post", | ||||
|                         url: "/admin/deviateRange/one", | ||||
|                         data: { 'deviateRangeId': id }, | ||||
|                         dataType: "json", | ||||
|                         success: function (data) { | ||||
|                             if (data) { | ||||
|                                 $("#deviateRangeId").val(data.id); | ||||
|                                 $("#deviateLowerLimit").val(data.lowerLimit); | ||||
|                                 $("#deviateUpperLimit").val(data.upperLimit); | ||||
|                                 $("#creator").val(data.creator); | ||||
|                                 ComboboxHelper.setDef("#type", data.type); | ||||
|                                 // 打开编辑弹窗 | ||||
|                                 $("#deviateRangeModal").modal('show'); | ||||
|                             } else { | ||||
|                                 $("#tipMsg").text("获取偏差范围出错"); | ||||
|                                 $("#tipModal").modal('show'); | ||||
|                             } | ||||
|                         } | ||||
|                     }); | ||||
|                 }); | ||||
|  | ||||
|                 $("#save").click(function () { | ||||
|                     if ($("#deviateRangeForm").validationEngine('validate')) { | ||||
|                         var lowerLimit = parseInt($('#deviateLowerLimit').val()); | ||||
|                         var upperLimit = parseInt($('#deviateUpperLimit').val()); | ||||
|                         if (lowerLimit > upperLimit) { | ||||
|                             $("#tipMsg").text("偏差下限不能大于上限"); | ||||
|                             $("#tipModal").modal('show'); | ||||
|                             return; | ||||
|                         } | ||||
|                         $("#save").prop('disabled', true); | ||||
|                         $.ajax({ | ||||
|                             type: "post", | ||||
|                             url: "/admin/deviateRange/save", | ||||
|                             data: $('#deviateRangeForm').serialize(), | ||||
|                             dataType: "json", | ||||
|                             success: function (res) { | ||||
|                                 $("#save").prop('disabled', false); | ||||
|                                 if (res.code == 200) { | ||||
|                                     $("#deviateRangeModal").modal('hide'); | ||||
|                                     $("#tipMsg").text("保存成功"); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                     TableHelper.doRefresh("#table"); | ||||
|                                 } else { | ||||
|                                     $("#tipMsg").text("保存失败,错误信息:" + res.message); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                 } | ||||
|                             } | ||||
|                         }); | ||||
|                     } | ||||
|                 }); | ||||
|  | ||||
|                 // 筛选按钮点击事件 | ||||
|                 $('#searchBtn').on('click', function () { | ||||
|                     TableHelper.doRefresh('#table'); | ||||
|                 }); | ||||
|               // 追加到 select 元素 | ||||
|               partitionId.append(option.clone()); | ||||
|  | ||||
|               deviatePartitionId.append(option.clone()); | ||||
|             }); | ||||
|           } | ||||
|         } | ||||
|     }, | ||||
|       }); | ||||
|  | ||||
|       $(function () { | ||||
|         $('#table').bootstrapTable('destroy'); | ||||
|         $('#table').bootstrapTable({ | ||||
|           columns: [ | ||||
|             { field: 'id', title: 'id', align: 'center', width: '15%' }, | ||||
|             { field: 'lowerLimit', title: '下限', align: 'center', width: '15%' }, | ||||
|             { field: 'upperLimit', title: '上限', width: '20%' }, | ||||
|             { field: 'creator', title: '创建人', align: 'center', width: '5%' }, | ||||
|             { | ||||
|               field: 'tmp', title: '操作', align: 'center', width: '20%', formatter: function (val, row, index) { | ||||
|                 var key = row.id; | ||||
|                 return "<button class='btn btn-sm btn-success opt-edit' data-id=" + key + ">编辑</button>  " + | ||||
|                   "<button class='btn btn-sm btn-danger opt-del' data-id=" + key + ">删除</button>"; | ||||
|               } | ||||
|             } | ||||
|           ], | ||||
|           cache: false, | ||||
|           striped: true, | ||||
|           showRefresh: true, | ||||
|           pageSize: 10, | ||||
|           pagination: true, | ||||
|           pageList: [10, 20, 30, 50], | ||||
|           sidePagination: "server", //表示服务端请求 | ||||
|           //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder | ||||
|           //设置为limit可以获取limit, offset, search, sort, order | ||||
|           queryParamsType: "undefined", | ||||
|           queryParams: function queryParams (params) {   //设置查询参数 | ||||
|             var param = { | ||||
|               pageNumber: params.pageNumber, | ||||
|               pageSize: params.pageSize, | ||||
|               type: parseInt($("#search-type").val()), | ||||
|               partitionId: parseInt($("#partitionId").val()) | ||||
|             }; | ||||
|             return param; | ||||
|           }, | ||||
|           toolbar: '#toolbar', | ||||
|           url: '/admin/deviateRange/list', | ||||
|           onLoadSuccess: function () {  //加载成功时执行 | ||||
|             console.log("load success"); | ||||
|           }, | ||||
|           onLoadError: function () {  //加载失败时执行 | ||||
|             console.log("load fail"); | ||||
|           } | ||||
|         }); | ||||
|  | ||||
|  | ||||
|         // 构建下拉组合框 | ||||
|         ComboboxHelper.build(null, '#status'); | ||||
|         ComboboxHelper.build(null, '#type'); | ||||
|         $("#deviateRangeForm").validationEngine(); | ||||
|  | ||||
|         $("#add").click(function () { | ||||
|           // 打开编辑弹窗 | ||||
|           $('#deviateRangeId').val(''); | ||||
|           $("#deviateRangeModal").modal('show'); | ||||
|           $("#deviateRangeForm")[0].reset(); | ||||
|         }); | ||||
|  | ||||
|         $("#table").on("click", '.opt-del', function () { | ||||
|           if (confirm("你确认删除该记录吗?" + | ||||
|             "\r\n删除偏差范围,会一起删除偏差奖池对应的配置,请谨慎操作!")) { | ||||
|             var id = $(this).attr("data-id"); | ||||
|             $.ajax({ | ||||
|               type: 'post', | ||||
|               url: "/admin/deviateRange/del", | ||||
|               data: { 'deviateRangeId': id }, | ||||
|               dataType: "json", | ||||
|               success: function (res) { | ||||
|                 if (res.code == 200) { | ||||
|                   $("#tipMsg").text("删除成功"); | ||||
|                   $("#tipModal").modal('show'); | ||||
|                   TableHelper.doRefresh("#table"); | ||||
|                 } else { | ||||
|                   $("#tipMsg").text("删除失败,错误信息:" + res.message); | ||||
|                   $("#tipModal").modal('show'); | ||||
|                 } | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|  | ||||
|         $("#table").on("click", '.opt-edit', function () { | ||||
|           var id = $(this).attr("data-id"); | ||||
|           $.ajax({ | ||||
|             type: "post", | ||||
|             url: "/admin/deviateRange/one", | ||||
|             data: { 'deviateRangeId': id }, | ||||
|             dataType: "json", | ||||
|             success: function (data) { | ||||
|               if (data) { | ||||
|                 $("#deviateRangeId").val(data.id); | ||||
|                 $("#deviateLowerLimit").val(data.lowerLimit); | ||||
|                 $("#deviateUpperLimit").val(data.upperLimit); | ||||
|                 $("#deviatePartitionId").val(data.partitionId); | ||||
|                 $("#creator").val(data.creator); | ||||
|                 ComboboxHelper.setDef("#type", data.type); | ||||
|                 // 打开编辑弹窗 | ||||
|                 $("#deviateRangeModal").modal('show'); | ||||
|               } else { | ||||
|                 $("#tipMsg").text("获取偏差范围出错"); | ||||
|                 $("#tipModal").modal('show'); | ||||
|               } | ||||
|             } | ||||
|           }); | ||||
|         }); | ||||
|  | ||||
|         $("#save").click(function () { | ||||
|           if ($("#deviateRangeForm").validationEngine('validate')) { | ||||
|             var lowerLimit = parseInt($('#deviateLowerLimit').val()); | ||||
|             var upperLimit = parseInt($('#deviateUpperLimit').val()); | ||||
|             if (lowerLimit > upperLimit) { | ||||
|               $("#tipMsg").text("偏差下限不能大于上限"); | ||||
|               $("#tipModal").modal('show'); | ||||
|               return; | ||||
|             } | ||||
|             $("#save").prop('disabled', true); | ||||
|             $.ajax({ | ||||
|               type: "post", | ||||
|               url: "/admin/deviateRange/save", | ||||
|               data: $('#deviateRangeForm').serialize(), | ||||
|               dataType: "json", | ||||
|               success: function (res) { | ||||
|                 $("#save").prop('disabled', false); | ||||
|                 if (res.code == 200) { | ||||
|                   $("#deviateRangeModal").modal('hide'); | ||||
|                   $("#tipMsg").text("保存成功"); | ||||
|                   $("#tipModal").modal('show'); | ||||
|                   TableHelper.doRefresh("#table"); | ||||
|                 } else { | ||||
|                   $("#tipMsg").text("保存失败,错误信息:" + res.message); | ||||
|                   $("#tipModal").modal('show'); | ||||
|                 } | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|  | ||||
|         // 筛选按钮点击事件 | ||||
|         $('#searchBtn').on('click', function () { | ||||
|           TableHelper.doRefresh('#table'); | ||||
|         }); | ||||
|  | ||||
|       }); | ||||
|     } | ||||
|   }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,332 +1,400 @@ | ||||
| <template> | ||||
|     <section class="content"> | ||||
|         <div class="box box-primary"> | ||||
|             <section class="content-header"> | ||||
|                 <h1 id="itemTitle"></h1> | ||||
|             </section> | ||||
|   <section class="content"> | ||||
|     <div class="box box-primary"> | ||||
|       <section class="content-header"> | ||||
|         <h1 id="itemTitle"></h1> | ||||
|       </section> | ||||
|  | ||||
|             <section class="content"> | ||||
|       <section class="content"> | ||||
|  | ||||
|                 <div id="toolbar"> | ||||
|                     <form action="" id="searchForm" method="POST"> | ||||
|                         <div class="col-sm-12"> | ||||
|                             <div class="col-sm-4"> | ||||
|                                 <label for="timeBegin" class="qry_col control-label">日期:</label> | ||||
|                                 <input type="text" name="timeBegin" id="timeBegin" class="input-sm" placeholder="起始时间"> | ||||
|                                 - <input type="text" name="timeEnd" id="timeEnd" class="input-sm" placeholder="结束时间"> | ||||
|                             </div> | ||||
|                             <label for="erbanNo" class="qry_col control-label">平台号:</label> | ||||
|                             <div class="col-sm-2"> | ||||
|                                 <input type="text" name="erbanNo" id="erbanNo" class="input-sm" placeholder=""> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                         <div class="col-sm-12"> | ||||
|                             <label for="boxType" class="qry_col control-label">许愿池类型:</label> | ||||
|                             <div class="col-sm-2"> | ||||
|                                 <select name="boxType" id="boxType" class="col-sm-2 form-control" | ||||
|                                     data-btn-class="btn-warning"> | ||||
|                                     <option value="" selected="selected">全部</option> | ||||
|                                     <option value="1">幸运许愿池</option> | ||||
|                                     <option value="2">梦幻许愿池</option> | ||||
|                                 </select> | ||||
|                             </div> | ||||
|                             <label for="poolType" class="qry_col control-label">奖池类型:</label> | ||||
|                             <div class="col-sm-2"> | ||||
|                                 <select name="poolType" id="poolType" class="col-sm-2 form-control" | ||||
|                                     data-btn-class="btn-warning"> | ||||
|                                     <option value="" selected="selected">全部</option> | ||||
|                                     <option value="1">幸运新人奖池</option> | ||||
|                                     <option value="2">幸运普通奖池</option> | ||||
|                                     <option value="3">幸运白名单奖池</option> | ||||
|                                     <option value="4">幸运偏差奖池</option> | ||||
|                                     <option value="12">幸运次数奖池</option> | ||||
|                                     <option value="7">梦幻普通奖池</option> | ||||
|                                     <option value="9">梦幻偏差奖池</option> | ||||
|                                     <option value="10">梦幻新人奖池</option> | ||||
|                                     <option value="11">梦幻白名单奖池</option> | ||||
|                                 </select> | ||||
|                             </div> | ||||
|                             <label for="dataType" class="qry_col control-label">数据类型:</label> | ||||
|                             <div class="col-sm-2"> | ||||
|                                 <select name="dataType" id="dataType" class="col-sm-2 form-control" | ||||
|                                     data-btn-class="btn-warning"> | ||||
|                                     <option value="1" selected="selected">普通用户数据</option> | ||||
|                                     <option value="2">被排除用户的数据</option> | ||||
|                                 </select> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </form> | ||||
|                     <button class="btn btn-primary" id="searchBtn">筛选</button> | ||||
|                     <div class="tips">因数据量庞大,默认不会显示每天的结果,默认只展示平台总收益情况,请先选择时间范围再搜索</div> | ||||
|                     <div class="dataCount"> | ||||
|                         <p> | ||||
|                             <span>抽奖记录总数:</span> | ||||
|                             <span id="countNum"></span> | ||||
|                         </p> | ||||
|                         <p> | ||||
|                             <span>用户投入钻石总数:</span> | ||||
|                             <span id="userPay"></span> | ||||
|                         </p> | ||||
|                         <p> | ||||
|                             <span>总平台总价值:</span> | ||||
|                             <span id="platformNum"></span> | ||||
|                         </p> | ||||
|                         <p> | ||||
|                             <span>总实际总价值:</span> | ||||
|                             <span id="actualNum"></span> | ||||
|                         </p> | ||||
|                         <p> | ||||
|                             <span>用户获得礼物中钻石数:</span> | ||||
|                             <span id="giftNum"></span> | ||||
|                         </p> | ||||
|                         <p> | ||||
|                             <span>用户获得非礼物总钻石数:</span> | ||||
|                             <span id="notGiftNum"></span> | ||||
|                         </p> | ||||
|                         <p> | ||||
|                             <span>用户获得实物总数:</span> | ||||
|                             <span id="realGiftNum"></span> | ||||
|                         </p> | ||||
|                     </div> | ||||
|                 </div> | ||||
|  | ||||
|  | ||||
|                 <div id="table"></div> | ||||
|             </section> | ||||
|         <div id="toolbar"> | ||||
|           <form action="" | ||||
|                 id="searchForm" | ||||
|                 method="POST"> | ||||
|             <div class="col-sm-12"> | ||||
|               <label for="partitionId" | ||||
|                      class="qry_col control-label">分区:</label> | ||||
|               <div class="col-sm-2"> | ||||
|                 <select id="partitionId" | ||||
|                         class="input-sm"></select> | ||||
|               </div> | ||||
|               <div class="col-sm-4"> | ||||
|                 <label for="timeBegin" | ||||
|                        class="qry_col control-label">日期:</label> | ||||
|                 <input type="text" | ||||
|                        name="timeBegin" | ||||
|                        id="timeBegin" | ||||
|                        class="input-sm" | ||||
|                        placeholder="起始时间"> | ||||
|                 - <input type="text" | ||||
|                        name="timeEnd" | ||||
|                        id="timeEnd" | ||||
|                        class="input-sm" | ||||
|                        placeholder="结束时间"> | ||||
|               </div> | ||||
|               <label for="erbanNo" | ||||
|                      class="qry_col control-label">平台号:</label> | ||||
|               <div class="col-sm-2"> | ||||
|                 <input type="text" | ||||
|                        name="erbanNo" | ||||
|                        id="erbanNo" | ||||
|                        class="input-sm" | ||||
|                        placeholder=""> | ||||
|               </div> | ||||
|             </div> | ||||
|             <div class="col-sm-12"> | ||||
|               <label for="boxType" | ||||
|                      class="qry_col control-label">许愿池类型:</label> | ||||
|               <div class="col-sm-2"> | ||||
|                 <select name="boxType" | ||||
|                         id="boxType" | ||||
|                         class="col-sm-2 form-control" | ||||
|                         data-btn-class="btn-warning"> | ||||
|                   <option value="" | ||||
|                           selected="selected">全部</option> | ||||
|                   <option value="1">幸运许愿池</option> | ||||
|                   <option value="2">梦幻许愿池</option> | ||||
|                 </select> | ||||
|               </div> | ||||
|               <label for="poolType" | ||||
|                      class="qry_col control-label">奖池类型:</label> | ||||
|               <div class="col-sm-2"> | ||||
|                 <select name="poolType" | ||||
|                         id="poolType" | ||||
|                         class="col-sm-2 form-control" | ||||
|                         data-btn-class="btn-warning"> | ||||
|                   <option value="" | ||||
|                           selected="selected">全部</option> | ||||
|                   <option value="1">幸运新人奖池</option> | ||||
|                   <option value="2">幸运普通奖池</option> | ||||
|                   <option value="3">幸运白名单奖池</option> | ||||
|                   <option value="4">幸运偏差奖池</option> | ||||
|                   <option value="12">幸运次数奖池</option> | ||||
|                   <option value="7">梦幻普通奖池</option> | ||||
|                   <option value="9">梦幻偏差奖池</option> | ||||
|                   <option value="10">梦幻新人奖池</option> | ||||
|                   <option value="11">梦幻白名单奖池</option> | ||||
|                 </select> | ||||
|               </div> | ||||
|               <label for="dataType" | ||||
|                      class="qry_col control-label">数据类型:</label> | ||||
|               <div class="col-sm-2"> | ||||
|                 <select name="dataType" | ||||
|                         id="dataType" | ||||
|                         class="col-sm-2 form-control" | ||||
|                         data-btn-class="btn-warning"> | ||||
|                   <option value="1" | ||||
|                           selected="selected">普通用户数据</option> | ||||
|                   <option value="2">被排除用户的数据</option> | ||||
|                 </select> | ||||
|               </div> | ||||
|             </div> | ||||
|           </form> | ||||
|           <button class="btn btn-primary" | ||||
|                   id="searchBtn">筛选</button> | ||||
|           <div class="tips">因数据量庞大,默认不会显示每天的结果,默认只展示平台总收益情况,请先选择时间范围再搜索</div> | ||||
|           <div class="dataCount"> | ||||
|             <p> | ||||
|               <span>抽奖记录总数:</span> | ||||
|               <span id="countNum"></span> | ||||
|             </p> | ||||
|             <p> | ||||
|               <span>用户投入钻石总数:</span> | ||||
|               <span id="userPay"></span> | ||||
|             </p> | ||||
|             <p> | ||||
|               <span>总平台总价值:</span> | ||||
|               <span id="platformNum"></span> | ||||
|             </p> | ||||
|             <p> | ||||
|               <span>总实际总价值:</span> | ||||
|               <span id="actualNum"></span> | ||||
|             </p> | ||||
|             <p> | ||||
|               <span>用户获得礼物中钻石数:</span> | ||||
|               <span id="giftNum"></span> | ||||
|             </p> | ||||
|             <p> | ||||
|               <span>用户获得非礼物总钻石数:</span> | ||||
|               <span id="notGiftNum"></span> | ||||
|             </p> | ||||
|             <p> | ||||
|               <span>用户获得实物总数:</span> | ||||
|               <span id="realGiftNum"></span> | ||||
|             </p> | ||||
|           </div> | ||||
|         </div> | ||||
|     </section> | ||||
|  | ||||
|         <div id="table"></div> | ||||
|       </section> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
|  | ||||
| export default { | ||||
|     name: "PrizeDataAdminNewView", | ||||
|     setup() { | ||||
|         return {}; | ||||
|     }, | ||||
|     created() { | ||||
|         this.$nextTick(function () { | ||||
|             this.initData(); | ||||
|   name: "PrizeDataAdminNewView", | ||||
|   setup () { | ||||
|     return {}; | ||||
|   }, | ||||
|   created () { | ||||
|     this.$nextTick(function () { | ||||
|       this.initData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     initData () { | ||||
|       $(function () { | ||||
|         $.ajax({ | ||||
|           type: 'get', | ||||
|           url: '/partition/listPartitionInfo', | ||||
|           dataType: 'json', | ||||
|           success: function (json) { | ||||
|             if (json.code == 200) { | ||||
|               //var deviatePartitionId = $("#deviatePartitionId"); | ||||
|               //deviatePartitionId.empty(); | ||||
|  | ||||
|               var partitionId = $("#partitionId"); | ||||
|               partitionId.empty(); | ||||
|  | ||||
|               var defaultOption = $('<option></option>').attr('value', '').text("全部"); | ||||
|               partitionId.append(defaultOption); | ||||
|  | ||||
|               // 遍历数据并添加 option | ||||
|               $.each(json.data, function (index, item) { | ||||
|                 // 创建新的 option 元素 | ||||
|                 var option = $('<option></option>') | ||||
|                   .attr('value', item.id)  // 设置 value 属性 | ||||
|                   .text(item.desc);           // 设置文本内容 | ||||
|  | ||||
|                 // 追加到 select 元素 | ||||
|                 partitionId.append(option.clone()); | ||||
|  | ||||
|                 //deviatePartitionId.append(option.clone()); | ||||
|               }); | ||||
|             } | ||||
|           } | ||||
|         }); | ||||
|     }, | ||||
|     methods: { | ||||
|         initData() { | ||||
|             $(function () { | ||||
|                 var picker1 = $('#timeBegin').datetimepicker({ | ||||
|                     format: 'yyyy-mm-dd', | ||||
|                     todayBtn: true, | ||||
|                     autoclose: true, | ||||
|                     minView: 'month', | ||||
|                     endDate: new Date() | ||||
|                 }); | ||||
|  | ||||
|                 var picker2 = $('#timeEnd').datetimepicker({ | ||||
|                     format: 'yyyy-mm-dd', | ||||
|                     todayBtn: true, | ||||
|                     autoclose: true, | ||||
|                     minView: 'month', | ||||
|                     endDate: new Date() | ||||
|                 }); | ||||
|         var picker1 = $('#timeBegin').datetimepicker({ | ||||
|           format: 'yyyy-mm-dd', | ||||
|           todayBtn: true, | ||||
|           autoclose: true, | ||||
|           minView: 'month', | ||||
|           endDate: new Date() | ||||
|         }); | ||||
|  | ||||
|                 var $timeBegin = '', $timeEnd = ''; | ||||
|                 var main = { | ||||
|                     init: function () { | ||||
|                         this.eventRegister(); | ||||
|                         this.valueChange(); | ||||
|                     }, | ||||
|         var picker2 = $('#timeEnd').datetimepicker({ | ||||
|           format: 'yyyy-mm-dd', | ||||
|           todayBtn: true, | ||||
|           autoclose: true, | ||||
|           minView: 'month', | ||||
|           endDate: new Date() | ||||
|         }); | ||||
|  | ||||
|                     eventRegister: function () { | ||||
|                         picker1.on('changeDate', function () { | ||||
|                             var date = $('#timeBegin').datetimepicker('getDate'); | ||||
|                             picker2.datetimepicker('setStartDate', date); | ||||
|                         }); | ||||
|                         picker2.on('changeDate', function () { | ||||
|                             var date = $('#timeEnd').datetimepicker('getDate'); | ||||
|                             picker1.datetimepicker('setEndDate', date); | ||||
|                         }); | ||||
|         var $timeBegin = '', $timeEnd = ''; | ||||
|         var main = { | ||||
|           init: function () { | ||||
|             this.eventRegister(); | ||||
|             this.valueChange(); | ||||
|           }, | ||||
|  | ||||
|                         $('#searchBtn').on('click', function () { | ||||
|                             var $dataCount = $('.dataCount'); | ||||
|                             // var $startDate = $('#timeBegin').val().replace(/\//g,'-'); | ||||
|                             var $startDate; | ||||
|                             if ($('#timeBegin').val() == "" || $('#timeBegin').val() == 'undefined') { | ||||
|                                 $startDate = ''; | ||||
|                             } else { | ||||
|                                 /*var arr = $('#timeBegin').val().split('/'); | ||||
|                                 var length = arr.length; | ||||
|                                 var $startDate = arr[length-1] +'-' + arr[0] + '-' + arr[length - 2];*/ | ||||
|                                 $startDate = $('#timeBegin').val(); | ||||
|                             } | ||||
|                             var $endDate; | ||||
|                             if ($('#timeEnd').val() == '' || $('#timeEnd').val() == 'undefined') { | ||||
|                                 $endDate = $startDate; | ||||
|                             } else { | ||||
|                                 /*var arr2 = $('#timeEnd').val().split('/'); | ||||
|                                 var length2 = arr2.length; | ||||
|                                 var $endDate = arr2[length2-1] + '-' + arr2[0]  + '-' + arr2[length2-2];*/ | ||||
|                                 $endDate = $('#timeEnd').val(); | ||||
|                             } | ||||
|           eventRegister: function () { | ||||
|             picker1.on('changeDate', function () { | ||||
|               var date = $('#timeBegin').datetimepicker('getDate'); | ||||
|               picker2.datetimepicker('setStartDate', date); | ||||
|             }); | ||||
|             picker2.on('changeDate', function () { | ||||
|               var date = $('#timeEnd').datetimepicker('getDate'); | ||||
|               picker1.datetimepicker('setEndDate', date); | ||||
|             }); | ||||
|  | ||||
|                             if ($startDate == '') { | ||||
|                                 $timeBegin = ''; | ||||
|                                 $timeEnd = ''; | ||||
|                             } else { | ||||
|                                 $timeBegin = $startDate + ' 00:00:00'; | ||||
|                                 $timeEnd = $endDate + ' 23:59:59'; | ||||
|                             } | ||||
|             $('#searchBtn').on('click', function () { | ||||
|               var $dataCount = $('.dataCount'); | ||||
|               // var $startDate = $('#timeBegin').val().replace(/\//g,'-'); | ||||
|               var $startDate; | ||||
|               if ($('#timeBegin').val() == "" || $('#timeBegin').val() == 'undefined') { | ||||
|                 $startDate = ''; | ||||
|               } else { | ||||
|                 /*var arr = $('#timeBegin').val().split('/'); | ||||
|                 var length = arr.length; | ||||
|                 var $startDate = arr[length-1] +'-' + arr[0] + '-' + arr[length - 2];*/ | ||||
|                 $startDate = $('#timeBegin').val(); | ||||
|               } | ||||
|               var $endDate; | ||||
|               if ($('#timeEnd').val() == '' || $('#timeEnd').val() == 'undefined') { | ||||
|                 $endDate = $startDate; | ||||
|               } else { | ||||
|                 /*var arr2 = $('#timeEnd').val().split('/'); | ||||
|                 var length2 = arr2.length; | ||||
|                 var $endDate = arr2[length2-1] + '-' + arr2[0]  + '-' + arr2[length2-2];*/ | ||||
|                 $endDate = $('#timeEnd').val(); | ||||
|               } | ||||
|  | ||||
|                             $.post('/admin/drawlottery/record/totalNew', { | ||||
|                                 erbanNo: $('#erbanNo').val(), | ||||
|                                 startDate: $timeBegin, | ||||
|                                 endDate: $timeEnd, | ||||
|                                 boxType: $('#boxType').val(), | ||||
|                                 poolType: $('#poolType').val(), | ||||
|                                 dataType: $('#dataType').val() | ||||
|                             }, function (res) { | ||||
|                                 console.log(res); | ||||
|               if ($startDate == '') { | ||||
|                 $timeBegin = ''; | ||||
|                 $timeEnd = ''; | ||||
|               } else { | ||||
|                 $timeBegin = $startDate + ' 00:00:00'; | ||||
|                 $timeEnd = $endDate + ' 23:59:59'; | ||||
|               } | ||||
|  | ||||
|                                 if (res.code == 200) { | ||||
|                                     var data = res.data; | ||||
|                                     $dataCount.find('#countNum').html(data.countNum); | ||||
|                                     $dataCount.find('#userPay').html(data.userTotalPay); | ||||
|                                     $dataCount.find('#platformNum').html(data.totalPlatformValue); | ||||
|                                     $dataCount.find('#actualNum').html(data.totalActualValue); | ||||
|                                     $dataCount.find('#giftNum').html(data.totalGiftActualValue); | ||||
|                                     $dataCount.find('#notGiftNum').html(data.totalNotGiftActualValue); | ||||
|                                     $dataCount.find('#realGiftNum').html(data.totalRealGiftActualValue); | ||||
|                                     //                            TableHelper.doRefresh('#table'); | ||||
|                                     tableRefresh(); | ||||
|                                 } else { | ||||
|                                     console.log('数据错误,导致加载失败,' + res.code); | ||||
|                                 } | ||||
|                             }) | ||||
|                         }); | ||||
|               $.post('/admin/drawlottery/record/totalNew', { | ||||
|                 erbanNo: $('#erbanNo').val(), | ||||
|                 startDate: $timeBegin, | ||||
|                 endDate: $timeEnd, | ||||
|                 boxType: $('#boxType').val(), | ||||
|                 poolType: $('#poolType').val(), | ||||
|                 dataType: $('#dataType').val(), | ||||
|                 partitionId: $("#partitionId").val(), | ||||
|               }, function (res) { | ||||
|                 console.log(res); | ||||
|  | ||||
|                         $('#table').on('click', '#details', function () { | ||||
|                             console.log($(this).data('id')); | ||||
|                         }); | ||||
|  | ||||
|  | ||||
|                     }, | ||||
|  | ||||
|                     valueChange: function () { | ||||
|                         var $dataCount = $('.dataCount'); | ||||
|                         $.post('/admin/drawlottery/record/totalNew', { | ||||
|                             erbanNo: $('#erbanNo').val(), | ||||
|                             startDate: $timeBegin, | ||||
|                             endDate: $timeEnd, | ||||
|                             boxType: $('#boxType').val(), | ||||
|                             poolType: $('#poolType').val(), | ||||
|                             dataType: $('#dataType').val() | ||||
|                         }, function (res) { | ||||
|                             console.log(res); | ||||
|  | ||||
|                             if (res.code == 200) { | ||||
|                                 var data = res.data; | ||||
|                                 $dataCount.find('#countNum').html(data.countNum); | ||||
|                                 $dataCount.find('#userPay').html(data.userTotalPay); | ||||
|                                 $dataCount.find('#platformNum').html(data.totalPlatformValue); | ||||
|                                 $dataCount.find('#actualNum').html(data.totalActualValue); | ||||
|                                 $dataCount.find('#giftNum').html(data.totalGiftActualValue); | ||||
|                                 $dataCount.find('#notGiftNum').html(data.totalNotGiftActualValue); | ||||
|                                 $dataCount.find('#realGiftNum').html(data.totalRealGiftActualValue); | ||||
|                                 TableHelper.doRefresh('#table'); | ||||
|                             } else { | ||||
|                                 console.log('数据错误,导致加载失败,' + res.code); | ||||
|                             } | ||||
|                         }) | ||||
|                     } | ||||
|                 }; | ||||
|                 main.init(); | ||||
|  | ||||
|                 function tableRefresh() { | ||||
|                     $('#table').bootstrapTable('destroy'); | ||||
|                     $('#table').bootstrapTable({ | ||||
|                         columns: [ | ||||
|                             { | ||||
|                                 field: 'createTime', title: '日期', align: 'center', valign: 'middle', width: '20%', formatter: function (val, rows, index) { | ||||
|                                     if (val) { | ||||
|                                         var date = new Date(val); | ||||
|                                         return date.format('yyyy-MM-dd') | ||||
|                                     } else { | ||||
|                                         return '-'; | ||||
|                                     } | ||||
|                                 } | ||||
|                             }, | ||||
|                             { field: 'countNum', title: '抽奖记录数', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'userTotalPay', title: '用户投入钻石数', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalPlatformValue', title: '总平台价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalActualValue', title: '总实际价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalGiftActualValue', title: '用户获得礼物钻石数', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalNotGiftActualValue', title: '用户获得非礼物钻石数', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalRealGiftActualValue', title: '用户获得实物', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             // {field: '', title: '操作', align: 'center', valign: 'middle', width: '10%',formatter: function(val,row,index) { | ||||
|                             //     var key = row.createTime; | ||||
|                             //     return '<button class="btn btn-primary btn-sm" id="details" data-id="' + key + '">查看详情</button>'; | ||||
|                             // }} | ||||
|                         ], | ||||
|                         cache: false, | ||||
|                         striped: true, | ||||
|                         showRefresh: false, | ||||
|                         pageSize: 10, | ||||
|                         pagination: true, | ||||
|                         pageList: [10, 20, 30, 50], | ||||
|                         sidePagination: 'server', | ||||
|                         queryParamsType: 'undefined', | ||||
|                         queryParams: function queryParams(params) { | ||||
|                             var param = { | ||||
|                                 pageSize: params.pageSize, | ||||
|                                 pageNumber: params.pageNumber, | ||||
|                                 startDate: $timeBegin, | ||||
|                                 endDate: $timeEnd, | ||||
|                                 boxType: $('#boxType').val(), | ||||
|                                 poolType: $('#poolType').val(), | ||||
|                                 erbanNo: $('#erbanNo').val(), | ||||
|                                 dataType: $('#dataType').val(), | ||||
|                             }; | ||||
|                             return param; | ||||
|                         }, | ||||
|                         uniqueId: 'id', | ||||
|                         toolbar: '#toolbar', | ||||
|                         url: '/admin/drawlottery/record/listNew', | ||||
|                         onLoadSuccess: function () { | ||||
|                             console.log('load success'); | ||||
|                         }, | ||||
|                         onLOadError: function () { | ||||
|                             console.log('load fail'); | ||||
|                         } | ||||
|                     }); | ||||
|                 if (res.code == 200) { | ||||
|                   var data = res.data; | ||||
|                   $dataCount.find('#countNum').html(data.countNum); | ||||
|                   $dataCount.find('#userPay').html(data.userTotalPay); | ||||
|                   $dataCount.find('#platformNum').html(data.totalPlatformValue); | ||||
|                   $dataCount.find('#actualNum').html(data.totalActualValue); | ||||
|                   $dataCount.find('#giftNum').html(data.totalGiftActualValue); | ||||
|                   $dataCount.find('#notGiftNum').html(data.totalNotGiftActualValue); | ||||
|                   $dataCount.find('#realGiftNum').html(data.totalRealGiftActualValue); | ||||
|                   //                            TableHelper.doRefresh('#table'); | ||||
|                   tableRefresh(); | ||||
|                 } else { | ||||
|                   console.log('数据错误,导致加载失败,' + res.code); | ||||
|                 } | ||||
|               }) | ||||
|             }); | ||||
|  | ||||
|             $('#table').on('click', '#details', function () { | ||||
|               console.log($(this).data('id')); | ||||
|             }); | ||||
|  | ||||
|  | ||||
|           }, | ||||
|  | ||||
|           valueChange: function () { | ||||
|             var $dataCount = $('.dataCount'); | ||||
|             $.post('/admin/drawlottery/record/totalNew', { | ||||
|               erbanNo: $('#erbanNo').val(), | ||||
|               startDate: $timeBegin, | ||||
|               endDate: $timeEnd, | ||||
|               boxType: $('#boxType').val(), | ||||
|               poolType: $('#poolType').val(), | ||||
|               dataType: $('#dataType').val() | ||||
|             }, function (res) { | ||||
|               console.log(res); | ||||
|  | ||||
|               if (res.code == 200) { | ||||
|                 var data = res.data; | ||||
|                 $dataCount.find('#countNum').html(data.countNum); | ||||
|                 $dataCount.find('#userPay').html(data.userTotalPay); | ||||
|                 $dataCount.find('#platformNum').html(data.totalPlatformValue); | ||||
|                 $dataCount.find('#actualNum').html(data.totalActualValue); | ||||
|                 $dataCount.find('#giftNum').html(data.totalGiftActualValue); | ||||
|                 $dataCount.find('#notGiftNum').html(data.totalNotGiftActualValue); | ||||
|                 $dataCount.find('#realGiftNum').html(data.totalRealGiftActualValue); | ||||
|                 TableHelper.doRefresh('#table'); | ||||
|               } else { | ||||
|                 console.log('数据错误,导致加载失败,' + res.code); | ||||
|               } | ||||
|             }) | ||||
|           } | ||||
|         }; | ||||
|         main.init(); | ||||
|  | ||||
|         function tableRefresh () { | ||||
|           $('#table').bootstrapTable('destroy'); | ||||
|           $('#table').bootstrapTable({ | ||||
|             columns: [ | ||||
|               { | ||||
|                 field: 'createTime', title: '日期', align: 'center', valign: 'middle', width: '20%', formatter: function (val, rows, index) { | ||||
|                   if (val) { | ||||
|                     var date = new Date(val); | ||||
|                     return date.format('yyyy-MM-dd') | ||||
|                   } else { | ||||
|                     return '-'; | ||||
|                   } | ||||
|                 } | ||||
|               }, | ||||
|               { field: 'countNum', title: '抽奖记录数', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'userTotalPay', title: '用户投入钻石数', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalPlatformValue', title: '总平台价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalActualValue', title: '总实际价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalGiftActualValue', title: '用户获得礼物钻石数', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalNotGiftActualValue', title: '用户获得非礼物钻石数', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalRealGiftActualValue', title: '用户获得实物', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               // {field: '', title: '操作', align: 'center', valign: 'middle', width: '10%',formatter: function(val,row,index) { | ||||
|               //     var key = row.createTime; | ||||
|               //     return '<button class="btn btn-primary btn-sm" id="details" data-id="' + key + '">查看详情</button>'; | ||||
|               // }} | ||||
|             ], | ||||
|             cache: false, | ||||
|             striped: true, | ||||
|             showRefresh: false, | ||||
|             pageSize: 10, | ||||
|             pagination: true, | ||||
|             pageList: [10, 20, 30, 50], | ||||
|             sidePagination: 'server', | ||||
|             queryParamsType: 'undefined', | ||||
|             queryParams: function queryParams (params) { | ||||
|               var param = { | ||||
|                 pageSize: params.pageSize, | ||||
|                 pageNumber: params.pageNumber, | ||||
|                 startDate: $timeBegin, | ||||
|                 endDate: $timeEnd, | ||||
|                 boxType: $('#boxType').val(), | ||||
|                 poolType: $('#poolType').val(), | ||||
|                 erbanNo: $('#erbanNo').val(), | ||||
|                 dataType: $('#dataType').val(), | ||||
|                 partitionId: $('#partitionId').val(), | ||||
|               }; | ||||
|               return param; | ||||
|             }, | ||||
|             uniqueId: 'id', | ||||
|             toolbar: '#toolbar', | ||||
|             url: '/admin/drawlottery/record/listNew', | ||||
|             onLoadSuccess: function () { | ||||
|               console.log('load success'); | ||||
|             }, | ||||
|             onLOadError: function () { | ||||
|               console.log('load fail'); | ||||
|             } | ||||
|           }); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|  | ||||
|       }) | ||||
|     } | ||||
|   }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style scoped> | ||||
| .dataCount { | ||||
|     display: flex; | ||||
|     justify-content: flex-start; | ||||
|     align-items: center; | ||||
|     margin-top: 10px; | ||||
|   display: flex; | ||||
|   justify-content: flex-start; | ||||
|   align-items: center; | ||||
|   margin-top: 10px; | ||||
| } | ||||
|  | ||||
| .dataCount>p { | ||||
|     padding: 5px; | ||||
|     border-radius: 5px; | ||||
|     background: #ccc; | ||||
|     margin-right: 10px; | ||||
| .dataCount > p { | ||||
|   padding: 5px; | ||||
|   border-radius: 5px; | ||||
|   background: #ccc; | ||||
|   margin-right: 10px; | ||||
| } | ||||
|  | ||||
| .tips { | ||||
|     color: red; | ||||
|     font-size: 14px; | ||||
|   color: red; | ||||
|   font-size: 14px; | ||||
| } | ||||
|  | ||||
| .qry_col { | ||||
|     float: left; | ||||
| }</style> | ||||
|   float: left; | ||||
| } | ||||
| </style> | ||||
| @@ -12,9 +12,14 @@ | ||||
|         <div id="toolbar"> | ||||
|  | ||||
|           <div class="col-sm-12"> | ||||
|             <form action="" id="searchForm" method="POST"> | ||||
|  | ||||
|               转盘分类:<select name="jackpotType" id="jackpotType" data-btn-class="btn btn-warning"> | ||||
|             <form action="" | ||||
|                   id="searchForm" | ||||
|                   method="POST"> | ||||
|               分区:<select id="partitionId" | ||||
|                       class="input-sm"></select> | ||||
|               转盘分类:<select name="jackpotType" | ||||
|                       class="input-sm" | ||||
|                       id="jackpotType"> | ||||
|                 <option value="1">幸运新人奖池</option> | ||||
|                 <option value="2">幸运普通奖池</option> | ||||
|                 <option value="3">幸运白名单奖池</option> | ||||
| @@ -29,17 +34,23 @@ | ||||
|               </select> | ||||
|               <label class="deviateRange"> | ||||
|                 偏差范围: | ||||
|                 <select name="deviateRange" id="deviateRange" data-btn-class="btn btn-warning"> | ||||
|                 <select name="deviateRange" | ||||
|                         id="deviateRange" | ||||
|                         data-btn-class="btn btn-warning"> | ||||
|                 </select> | ||||
|               </label> | ||||
|               <label class="diamondDeviateRange"> | ||||
|                 偏差范围: | ||||
|                 <select name="diamondDeviateRange" id="diamondDeviateRange" data-btn-class="btn btn-warning"> | ||||
|                 <select name="diamondDeviateRange" | ||||
|                         id="diamondDeviateRange" | ||||
|                         data-btn-class="btn btn-warning"> | ||||
|                 </select> | ||||
|               </label> | ||||
|             </form> | ||||
|             <button class="btn btn-primary" id="searchBtn">搜索</button> | ||||
|             <button class="btn btn-primary" id="add">添加奖品</button> | ||||
|             <button class="btn btn-primary" | ||||
|                     id="searchBtn">搜索</button> | ||||
|             <button class="btn btn-primary" | ||||
|                     id="add">添加奖品</button> | ||||
|           </div> | ||||
|  | ||||
|           <div class="col-sm-12 jackpot"> | ||||
| @@ -51,10 +62,14 @@ | ||||
|             </p> | ||||
|  | ||||
|             <p class="col-sm-12"> | ||||
|               <span class="col-sm-3" id="jackpotName"></span> | ||||
|               <span class="col-sm-3" id="jackpotNum"></span> | ||||
|               <span class="col-sm-3" id="prizeNum"></span> | ||||
|               <span class="col-sm-3" id="expectNum"></span> | ||||
|               <span class="col-sm-3" | ||||
|                     id="jackpotName"></span> | ||||
|               <span class="col-sm-3" | ||||
|                     id="jackpotNum"></span> | ||||
|               <span class="col-sm-3" | ||||
|                     id="prizeNum"></span> | ||||
|               <span class="col-sm-3" | ||||
|                     id="expectNum"></span> | ||||
|             </p> | ||||
|           </div> | ||||
|  | ||||
| @@ -65,31 +80,47 @@ | ||||
|   </section> | ||||
|  | ||||
|   <!-- 添加弹窗 --> | ||||
|   <div class="modal fade" id="addModal" tabindex="-1" role="dialog" aria-labelledby="modalLabel"> | ||||
|   <div class="modal fade" | ||||
|        id="addModal" | ||||
|        tabindex="-1" | ||||
|        role="dialog" | ||||
|        aria-labelledby="modalLabel"> | ||||
|  | ||||
|     <div class="modal-dialog" role="document"> | ||||
|     <div class="modal-dialog" | ||||
|          role="document"> | ||||
|       <div class="modal-content"> | ||||
|  | ||||
|         <div class="modal-header"> | ||||
|           <button type="button" class="close" data-dismiss="modal" aria-label="Close"> | ||||
|           <button type="button" | ||||
|                   class="close" | ||||
|                   data-dismiss="modal" | ||||
|                   aria-label="Close"> | ||||
|             <span aria-hidden="true">x</span> | ||||
|           </button> | ||||
|  | ||||
|           <h4 class="modal-title" id="addModalLabel">添加奖品</h4> | ||||
|           <h4 class="modal-title" | ||||
|               id="addModalLabel">添加奖品</h4> | ||||
|         </div> | ||||
|  | ||||
|         <div class="modal-body"> | ||||
|           <form action="" class="form-horizontal" id="addForm"> | ||||
|           <form action="" | ||||
|                 class="form-horizontal" | ||||
|                 id="addForm"> | ||||
|  | ||||
|             <!-- 选择奖品 --> | ||||
|             <div class="form-group"> | ||||
|               <label for="" class="col-sm-3 control-label">选择奖品:</label> | ||||
|               <label for="" | ||||
|                      class="col-sm-3 control-label">选择奖品:</label> | ||||
|               <div class="col-sm-8"> | ||||
|                 <select name="awardType" id="awardType" data-btn-class="btn btn-warning"> | ||||
|                 <select name="awardType" | ||||
|                         id="awardType" | ||||
|                         data-btn-class="btn btn-warning"> | ||||
|                   <!-- <option value=""></option> --> | ||||
|                 </select> | ||||
|  | ||||
|                 <select name="awardChoose" id="awardChoose" data-btn-class="btn btn-warning"> | ||||
|                 <select name="awardChoose" | ||||
|                         id="awardChoose" | ||||
|                         data-btn-class="btn btn-warning"> | ||||
|                   <!-- <option value=""></option> --> | ||||
|                 </select> | ||||
|               </div> | ||||
| @@ -97,19 +128,29 @@ | ||||
|  | ||||
|             <!-- 奖品个数 --> | ||||
|             <div class="form-group"> | ||||
|               <label for="" class="col-sm-3 control-label">奖品个数:</label> | ||||
|               <label for="" | ||||
|                      class="col-sm-3 control-label">奖品个数:</label> | ||||
|  | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="text" id="jackpotNumber" name="jackpotNumber" class=" validate[required]" placeholder="单行输入"> | ||||
|                 <input type="text" | ||||
|                        id="jackpotNumber" | ||||
|                        name="jackpotNumber" | ||||
|                        class=" validate[required]" | ||||
|                        placeholder="单行输入"> | ||||
|               </div> | ||||
|             </div> | ||||
|  | ||||
|             <!-- 中奖率 --> | ||||
|             <div class="form-group"> | ||||
|               <label for="" class="col-sm-3 control-label">实际中奖率:</label> | ||||
|               <label for="" | ||||
|                      class="col-sm-3 control-label">实际中奖率:</label> | ||||
|  | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="text" id="winningRate" name="winningRate" class=" validate[required]" placeholder="单行输入">% | ||||
|                 <input type="text" | ||||
|                        id="winningRate" | ||||
|                        name="winningRate" | ||||
|                        class=" validate[required]" | ||||
|                        placeholder="单行输入">% | ||||
|                 <br /> | ||||
|                 <div class="tips"> | ||||
|                   <i class="glyphicon glyphicon-info-sign"></i>中奖率综合为100,当前概率不得超过100 | ||||
| @@ -119,10 +160,15 @@ | ||||
|  | ||||
|             <!-- 展示中奖率 --> | ||||
|             <div class="form-group"> | ||||
|               <label for="" class="col-sm-3 control-label">展示中奖率:</label> | ||||
|               <label for="" | ||||
|                      class="col-sm-3 control-label">展示中奖率:</label> | ||||
|  | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="text" id="showRate" name="showRate" class=" validate[required]" placeholder="单行输入">% | ||||
|                 <input type="text" | ||||
|                        id="showRate" | ||||
|                        name="showRate" | ||||
|                        class=" validate[required]" | ||||
|                        placeholder="单行输入">% | ||||
|                 <br /> | ||||
|                 <div class="tips"> | ||||
|                   <i class="glyphicon glyphicon-info-sign"></i>中奖率综合为100,当前概率不得超过100 | ||||
| @@ -131,21 +177,41 @@ | ||||
|             </div> | ||||
|  | ||||
|             <div class="form-group"> | ||||
|               <label for="" class="col-sm-3 control-label">是否默认奖品:</label> | ||||
|               <label for="" | ||||
|                      class="col-sm-3 control-label">是否默认奖品:</label> | ||||
|               <div class="col-sm-8"> | ||||
|                 <select name="itemType" id="itemType" data-btn-class="btn btn-warning"> | ||||
|                 <select name="itemType" | ||||
|                         id="itemType" | ||||
|                         data-btn-class="btn btn-warning"> | ||||
|                   <option value="1"> 默认奖品 </option> | ||||
|                   <option value="2"> 普通奖品 </option> | ||||
|                 </select> | ||||
|               </div> | ||||
|             </div> | ||||
|  | ||||
|             <!-- 创建者 --> | ||||
|             <div class="form-group"> | ||||
|               <label for="" class="col-sm-3 control-label">创建者:</label> | ||||
|             <!-- 分区 --> | ||||
|             <div class="form-group awardPartitionId"> | ||||
|               <label for="awardPartitionId" | ||||
|                      class="col-sm-3 control-label">分区:</label> | ||||
|  | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="text" id="creator" name="creator" class="validate[required]" placeholder="必填项"> | ||||
|                 <select name="awardPartitionId" | ||||
|                         id="awardPartitionId"> | ||||
|                 </select> | ||||
|               </div> | ||||
|             </div> | ||||
|  | ||||
|             <!-- 创建者 --> | ||||
|             <div class="form-group"> | ||||
|               <label for="" | ||||
|                      class="col-sm-3 control-label">创建者:</label> | ||||
|  | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="text" | ||||
|                        id="creator" | ||||
|                        name="creator" | ||||
|                        class="validate[required]" | ||||
|                        placeholder="必填项"> | ||||
|               </div> | ||||
|             </div> | ||||
|  | ||||
| @@ -153,8 +219,12 @@ | ||||
|         </div> | ||||
|  | ||||
|         <div class="modal-footer"> | ||||
|           <button class="btn btn-default" type="button" id="addReset">重置</button> | ||||
|           <button class="btn btn-primary" type="button" id="addSave">保存</button> | ||||
|           <button class="btn btn-default" | ||||
|                   type="button" | ||||
|                   id="addReset">重置</button> | ||||
|           <button class="btn btn-primary" | ||||
|                   type="button" | ||||
|                   id="addSave">保存</button> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
| @@ -162,35 +232,56 @@ | ||||
|   </div> | ||||
|  | ||||
|   <!-- 编辑弹窗 --> | ||||
|   <div class="modal fade" id="editModal" tabindex="-1" role="dialog" aria-labelledby="modalLabel"> | ||||
|     <div class="modal-dialog" role="document"> | ||||
|   <div class="modal fade" | ||||
|        id="editModal" | ||||
|        tabindex="-1" | ||||
|        role="dialog" | ||||
|        aria-labelledby="modalLabel"> | ||||
|     <div class="modal-dialog" | ||||
|          role="document"> | ||||
|       <div class="modal-content"> | ||||
|         <div class="modal-header"> | ||||
|           <button type="button" class="close" data-dismiss="modal" aria-label="Close"> | ||||
|           <button type="button" | ||||
|                   class="close" | ||||
|                   data-dismiss="modal" | ||||
|                   aria-label="Close"> | ||||
|             <span aria-hidden="true">x</span> | ||||
|           </button> | ||||
|           <h4 class="modal-title" id="editModalLabel">编辑奖品</h4> | ||||
|           <h4 class="modal-title" | ||||
|               id="editModalLabel">编辑奖品</h4> | ||||
|         </div> | ||||
|  | ||||
|         <div class="modal-body"> | ||||
|           <form action="" class="form-horizontal" id="editForm"> | ||||
|             <input type="hidden" id="editId"> | ||||
|           <form action="" | ||||
|                 class="form-horizontal" | ||||
|                 id="editForm"> | ||||
|             <input type="hidden" | ||||
|                    id="editId"> | ||||
|             <!-- 奖品个数 --> | ||||
|             <div class="form-group"> | ||||
|               <label for="" class="col-sm-3 control-label">奖品个数:</label> | ||||
|               <label for="" | ||||
|                      class="col-sm-3 control-label">奖品个数:</label> | ||||
|  | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="text" id="jackpotNumber2" name="jackpotNumber2" class=" validate[required]" | ||||
|                   placeholder="单行输入"> | ||||
|                 <input type="text" | ||||
|                        id="jackpotNumber2" | ||||
|                        name="jackpotNumber2" | ||||
|                        class=" validate[required]" | ||||
|                        placeholder="单行输入"> | ||||
|               </div> | ||||
|             </div> | ||||
|  | ||||
|             <!-- 中奖率 --> | ||||
|             <div class="form-group"> | ||||
|               <label for="" class="col-sm-3 control-label">实际中奖率:</label> | ||||
|               <label for="" | ||||
|                      class="col-sm-3 control-label">实际中奖率:</label> | ||||
|  | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="text" id="winningRate2" name="winningRate2" class=" validate[required]" placeholder="单行输入">% | ||||
|                 <input type="text" | ||||
|                        id="winningRate2" | ||||
|                        name="winningRate2" | ||||
|                        class=" validate[required]" | ||||
|                        placeholder="单行输入">% | ||||
|                 <br /> | ||||
|                 <div class="tips"> | ||||
|                   <i class="glyphicon glyphicon-info-sign"></i>中奖率综合为100,当前概率不得超过100 | ||||
| @@ -200,10 +291,15 @@ | ||||
|  | ||||
|             <!-- 展示给用户看的中奖率 --> | ||||
|             <div class="form-group"> | ||||
|               <label for="" class="col-sm-3 control-label">展示中奖率:</label> | ||||
|               <label for="" | ||||
|                      class="col-sm-3 control-label">展示中奖率:</label> | ||||
|  | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="text" id="showRate2" name="showRate2" class=" validate[required]" placeholder="单行输入">% | ||||
|                 <input type="text" | ||||
|                        id="showRate2" | ||||
|                        name="showRate2" | ||||
|                        class=" validate[required]" | ||||
|                        placeholder="单行输入">% | ||||
|                 <br /> | ||||
|                 <div class="tips"> | ||||
|                   <i class="glyphicon glyphicon-info-sign"></i>中奖率综合为100,当前概率不得超过100 | ||||
| @@ -211,29 +307,52 @@ | ||||
|               </div> | ||||
|             </div> | ||||
|             <div class="form-group"> | ||||
|               <label for="" class="col-sm-3 control-label">是否默认奖品:</label> | ||||
|               <label for="" | ||||
|                      class="col-sm-3 control-label">是否默认奖品:</label> | ||||
|               <div class="col-sm-8"> | ||||
|                 <select name="itemType" id="itemType2" data-btn-class="btn btn-warning"> | ||||
|                 <select name="itemType" | ||||
|                         id="itemType2" | ||||
|                         data-btn-class="btn btn-warning"> | ||||
|                   <option value="1"> 默认奖品 </option> | ||||
|                   <option value="2"> 普通奖品 </option> | ||||
|                 </select> | ||||
|               </div> | ||||
|             </div> | ||||
|  | ||||
|             <!-- 创建者 --> | ||||
|             <div class="form-group"> | ||||
|               <label for="" class="col-sm-3 control-label">创建者:</label> | ||||
|             <!-- 分区 --> | ||||
|             <div class="form-group awardPartitionId"> | ||||
|               <label for="awardPartitionId2" | ||||
|                      class="col-sm-3 control-label">分区:</label> | ||||
|  | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="text" id="creator2" name="creator2" class="validate[required]"> | ||||
|                 <select name="awardPartitionId2" | ||||
|                         id="awardPartitionId2"> | ||||
|                 </select> | ||||
|               </div> | ||||
|             </div> | ||||
|  | ||||
|             <!-- 创建者 --> | ||||
|             <div class="form-group"> | ||||
|               <label for="" | ||||
|                      class="col-sm-3 control-label">创建者:</label> | ||||
|  | ||||
|               <div class="col-sm-8"> | ||||
|                 <input type="text" | ||||
|                        id="creator2" | ||||
|                        name="creator2" | ||||
|                        class="validate[required]"> | ||||
|               </div> | ||||
|             </div> | ||||
|           </form> | ||||
|         </div> | ||||
|  | ||||
|         <div class="modal-footer"> | ||||
|           <button class="btn btn-default" type="button" id="editReset">重置</button> | ||||
|           <button class="btn btn-primary" type="button" id="editSave">保存</button> | ||||
|           <button class="btn btn-default" | ||||
|                   type="button" | ||||
|                   id="editReset">重置</button> | ||||
|           <button class="btn btn-primary" | ||||
|                   type="button" | ||||
|                   id="editSave">保存</button> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
| @@ -243,6 +362,7 @@ | ||||
| <script> | ||||
| import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
|  | ||||
| var partitionInfo = {} | ||||
| var idObj = {}; | ||||
| var typeObj = {}; | ||||
| var pId = '', saveId = ''; | ||||
| @@ -251,32 +371,85 @@ var ACCURACY = 1000; // 小数点精度 | ||||
| var RATIO_PART = 100000; // 概率换算单位 | ||||
| export default { | ||||
|   name: "PrizeManageAdminView", | ||||
|   setup() { | ||||
|   setup () { | ||||
|     return {}; | ||||
|   }, | ||||
|   created() { | ||||
|   created () { | ||||
|     this.initData(); | ||||
|  | ||||
|   }, | ||||
|   mounted() { | ||||
|   mounted () { | ||||
|  | ||||
|   }, | ||||
|   methods: { | ||||
|     initData() { | ||||
|     initData () { | ||||
|       this.$nextTick(function () { | ||||
|         var main = { | ||||
|           init: function () { | ||||
|             this.initPartitionIdSelect(); | ||||
|  | ||||
|             $('.deviateRange').hide(); | ||||
|             $('.chargeDeviateRange').hide(); | ||||
|             $('.diamondDeviateRange').hide(); | ||||
|  | ||||
|             this.eventRegister(); | ||||
|             this.getDataFormBack(); | ||||
|  | ||||
|             this.initDeviateRangeSelect(); | ||||
|             this.initDiamondDeviateRangeSelect(); | ||||
|             //$('#selectReplacePrize').hide(); | ||||
|             //this.initReplacePrizeSelect(); | ||||
|           }, | ||||
|  | ||||
|           initPartitionIdSelect: function () { | ||||
|             $.ajax({ | ||||
|               type: 'get', | ||||
|               url: '/partition/listPartitionInfo', | ||||
|               dataType: 'json', | ||||
|               success: function (json) { | ||||
|                 if (json.code == 200) { | ||||
|                   var awardPartitionId = $("#awardPartitionId"); | ||||
|                   awardPartitionId.empty(); | ||||
|  | ||||
|                   var awardPartitionId2 = $("#awardPartitionId2"); | ||||
|                   awardPartitionId2.empty(); | ||||
|  | ||||
|                   var partitionId = $("#partitionId"); | ||||
|                   partitionId.empty(); | ||||
|  | ||||
|                   var defaultOption = $('<option></option>').attr('value', '').text("全部"); | ||||
|                   partitionId.append(defaultOption); | ||||
|  | ||||
|                   // 遍历数据并添加 option | ||||
|                   $.each(json.data, function (index, item) { | ||||
|                     // 创建新的 option 元素 | ||||
|                     var option = $('<option></option>') | ||||
|                       .attr('value', item.id)  // 设置 value 属性 | ||||
|                       .text(item.desc);           // 设置文本内容 | ||||
|  | ||||
|                     // 追加到 select 元素 | ||||
|                     partitionId.append(option.clone()); | ||||
|  | ||||
|                     awardPartitionId.append(option.clone()); | ||||
|  | ||||
|                     awardPartitionId2.append(option.clone()); | ||||
|                   }); | ||||
|  | ||||
|                   partitionInfo = json.data.reduce((acc, item) => { | ||||
|                     acc[item.id] = item.desc; | ||||
|                     return acc; | ||||
|                   }, {}); | ||||
|                 } | ||||
|               } | ||||
|             }); | ||||
|  | ||||
|             $('#partitionId').change(function () { | ||||
|               const partitionId = $(this).val(); | ||||
|               main.initDeviateRangeSelect(partitionId); | ||||
|               main.initDiamondDeviateRangeSelect(partitionId); | ||||
|             }); | ||||
|           }, | ||||
|  | ||||
|           eventRegister: function () { | ||||
|  | ||||
|           }, | ||||
| @@ -306,36 +479,38 @@ export default { | ||||
|             }); | ||||
|           }, | ||||
|  | ||||
|           initDeviateRangeSelect: function () { | ||||
|             let options = $('#deviateRange').children(); | ||||
|             if (options.length <= 0) { | ||||
|               $.get('/admin/deviateRange/list?type=1', {}, function (res) { | ||||
|                 if (res.total > 0) { | ||||
|                   var rows = res.rows; | ||||
|                   for (var i = 0; i < rows.length; i++) { | ||||
|                     var deviateRange = rows[i]; | ||||
|                     var str = '<option value=' + deviateRange.id + '>' + deviateRange.lowerLimit + '~' + deviateRange.upperLimit + '</option>'; | ||||
|           initDeviateRangeSelect: function (partitionId) { | ||||
|             $('#deviateRange').empty(); | ||||
|  | ||||
|             $.get('/admin/deviateRange/list?type=1', {}, function (res) { | ||||
|               if (res.total > 0) { | ||||
|                 var rows = res.rows; | ||||
|                 for (var i = 0; i < rows.length; i++) { | ||||
|                   var deviateRange = rows[i]; | ||||
|                   if (undefined != partitionId && '' != partitionId && deviateRange.partitionId == partitionId) { | ||||
|                     var str = '<option partitionId = ' + deviateRange.partitionId + ' value=' + deviateRange.id + '>' + deviateRange.lowerLimit + '~' + deviateRange.upperLimit + '</option>'; | ||||
|                     $('#deviateRange').append(str); | ||||
|                   } | ||||
|                 } | ||||
|               }); | ||||
|             } | ||||
|               } | ||||
|             }); | ||||
|           }, | ||||
|  | ||||
|           initDiamondDeviateRangeSelect: function () { | ||||
|             let options = $('#diamondDeviateRange').children(); | ||||
|             if (options.length <= 0) { | ||||
|               $.get('/admin/deviateRange/list?type=4', {}, function (res) { | ||||
|                 if (res.total > 0) { | ||||
|                   var rows = res.rows; | ||||
|                   for (var i = 0; i < rows.length; i++) { | ||||
|                     var deviateRange = rows[i]; | ||||
|                     var str = '<option value=' + deviateRange.id + '>' + deviateRange.lowerLimit + '~' + deviateRange.upperLimit + '</option>'; | ||||
|           initDiamondDeviateRangeSelect: function (partitionId) { | ||||
|             $('#diamondDeviateRange').empty(); | ||||
|  | ||||
|             $.get('/admin/deviateRange/list?type=4', {}, function (res) { | ||||
|               if (res.total > 0) { | ||||
|                 var rows = res.rows; | ||||
|                 for (var i = 0; i < rows.length; i++) { | ||||
|                   var deviateRange = rows[i]; | ||||
|                   if (undefined != partitionId && '' != partitionId && deviateRange.partitionId == partitionId) { | ||||
|                     var str = '<option partitionId = ' + deviateRange.partitionId + ' value=' + deviateRange.id + '>' + deviateRange.lowerLimit + '~' + deviateRange.upperLimit + '</option>'; | ||||
|                     $('#diamondDeviateRange').append(str); | ||||
|                   } | ||||
|                 } | ||||
|               }); | ||||
|             } | ||||
|               } | ||||
|             }); | ||||
|           }, | ||||
|  | ||||
|           initReplacePrizeSelect: function () { | ||||
| @@ -358,7 +533,7 @@ export default { | ||||
|         $('#table').bootstrapTable('destroy'); | ||||
|         $('#table').bootstrapTable({ | ||||
|           columns: [ | ||||
|             { field: 'id', title: '奖品编号', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { field: 'id', title: '奖品编号', align: 'center', valign: 'middle', width: '3%' }, | ||||
|             { | ||||
|               field: 'prizeName', title: '奖品名称', align: 'center', valign: 'middle', width: '10%', formatter: function (val, row, index) { | ||||
|                 var key = row.prizeId; | ||||
| @@ -448,6 +623,11 @@ export default { | ||||
|               } | ||||
|             }, | ||||
|             { field: 'usePrizeNum', title: '被抽中数量', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { | ||||
|               field: 'partitionId', title: '分区', align: 'center', valign: 'middle', width: '10%', formatter: function (val, row, index) { | ||||
|                 return partitionInfo[val] || val; | ||||
|               } | ||||
|             }, | ||||
|             { | ||||
|               field: '', title: '操作', align: 'center', valign: 'middle', width: '10%', formatter: function (val, row, index) { | ||||
|                 var key = row.id; | ||||
| @@ -463,13 +643,14 @@ export default { | ||||
|           pageList: [10, 20, 30, 50], | ||||
|           sidePagination: 'server', | ||||
|           queryParamsType: 'undefined', | ||||
|           queryParams: function queryParams(params) { | ||||
|           queryParams: function queryParams (params) { | ||||
|  | ||||
|             var param = { | ||||
|               pageSize: params.pageSize, | ||||
|               pageNumber: params.pageNumber, | ||||
|               poolType: parseInt($('#jackpotType').val()), | ||||
|               deviateRangeId: getDeviateRangeId() | ||||
|               deviateRangeId: getDeviateRangeId(), | ||||
|               partitionId: $('#partitionId').val(), | ||||
|             }; | ||||
|  | ||||
|             return param; | ||||
| @@ -479,7 +660,6 @@ export default { | ||||
|           url: '/admin/prizePoolItem/list', | ||||
|           onLoadSuccess: function (res) { | ||||
|             console.log('load success'); | ||||
|             console.log(res.rows); | ||||
|             var arr = []; | ||||
|             var Num = 0; | ||||
|             var expectNum = 0; | ||||
| @@ -587,7 +767,6 @@ export default { | ||||
|         $('#addModal').find('#awardType').on('change', function () { | ||||
|           $('#awardChoose').find('option').remove(); | ||||
|           var key = $(this).val(); | ||||
|           console.log(key); | ||||
|           // var str = '<option></option>'; | ||||
|           // $('#awardChoose').append(str); | ||||
|           var str; | ||||
| @@ -605,12 +784,12 @@ export default { | ||||
|           var id = $(this).data('id'); | ||||
|           var data = $('#table').bootstrapTable('getRowByUniqueId', id); | ||||
|  | ||||
|           console.log(data); | ||||
|           $('#editModal').find('#jackpotNumber2').val(data.prizeNum); | ||||
|           $('#editModal').find('#winningRate2').val(data.occupationRatio / ACCURACY); | ||||
|           $('#editModal').find('#showRate2').val(data.showRatio / ACCURACY); | ||||
|           $('#editModal').find('#creator2').val(data.creator); | ||||
|           $('#editModal').find('#itemType2').val(data.itemType); | ||||
|           $('#editModal').find('#awardPartitionId2').val(data.partitionId); | ||||
|           pId = data.prizeId; | ||||
|           saveId = id; | ||||
|         }); | ||||
| @@ -660,7 +839,8 @@ export default { | ||||
|             occupationRatio: $('#winningRate').val() * ACCURACY, | ||||
|             showRatio: $('#showRate').val() * ACCURACY, | ||||
|             creator: $('#creator').val(), | ||||
|             itemType: $('#itemType').val() | ||||
|             itemType: $('#itemType').val(), | ||||
|             partitionId: $('#awardPartitionId').val(), | ||||
|           }, function (res) { | ||||
|             if (res.code == 200) { | ||||
|               $('#addModal').modal('hide'); | ||||
| @@ -715,7 +895,8 @@ export default { | ||||
|             occupationRatio: $('#winningRate2').val() * ACCURACY, | ||||
|             showRatio: $('#showRate2').val() * ACCURACY, | ||||
|             creator: $('#creator2').val(), | ||||
|             itemType: $('#itemType2').val() | ||||
|             itemType: $('#itemType2').val(), | ||||
|             partitionId: $('#awardPartitionId2').val(), | ||||
|           }, function (res) { | ||||
|             if (res.code == 200) { | ||||
|               // console.log(res); | ||||
| @@ -774,7 +955,7 @@ export default { | ||||
|  | ||||
| }; | ||||
|  | ||||
| function clearModal() { | ||||
| function clearModal () { | ||||
|   $('#addForm').find('input[type=text],select,input[type=hidden]').each(function () { | ||||
|     $(this).val(''); | ||||
|   }); | ||||
| @@ -783,7 +964,7 @@ function clearModal() { | ||||
|   }); | ||||
| } | ||||
|  | ||||
| function getDeviateRangeId() { | ||||
| function getDeviateRangeId () { | ||||
|   if ($('#deviateRange').val()) { | ||||
|     var jackpotType = $('#jackpotType').val(); | ||||
|     if (jackpotType == '4') { | ||||
| @@ -814,7 +995,7 @@ function getDeviateRangeId() { | ||||
|   align-items: center; | ||||
| } | ||||
|  | ||||
| #toolbar>div:first-child { | ||||
| #toolbar > div:first-child { | ||||
|   margin-right: 10px; | ||||
| } | ||||
| </style> | ||||
| @@ -1,179 +1,197 @@ | ||||
| <template> | ||||
|     <section class="content"> | ||||
|         <div class="box box-primary"> | ||||
|             <section class="content-header"> | ||||
|                 <h1 id="itemTitle"></h1> | ||||
|             </section> | ||||
|   <section class="content"> | ||||
|     <div class="box box-primary"> | ||||
|       <section class="content-header"> | ||||
|         <h1 id="itemTitle"></h1> | ||||
|       </section> | ||||
|  | ||||
|             <section class="content"> | ||||
|                 <div id="table"></div> | ||||
|                 <div id="toolbar"> | ||||
|                     <div class="col-sm-12"> | ||||
|                         <div class="pull-left"> | ||||
|                             <form action="/admin/box/record/export" id="searchForm" method="POST"> | ||||
|                                 平台号:<input type="text" id="msNo" name="msNo" class="input-sm" placeholder="请输入平台号"> | ||||
|       <section class="content"> | ||||
|         <div id="table"></div> | ||||
|         <div id="toolbar"> | ||||
|           <div class="col-sm-12"> | ||||
|             <div class="pull-left"> | ||||
|               <form action="/admin/box/record/export" | ||||
|                     id="searchForm" | ||||
|                     method="POST"> | ||||
|                 平台号:<input type="text" | ||||
|                        id="msNo" | ||||
|                        name="msNo" | ||||
|                        class="input-sm" | ||||
|                        placeholder="请输入平台号"> | ||||
|  | ||||
|                                 奖品名称:<input type="text" id="prizeName" name="prizeName" class="input-sm" | ||||
|                                     placeholder="请输入奖品名称"> | ||||
|                 奖品名称:<input type="text" | ||||
|                        id="prizeName" | ||||
|                        name="prizeName" | ||||
|                        class="input-sm" | ||||
|                        placeholder="请输入奖品名称"> | ||||
|  | ||||
|                                 日期:<input type="text" name="startDate" id="timeBegin" class="input-sm datetime" | ||||
|                                     placeholder="起始时间"> | ||||
|                                 - <input type="text" name="endDate" id="timeEnd" class="input-sm datetime" | ||||
|                                     placeholder="结束时间"> | ||||
|                 日期:<input type="text" | ||||
|                        name="startDate" | ||||
|                        id="timeBegin" | ||||
|                        class="input-sm datetime" | ||||
|                        placeholder="起始时间"> | ||||
|                 - <input type="text" | ||||
|                        name="endDate" | ||||
|                        id="timeEnd" | ||||
|                        class="input-sm datetime" | ||||
|                        placeholder="结束时间"> | ||||
|  | ||||
|                             </form> | ||||
|                         </div> | ||||
|               </form> | ||||
|             </div> | ||||
|  | ||||
|                         <div class="pull-right"> | ||||
|                                 <button id="searchBtn" class="btn btn-primary">筛选</button> | ||||
|                             <button id="exportBtn" class="btn btn-primary">导出</button> | ||||
|                         </div> | ||||
|                     </div> | ||||
|             <div class="pull-right"> | ||||
|                   <button id="searchBtn" | ||||
|                       class="btn btn-primary">筛选</button> | ||||
|               <button id="exportBtn" | ||||
|                       class="btn btn-primary">导出</button> | ||||
|             </div> | ||||
|           </div> | ||||
|  | ||||
|                 </div> | ||||
|             </section> | ||||
|         </div> | ||||
|     </section> | ||||
|       </section> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
|  | ||||
| export default { | ||||
|     name: "PrizeRecordAdminView", | ||||
|     setup() { | ||||
|         return {}; | ||||
|     }, | ||||
|     created() { | ||||
|         this.$nextTick(function () { | ||||
|             this.initData(); | ||||
|   name: "PrizeRecordAdminView", | ||||
|   setup () { | ||||
|     return {}; | ||||
|   }, | ||||
|   created () { | ||||
|     this.$nextTick(function () { | ||||
|       this.initData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     initData () { | ||||
|       $(function () { | ||||
|  | ||||
|         $('.datetime').datetimepicker({ | ||||
|           format: 'yyyy-mm-dd hh:ii:00', | ||||
|           autoclose: true | ||||
|         }); | ||||
|     }, | ||||
|     methods: { | ||||
|         initData() { | ||||
|             $(function () { | ||||
|  | ||||
|                 $('.datetime').datetimepicker({ | ||||
|                     format: 'yyyy-mm-dd hh:ii:00', | ||||
|                     autoclose: true | ||||
|                 }); | ||||
|         var main = { | ||||
|           init: function () { | ||||
|             this.eventRegister(); | ||||
|             this.getDataFromBack(); | ||||
|           }, | ||||
|  | ||||
|                 var main = { | ||||
|                     init: function () { | ||||
|                         this.eventRegister(); | ||||
|                         this.getDataFromBack(); | ||||
|                     }, | ||||
|           eventRegister: function () { | ||||
|  | ||||
|                     eventRegister: function () { | ||||
|           }, | ||||
|  | ||||
|                     }, | ||||
|           getDataFromBack: function () { | ||||
|  | ||||
|                     getDataFromBack: function () { | ||||
|           } | ||||
|         }; | ||||
|         main.init(); | ||||
|  | ||||
|                     } | ||||
|                 }; | ||||
|                 main.init(); | ||||
|         $('#table').bootstrapTable('destroy'); | ||||
|         $('#table').bootstrapTable({ | ||||
|           columns: [ | ||||
|             { field: 'id', title: 'id', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { field: 'uid', title: 'uid', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { field: 'erbanNo', title: '平台号', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { field: 'nick', title: '用户昵称', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { field: 'partition', title: '分区', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { field: 'prizeName', title: '奖品名称', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { | ||||
|               field: 'createTime', title: '抽奖时间', align: 'center', valign: 'middle', width: '20%', formatter: function (val, row, index) { | ||||
|                 if (val) { | ||||
|                   var date = new Date(val); | ||||
|                   return date.format('yyyy-MM-dd hh:mm:ss'); | ||||
|                 } else { | ||||
|                   return '-'; | ||||
|                 } | ||||
|               } | ||||
|             }, | ||||
|             { field: 'platformValue', title: '平台价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { field: 'actualValue', title: '实际价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|             { | ||||
|               field: 'prizePoolType', title: '转盘类型', align: 'center', valign: 'middle', width: '10%', formatter: function (val, row, index) { | ||||
|                 switch (row.prizePoolType) { | ||||
|                   case 1: | ||||
|                     return '幸运新人奖池'; | ||||
|  | ||||
|                 $('#table').bootstrapTable('destroy'); | ||||
|                 $('#table').bootstrapTable({ | ||||
|                     columns: [ | ||||
|                         { field: 'id', title: 'id', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                         { field: 'uid', title: 'uid', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                         { field: 'erbanNo', title: '平台号', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                         { field: 'nick', title: '用户昵称', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                         { field: 'prizeName', title: '奖品名称', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                         { | ||||
|                             field: 'createTime', title: '抽奖时间', align: 'center', valign: 'middle', width: '20%', formatter: function (val, row, index) { | ||||
|                                 if (val) { | ||||
|                                     var date = new Date(val); | ||||
|                                     return date.format('yyyy-MM-dd hh:mm:ss'); | ||||
|                                 } else { | ||||
|                                     return '-'; | ||||
|                                 } | ||||
|                             } | ||||
|                         }, | ||||
|                         { field: 'platformValue', title: '平台价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                         { field: 'actualValue', title: '实际价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                         { | ||||
|                             field: 'prizePoolType', title: '转盘类型', align: 'center', valign: 'middle', width: '10%', formatter: function (val, row, index) { | ||||
|                                 switch (row.prizePoolType) { | ||||
|                                     case 1: | ||||
|                                         return '幸运新人奖池'; | ||||
|                   case 2: | ||||
|                     return '幸运普通奖池'; | ||||
|  | ||||
|                                     case 2: | ||||
|                                         return '幸运普通奖池'; | ||||
|                   case 3: | ||||
|                     return '幸运白名单奖池'; | ||||
|  | ||||
|                                     case 3: | ||||
|                                         return '幸运白名单奖池'; | ||||
|                   case 4: | ||||
|                     return '幸运偏差奖池'; | ||||
|  | ||||
|                                     case 4: | ||||
|                                         return '幸运偏差奖池'; | ||||
|                   case 12: | ||||
|                     return '幸运次数奖池'; | ||||
|  | ||||
|                                     case 12: | ||||
|                                         return '幸运次数奖池'; | ||||
|                   case 7: | ||||
|                     return '梦幻普通奖池'; | ||||
|  | ||||
|                                     case 7: | ||||
|                                         return '梦幻普通奖池'; | ||||
|                   case 9: | ||||
|                     return '梦幻偏差奖池'; | ||||
|  | ||||
|                                     case 9: | ||||
|                                         return '梦幻偏差奖池'; | ||||
|                   case 10: | ||||
|                     return '梦幻新人奖池'; | ||||
|  | ||||
|                                     case 10: | ||||
|                                         return '梦幻新人奖池'; | ||||
|                   case 11: | ||||
|                     return '梦幻白名单奖池'; | ||||
|  | ||||
|                                     case 11: | ||||
|                                         return '梦幻白名单奖池'; | ||||
|                   case 13: | ||||
|                     return '普通管理奖池'; | ||||
|  | ||||
|                                     case 13: | ||||
|                                         return '普通管理奖池'; | ||||
|                   case 14: | ||||
|                     return '梦幻管理奖池'; | ||||
|  | ||||
|                                     case 14: | ||||
|                                         return '梦幻管理奖池'; | ||||
|                 } | ||||
|               } | ||||
|             } | ||||
|           ], | ||||
|           cache: false, | ||||
|           striped: true, | ||||
|           showRefresh: false, | ||||
|           pageSize: 10, | ||||
|           pagination: true, | ||||
|           pageList: [10, 20, 30, 50], | ||||
|           sidePagination: 'server', | ||||
|           queryParamsType: 'undefined', | ||||
|           queryParams: function queryParams (params) { | ||||
|             var param = { | ||||
|               pageSize: params.pageSize, | ||||
|               pageNumber: params.pageNumber, | ||||
|               startDate: $('#timeBegin').val(), | ||||
|               endDate: $('#timeEnd').val(), | ||||
|               msNo: $('#msNo').val(), | ||||
|               prizeName: $("#prizeName").val() | ||||
|             }; | ||||
|             return param; | ||||
|           }, | ||||
|           uniqueId: 'id', | ||||
|           toolbar: '#toolbar', | ||||
|           url: '/admin/box/record/list', | ||||
|           onLOadSuccess: function () { | ||||
|             console.log('load success'); | ||||
|           }, | ||||
|           onLoadError: function () { | ||||
|             console.log('load fail'); | ||||
|           } | ||||
|         }); | ||||
|         // 筛选按钮点击事件 | ||||
|         $('#searchBtn').on('click', function () { | ||||
|           TableHelper.doRefresh('#table'); | ||||
|         }); | ||||
|  | ||||
|                                 } | ||||
|                             } | ||||
|                         } | ||||
|                     ], | ||||
|                     cache: false, | ||||
|                     striped: true, | ||||
|                     showRefresh: false, | ||||
|                     pageSize: 10, | ||||
|                     pagination: true, | ||||
|                     pageList: [10, 20, 30, 50], | ||||
|                     sidePagination: 'server', | ||||
|                     queryParamsType: 'undefined', | ||||
|                     queryParams: function queryParams(params) { | ||||
|                         var param = { | ||||
|                             pageSize: params.pageSize, | ||||
|                             pageNumber: params.pageNumber, | ||||
|                             startDate: $('#timeBegin').val(), | ||||
|                             endDate: $('#timeEnd').val(), | ||||
|                             msNo: $('#msNo').val(), | ||||
|                             prizeName: $("#prizeName").val() | ||||
|                         }; | ||||
|                         return param; | ||||
|                     }, | ||||
|                     uniqueId: 'id', | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/box/record/list', | ||||
|                     onLOadSuccess: function () { | ||||
|                         console.log('load success'); | ||||
|                     }, | ||||
|                     onLoadError: function () { | ||||
|                         console.log('load fail'); | ||||
|                     } | ||||
|                 }); | ||||
|                 // 筛选按钮点击事件 | ||||
|                 $('#searchBtn').on('click', function () { | ||||
|                     TableHelper.doRefresh('#table'); | ||||
|                 }); | ||||
|  | ||||
|                 $("#exportBtn").on('click', function () { | ||||
|                     $("#searchForm").submit(); | ||||
|                 }) | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|         $("#exportBtn").on('click', function () { | ||||
|           $("#searchForm").submit(); | ||||
|         }) | ||||
|       }) | ||||
|     } | ||||
|   }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|   | ||||
| @@ -1,296 +1,315 @@ | ||||
| <template> | ||||
|     <section class="content"> | ||||
|         <div class="box box-primary"> | ||||
|             <div class="box-body"> | ||||
|                 <section class="content-header"> | ||||
|                     <h1 id="itemTitle"></h1> | ||||
|                 </section> | ||||
|                 <section class="content"> | ||||
|                     <div id="table"></div> | ||||
|                     <div id="toolbar"> | ||||
|                         <label class="source"> | ||||
|                             选择时间: <input type="text" name="startTime" id="startTime" class="input-sm"> | ||||
|                             至 <input type="text" id="endTime" name="endTime" class="input-sm"> | ||||
|                         </label> | ||||
|                         <label class="source"> | ||||
|                             宝箱类型: <select name="boxType" id="boxType" class="input-sm"> | ||||
|                                 <option value="0">全部</option> | ||||
|                                 <option value="1">幸运许愿池</option> | ||||
|                                 <option value="2">梦幻许愿池</option> | ||||
|                             </select> | ||||
|                         </label> | ||||
|                         <label class="source"> | ||||
|                             查询凭据:<select name="source" id="source" class="input-sm"> | ||||
|                                 <option value="1">平台号</option> | ||||
|                                 <option value="2">偏差范围</option> | ||||
|                             </select> | ||||
|                         </label> | ||||
|                         <label class="msNo"> | ||||
|                             平台号:<input type="text" placeholder="请输入草莓号" id="msNo" class="input-sm"> | ||||
|                         </label> | ||||
|                         <label class="deviation"> | ||||
|                             偏差值: <input type="text" id="minDis" class="input-m"> - <input type="text" id="maxDis" | ||||
|                                 class="input-m"> | ||||
|                         </label> | ||||
|                         <button id="btnSearch" class="btn btn-sm btn-primary">查询</button> | ||||
|                     </div> | ||||
|                 </section> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|   <section class="content"> | ||||
|     <div class="box box-primary"> | ||||
|       <div class="box-body"> | ||||
|         <section class="content-header"> | ||||
|           <h1 id="itemTitle"></h1> | ||||
|         </section> | ||||
|         <section class="content"> | ||||
|           <div id="table"></div> | ||||
|           <div id="toolbar"> | ||||
|             <label class="source"> | ||||
|               选择时间: <input type="text" | ||||
|                      name="startTime" | ||||
|                      id="startTime" | ||||
|                      class="input-sm"> | ||||
|               至 <input type="text" | ||||
|                      id="endTime" | ||||
|                      name="endTime" | ||||
|                      class="input-sm"> | ||||
|             </label> | ||||
|             <label class="source"> | ||||
|               宝箱类型: <select name="boxType" | ||||
|                       id="boxType" | ||||
|                       class="input-sm"> | ||||
|                 <option value="0">全部</option> | ||||
|                 <option value="1">幸运许愿池</option> | ||||
|                 <option value="2">梦幻许愿池</option> | ||||
|               </select> | ||||
|             </label> | ||||
|             <label class="source"> | ||||
|               查询凭据:<select name="source" | ||||
|                       id="source" | ||||
|                       class="input-sm"> | ||||
|                 <option value="1">平台号</option> | ||||
|                 <option value="2">偏差范围</option> | ||||
|               </select> | ||||
|             </label> | ||||
|             <label class="msNo"> | ||||
|               平台号:<input type="text" | ||||
|                      placeholder="请输入草莓号" | ||||
|                      id="msNo" | ||||
|                      class="input-sm"> | ||||
|             </label> | ||||
|             <label class="deviation"> | ||||
|               偏差值: <input type="text" | ||||
|                      id="minDis" | ||||
|                      class="input-m"> - <input type="text" | ||||
|                      id="maxDis" | ||||
|                      class="input-m"> | ||||
|             </label> | ||||
|             <button id="btnSearch" | ||||
|                     class="btn btn-sm btn-primary">查询</button> | ||||
|           </div> | ||||
|         </section> | ||||
|       </div> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
|  | ||||
| export default { | ||||
|     name: "PrizeStatisAdminNewView", | ||||
|     setup() { | ||||
|         return {}; | ||||
|     }, | ||||
|     created() { | ||||
|         this.$nextTick(function () { | ||||
|             this.initData(); | ||||
|         }); | ||||
|     }, | ||||
|     methods: { | ||||
|         initData() { | ||||
|             $(function () { | ||||
|                 //searchHistory(); | ||||
|                 var whiteList = {}; | ||||
|                 requestWhiteList(searchHistory()); | ||||
|                 function searchHistory() { | ||||
|                     $('#table').bootstrapTable('destroy'); | ||||
|                     $('#table').bootstrapTable({ | ||||
|                         columns: [ | ||||
|                             { field: 'uid', title: 'uid', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'erbanNo', title: '平台号', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'nick', title: '昵称', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalPurchaseMoney', title: '历史抽奖充值总额', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalDrawMoney', title: '历史抽奖总额', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalPlatformValue', title: '历史获奖平台价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalActualValue', title: '历史获奖实际价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { | ||||
|                                 field: 'deviation', title: '偏差值', align: 'center', valign: 'middle', width: '10%', formatter: function (val, row, index) { | ||||
|                                     if (val > 0) { | ||||
|                                         return '<span style="color:red">+' + val + '</span>'; | ||||
|                                     } else { | ||||
|                                         return '<span style="color:green">' + val + '</span>'; | ||||
|                                     } | ||||
|                                 } | ||||
|                             }, | ||||
|                             { | ||||
|                                 field: 'useNum', title: '历史白名单次数', align: 'center', valign: 'middle', width: '5%', formatter: function (val, row, index) { | ||||
|                                     var uid = row.uid; | ||||
|                                     if (whiteList[uid]) { | ||||
|                                         return whiteList[uid].useNum; | ||||
|                                     } else { | ||||
|                                         return 0; | ||||
|                                     } | ||||
|                                 } | ||||
|                             }, | ||||
|                             { | ||||
|                                 field: 'whiteStatus', title: '白名单状态', align: 'center', valign: 'middle', width: '5%', formatter: function (val, row, index) { | ||||
|                                     var uid = row.uid; | ||||
|                                     if (whiteList[uid] && whiteList[uid].availableNum > 0) { | ||||
|                                         return '<span style="color:red">待抽奖</span>'; | ||||
|                                     } else { | ||||
|                                         return '<span style="color:green">未设置</span>'; | ||||
|                                     } | ||||
|                                 } | ||||
|                             }, | ||||
|                             { | ||||
|                                 field: 'diamondUseNum', | ||||
|                                 title: '梦幻白名单次数', | ||||
|                                 align: 'center', | ||||
|                                 valign: 'middle', | ||||
|                                 width: '5%', | ||||
|                                 formatter: function (val, row, index) { | ||||
|                                     var uid = row.uid; | ||||
|                                     if (whiteList[uid]) { | ||||
|                                         return whiteList[uid].useDiamondNum; | ||||
|                                     } else { | ||||
|                                         return 0; | ||||
|                                     } | ||||
|                                 } | ||||
|                             }, | ||||
|                             { | ||||
|                                 field: 'diamondWhiteStatus', | ||||
|                                 title: '梦幻白名单状态', | ||||
|                                 align: 'center', | ||||
|                                 valign: 'middle', | ||||
|                                 width: '5%', | ||||
|                                 formatter: function (val, row, index) { | ||||
|                                     var uid = row.uid; | ||||
|                                     if (whiteList[uid] && whiteList[uid].availableDiamondNum > 0) { | ||||
|                                         return '<span style="color:red">待抽奖</span>'; | ||||
|                                     } else { | ||||
|                                         return '<span style="color:green">未设置</span>'; | ||||
|                                     } | ||||
|                                 } | ||||
|                             }, | ||||
|                             { | ||||
|                                 field: 'tmp', | ||||
|                                 title: '操作', | ||||
|                                 align: 'center', | ||||
|                                 width: '10%', | ||||
|                                 valign: 'middle', | ||||
|                                 formatter: function (val, row, index) { | ||||
|                                     var btnStr = ""; | ||||
|                                     var uid = row.uid; | ||||
|                                     if (whiteList[uid] && whiteList[uid].availableNum > 0) { | ||||
|                                         btnStr += "<button class='btn btn-sm btn-warning opt-del normal-box-del' data-id=" + uid + ">移除普通白名单</button>"; | ||||
|                                     } else { | ||||
|                                         btnStr += "<button class='btn btn-sm btn-success opt-set normal-box-set' data-id=" + uid + ">设置普通白名单</button>"; | ||||
|                                     } | ||||
|                                     if (whiteList[uid] && whiteList[uid].availableDiamondNum > 0) { | ||||
|                                         btnStr += "<button class='btn btn-sm btn-warning opt-del diamond-box-del' data-id=" + uid + ">移除梦幻白名单</button>"; | ||||
|                                     } else { | ||||
|                                         btnStr += "<button class='btn btn-sm btn-success opt-set diamond-box-set' data-id=" + uid + ">设置梦幻白名单</button>"; | ||||
|                                     } | ||||
|                                     return btnStr; | ||||
|                                 } | ||||
|                             } | ||||
|                         ], | ||||
|                         cache: false, | ||||
|                         striped: true, | ||||
|                         showRefresh: false, | ||||
|                         pageSize: 10, | ||||
|                         pagination: true, | ||||
|                         pageList: [10, 20, 30, 50], | ||||
|                         sidePagination: "server", //表示服务端请求 | ||||
|                         //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder | ||||
|                         //设置为limit可以获取limit, offset, search, sort, order | ||||
|                         queryParamsType: "undefined", | ||||
|                         queryParams: function queryParams(params) {   //设置查询参数 | ||||
|                             var param = { | ||||
|                                 pageSize: params.pageSize, | ||||
|                                 pageNumber: params.pageNumber, | ||||
|                                 msNo: $('#msNo').val(), | ||||
|                                 boxType: $("#boxType").val(), | ||||
|                                 minDis: $('#minDis').val(), | ||||
|                                 maxDis: $('#maxDis').val(), | ||||
|                                 source: $('#source').val(), | ||||
|                                 startTime: $("#startTime").val(), | ||||
|                                 endTime: $("#endTime").val() | ||||
|                             }; | ||||
|                             console.log(param); | ||||
|                             return param; | ||||
|                         }, | ||||
|                         uniqueId: 'uid', | ||||
|                         toolbar: '#toolbar', | ||||
|                         url: '/admin/box/record/statis/list', | ||||
|                         onLoadSuccess: function () {  //加载成功时执行 | ||||
|                             console.log("load success"); | ||||
|                         }, | ||||
|                         onLoadError: function () {  //加载失败时执行 | ||||
|                             console.log("load fail"); | ||||
|                         } | ||||
|                     }) | ||||
|   name: "PrizeStatisAdminNewView", | ||||
|   setup () { | ||||
|     return {}; | ||||
|   }, | ||||
|   created () { | ||||
|     this.$nextTick(function () { | ||||
|       this.initData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     initData () { | ||||
|       $(function () { | ||||
|         //searchHistory(); | ||||
|         var whiteList = {}; | ||||
|         requestWhiteList(searchHistory()); | ||||
|         function searchHistory () { | ||||
|           $('#table').bootstrapTable('destroy'); | ||||
|           $('#table').bootstrapTable({ | ||||
|             columns: [ | ||||
|               { field: 'uid', title: 'uid', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'erbanNo', title: '平台号', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'nick', title: '昵称', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'partition', title: '分区', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalPurchaseMoney', title: '历史抽奖充值总额', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalDrawMoney', title: '历史抽奖总额', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalPlatformValue', title: '历史获奖平台价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalActualValue', title: '历史获奖实际价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { | ||||
|                 field: 'deviation', title: '偏差值', align: 'center', valign: 'middle', width: '10%', formatter: function (val, row, index) { | ||||
|                   if (val > 0) { | ||||
|                     return '<span style="color:red">+' + val + '</span>'; | ||||
|                   } else { | ||||
|                     return '<span style="color:green">' + val + '</span>'; | ||||
|                   } | ||||
|                 } | ||||
|  | ||||
|                 $('#source').on('change', function () { | ||||
|                     var source = parseInt($(this).val()); | ||||
|                     if (source == 1) { | ||||
|                         $('.msNo').show(); | ||||
|                         $('.deviation').hide(); | ||||
|                     } else { | ||||
|                         $('.msNo').hide(); | ||||
|                         $('.deviation').show(); | ||||
|                     } | ||||
|                 }); | ||||
|  | ||||
|                 $('#table').on('click', '.normal-box-set', function () { | ||||
|                     var uid = $(this).data('id'); | ||||
|                     editWhiteList(uid, 1, 1); | ||||
|                 }); | ||||
|  | ||||
|                 $('#table').on('click', '.diamond-box-set', function () { | ||||
|                     var uid = $(this).data('id'); | ||||
|                     editWhiteList(uid, 1, 2); | ||||
|                 }); | ||||
|  | ||||
|                 $('#table').on('click', '.normal-box-del', function () { | ||||
|                     var uid = $(this).data('id'); | ||||
|                     editWhiteList(uid, 0, 1); | ||||
|                 }); | ||||
|  | ||||
|                 $('#table').on('click', '.diamond-box-del', function () { | ||||
|                     var uid = $(this).data('id'); | ||||
|                     editWhiteList(uid, 0, 2); | ||||
|                 }); | ||||
|                 $('#btnSearch').on('click', function () { | ||||
|                     var source = $('#source').val(); | ||||
|                     var msNo = $('#msNo').val(); | ||||
|                     var minDis = $('#minDis').val(); | ||||
|                     var maxDis = $('#maxDis').val(); | ||||
|                     if (source == 1 && msNo == '') { | ||||
|                         $("#tipMsg").text("请输入平台号"); | ||||
|                         $("#tipModal").modal('show'); | ||||
|                         return; | ||||
|                     } else if (source == 2 && (minDis == '' || maxDis == '')) { | ||||
|                         $("#tipMsg").text("请输入偏差值"); | ||||
|                         $("#tipModal").modal('show'); | ||||
|                         return; | ||||
|                     } | ||||
|                     requestWhiteList(searchHistory()); | ||||
|                 }); | ||||
|  | ||||
|                 function editWhiteList(uid, availableNum, boxType) { | ||||
|                     $.post("/admin/prizeWhiteUser/save", { uid: uid, availableNum: availableNum, boxType: boxType }, function (res) { | ||||
|                         if (res.code == 200) { | ||||
|                             if (availableNum > 0) { | ||||
|                                 $("#tipMsg").text("设置成功"); | ||||
|                             } else { | ||||
|                                 $("#tipMsg").text("移除成功"); | ||||
|                             } | ||||
|                             $("#tipModal").modal('show'); | ||||
|  | ||||
|                             requestWhiteList(function () { | ||||
|                                 TableHelper.doRefresh('#table'); | ||||
|                             }) | ||||
|                         } else { | ||||
|                             $("#tipMsg").text("设置失败"); | ||||
|                             $("#tipModal").modal('show'); | ||||
|                         } | ||||
|                     }) | ||||
|               }, | ||||
|               { | ||||
|                 field: 'useNum', title: '历史白名单次数', align: 'center', valign: 'middle', width: '5%', formatter: function (val, row, index) { | ||||
|                   var uid = row.uid; | ||||
|                   if (whiteList[uid]) { | ||||
|                     return whiteList[uid].useNum; | ||||
|                   } else { | ||||
|                     return 0; | ||||
|                   } | ||||
|                 } | ||||
|  | ||||
|                 function requestWhiteList(callback) { | ||||
|                     $.ajax({ | ||||
|                         url: '/admin/prizeWhiteUser/list', | ||||
|                         success: function (res) { | ||||
|                             console.log(res); | ||||
|                             if (res.code == 200) { | ||||
|                                 whiteList = res.data; | ||||
|                                 typeof callback === 'function' && callback(); | ||||
|                             } | ||||
|  | ||||
|                         } | ||||
|                     }) | ||||
|               }, | ||||
|               { | ||||
|                 field: 'whiteStatus', title: '白名单状态', align: 'center', valign: 'middle', width: '5%', formatter: function (val, row, index) { | ||||
|                   var uid = row.uid; | ||||
|                   if (whiteList[uid] && whiteList[uid].availableNum > 0) { | ||||
|                     return '<span style="color:red">待抽奖</span>'; | ||||
|                   } else { | ||||
|                     return '<span style="color:green">未设置</span>'; | ||||
|                   } | ||||
|                 } | ||||
|  | ||||
|                 // 初始化时间选择器 | ||||
|                 $('#startTime').datetimepicker({ | ||||
|                     format: 'yyyy-mm-dd hh:ii:00', | ||||
|                     autoclose: true | ||||
|                 }) | ||||
|                 $("#endTime").datetimepicker({ | ||||
|                     format: 'yyyy-mm-dd hh:ii:00', | ||||
|                     autoclose: true | ||||
|                 }); | ||||
|             }) | ||||
|               }, | ||||
|               { | ||||
|                 field: 'diamondUseNum', | ||||
|                 title: '梦幻白名单次数', | ||||
|                 align: 'center', | ||||
|                 valign: 'middle', | ||||
|                 width: '5%', | ||||
|                 formatter: function (val, row, index) { | ||||
|                   var uid = row.uid; | ||||
|                   if (whiteList[uid]) { | ||||
|                     return whiteList[uid].useDiamondNum; | ||||
|                   } else { | ||||
|                     return 0; | ||||
|                   } | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 field: 'diamondWhiteStatus', | ||||
|                 title: '梦幻白名单状态', | ||||
|                 align: 'center', | ||||
|                 valign: 'middle', | ||||
|                 width: '5%', | ||||
|                 formatter: function (val, row, index) { | ||||
|                   var uid = row.uid; | ||||
|                   if (whiteList[uid] && whiteList[uid].availableDiamondNum > 0) { | ||||
|                     return '<span style="color:red">待抽奖</span>'; | ||||
|                   } else { | ||||
|                     return '<span style="color:green">未设置</span>'; | ||||
|                   } | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 field: 'tmp', | ||||
|                 title: '操作', | ||||
|                 align: 'center', | ||||
|                 width: '10%', | ||||
|                 valign: 'middle', | ||||
|                 formatter: function (val, row, index) { | ||||
|                   var btnStr = ""; | ||||
|                   var uid = row.uid; | ||||
|                   if (whiteList[uid] && whiteList[uid].availableNum > 0) { | ||||
|                     btnStr += "<button class='btn btn-sm btn-warning opt-del normal-box-del' data-id=" + uid + ">移除普通白名单</button>"; | ||||
|                   } else { | ||||
|                     btnStr += "<button class='btn btn-sm btn-success opt-set normal-box-set' data-id=" + uid + ">设置普通白名单</button>"; | ||||
|                   } | ||||
|                   if (whiteList[uid] && whiteList[uid].availableDiamondNum > 0) { | ||||
|                     btnStr += "<button class='btn btn-sm btn-warning opt-del diamond-box-del' data-id=" + uid + ">移除梦幻白名单</button>"; | ||||
|                   } else { | ||||
|                     btnStr += "<button class='btn btn-sm btn-success opt-set diamond-box-set' data-id=" + uid + ">设置梦幻白名单</button>"; | ||||
|                   } | ||||
|                   return btnStr; | ||||
|                 } | ||||
|               } | ||||
|             ], | ||||
|             cache: false, | ||||
|             striped: true, | ||||
|             showRefresh: false, | ||||
|             pageSize: 10, | ||||
|             pagination: true, | ||||
|             pageList: [10, 20, 30, 50], | ||||
|             sidePagination: "server", //表示服务端请求 | ||||
|             //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder | ||||
|             //设置为limit可以获取limit, offset, search, sort, order | ||||
|             queryParamsType: "undefined", | ||||
|             queryParams: function queryParams (params) {   //设置查询参数 | ||||
|               var param = { | ||||
|                 pageSize: params.pageSize, | ||||
|                 pageNumber: params.pageNumber, | ||||
|                 msNo: $('#msNo').val(), | ||||
|                 boxType: $("#boxType").val(), | ||||
|                 minDis: $('#minDis').val(), | ||||
|                 maxDis: $('#maxDis').val(), | ||||
|                 source: $('#source').val(), | ||||
|                 startTime: $("#startTime").val(), | ||||
|                 endTime: $("#endTime").val() | ||||
|               }; | ||||
|               console.log(param); | ||||
|               return param; | ||||
|             }, | ||||
|             uniqueId: 'uid', | ||||
|             toolbar: '#toolbar', | ||||
|             url: '/admin/box/record/statis/list', | ||||
|             onLoadSuccess: function () {  //加载成功时执行 | ||||
|               console.log("load success"); | ||||
|             }, | ||||
|             onLoadError: function () {  //加载失败时执行 | ||||
|               console.log("load fail"); | ||||
|             } | ||||
|           }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|         $('#source').on('change', function () { | ||||
|           var source = parseInt($(this).val()); | ||||
|           if (source == 1) { | ||||
|             $('.msNo').show(); | ||||
|             $('.deviation').hide(); | ||||
|           } else { | ||||
|             $('.msNo').hide(); | ||||
|             $('.deviation').show(); | ||||
|           } | ||||
|         }); | ||||
|  | ||||
|         $('#table').on('click', '.normal-box-set', function () { | ||||
|           var uid = $(this).data('id'); | ||||
|           editWhiteList(uid, 1, 1); | ||||
|         }); | ||||
|  | ||||
|         $('#table').on('click', '.diamond-box-set', function () { | ||||
|           var uid = $(this).data('id'); | ||||
|           editWhiteList(uid, 1, 2); | ||||
|         }); | ||||
|  | ||||
|         $('#table').on('click', '.normal-box-del', function () { | ||||
|           var uid = $(this).data('id'); | ||||
|           editWhiteList(uid, 0, 1); | ||||
|         }); | ||||
|  | ||||
|         $('#table').on('click', '.diamond-box-del', function () { | ||||
|           var uid = $(this).data('id'); | ||||
|           editWhiteList(uid, 0, 2); | ||||
|         }); | ||||
|         $('#btnSearch').on('click', function () { | ||||
|           var source = $('#source').val(); | ||||
|           var msNo = $('#msNo').val(); | ||||
|           var minDis = $('#minDis').val(); | ||||
|           var maxDis = $('#maxDis').val(); | ||||
|           if (source == 1 && msNo == '') { | ||||
|             $("#tipMsg").text("请输入平台号"); | ||||
|             $("#tipModal").modal('show'); | ||||
|             return; | ||||
|           } else if (source == 2 && (minDis == '' || maxDis == '')) { | ||||
|             $("#tipMsg").text("请输入偏差值"); | ||||
|             $("#tipModal").modal('show'); | ||||
|             return; | ||||
|           } | ||||
|           requestWhiteList(searchHistory()); | ||||
|         }); | ||||
|  | ||||
|         function editWhiteList (uid, availableNum, boxType) { | ||||
|           $.post("/admin/prizeWhiteUser/save", { uid: uid, availableNum: availableNum, boxType: boxType }, function (res) { | ||||
|             if (res.code == 200) { | ||||
|               if (availableNum > 0) { | ||||
|                 $("#tipMsg").text("设置成功"); | ||||
|               } else { | ||||
|                 $("#tipMsg").text("移除成功"); | ||||
|               } | ||||
|               $("#tipModal").modal('show'); | ||||
|  | ||||
|               requestWhiteList(function () { | ||||
|                 TableHelper.doRefresh('#table'); | ||||
|               }) | ||||
|             } else { | ||||
|               $("#tipMsg").text("设置失败"); | ||||
|               $("#tipModal").modal('show'); | ||||
|             } | ||||
|           }) | ||||
|         } | ||||
|  | ||||
|         function requestWhiteList (callback) { | ||||
|           $.ajax({ | ||||
|             url: '/admin/prizeWhiteUser/list', | ||||
|             success: function (res) { | ||||
|               console.log(res); | ||||
|               if (res.code == 200) { | ||||
|                 whiteList = res.data; | ||||
|                 typeof callback === 'function' && callback(); | ||||
|               } | ||||
|  | ||||
|             } | ||||
|           }) | ||||
|         } | ||||
|  | ||||
|         // 初始化时间选择器 | ||||
|         $('#startTime').datetimepicker({ | ||||
|           format: 'yyyy-mm-dd hh:ii:00', | ||||
|           autoclose: true | ||||
|         }) | ||||
|         $("#endTime").datetimepicker({ | ||||
|           format: 'yyyy-mm-dd hh:ii:00', | ||||
|           autoclose: true | ||||
|         }); | ||||
|       }) | ||||
|     } | ||||
|   }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style scoped> | ||||
| .deviation { | ||||
|     display: none; | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| #toolbar label { | ||||
|     margin-right: 6px; | ||||
| }</style> | ||||
|   margin-right: 6px; | ||||
| } | ||||
| </style> | ||||
| @@ -1,296 +1,315 @@ | ||||
| <template> | ||||
|     <section class="content"> | ||||
|         <div class="box box-primary"> | ||||
|             <div class="box-body"> | ||||
|                 <section class="content-header"> | ||||
|                     <h1 id="itemTitle"></h1> | ||||
|                 </section> | ||||
|                 <section class="content"> | ||||
|                     <div id="table"></div> | ||||
|                     <div id="toolbar"> | ||||
|                         <label class="source"> | ||||
|                             选择时间: <input type="text" name="startTime" id="startTime" class="input-sm"> | ||||
|                             至 <input type="text" id="endTime" name="endTime" class="input-sm"> | ||||
|                         </label> | ||||
|                         <label class="source"> | ||||
|                             宝箱类型: <select name="boxType" id="boxType" class="input-sm"> | ||||
|                                 <option value="0">全部</option> | ||||
|                                 <option value="1">幸运许愿池</option> | ||||
|                                 <option value="2">梦幻许愿池</option> | ||||
|                             </select> | ||||
|                         </label> | ||||
|                         <label class="source"> | ||||
|                             查询凭据:<select name="source" id="source" class="input-sm"> | ||||
|                                 <option value="1">平台号</option> | ||||
|                                 <option value="2">偏差范围</option> | ||||
|                             </select> | ||||
|                         </label> | ||||
|                         <label class="msNo"> | ||||
|                             平台号:<input type="text" placeholder="请输入草莓号" id="msNo" class="input-sm"> | ||||
|                         </label> | ||||
|                         <label class="deviation"> | ||||
|                             偏差值: <input type="text" id="minDis" class="input-m"> - <input type="text" id="maxDis" | ||||
|                                 class="input-m"> | ||||
|                         </label> | ||||
|                         <button id="btnSearch" class="btn btn-sm btn-primary">查询</button> | ||||
|                     </div> | ||||
|                 </section> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|   <section class="content"> | ||||
|     <div class="box box-primary"> | ||||
|       <div class="box-body"> | ||||
|         <section class="content-header"> | ||||
|           <h1 id="itemTitle"></h1> | ||||
|         </section> | ||||
|         <section class="content"> | ||||
|           <div id="table"></div> | ||||
|           <div id="toolbar"> | ||||
|             <label class="source"> | ||||
|               选择时间: <input type="text" | ||||
|                      name="startTime" | ||||
|                      id="startTime" | ||||
|                      class="input-sm"> | ||||
|               至 <input type="text" | ||||
|                      id="endTime" | ||||
|                      name="endTime" | ||||
|                      class="input-sm"> | ||||
|             </label> | ||||
|             <label class="source"> | ||||
|               宝箱类型: <select name="boxType" | ||||
|                       id="boxType" | ||||
|                       class="input-sm"> | ||||
|                 <option value="0">全部</option> | ||||
|                 <option value="1">幸运许愿池</option> | ||||
|                 <option value="2">梦幻许愿池</option> | ||||
|               </select> | ||||
|             </label> | ||||
|             <label class="source"> | ||||
|               查询凭据:<select name="source" | ||||
|                       id="source" | ||||
|                       class="input-sm"> | ||||
|                 <option value="1">平台号</option> | ||||
|                 <option value="2">偏差范围</option> | ||||
|               </select> | ||||
|             </label> | ||||
|             <label class="msNo"> | ||||
|               平台号:<input type="text" | ||||
|                      placeholder="请输入草莓号" | ||||
|                      id="msNo" | ||||
|                      class="input-sm"> | ||||
|             </label> | ||||
|             <label class="deviation"> | ||||
|               偏差值: <input type="text" | ||||
|                      id="minDis" | ||||
|                      class="input-m"> - <input type="text" | ||||
|                      id="maxDis" | ||||
|                      class="input-m"> | ||||
|             </label> | ||||
|             <button id="btnSearch" | ||||
|                     class="btn btn-sm btn-primary">查询</button> | ||||
|           </div> | ||||
|         </section> | ||||
|       </div> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
|  | ||||
| export default { | ||||
|     name: "PrizeStatisAdminView", | ||||
|     setup() { | ||||
|         return {}; | ||||
|     }, | ||||
|     created() { | ||||
|         this.$nextTick(function () { | ||||
|             this.initData(); | ||||
|         }); | ||||
|     }, | ||||
|     methods: { | ||||
|         initData() { | ||||
|             $(function () { | ||||
|                 //searchHistory(); | ||||
|                 var whiteList = {}; | ||||
|                 requestWhiteList(searchHistory()); | ||||
|                 function searchHistory() { | ||||
|                     $('#table').bootstrapTable('destroy'); | ||||
|                     $('#table').bootstrapTable({ | ||||
|                         columns: [ | ||||
|                             { field: 'uid', title: 'uid', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'erbanNo', title: '平台号', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'nick', title: '昵称', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalPurchaseMoney', title: '历史抽奖充值总额', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalDrawMoney', title: '历史抽奖总额', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalPlatformValue', title: '历史获奖平台价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { field: 'totalActualValue', title: '历史获奖实际价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|                             { | ||||
|                                 field: 'deviation', title: '偏差值', align: 'center', valign: 'middle', width: '10%', formatter: function (val, row, index) { | ||||
|                                     if (val > 0) { | ||||
|                                         return '<span style="color:red">+' + val + '</span>'; | ||||
|                                     } else { | ||||
|                                         return '<span style="color:green">' + val + '</span>'; | ||||
|                                     } | ||||
|                                 } | ||||
|                             }, | ||||
|                             { | ||||
|                                 field: 'useNum', title: '历史白名单次数', align: 'center', valign: 'middle', width: '5%', formatter: function (val, row, index) { | ||||
|                                     var uid = row.uid; | ||||
|                                     if (whiteList[uid]) { | ||||
|                                         return whiteList[uid].useNum; | ||||
|                                     } else { | ||||
|                                         return 0; | ||||
|                                     } | ||||
|                                 } | ||||
|                             }, | ||||
|                             { | ||||
|                                 field: 'whiteStatus', title: '白名单状态', align: 'center', valign: 'middle', width: '5%', formatter: function (val, row, index) { | ||||
|                                     var uid = row.uid; | ||||
|                                     if (whiteList[uid] && whiteList[uid].availableNum > 0) { | ||||
|                                         return '<span style="color:red">待抽奖</span>'; | ||||
|                                     } else { | ||||
|                                         return '<span style="color:green">未设置</span>'; | ||||
|                                     } | ||||
|                                 } | ||||
|                             }, | ||||
|                             { | ||||
|                                 field: 'diamondUseNum', | ||||
|                                 title: '梦幻白名单次数', | ||||
|                                 align: 'center', | ||||
|                                 valign: 'middle', | ||||
|                                 width: '5%', | ||||
|                                 formatter: function (val, row, index) { | ||||
|                                     var uid = row.uid; | ||||
|                                     if (whiteList[uid]) { | ||||
|                                         return whiteList[uid].useDiamondNum; | ||||
|                                     } else { | ||||
|                                         return 0; | ||||
|                                     } | ||||
|                                 } | ||||
|                             }, | ||||
|                             { | ||||
|                                 field: 'diamondWhiteStatus', | ||||
|                                 title: '梦幻白名单状态', | ||||
|                                 align: 'center', | ||||
|                                 valign: 'middle', | ||||
|                                 width: '5%', | ||||
|                                 formatter: function (val, row, index) { | ||||
|                                     var uid = row.uid; | ||||
|                                     if (whiteList[uid] && whiteList[uid].availableDiamondNum > 0) { | ||||
|                                         return '<span style="color:red">待抽奖</span>'; | ||||
|                                     } else { | ||||
|                                         return '<span style="color:green">未设置</span>'; | ||||
|                                     } | ||||
|                                 } | ||||
|                             }, | ||||
|                             { | ||||
|                                 field: 'tmp', | ||||
|                                 title: '操作', | ||||
|                                 align: 'center', | ||||
|                                 width: '10%', | ||||
|                                 valign: 'middle', | ||||
|                                 formatter: function (val, row, index) { | ||||
|                                     var btnStr = ""; | ||||
|                                     var uid = row.uid; | ||||
|                                     if (whiteList[uid] && whiteList[uid].availableNum > 0) { | ||||
|                                         btnStr += "<button class='btn btn-sm btn-warning opt-del normal-box-del' data-id=" + uid + ">移除普通白名单</button>"; | ||||
|                                     } else { | ||||
|                                         btnStr += "<button class='btn btn-sm btn-success opt-set normal-box-set' data-id=" + uid + ">设置普通白名单</button>"; | ||||
|                                     } | ||||
|                                     if (whiteList[uid] && whiteList[uid].availableDiamondNum > 0) { | ||||
|                                         btnStr += "<button class='btn btn-sm btn-warning opt-del diamond-box-del' data-id=" + uid + ">移除梦幻白名单</button>"; | ||||
|                                     } else { | ||||
|                                         btnStr += "<button class='btn btn-sm btn-success opt-set diamond-box-set' data-id=" + uid + ">设置梦幻白名单</button>"; | ||||
|                                     } | ||||
|                                     return btnStr; | ||||
|                                 } | ||||
|                             } | ||||
|                         ], | ||||
|                         cache: false, | ||||
|                         striped: true, | ||||
|                         showRefresh: false, | ||||
|                         pageSize: 10, | ||||
|                         pagination: true, | ||||
|                         pageList: [10, 20, 30, 50], | ||||
|                         sidePagination: "server", //表示服务端请求 | ||||
|                         //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder | ||||
|                         //设置为limit可以获取limit, offset, search, sort, order | ||||
|                         queryParamsType: "undefined", | ||||
|                         queryParams: function queryParams(params) {   //设置查询参数 | ||||
|                             var param = { | ||||
|                                 pageSize: params.pageSize, | ||||
|                                 pageNumber: params.pageNumber, | ||||
|                                 msNo: $('#msNo').val(), | ||||
|                                 boxType: $("#boxType").val(), | ||||
|                                 minDis: $('#minDis').val(), | ||||
|                                 maxDis: $('#maxDis').val(), | ||||
|                                 source: $('#source').val(), | ||||
|                                 startTime: $("#startTime").val(), | ||||
|                                 endTime: $("#endTime").val() | ||||
|                             }; | ||||
|                             console.log(param); | ||||
|                             return param; | ||||
|                         }, | ||||
|                         uniqueId: 'uid', | ||||
|                         toolbar: '#toolbar', | ||||
|                         url: '/admin/box/record/statis/list', | ||||
|                         onLoadSuccess: function () {  //加载成功时执行 | ||||
|                             console.log("load success"); | ||||
|                         }, | ||||
|                         onLoadError: function () {  //加载失败时执行 | ||||
|                             console.log("load fail"); | ||||
|                         } | ||||
|                     }) | ||||
|   name: "PrizeStatisAdminView", | ||||
|   setup () { | ||||
|     return {}; | ||||
|   }, | ||||
|   created () { | ||||
|     this.$nextTick(function () { | ||||
|       this.initData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     initData () { | ||||
|       $(function () { | ||||
|         //searchHistory(); | ||||
|         var whiteList = {}; | ||||
|         requestWhiteList(searchHistory()); | ||||
|         function searchHistory () { | ||||
|           $('#table').bootstrapTable('destroy'); | ||||
|           $('#table').bootstrapTable({ | ||||
|             columns: [ | ||||
|               { field: 'uid', title: 'uid', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'erbanNo', title: '平台号', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'nick', title: '昵称', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'partition', title: '分区', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalPurchaseMoney', title: '历史抽奖充值总额', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalDrawMoney', title: '历史抽奖总额', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalPlatformValue', title: '历史获奖平台价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { field: 'totalActualValue', title: '历史获奖实际价值', align: 'center', valign: 'middle', width: '10%' }, | ||||
|               { | ||||
|                 field: 'deviation', title: '偏差值', align: 'center', valign: 'middle', width: '10%', formatter: function (val, row, index) { | ||||
|                   if (val > 0) { | ||||
|                     return '<span style="color:red">+' + val + '</span>'; | ||||
|                   } else { | ||||
|                     return '<span style="color:green">' + val + '</span>'; | ||||
|                   } | ||||
|                 } | ||||
|  | ||||
|                 $('#source').on('change', function () { | ||||
|                     var source = parseInt($(this).val()); | ||||
|                     if (source == 1) { | ||||
|                         $('.msNo').show(); | ||||
|                         $('.deviation').hide(); | ||||
|                     } else { | ||||
|                         $('.msNo').hide(); | ||||
|                         $('.deviation').show(); | ||||
|                     } | ||||
|                 }); | ||||
|  | ||||
|                 $('#table').on('click', '.normal-box-set', function () { | ||||
|                     var uid = $(this).data('id'); | ||||
|                     editWhiteList(uid, 1, 1); | ||||
|                 }); | ||||
|  | ||||
|                 $('#table').on('click', '.diamond-box-set', function () { | ||||
|                     var uid = $(this).data('id'); | ||||
|                     editWhiteList(uid, 1, 2); | ||||
|                 }); | ||||
|  | ||||
|                 $('#table').on('click', '.normal-box-del', function () { | ||||
|                     var uid = $(this).data('id'); | ||||
|                     editWhiteList(uid, 0, 1); | ||||
|                 }); | ||||
|  | ||||
|                 $('#table').on('click', '.diamond-box-del', function () { | ||||
|                     var uid = $(this).data('id'); | ||||
|                     editWhiteList(uid, 0, 2); | ||||
|                 }); | ||||
|                 $('#btnSearch').on('click', function () { | ||||
|                     var source = $('#source').val(); | ||||
|                     var msNo = $('#msNo').val(); | ||||
|                     var minDis = $('#minDis').val(); | ||||
|                     var maxDis = $('#maxDis').val(); | ||||
|                     if (source == 1 && msNo == '') { | ||||
|                         $("#tipMsg").text("请输入平台号"); | ||||
|                         $("#tipModal").modal('show'); | ||||
|                         return; | ||||
|                     } else if (source == 2 && (minDis == '' || maxDis == '')) { | ||||
|                         $("#tipMsg").text("请输入偏差值"); | ||||
|                         $("#tipModal").modal('show'); | ||||
|                         return; | ||||
|                     } | ||||
|                     requestWhiteList(searchHistory()); | ||||
|                 }); | ||||
|  | ||||
|                 function editWhiteList(uid, availableNum, boxType) { | ||||
|                     $.post("/admin/prizeWhiteUser/save", { uid: uid, availableNum: availableNum, boxType: boxType }, function (res) { | ||||
|                         if (res.code == 200) { | ||||
|                             if (availableNum > 0) { | ||||
|                                 $("#tipMsg").text("设置成功"); | ||||
|                             } else { | ||||
|                                 $("#tipMsg").text("移除成功"); | ||||
|                             } | ||||
|                             $("#tipModal").modal('show'); | ||||
|  | ||||
|                             requestWhiteList(function () { | ||||
|                                 TableHelper.doRefresh('#table'); | ||||
|                             }) | ||||
|                         } else { | ||||
|                             $("#tipMsg").text("设置失败"); | ||||
|                             $("#tipModal").modal('show'); | ||||
|                         } | ||||
|                     }) | ||||
|               }, | ||||
|               { | ||||
|                 field: 'useNum', title: '历史白名单次数', align: 'center', valign: 'middle', width: '5%', formatter: function (val, row, index) { | ||||
|                   var uid = row.uid; | ||||
|                   if (whiteList[uid]) { | ||||
|                     return whiteList[uid].useNum; | ||||
|                   } else { | ||||
|                     return 0; | ||||
|                   } | ||||
|                 } | ||||
|  | ||||
|                 function requestWhiteList(callback) { | ||||
|                     $.ajax({ | ||||
|                         url: '/admin/prizeWhiteUser/list', | ||||
|                         success: function (res) { | ||||
|                             console.log(res); | ||||
|                             if (res.code == 200) { | ||||
|                                 whiteList = res.data; | ||||
|                                 typeof callback === 'function' && callback(); | ||||
|                             } | ||||
|  | ||||
|                         } | ||||
|                     }) | ||||
|               }, | ||||
|               { | ||||
|                 field: 'whiteStatus', title: '白名单状态', align: 'center', valign: 'middle', width: '5%', formatter: function (val, row, index) { | ||||
|                   var uid = row.uid; | ||||
|                   if (whiteList[uid] && whiteList[uid].availableNum > 0) { | ||||
|                     return '<span style="color:red">待抽奖</span>'; | ||||
|                   } else { | ||||
|                     return '<span style="color:green">未设置</span>'; | ||||
|                   } | ||||
|                 } | ||||
|  | ||||
|                 // 初始化时间选择器 | ||||
|                 $('#startTime').datetimepicker({ | ||||
|                     format: 'yyyy-mm-dd hh:ii:00', | ||||
|                     autoclose: true | ||||
|                 }) | ||||
|                 $("#endTime").datetimepicker({ | ||||
|                     format: 'yyyy-mm-dd hh:ii:00', | ||||
|                     autoclose: true | ||||
|                 }); | ||||
|             }) | ||||
|               }, | ||||
|               { | ||||
|                 field: 'diamondUseNum', | ||||
|                 title: '梦幻白名单次数', | ||||
|                 align: 'center', | ||||
|                 valign: 'middle', | ||||
|                 width: '5%', | ||||
|                 formatter: function (val, row, index) { | ||||
|                   var uid = row.uid; | ||||
|                   if (whiteList[uid]) { | ||||
|                     return whiteList[uid].useDiamondNum; | ||||
|                   } else { | ||||
|                     return 0; | ||||
|                   } | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 field: 'diamondWhiteStatus', | ||||
|                 title: '梦幻白名单状态', | ||||
|                 align: 'center', | ||||
|                 valign: 'middle', | ||||
|                 width: '5%', | ||||
|                 formatter: function (val, row, index) { | ||||
|                   var uid = row.uid; | ||||
|                   if (whiteList[uid] && whiteList[uid].availableDiamondNum > 0) { | ||||
|                     return '<span style="color:red">待抽奖</span>'; | ||||
|                   } else { | ||||
|                     return '<span style="color:green">未设置</span>'; | ||||
|                   } | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 field: 'tmp', | ||||
|                 title: '操作', | ||||
|                 align: 'center', | ||||
|                 width: '10%', | ||||
|                 valign: 'middle', | ||||
|                 formatter: function (val, row, index) { | ||||
|                   var btnStr = ""; | ||||
|                   var uid = row.uid; | ||||
|                   if (whiteList[uid] && whiteList[uid].availableNum > 0) { | ||||
|                     btnStr += "<button class='btn btn-sm btn-warning opt-del normal-box-del' data-id=" + uid + ">移除普通白名单</button>"; | ||||
|                   } else { | ||||
|                     btnStr += "<button class='btn btn-sm btn-success opt-set normal-box-set' data-id=" + uid + ">设置普通白名单</button>"; | ||||
|                   } | ||||
|                   if (whiteList[uid] && whiteList[uid].availableDiamondNum > 0) { | ||||
|                     btnStr += "<button class='btn btn-sm btn-warning opt-del diamond-box-del' data-id=" + uid + ">移除梦幻白名单</button>"; | ||||
|                   } else { | ||||
|                     btnStr += "<button class='btn btn-sm btn-success opt-set diamond-box-set' data-id=" + uid + ">设置梦幻白名单</button>"; | ||||
|                   } | ||||
|                   return btnStr; | ||||
|                 } | ||||
|               } | ||||
|             ], | ||||
|             cache: false, | ||||
|             striped: true, | ||||
|             showRefresh: false, | ||||
|             pageSize: 10, | ||||
|             pagination: true, | ||||
|             pageList: [10, 20, 30, 50], | ||||
|             sidePagination: "server", //表示服务端请求 | ||||
|             //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder | ||||
|             //设置为limit可以获取limit, offset, search, sort, order | ||||
|             queryParamsType: "undefined", | ||||
|             queryParams: function queryParams (params) {   //设置查询参数 | ||||
|               var param = { | ||||
|                 pageSize: params.pageSize, | ||||
|                 pageNumber: params.pageNumber, | ||||
|                 msNo: $('#msNo').val(), | ||||
|                 boxType: $("#boxType").val(), | ||||
|                 minDis: $('#minDis').val(), | ||||
|                 maxDis: $('#maxDis').val(), | ||||
|                 source: $('#source').val(), | ||||
|                 startTime: $("#startTime").val(), | ||||
|                 endTime: $("#endTime").val() | ||||
|               }; | ||||
|               console.log(param); | ||||
|               return param; | ||||
|             }, | ||||
|             uniqueId: 'uid', | ||||
|             toolbar: '#toolbar', | ||||
|             url: '/admin/box/record/statis/list', | ||||
|             onLoadSuccess: function () {  //加载成功时执行 | ||||
|               console.log("load success"); | ||||
|             }, | ||||
|             onLoadError: function () {  //加载失败时执行 | ||||
|               console.log("load fail"); | ||||
|             } | ||||
|           }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|         $('#source').on('change', function () { | ||||
|           var source = parseInt($(this).val()); | ||||
|           if (source == 1) { | ||||
|             $('.msNo').show(); | ||||
|             $('.deviation').hide(); | ||||
|           } else { | ||||
|             $('.msNo').hide(); | ||||
|             $('.deviation').show(); | ||||
|           } | ||||
|         }); | ||||
|  | ||||
|         $('#table').on('click', '.normal-box-set', function () { | ||||
|           var uid = $(this).data('id'); | ||||
|           editWhiteList(uid, 1, 1); | ||||
|         }); | ||||
|  | ||||
|         $('#table').on('click', '.diamond-box-set', function () { | ||||
|           var uid = $(this).data('id'); | ||||
|           editWhiteList(uid, 1, 2); | ||||
|         }); | ||||
|  | ||||
|         $('#table').on('click', '.normal-box-del', function () { | ||||
|           var uid = $(this).data('id'); | ||||
|           editWhiteList(uid, 0, 1); | ||||
|         }); | ||||
|  | ||||
|         $('#table').on('click', '.diamond-box-del', function () { | ||||
|           var uid = $(this).data('id'); | ||||
|           editWhiteList(uid, 0, 2); | ||||
|         }); | ||||
|         $('#btnSearch').on('click', function () { | ||||
|           var source = $('#source').val(); | ||||
|           var msNo = $('#msNo').val(); | ||||
|           var minDis = $('#minDis').val(); | ||||
|           var maxDis = $('#maxDis').val(); | ||||
|           if (source == 1 && msNo == '') { | ||||
|             $("#tipMsg").text("请输入平台号"); | ||||
|             $("#tipModal").modal('show'); | ||||
|             return; | ||||
|           } else if (source == 2 && (minDis == '' || maxDis == '')) { | ||||
|             $("#tipMsg").text("请输入偏差值"); | ||||
|             $("#tipModal").modal('show'); | ||||
|             return; | ||||
|           } | ||||
|           requestWhiteList(searchHistory()); | ||||
|         }); | ||||
|  | ||||
|         function editWhiteList (uid, availableNum, boxType) { | ||||
|           $.post("/admin/prizeWhiteUser/save", { uid: uid, availableNum: availableNum, boxType: boxType }, function (res) { | ||||
|             if (res.code == 200) { | ||||
|               if (availableNum > 0) { | ||||
|                 $("#tipMsg").text("设置成功"); | ||||
|               } else { | ||||
|                 $("#tipMsg").text("移除成功"); | ||||
|               } | ||||
|               $("#tipModal").modal('show'); | ||||
|  | ||||
|               requestWhiteList(function () { | ||||
|                 TableHelper.doRefresh('#table'); | ||||
|               }) | ||||
|             } else { | ||||
|               $("#tipMsg").text("设置失败"); | ||||
|               $("#tipModal").modal('show'); | ||||
|             } | ||||
|           }) | ||||
|         } | ||||
|  | ||||
|         function requestWhiteList (callback) { | ||||
|           $.ajax({ | ||||
|             url: '/admin/prizeWhiteUser/list', | ||||
|             success: function (res) { | ||||
|               console.log(res); | ||||
|               if (res.code == 200) { | ||||
|                 whiteList = res.data; | ||||
|                 typeof callback === 'function' && callback(); | ||||
|               } | ||||
|  | ||||
|             } | ||||
|           }) | ||||
|         } | ||||
|  | ||||
|         // 初始化时间选择器 | ||||
|         $('#startTime').datetimepicker({ | ||||
|           format: 'yyyy-mm-dd hh:ii:00', | ||||
|           autoclose: true | ||||
|         }) | ||||
|         $("#endTime").datetimepicker({ | ||||
|           format: 'yyyy-mm-dd hh:ii:00', | ||||
|           autoclose: true | ||||
|         }); | ||||
|       }) | ||||
|     } | ||||
|   }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style scoped> | ||||
| .deviation { | ||||
|     display: none; | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| #toolbar label { | ||||
|     margin-right: 6px; | ||||
| }</style> | ||||
|   margin-right: 6px; | ||||
| } | ||||
| </style> | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -33,7 +33,7 @@ | ||||
|             <el-table-column align="center" prop="icon" label="入口icon"> | ||||
|                 <template v-slot="scope"> | ||||
|                     <el-image style="width: 100px; height: 100px" :src="scope.row.icon" :zoom-rate="1.1" | ||||
|                         :preview-src-list="[scope.row.icon]" fit="cover" preview-teleported="true" | ||||
|                         :preview-src-list="[scope.row.icon]" fit="scale-down" preview-teleported="true" | ||||
|                         hide-on-click-modal="true" /> | ||||
|                 </template> | ||||
|             </el-table-column> | ||||
|   | ||||
| @@ -33,7 +33,7 @@ | ||||
|             <el-table-column align="center" prop="icon" label="入口icon"> | ||||
|                 <template v-slot="scope"> | ||||
|                     <el-image style="width: 100px; height: 100px" :src="scope.row.icon" :zoom-rate="1.1" | ||||
|                         :preview-src-list="[scope.row.icon]" fit="cover" preview-teleported="true" | ||||
|                         :preview-src-list="[scope.row.icon]" fit="scale-down" preview-teleported="true" | ||||
|                         hide-on-click-modal="true" /> | ||||
|                 </template> | ||||
|             </el-table-column> | ||||
|   | ||||
| @@ -33,7 +33,7 @@ | ||||
|             <el-table-column align="center" prop="url" label="开屏页" width="200"> | ||||
|                 <template v-slot="scope"> | ||||
|                     <el-image style="width: 100%; height: 100px" :src="scope.row.url" :zoom-rate="1.1" | ||||
|                         :preview-src-list="[scope.row.url]" fit="cover" preview-teleported="true" | ||||
|                         :preview-src-list="[scope.row.url]" fit="scale-down" preview-teleported="true" | ||||
|                         hide-on-click-modal="true" /> | ||||
|                 </template> | ||||
|             </el-table-column> | ||||
|   | ||||
| @@ -41,7 +41,7 @@ | ||||
|             :src="scope.row.photoUrl" | ||||
|             :zoom-rate="1.1" | ||||
|             :preview-src-list="[scope.row.photoUrl]" | ||||
|             fit="cover" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|         /></template> | ||||
| @@ -58,7 +58,7 @@ | ||||
|             style="width: 30px; height: 30px; vertical-align: middle; margin-right: 6px" | ||||
|             :src="scope.row.picUrl" | ||||
|             :zoom-rate="1" | ||||
|             fit="cover" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|           /> | ||||
|           <img | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -10,15 +10,30 @@ | ||||
|         <div class="big-tips"> | ||||
|           数据量过大,不再默认加载所有的数据,请先选择时间后,再点查询按钮 | ||||
|         </div> | ||||
|         <form id="searchForm" action="/admin/roomSerial/export" method="POST"> | ||||
|         <form id="searchForm" | ||||
|               action="/admin/roomSerial/export" | ||||
|               method="POST"> | ||||
|           房主平台号(多个查询以英文逗号分隔): | ||||
|           <input type="text" name="erbanNos" id="erbanNos" class="input-sm"  style="margin-right: 40px;display: inline-block;"/> 选择时间: | ||||
|           <input type="text" name="startTime" id="startTime" class="input-sm" /> 至 | ||||
|           <input type="text" id="endTime" name="endTime" class="input-sm" /> | ||||
|           <input type="text" | ||||
|                  name="erbanNos" | ||||
|                  id="erbanNos" | ||||
|                  class="input-sm" | ||||
|                  style="margin-right: 40px;display: inline-block;" /> 选择时间: | ||||
|           <input type="text" | ||||
|                  name="startTime" | ||||
|                  id="startTime" | ||||
|                  class="input-sm" /> 至 | ||||
|           <input type="text" | ||||
|                  id="endTime" | ||||
|                  name="endTime" | ||||
|                  class="input-sm" /> | ||||
|           <br /> | ||||
|           <div style="width: 60%"> | ||||
|             房间类型: | ||||
|             <select name="isPermit" id="isPermit" class="input-sm" style="width: 30%;display: inline-block;"> | ||||
|             <select name="isPermit" | ||||
|                     id="isPermit" | ||||
|                     class="input-sm" | ||||
|                     style="width: 30%;display: inline-block;"> | ||||
|               <option value="0">全部</option> | ||||
|               <option value="1">牌照房</option> | ||||
|               <option value="3">新秀房</option> | ||||
| @@ -29,10 +44,12 @@ | ||||
|         </form> | ||||
|       </div> | ||||
|       <div class="col-sm-8"> | ||||
|         <button id="room-serial-refresh" class="btn btn-default"> | ||||
|         <button id="room-serial-refresh" | ||||
|                 class="btn btn-default"> | ||||
|           <i class="glyphicon glyphicon-wrench"></i>查询 | ||||
|         </button> | ||||
|         <button id="room-serial-export" class="btn btn-default"> | ||||
|         <button id="room-serial-export" | ||||
|                 class="btn btn-default"> | ||||
|           <i class="glyphicon glyphicon-plus"></i>导出 | ||||
|         </button> | ||||
|       </div> | ||||
| @@ -40,37 +57,40 @@ | ||||
|   </section> | ||||
|   <!-- .content --> | ||||
|  | ||||
|   <div | ||||
|     class="modal fade" | ||||
|     id="tipModal" | ||||
|     tabindex="-1" | ||||
|     role="dialog" | ||||
|     aria-labelledby="modalLabel" | ||||
|   > | ||||
|     <div class="modal-dialog" role="document"> | ||||
|   <div class="modal fade" | ||||
|        id="tipModal" | ||||
|        tabindex="-1" | ||||
|        role="dialog" | ||||
|        aria-labelledby="modalLabel"> | ||||
|     <div class="modal-dialog" | ||||
|          role="document"> | ||||
|       <div class="modal-content"> | ||||
|         <div class="modal-header"> | ||||
|           <h4 class="modal-title">提示信息</h4> | ||||
|         </div> | ||||
|         <div class="modal-body" id="tipMsg"></div> | ||||
|         <div class="modal-body" | ||||
|              id="tipMsg"></div> | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
|  | ||||
|   <div | ||||
|     class="modal fade" | ||||
|     id="roomGiftSerialDetailModal" | ||||
|     tabindex="-1" | ||||
|     role="dialog" | ||||
|     aria-labelledby="modalLabel" | ||||
|   > | ||||
|     <div class="modal-dialog" role="document"> | ||||
|   <div class="modal fade" | ||||
|        id="roomGiftSerialDetailModal" | ||||
|        tabindex="-1" | ||||
|        role="dialog" | ||||
|        aria-labelledby="modalLabel"> | ||||
|     <div class="modal-dialog" | ||||
|          role="document"> | ||||
|       <div class="modal-content"> | ||||
|         <div class="modal-header"> | ||||
|           <button type="button" class="close" data-dismiss="modal" aria-label="Close"> | ||||
|           <button type="button" | ||||
|                   class="close" | ||||
|                   data-dismiss="modal" | ||||
|                   aria-label="Close"> | ||||
|             <span aria-hidden="true">×</span> | ||||
|           </button> | ||||
|           <h4 class="modal-title" id="roomGiftSerialDetailModalTitle">房间明细</h4> | ||||
|           <h4 class="modal-title" | ||||
|               id="roomGiftSerialDetailModalTitle">房间明细</h4> | ||||
|         </div> | ||||
|         <div class="modal-body"> | ||||
|           <div class="summary col-sm-12"> | ||||
| @@ -95,7 +115,9 @@ | ||||
|         </div> | ||||
|         <div class="modal-footer"> | ||||
|           <h4 id="roundDetailModalFooter"></h4> | ||||
|           <button type="button" class="btn btn-default" data-dismiss="modal">确定</button> | ||||
|           <button type="button" | ||||
|                   class="btn btn-default" | ||||
|                   data-dismiss="modal">确定</button> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
| @@ -109,16 +131,16 @@ import { serverError } from "@/utils/maintainer"; | ||||
|  | ||||
| export default { | ||||
|   name: "RoomSerialView", | ||||
|   setup() { | ||||
|   setup () { | ||||
|     return {}; | ||||
|   }, | ||||
|   created() { | ||||
|   created () { | ||||
|     this.$nextTick(function () { | ||||
|       this.initData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     initData() { | ||||
|     initData () { | ||||
|       // ComboboxHelper.build(null, '#isPermit'); | ||||
|       $(function () { | ||||
|         $("#table").bootstrapTable("destroy"); | ||||
| @@ -140,11 +162,10 @@ export default { | ||||
|               align: "center", | ||||
|               width: "10%", | ||||
|             }, | ||||
|             { field: "totalRadish", title: "萝卜流水", align: "center", width: "10%" }, | ||||
|             // { field: "totalRadish", title: "萝卜流水", align: "center", width: "10%" }, | ||||
|             { field: "roomTitle", title: "房间标题", align: "center", width: "10%" }, | ||||
|             { field: "clanName", title: "公会名称", align: "center", width: "10%" }, | ||||
|             { field: "executionTime", title: "统计时间", align: "center", width: "15%" }, | ||||
|             { field: "executionTime", title: "统计时间", align: "center", width: "15%" }, | ||||
|             { | ||||
|               field: "id", | ||||
|               title: "操作", | ||||
| @@ -169,15 +190,11 @@ export default { | ||||
|           cache: false, | ||||
|           striped: true, | ||||
|           showRefresh: false, | ||||
|           pageSize: 10, | ||||
|           pagination: true, | ||||
|           pageList: [1, 10, 20, 30, 50], | ||||
|           pagination: false, | ||||
|           search: false, | ||||
|           sidePagination: "server", //表示服务端请求 | ||||
|           //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder | ||||
|           //设置为limit可以获取limit, offset, search, sort, order | ||||
|           queryParamsType: "undefined", | ||||
|           queryParams: function queryParams(params) { | ||||
|           queryParams: function queryParams (params) { | ||||
|             //设置查询参数 | ||||
|             var param = { | ||||
|               pageNumber: params.pageNumber, | ||||
| @@ -200,6 +217,7 @@ export default { | ||||
|           onLoadError: function () { | ||||
|             //加载失败时执行 | ||||
|             console.log("load fail"); | ||||
|             enableRefreshBtn(); | ||||
|           }, | ||||
|         }); | ||||
|  | ||||
| @@ -219,7 +237,7 @@ export default { | ||||
|  | ||||
|         $("#room-serial-refresh").click(function () { | ||||
|           disableRefreshBtn(); | ||||
|           $("#table").bootstrapTable("refresh", { url: "/admin/roomSerial/listByPage" }); | ||||
|           $("#table").bootstrapTable("refresh", { url: "/admin/roomSerial/list" }); | ||||
|         }); | ||||
|  | ||||
|         $("#room-serial-export").click(function () { | ||||
| @@ -235,11 +253,11 @@ export default { | ||||
|           } | ||||
|         }); | ||||
|  | ||||
|         function disableRefreshBtn() { | ||||
|         function disableRefreshBtn () { | ||||
|           $("#room-serial-refresh").attr("disabled", "true"); | ||||
|         } | ||||
|  | ||||
|         function enableRefreshBtn() { | ||||
|         function enableRefreshBtn () { | ||||
|           $("#room-serial-refresh").removeAttr("disabled"); | ||||
|         } | ||||
|  | ||||
| @@ -282,7 +300,7 @@ export default { | ||||
|             search: false, | ||||
|             sidePagination: "server", //表示服务端请求 | ||||
|             queryParamsType: "undefined", | ||||
|             queryParams: function queryParams(params) { | ||||
|             queryParams: function queryParams (params) { | ||||
|               //设置查询参数 | ||||
|               var param = { | ||||
|                 page: params.pageNumber, | ||||
| @@ -330,7 +348,7 @@ export default { | ||||
|           }); | ||||
|         }); | ||||
|  | ||||
|         function apiResult(json) { | ||||
|         function apiResult (json) { | ||||
|           if (json.code == 200 && json.message == "success") { | ||||
|             return true; | ||||
|           } | ||||
|   | ||||
							
								
								
									
										573
									
								
								src/views/roomBackground/appUiSet.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										573
									
								
								src/views/roomBackground/appUiSet.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,573 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>说明:</span> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <span>头图尺寸:</span> | ||||
|       <div class="text">750*280</div> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <span>icon尺寸:</span> | ||||
|       <div class="text">80*80</div> | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>首页头图:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess1" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img v-if="inquire.imageUrl1" :src="inquire.imageUrl1" class="avatar" /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(1)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>首页底图:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess2" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img v-if="inquire.imageUrl2" :src="inquire.imageUrl2" class="avatar" /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(2)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>首页icon选中状态:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess3" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img v-if="inquire.imageUrl3" :src="inquire.imageUrl3" class="avatar" /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(3)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>首页icon未选中状态:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess4" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img v-if="inquire.imageUrl4" :src="inquire.imageUrl4" class="avatar" /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(4)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>游戏icon选中状态:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess5" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img v-if="inquire.imageUrl5" :src="inquire.imageUrl5" class="avatar" /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(5)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>游戏icon未选中状态:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess6" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img v-if="inquire.imageUrl6" :src="inquire.imageUrl6" class="avatar" /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(6)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>动态icon选中状态:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess7" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img v-if="inquire.imageUrl7" :src="inquire.imageUrl7" class="avatar" /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(7)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>动态icon未选中状态:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess8" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img v-if="inquire.imageUrl8" :src="inquire.imageUrl8" class="avatar" /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(8)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>消息icon选中状态:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess9" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img v-if="inquire.imageUrl9" :src="inquire.imageUrl9" class="avatar" /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(9)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>消息icon未选中状态:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess10" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img | ||||
|           v-if="inquire.imageUrl10" | ||||
|           :src="inquire.imageUrl10" | ||||
|           class="avatar" | ||||
|         /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(10)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>我的icon选中状态:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess11" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img | ||||
|           v-if="inquire.imageUrl11" | ||||
|           :src="inquire.imageUrl11" | ||||
|           class="avatar" | ||||
|         /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(11)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>我的icon未选中状态:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess12" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img | ||||
|           v-if="inquire.imageUrl12" | ||||
|           :src="inquire.imageUrl12" | ||||
|           class="avatar" | ||||
|         /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(12)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>横条icon:</span> | ||||
|       <el-upload | ||||
|         class="avatar-uploader" | ||||
|         action="/admin/tencent/cos/upload/file" | ||||
|         :show-file-list="false" | ||||
|         :on-success="handleAvatarSuccess13" | ||||
|         :before-upload="beforeAvatarUpload" | ||||
|         :on-error="handleAvatarError" | ||||
|       > | ||||
|         <img | ||||
|           v-if="inquire.imageUrl13" | ||||
|           :src="inquire.imageUrl13" | ||||
|           class="avatar" | ||||
|         /> | ||||
|         <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|       </el-upload> | ||||
|       <el-button class="primary but" type="primary" @click="defaultFun(13)" | ||||
|         >恢复默认</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <div class="inquireBox"> | ||||
|       <span>背景颜色:</span> | ||||
|       <el-input | ||||
|         v-model="inquire.color" | ||||
|         placeholder="例如:#FFFFFF" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <el-button | ||||
|       style="margin-bottom: 20px" | ||||
|       class="primary but" | ||||
|       type="primary" | ||||
|       @click="seave()" | ||||
|       >保存设置</el-button | ||||
|     > | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   appUiSetting, | ||||
|   appUiSettingSave, | ||||
| } from "@/api/roomBackground/roomBackground"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage, ElTable } from "element-plus"; | ||||
| import { ref } from "vue"; | ||||
| import { ElMessageBox } from "element-plus"; // 正确引入 ElM | ||||
| export default { | ||||
|   name: "appUiSet", | ||||
|   data() { | ||||
|     return { | ||||
|       inquire: { | ||||
|         imageUrl1: "", | ||||
|         imageUrl2: "", | ||||
|         imageUrl3: "", | ||||
|         imageUrl4: "", | ||||
|         imageUrl5: "", | ||||
|         imageUrl6: "", | ||||
|         imageUrl7: "", | ||||
|         imageUrl8: "", | ||||
|         imageUrl9: "", | ||||
|         imageUrl10: "", | ||||
|         imageUrl11: "", | ||||
|         imageUrl12: "", | ||||
|         imageUrl13: "", | ||||
|         color: "", | ||||
|       }, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       appUiSetting().then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           console.log(res.data); | ||||
|           this.inquire.imageUrl1 = res.data.headIcon; | ||||
|           this.inquire.imageUrl2 = res.data.navbar; | ||||
|           this.inquire.imageUrl3 = res.data.homeSelectIcon; | ||||
|           this.inquire.imageUrl4 = res.data.homeUnSelectIcon; | ||||
|           this.inquire.imageUrl5 = res.data.gameSelectIcon; | ||||
|           this.inquire.imageUrl6 = res.data.gameUnSelectIcon; | ||||
|           this.inquire.imageUrl7 = res.data.dynamicSelectIcon; | ||||
|           this.inquire.imageUrl8 = res.data.dynamicUnSelectIcon; | ||||
|           this.inquire.imageUrl9 = res.data.msgSelectIcon; | ||||
|           this.inquire.imageUrl10 = res.data.msgUnSelectIcon; | ||||
|           this.inquire.imageUrl11 = res.data.mineSelectIcon; | ||||
|           this.inquire.imageUrl12 = res.data.mineUnSelectIcon; | ||||
|           this.inquire.imageUrl13 = res.data.selectBar; | ||||
|           this.inquire.color = res.data.backgroundColor; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     seave() { | ||||
|       var obj = { | ||||
|         headIcon: this.inquire.imageUrl1, | ||||
|         navbar: this.inquire.imageUrl2, | ||||
|         homeSelectIcon: this.inquire.imageUrl3, | ||||
|         homeUnSelectIcon: this.inquire.imageUrl4, | ||||
|         gameSelectIcon: this.inquire.imageUrl5, | ||||
|         gameUnSelectIcon: this.inquire.imageUrl6, | ||||
|         dynamicSelectIcon: this.inquire.imageUrl7, | ||||
|         dynamicUnSelectIcon: this.inquire.imageUrl8, | ||||
|         msgSelectIcon: this.inquire.imageUrl9, | ||||
|         msgUnSelectIcon: this.inquire.imageUrl10, | ||||
|         mineSelectIcon: this.inquire.imageUrl11, | ||||
|         mineUnSelectIcon: this.inquire.imageUrl12, | ||||
|         selectBar: this.inquire.imageUrl13, | ||||
|         backgroundColor: this.inquire.color, | ||||
|       }; | ||||
|       // obj = JSON.stringify(obj); | ||||
|       appUiSettingSave(obj).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "保存成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     defaultFun(num){ | ||||
|       console.log(this.inquire); | ||||
|       console.log(this.inquire[`imageUrl${num}`]); | ||||
|       this.inquire[`imageUrl${num}`] = ''; | ||||
|       console.log(this.inquire); | ||||
|     }, | ||||
|     handleAvatarSuccess1(res, file) { | ||||
|       this.inquire.imageUrl1 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess2(res, file) { | ||||
|       this.inquire.imageUrl2 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess3(res, file) { | ||||
|       this.inquire.imageUrl3 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess4(res, file) { | ||||
|       this.inquire.imageUrl4 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess5(res, file) { | ||||
|       this.inquire.imageUrl5 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess6(res, file) { | ||||
|       this.inquire.imageUrl6 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess7(res, file) { | ||||
|       this.inquire.imageUrl7 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess8(res, file) { | ||||
|       this.inquire.imageUrl8 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess9(res, file) { | ||||
|       this.inquire.imageUrl9 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess10(res, file) { | ||||
|       this.inquire.imageUrl10 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess11(res, file) { | ||||
|       this.inquire.imageUrl11 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess12(res, file) { | ||||
|       this.inquire.imageUrl12 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess13(res, file) { | ||||
|       this.inquire.imageUrl13 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     beforeAvatarUpload() { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传中~", | ||||
|         type: "warning", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarError() { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传失败!", | ||||
|         type: "error", | ||||
|       }); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .text { | ||||
|       display: inline-block; | ||||
|     } | ||||
|   } | ||||
|   .inquireBox { | ||||
|     margin-top: 10px; | ||||
|     margin-bottom: 10px; | ||||
|     display: flex; | ||||
|     align-items: center; | ||||
|     span { | ||||
|       display: block; | ||||
|       margin-right: 20px; | ||||
|       width: 100px; | ||||
|     } | ||||
|     .but { | ||||
|       margin-left: 20px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| .selectBox { | ||||
|   display: flex; | ||||
|   height: 35px; | ||||
|   line-height: 35px; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| .selectBoxImg { | ||||
|   height: 150px; | ||||
| } | ||||
| .pagination { | ||||
|   margin: 10px auto 10px; | ||||
|   position: relative; | ||||
|   left: 50%; | ||||
|   transform: translateX(-50%); | ||||
| } | ||||
| .pagination_in { | ||||
|   text-align: center; | ||||
| } | ||||
| .dialogBox { | ||||
|   width: 100%; | ||||
|   //   height: 50px; | ||||
|   //   line-height: 50px; | ||||
|   display: flex; | ||||
|   align-items: baseline; | ||||
|   margin-bottom: 20px; | ||||
|   .input { | ||||
|     width: 50%; | ||||
|   } | ||||
|   .selectBox { | ||||
|     display: flex; | ||||
|     height: 35px; | ||||
|     line-height: 35px; | ||||
|     margin-bottom: 20px; | ||||
|   } | ||||
|   .selectBoxImg { | ||||
|     height: 150px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										683
									
								
								src/views/roomBackground/roomBackground.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										683
									
								
								src/views/roomBackground/roomBackground.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,683 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>分区</span> | ||||
|       <el-select v-model="inquire.partitionId" placeholder="请选择"> | ||||
|         <el-option | ||||
|           v-for="item in inquire.partitionArr" | ||||
|           :key="item.id" | ||||
|           :label="item.desc" | ||||
|           :value="item.id" | ||||
|         > | ||||
|         </el-option> | ||||
|       </el-select> | ||||
|     </div> | ||||
|     <!-- 名称 --> | ||||
|     <div class="inquire"> | ||||
|       <span class="demonstration">id</span> | ||||
|       <el-input v-model="inquire.id" placeholder="" class="input"></el-input> | ||||
|     </div> | ||||
|     <!-- 状态 --> | ||||
|     <div class="inquire"> | ||||
|       <span>状态</span> | ||||
|       <el-select v-model="inquire.status" placeholder="请选择"> | ||||
|         <el-option | ||||
|           v-for="item in inquire.statusArr" | ||||
|           :key="item.status" | ||||
|           :label="item.desc" | ||||
|           :value="item.status" | ||||
|         > | ||||
|         </el-option> | ||||
|       </el-select> | ||||
|     </div> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button | ||||
|       class="primary" | ||||
|       type="primary" | ||||
|       @click=" | ||||
|         tableData = []; | ||||
|         currentPage = 1; | ||||
|         isFinished = false; | ||||
|         getData(); | ||||
|       " | ||||
|       >查询</el-button | ||||
|     > | ||||
|     <!-- 重置按钮 --> | ||||
|     <el-button | ||||
|       class="primary" | ||||
|       type="primary" | ||||
|       @click=" | ||||
|         inquire.partitionId = ''; | ||||
|         inquire.id = ''; | ||||
|         inquire.status = ''; | ||||
|         getData(); | ||||
|       " | ||||
|       >重置按钮</el-button | ||||
|     > | ||||
|     <!-- 新增按钮 --> | ||||
|     <el-button | ||||
|       class="primary" | ||||
|       type="primary" | ||||
|       @click=" | ||||
|         dialogVisibleTitle = '新增'; | ||||
|         dialogVisibleTitleType = 1; | ||||
|         dialogObj.checkedArr = []; | ||||
|         dialogObj.radio = '0'; | ||||
|         dialogObj.imageUrl1 = ''; | ||||
|         dialogObj.imageUrl2 = ''; | ||||
|         dialogObj.imageUrl3 = ''; | ||||
|         dialogObj.price = ''; | ||||
|         dialogObj.renew = ''; | ||||
|         dialogObj.originalPrice = ''; | ||||
|         dialogObj.day = ''; | ||||
|         dialogObj.sort = ''; | ||||
|         dialogObj.radio2 = '1'; | ||||
|         dialogVisible = true; | ||||
|       " | ||||
|       >新增</el-button | ||||
|     > | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       ref="multipleTable" | ||||
|       @selection-change="handleSelectionChange" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="id" align="center" label="id" /> | ||||
|       <el-table-column prop="type" align="center" label="是否免费"> | ||||
|         <template v-slot="scope">{{ | ||||
|           scope.row.type == 0 ? "免费" : scope.row.type == 1 ? "付费" : "自定义" | ||||
|         }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="buyGoldPrice" align="center" label="购买价格" /> | ||||
|       <el-table-column prop="renewGoldPrice" align="center" label="续费价格" /> | ||||
|       <el-table-column prop="originalGoldPrice" align="center" label="原价" /> | ||||
|       <el-table-column prop="buyHour" align="center" label="有效期" /> | ||||
|       <el-table-column prop="seq" align="center" label="排序" /> | ||||
|       <el-table-column prop="status" align="center" label="上架状态"> | ||||
|         <template v-slot="scope">{{ | ||||
|           scope.row.status == 1 ? "上架" : "下架" | ||||
|         }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="url" align="center" label="图片"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-image | ||||
|             style="width: 100px; height: 100px" | ||||
|             :src="scope.row.url" | ||||
|             :zoom-rate="1.1" | ||||
|             :preview-src-list="[scope.row.url]" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|           /> | ||||
|           <!-- <div | ||||
|             v-show="scope.row.url.toLowerCase().endsWith('.svga')" | ||||
|             :id="'guide' + scope.row.id" | ||||
|             class="game-guide" | ||||
|           > | ||||
|             {{ guideFn(scope.row.id, scope.row.url) }} | ||||
|           </div> --> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="createTime" align="center" label="创建时间" /> | ||||
|       <el-table-column prop="partitionDesc" align="center" label="分区" /> | ||||
|       <el-table-column prop="adminUser" align="center" label="操作人" /> | ||||
|       <el-table-column align="center" label="操作"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             @click=" | ||||
|               dialogVisibleTitle = '编辑'; | ||||
|               dialogVisibleTitleType = 2; | ||||
|               dialogObj.checkedArr = checkedArrFun(scope.row.partitionFlag); | ||||
|               dialogObj.radio = scope.row.type.toString(); | ||||
|               dialogObj.price = scope.row.buyGoldPrice; | ||||
|               dialogObj.renew = scope.row.renewGoldPrice; | ||||
|               dialogObj.originalPrice = scope.row.originalGoldPrice; | ||||
|               dialogObj.day = scope.row.buyHour; | ||||
|               dialogObj.sort = scope.row.seq; | ||||
|               dialogObj.radio2 = scope.row.status.toString(); | ||||
|               dialogObj.imageUrl2 = scope.row.url; | ||||
|               dialogObj.imageUrl1 = ''; | ||||
|               dialogObj.imageUrl3 = ''; | ||||
|               dialogObj.id = scope.row.id; | ||||
|               dialogVisible = true; | ||||
|             " | ||||
|             >编辑</el-button | ||||
|           > | ||||
|           <!-- <el-button class="primary" type="primary" @click="del(scope.row)" | ||||
|             >删除</el-button | ||||
|           > --> | ||||
|           <!-- 删除弹出框 --> | ||||
|           <!-- <el-popover | ||||
|             v-model:visible="scope.row.visible1" | ||||
|             placement="top" | ||||
|             :width="160" | ||||
|           > | ||||
|             <p>确定要删除么?</p> | ||||
|             <div style="text-align: right; margin: 0"> | ||||
|               <el-button size="small" @click="scope.row.visible1 = false"> | ||||
|                 取消 | ||||
|               </el-button> | ||||
|               <el-button | ||||
|                 size="small" | ||||
|                 type="primary" | ||||
|                 @click="pass(scope.row.id)" | ||||
|               > | ||||
|                 确认 | ||||
|               </el-button> | ||||
|             </div> | ||||
|             <template #reference> | ||||
|               <el-button | ||||
|                 class="danger" | ||||
|                 type="danger" | ||||
|                 @click="scope.row.visible1 = true" | ||||
|                 >删除</el-button | ||||
|               > --> | ||||
|           <!-- </template> | ||||
|           </el-popover> --> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|  | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[1, 10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|  | ||||
|     <!-- 新增或编辑 --> | ||||
|     <el-dialog | ||||
|       v-model="dialogVisible" | ||||
|       :title="dialogVisibleTitle" | ||||
|       center | ||||
|       :width="500" | ||||
|     > | ||||
|       <div class="dialogBox"> | ||||
|         <span>分区:</span> | ||||
|         <el-checkbox-group v-model="dialogObj.checkedArr"> | ||||
|           <el-checkbox | ||||
|             v-for="(item, i) in inquire.partitionArr" | ||||
|             :key="i" | ||||
|             :label="item.id" | ||||
|             >{{ item.desc }}</el-checkbox | ||||
|           > | ||||
|         </el-checkbox-group> | ||||
|       </div> | ||||
|       <div class="dialogBox"> | ||||
|         <span>是否免费:</span> | ||||
|         <div> | ||||
|           <el-radio v-model="dialogObj.radio" label="0">是</el-radio> | ||||
|           <el-radio v-model="dialogObj.radio" label="1">否</el-radio> | ||||
|         </div> | ||||
|       </div> | ||||
|       <!-- <div class="dialogBox"> | ||||
|         <span>房内图标:</span> | ||||
|         <el-upload | ||||
|           class="avatar-uploader" | ||||
|           action="/admin/tencent/cos/upload/file" | ||||
|           :show-file-list="false" | ||||
|           :on-success="handleAvatarSuccess" | ||||
|           :before-upload="beforeAvatarUpload" | ||||
|           :on-error="handleAvatarError" | ||||
|         > | ||||
|           <img | ||||
|             v-if="dialogObj.imageUrl1" | ||||
|             :src="dialogObj.imageUrl1" | ||||
|             class="avatar" | ||||
|           /> | ||||
|           <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|         </el-upload> | ||||
|       </div> --> | ||||
|       <div class="dialogBox"> | ||||
|         <span>购买价格:</span> | ||||
|         <el-input | ||||
|           v-model="dialogObj.price" | ||||
|           placeholder="如果是免费请写0" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <div class="dialogBox"> | ||||
|         <span>续费价格:</span> | ||||
|         <el-input | ||||
|           v-model="dialogObj.renew" | ||||
|           placeholder="如果是免费请写0" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <div class="dialogBox"> | ||||
|         <span>原价:</span> | ||||
|         <el-input | ||||
|           v-model="dialogObj.originalPrice" | ||||
|           placeholder="如果是免费请写0" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <div class="dialogBox"> | ||||
|         <span>有效天数:</span> | ||||
|         <el-input | ||||
|           v-model="dialogObj.day" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <div class="dialogBox"> | ||||
|         <span>排序:</span> | ||||
|         <el-input | ||||
|           v-model="dialogObj.sort" | ||||
|           placeholder="" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <div class="dialogBox"> | ||||
|         <span>状态:</span> | ||||
|         <div> | ||||
|           <el-radio v-model="dialogObj.radio2" label="1">上架</el-radio> | ||||
|           <el-radio v-model="dialogObj.radio2" label="-1">下架</el-radio> | ||||
|         </div> | ||||
|       </div> | ||||
|       <div class="dialogBox"> | ||||
|         <span>背景图片:</span> | ||||
|         <el-upload | ||||
|           class="avatar-uploader" | ||||
|           action="/admin/tencent/cos/upload/file" | ||||
|           :show-file-list="false" | ||||
|           :on-success="handleAvatarSuccess2" | ||||
|           :before-upload="beforeAvatarUpload" | ||||
|           :on-error="handleAvatarError" | ||||
|         > | ||||
|           <!-- 这里是原来的图片预览 --> | ||||
|           <el-image | ||||
|              | ||||
|             style="width: 100px; height: 100px" | ||||
|             :src="dialogObj.imageUrl2" | ||||
|             :zoom-rate="1.1" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|           /> | ||||
|           <!-- <div | ||||
|             v-show="dialogObj.imageUrl2.toLowerCase().endsWith('.svga')" | ||||
|             id="guide2" | ||||
|             class="game-guide" | ||||
|           > | ||||
|             {{ guideFn2(dialogObj.imageUrl2) }} | ||||
|           </div> --> | ||||
|         </el-upload> | ||||
|       </div> | ||||
|       <!-- <div class="dialogBox"> | ||||
|         <span>动效图片:</span> | ||||
|         <el-upload | ||||
|           class="avatar-uploader" | ||||
|           action="/admin/tencent/cos/upload/file" | ||||
|           :show-file-list="false" | ||||
|           :on-success="handleAvatarSuccess3" | ||||
|           :before-upload="beforeAvatarUpload" | ||||
|           :on-error="handleAvatarError" | ||||
|         > | ||||
|           <img | ||||
|             v-if="dialogObj.imageUrl3" | ||||
|             :src="dialogObj.imageUrl3" | ||||
|             class="avatar" | ||||
|           /> | ||||
|           <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon> | ||||
|         </el-upload> | ||||
|       </div> --> | ||||
|       <template #footer> | ||||
|         <div class="dialog-footer"> | ||||
|           <el-button @click="dialogVisible = false">取消</el-button> | ||||
|           <el-button type="primary" @click="addNeid(dialogVisibleTitleType)" | ||||
|             >确认</el-button | ||||
|           > | ||||
|         </div> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   listPartitionInfo, | ||||
|   page, | ||||
|   roomBackgroundAdd, | ||||
|   roomBackgroundUpdate, | ||||
| } from "@/api/roomBackground/roomBackground"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage, ElTable } from "element-plus"; | ||||
| import { ref, onMounted, nextTick } from "vue"; | ||||
| import SVGA from "svgaplayerweb"; | ||||
| export default { | ||||
|   name: "roomBackground", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         partitionId: "", | ||||
|         partitionArr: [], | ||||
|         id: "", | ||||
|         status: "", | ||||
|         statusArr: [ | ||||
|           { | ||||
|             status: "1", | ||||
|             desc: "上架", | ||||
|           }, | ||||
|           { | ||||
|             status: "-1", | ||||
|             desc: "下架", | ||||
|           }, | ||||
|         ], | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 分页 | ||||
|       total: 0, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|       isLoading: false, // 加载状态 | ||||
|       isFinished: false, // 是否加载完成 | ||||
|       //   删除相关 | ||||
|       visible: false, | ||||
|       //   编辑新增 | ||||
|       dialogVisible: false, | ||||
|       dialogVisibleTitle: "新增", | ||||
|       dialogVisibleTitleType: 1, //1新增2编辑 | ||||
|       dialogObj: { | ||||
|         checkedArr: [], | ||||
|         radio: "1", | ||||
|         imageUrl1: "", | ||||
|         imageUrl2: "", | ||||
|         imageUrl3: "", | ||||
|         price: "", | ||||
|         renew: "", | ||||
|         originalPrice: "", | ||||
|         day: "", | ||||
|         sort: "", | ||||
|         radio2: "1", | ||||
|         id: null, | ||||
|       }, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     listPartitionInfo().then((res) => { | ||||
|       console.log(res); | ||||
|       this.inquire.partitionArr = res.data; | ||||
|       this.getData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     guideFn(id, url) { | ||||
|       // 等待 DOM 渲染完成 | ||||
|       this.$nextTick(() => { | ||||
|         const guideElement = document.getElementById("guide" + id); | ||||
|         if (guideElement && url.toLowerCase().endsWith(".svga")) { | ||||
|           let player = new SVGA.Player(guideElement); | ||||
|           let parser = new SVGA.Parser(); | ||||
|           parser.load(url, (videoItem) => { | ||||
|             // 你的svga文件路径 | ||||
|             player.setVideoItem(videoItem); | ||||
|             player.startAnimation(); // 开始动画 | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     guideFn2(url) { | ||||
|       // 等待 DOM 渲染完成 | ||||
|       this.$nextTick(() => { | ||||
|         const guideElement = document.getElementById("guide2"); | ||||
|         if (guideElement && url.toLowerCase().endsWith(".svga")) { | ||||
|           let player = new SVGA.Player(guideElement); | ||||
|           let parser = new SVGA.Parser(); | ||||
|           parser.load(url, (videoItem) => { | ||||
|             // 你的 svga 文件路径 | ||||
|             player.setVideoItem(videoItem); | ||||
|             player.startAnimation(); // 开始动画 | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.isLoading = true; | ||||
|       this.loading = true; | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       page({ | ||||
|         partitionId: this.inquire.partitionId, | ||||
|         id: this.inquire.id, | ||||
|         status: this.inquire.status, | ||||
|         page: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           this.tableData = res.data.rows; | ||||
|           this.total = res.data.total; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 确认新增/确认编辑 | ||||
|     addNeid(type) { | ||||
|       if (type == 1) { | ||||
|         var partitionIdNum = this.dialogObj.checkedArr.reduce( | ||||
|           (accumulator, currentValue) => { | ||||
|             return accumulator + currentValue; | ||||
|           }, | ||||
|           0 | ||||
|         ); | ||||
|         roomBackgroundAdd({ | ||||
|           partitionId: partitionIdNum, | ||||
|           type: this.dialogObj.radio, | ||||
|           buyGoldPrice: this.dialogObj.price, | ||||
|           renewGoldPrice: this.dialogObj.renew, | ||||
|           originalGoldPrice: this.dialogObj.originalPrice, | ||||
|           buyHour: this.dialogObj.day, | ||||
|           seq: this.dialogObj.sort, | ||||
|           status: this.dialogObj.radio2, | ||||
|           url: this.dialogObj.imageUrl2, | ||||
|         }).then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             this.dialogVisible = false; | ||||
|             this.getData(); | ||||
|           } else { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "error", | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       } else { | ||||
|         var partitionIdNumEid = this.dialogObj.checkedArr.reduce( | ||||
|           (accumulator, currentValue) => { | ||||
|             return accumulator + currentValue; | ||||
|           }, | ||||
|           0 | ||||
|         ); | ||||
|         roomBackgroundUpdate({ | ||||
|           partitionId: partitionIdNumEid, | ||||
|           type: this.dialogObj.radio, | ||||
|           buyGoldPrice: this.dialogObj.price, | ||||
|           renewGoldPrice: this.dialogObj.renew, | ||||
|           originalGoldPrice: this.dialogObj.originalPrice, | ||||
|           buyHour: this.dialogObj.day, | ||||
|           seq: this.dialogObj.sort, | ||||
|           status: this.dialogObj.radio2, | ||||
|           url: this.dialogObj.imageUrl2, | ||||
|           id: this.dialogObj.id, | ||||
|         }).then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             this.dialogVisible = false; | ||||
|             this.getData(); | ||||
|           } else { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "error", | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
|     checkedArrFun(num) { | ||||
|       const arr = this.inquire.partitionArr | ||||
|         .filter((p) => { | ||||
|           return num == 0 || p.id == (p.id & num); | ||||
|         }) | ||||
|         .map((p) => p.id); | ||||
|       return arr; | ||||
|     }, | ||||
|     handleAvatarSuccess(res, file) { | ||||
|       console.log(file); | ||||
|       // this.operation.imageUrl1 = URL.createObjectURL(); | ||||
|       this.dialogObj.imageUrl1 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess2(res, file) { | ||||
|       console.log(file); | ||||
|       // this.operation.imageUrl1 = URL.createObjectURL(); | ||||
|       this.dialogObj.imageUrl2 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess3(res, file) { | ||||
|       console.log(file); | ||||
|       // this.operation.imageUrl1 = URL.createObjectURL(); | ||||
|       this.dialogObj.imageUrl3 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     beforeAvatarUpload() { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传中~", | ||||
|         type: "warning", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarError() { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传失败!", | ||||
|         type: "error", | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
|   mounted() {}, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| .selectBox { | ||||
|   display: flex; | ||||
|   height: 35px; | ||||
|   line-height: 35px; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| .selectBoxImg { | ||||
|   height: 150px; | ||||
| } | ||||
| .pagination { | ||||
|   margin: 10px auto 10px; | ||||
|   position: relative; | ||||
|   left: 50%; | ||||
|   transform: translateX(-50%); | ||||
| } | ||||
| .pagination_in { | ||||
|   text-align: center; | ||||
| } | ||||
| .dialogBox { | ||||
|   width: 100%; | ||||
|   //   height: 50px; | ||||
|   //   line-height: 50px; | ||||
|   display: flex; | ||||
|   align-items: baseline; | ||||
|   margin-bottom: 20px; | ||||
|   .input { | ||||
|     width: 50%; | ||||
|   } | ||||
|   .selectBox { | ||||
|     display: flex; | ||||
|     height: 35px; | ||||
|     line-height: 35px; | ||||
|     margin-bottom: 20px; | ||||
|   } | ||||
|   .selectBoxImg { | ||||
|     height: 150px; | ||||
|   } | ||||
| } | ||||
| .game-guide { | ||||
|   width: 100px; | ||||
|   height: 100px; | ||||
|   overflow: hidden; | ||||
|   // left: 50%; | ||||
|   // top: 50%; | ||||
|   // transform: translate(-50%,-50%); | ||||
|   canvas { | ||||
|     position: absolute; | ||||
|     left: 0; | ||||
|     top: 0; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										425
									
								
								src/views/roomBackground/roomBackgroundCustom.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										425
									
								
								src/views/roomBackground/roomBackgroundCustom.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,425 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>分区</span> | ||||
|       <el-select v-model="inquire.partitionId" placeholder="请选择"> | ||||
|         <el-option | ||||
|           v-for="item in inquire.partitionArr" | ||||
|           :key="item.id" | ||||
|           :label="item.desc" | ||||
|           :value="item.id" | ||||
|         > | ||||
|         </el-option> | ||||
|       </el-select> | ||||
|     </div> | ||||
|     <!-- 名称 --> | ||||
|     <div class="inquire"> | ||||
|       <span class="demonstration">用户ID</span> | ||||
|       <el-input v-model="inquire.id" placeholder="" class="input"></el-input> | ||||
|     </div> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" type="primary" @click="getData()" | ||||
|       >查询</el-button | ||||
|     > | ||||
|     <el-button | ||||
|       class="primary" | ||||
|       type="primary" | ||||
|       @click=" | ||||
|         inquire.partitionId = null; | ||||
|         inquire.id = null; | ||||
|         getData(); | ||||
|       " | ||||
|       >重置搜索</el-button | ||||
|     > | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       ref="multipleTable" | ||||
|       @selection-change="handleSelectionChange" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="id" align="center" label="数字" /> | ||||
|       <el-table-column prop="erbanNo" align="center" label="用户ID" /> | ||||
|       <el-table-column prop="nick" align="center" label="用户昵称" /> | ||||
|       <el-table-column prop="partitionDesc" align="center" label="所在区" /> | ||||
|       <el-table-column prop="createTime" align="center" label="申请时间" /> | ||||
|       <el-table-column prop="url" align="center" label="图片"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-image | ||||
|             v-if="scope.row.url" | ||||
|             style="width: 100px; height: 100px" | ||||
|             :src="scope.row.url" | ||||
|             :zoom-rate="1.1" | ||||
|             :preview-src-list="[scope.row.url]" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|           /> | ||||
|           <div v-else>/</div> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="status" align="center" label="状态"> | ||||
|         <template v-slot="scope">{{ | ||||
|           scope.row.status < 0 | ||||
|             ? "过期" | ||||
|             : scope.row.status == 0 | ||||
|             ? "审核中" | ||||
|             : scope.row.status == 1 | ||||
|             ? "通过" | ||||
|             : "不通过" | ||||
|         }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="updateTime" align="center" label="审核时间" /> | ||||
|       <el-table-column prop="adminUser" align="center" label="操作人"> | ||||
|         <template v-slot="scope">{{ | ||||
|           scope.row.adminUser ? scope.row.adminUser : "-" | ||||
|         }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="操作" width="300"> | ||||
|         <template v-slot="scope"> | ||||
|           <!-- 通过弹出框 --> | ||||
|           <el-popover | ||||
|             v-model:visible="scope.row.visible1" | ||||
|             placement="top" | ||||
|             :width="160" | ||||
|           > | ||||
|             <p>确定要通过么?</p> | ||||
|             <div style="text-align: right; margin: 0"> | ||||
|               <el-button size="small" @click="scope.row.visible1 = false"> | ||||
|                 取消 | ||||
|               </el-button> | ||||
|               <el-button | ||||
|                 size="small" | ||||
|                 type="primary" | ||||
|                 @click="pass(scope.row.id)" | ||||
|               > | ||||
|                 确认 | ||||
|               </el-button> | ||||
|             </div> | ||||
|             <template #reference> | ||||
|               <el-button | ||||
|                 v-show="scope.row.status == 0" | ||||
|                 class="primary" | ||||
|                 type="primary" | ||||
|                 @click="scope.row.visible1 = true" | ||||
|                 >通过</el-button | ||||
|               > | ||||
|             </template> | ||||
|           </el-popover> | ||||
|  | ||||
|           <!-- 拒绝弹出框 --> | ||||
|           <el-popover | ||||
|             v-model:visible="scope.row.visible2" | ||||
|             placement="top" | ||||
|             :width="160" | ||||
|           > | ||||
|             <p>确定要拒绝么?</p> | ||||
|             <div style="text-align: right; margin: 0"> | ||||
|               <el-button size="small" @click="scope.row.visible2 = false"> | ||||
|                 取消 | ||||
|               </el-button> | ||||
|               <el-button | ||||
|                 size="small" | ||||
|                 type="primary" | ||||
|                 @click="reject(scope.row.id)" | ||||
|               > | ||||
|                 确认 | ||||
|               </el-button> | ||||
|             </div> | ||||
|             <template #reference> | ||||
|               <el-button | ||||
|                 v-show="scope.row.status == 0" | ||||
|                 class="primary" | ||||
|                 type="primary" | ||||
|                 @click="scope.row.visible2 = true" | ||||
|                 >拒绝</el-button | ||||
|               > | ||||
|             </template> | ||||
|           </el-popover> | ||||
|  | ||||
|           <!-- 删除弹出框 --> | ||||
|           <el-popover | ||||
|             v-model:visible="scope.row.visible3" | ||||
|             placement="top" | ||||
|             :width="160" | ||||
|           > | ||||
|             <p>确定要删除么?</p> | ||||
|             <div style="text-align: right; margin: 0"> | ||||
|               <el-button size="small" @click="scope.row.visible3 = false"> | ||||
|                 取消 | ||||
|               </el-button> | ||||
|               <el-button size="small" type="primary" @click="del(scope.row.id)"> | ||||
|                 确认 | ||||
|               </el-button> | ||||
|             </div> | ||||
|             <template #reference> | ||||
|               <el-button | ||||
|                 class="danger" | ||||
|                 type="danger" | ||||
|                 @click="scope.row.visible3 = true" | ||||
|                 >删除</el-button | ||||
|               > | ||||
|             </template> | ||||
|           </el-popover></template | ||||
|         > | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|  | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[1, 10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   listPartitionInfo, | ||||
|   customPage, | ||||
|   customPass, | ||||
|   customReject, | ||||
|   customDel, | ||||
| } from "@/api/roomBackground/roomBackground"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage, ElTable } from "element-plus"; | ||||
| import { ref } from "vue"; | ||||
| import { ElMessageBox } from "element-plus"; // 正确引入 ElM | ||||
| export default { | ||||
|   name: "roomBackgroundCustom", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         partitionId: "", | ||||
|         partitionArr: [], | ||||
|         id: "", | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [{ x: "x" }], | ||||
|       // 分页 | ||||
|       total: 0, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|       //   删除相关 | ||||
|       // visible1: false, | ||||
|       // visible2: false, | ||||
|       // visible3: false, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.loading = true; | ||||
|     listPartitionInfo().then((res) => { | ||||
|       console.log(res); | ||||
|       this.inquire.partitionArr = res.data; | ||||
|       this.getData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       customPage({ | ||||
|         partitionId: this.inquire.partitionId, | ||||
|         erbanNo: this.inquire.id, | ||||
|         pageNum: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           this.tableData = res.data.rows; | ||||
|           this.total = res.data.total; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 通过 | ||||
|     pass(id) { | ||||
|       customPass({ id }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "操作成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 拒绝 | ||||
|     reject(id) { | ||||
|       customReject({ id }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "操作成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 删除 | ||||
|     del(id) { | ||||
|       customDel({ id }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "操作成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess(res, file) { | ||||
|       console.log(file); | ||||
|       // this.operation.imageUrl1 = URL.createObjectURL(); | ||||
|       this.dialogObj.imageUrl1 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess2(res, file) { | ||||
|       console.log(file); | ||||
|       // this.operation.imageUrl1 = URL.createObjectURL(); | ||||
|       this.dialogObj.imageUrl2 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarSuccess3(res, file) { | ||||
|       console.log(file); | ||||
|       // this.operation.imageUrl1 = URL.createObjectURL(); | ||||
|       this.dialogObj.imageUrl3 = file.response.data; | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传成功!", | ||||
|         type: "success", | ||||
|       }); | ||||
|     }, | ||||
|     beforeAvatarUpload() { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传中~", | ||||
|         type: "warning", | ||||
|       }); | ||||
|     }, | ||||
|     handleAvatarError() { | ||||
|       ElMessage({ | ||||
|         showClose: true, | ||||
|         message: "上传失败!", | ||||
|         type: "error", | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| .selectBox { | ||||
|   display: flex; | ||||
|   height: 35px; | ||||
|   line-height: 35px; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| .selectBoxImg { | ||||
|   height: 150px; | ||||
| } | ||||
| .pagination { | ||||
|   margin: 10px auto 10px; | ||||
|   position: relative; | ||||
|   left: 50%; | ||||
|   transform: translateX(-50%); | ||||
| } | ||||
| .pagination_in { | ||||
|   text-align: center; | ||||
| } | ||||
| .dialogBox { | ||||
|   width: 100%; | ||||
|   //   height: 50px; | ||||
|   //   line-height: 50px; | ||||
|   display: flex; | ||||
|   align-items: baseline; | ||||
|   margin-bottom: 20px; | ||||
|   .input { | ||||
|     width: 50%; | ||||
|   } | ||||
|   .selectBox { | ||||
|     display: flex; | ||||
|     height: 35px; | ||||
|     line-height: 35px; | ||||
|     margin-bottom: 20px; | ||||
|   } | ||||
|   .selectBoxImg { | ||||
|     height: 150px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										374
									
								
								src/views/ssGuild/SsGuild.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										374
									
								
								src/views/ssGuild/SsGuild.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,374 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>主播ID</span> | ||||
|       <el-input | ||||
|         v-model="inquire.anchorId" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <span>公会ID</span> | ||||
|       <el-input | ||||
|         v-model="inquire.guildId" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <span>公会长ID</span> | ||||
|       <el-input | ||||
|         v-model="inquire.guildUserId" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <span>周期</span> | ||||
|       <el-select v-model="inquire.weekTime" placeholder="请选择"> | ||||
|         <el-option | ||||
|           v-for="item in inquire.weekTimeOptions" | ||||
|           :key="item.cycleDateBegin" | ||||
|           :label="item.cycleDateShow" | ||||
|           :value="item.cycleDateBegin" | ||||
|         > | ||||
|         </el-option> | ||||
|       </el-select> | ||||
|     </div> | ||||
|     <div class="inquire"> | ||||
|       <span>发放状态</span> | ||||
|       <el-select v-model="inquire.status" placeholder="请选择"> | ||||
|         <el-option | ||||
|           v-for="item in inquire.statusOptions" | ||||
|           :key="item.value" | ||||
|           :label="item.label" | ||||
|           :value="item.value" | ||||
|         > | ||||
|         </el-option> | ||||
|       </el-select> | ||||
|     </div> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" type="primary" @click="getData()" | ||||
|       >查询</el-button | ||||
|     > | ||||
|     <el-button class="primary" type="primary" @click="confirmExport2Excel()" | ||||
|       >导出</el-button | ||||
|     > | ||||
|     <el-button class="warning" type="warning " @click="sendGoldFun()" | ||||
|       >批量发放</el-button | ||||
|     > | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       ref="multipleTable" | ||||
|       @selection-change="handleSelectionChange" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column type="selection" :selectable="callback" label="选择" /> | ||||
|       <el-table-column prop="cycleDate" align="center" label="周期" /> | ||||
|       <el-table-column prop="erbanNo" align="center" label="主播ID" /> | ||||
|       <el-table-column prop="guildId" align="center" label="公会ID" /> | ||||
|       <el-table-column | ||||
|         prop="guildDiamondNum" | ||||
|         align="center" | ||||
|         label="公会总流水" | ||||
|       /> | ||||
|       <el-table-column prop="ssLevelName" align="center" label="公会等级" /> | ||||
|       <el-table-column prop="diamondNum" align="center" label="主播流水" /> | ||||
|       <el-table-column prop="memberLevelName" align="center" label="主播档位" /> | ||||
|       <el-table-column prop="goldNum" align="center" label="主播获得奖励" /> | ||||
|       <el-table-column align="center" prop="giftInfo" label="发放状态"> | ||||
|         <template v-slot="scope"> | ||||
|           {{ scope.row.sendStatusStr }} | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="sendUser" align="center" label="发放人" /> | ||||
|       <el-table-column align="center" label="操作" width="300"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="sendGoldOneFun(scope.row)" | ||||
|             :class="scope.row.sendStatusStr == '未发放' ? 'primary' : 'info'" | ||||
|             :type="scope.row.sendStatusStr == '未发放' ? 'primary' : 'info'" | ||||
|             size="default" | ||||
|             :disabled="scope.row.sendStatusStr == '未发放' ? false : true" | ||||
|             >{{ | ||||
|               scope.row.sendStatusStr == "未发放" ? "发放" : "已发放" | ||||
|             }}</el-button | ||||
|           > | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|  | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   cycleDateList, | ||||
|   list, | ||||
|   ssGuildExport, | ||||
|   sendGold, | ||||
| } from "@/api/SsGuild/SsGuild"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage, ElTable } from "element-plus"; | ||||
| import { ref } from "vue"; | ||||
| import { ElMessageBox } from "element-plus"; // 正确引入 ElM | ||||
| export default { | ||||
|   name: "SsGuild", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       delDialog: false, | ||||
|       delDialogData: null, | ||||
|       selectedRows: [], //存储选中行数据 | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         anchorId: "", | ||||
|         guildId: "", | ||||
|         guildUserId: "", | ||||
|         weekTime: "", | ||||
|         weekTimeOptions: [], | ||||
|         status: "", | ||||
|         statusOptions: [ | ||||
|           { value: 0, label: "未发放" }, | ||||
|           { value: 1, label: "已发放" }, | ||||
|         ], | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 分页 | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     cycleDateList().then((res) => { | ||||
|       this.inquire.weekTimeOptions = res.data; | ||||
|     }); | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd hh:mm:ss"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd hh:mm:ss"); | ||||
|       } | ||||
|       list({ | ||||
|         erbanNo: this.inquire.anchorId, | ||||
|         guildId: this.inquire.guildId, | ||||
|         ownerErbanNo: this.inquire.guildUserId, | ||||
|         cycleDate: this.inquire.weekTime, | ||||
|         status: this.inquire.status, | ||||
|         pageNo: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           this.total = res.data.total; | ||||
|           this.tableData = res.data.rows; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     handleSelectionChange(val) { | ||||
|       this.selectedRows = val; | ||||
|       console.log("Selected rows:", this.selectedRows); | ||||
|     }, | ||||
|     handleGetSelection() { | ||||
|       // 获取选中的行数据 | ||||
|       console.log("Current selected rows:", this.selectedRows); | ||||
|     }, | ||||
|     // 确认导出 | ||||
|     confirmExport2Excel() { | ||||
|       ElMessageBox.confirm("确定导出Excel吗?", "提示", { | ||||
|         confirmButtonText: "确定", | ||||
|         cancelButtonText: "取消", | ||||
|         type: "warning", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           ssGuildExport({ | ||||
|             erbanNo: this.inquire.anchorId, | ||||
|             guildId: this.inquire.guildId, | ||||
|             ownerErbanNo: this.inquire.guildUserId, | ||||
|             cycleDate: this.inquire.weekTime, | ||||
|             status: this.inquire.status, | ||||
|           }) | ||||
|             .then((res) => { | ||||
|               // if (res) { | ||||
|               //   this.exportVisible = false; | ||||
|               //   this.btnLoading = false; | ||||
|               //   let alink = document.createElement("a"); | ||||
|               //   alink.download = `SS公会奖励发放.xls`; | ||||
|               //   alink.style.display = "none"; | ||||
|               //   const blob = new Blob([res.data]); | ||||
|               //   alink.href = URL.createObjectURL(blob); | ||||
|               //   document.body.appendChild(alink); | ||||
|               //   alink.click(); | ||||
|               //   URL.revokeObjectURL(alink.href); | ||||
|               // } | ||||
|             }) | ||||
|             .catch((err) => { | ||||
|               console.error(err); // 打印错误信息 | ||||
|               ElMessage.error("导出失败"); | ||||
|             }); | ||||
|         }) | ||||
|         .catch(() => { | ||||
|           ElMessage({ | ||||
|             type: "info", | ||||
|             message: "取消", | ||||
|           }); | ||||
|         }); | ||||
|     }, | ||||
|     callback(row) { | ||||
|       return row.sendStatusStr == "未发放" ? true : false; | ||||
|     }, | ||||
|     // 确认批量发放 | ||||
|     sendGoldFun() { | ||||
|       ElMessageBox.confirm("确定发放奖励吗?", "提示", { | ||||
|         confirmButtonText: "确定", | ||||
|         cancelButtonText: "取消", | ||||
|         type: "warning", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           var str = ""; | ||||
|           this.selectedRows.forEach((res) => { | ||||
|             str += `${res.id},`; | ||||
|           }); | ||||
|           sendGold({ ids: str }) | ||||
|             .then((res) => { | ||||
|               if (res.code == 200) { | ||||
|                 ElMessage({ | ||||
|                   showClose: true, | ||||
|                   message: "发放成功", | ||||
|                   type: "success", | ||||
|                 }); | ||||
|                 this.getData(); | ||||
|               } else { | ||||
|                 ElMessage({ | ||||
|                   showClose: true, | ||||
|                   message: res.message, | ||||
|                   type: "error", | ||||
|                 }); | ||||
|               } | ||||
|             }) | ||||
|             .catch((err) => { | ||||
|               console.error(err); // 打印错误信息 | ||||
|               ElMessage.error("发放失败"); | ||||
|             }); | ||||
|         }) | ||||
|         .catch(() => { | ||||
|           ElMessage({ | ||||
|             type: "info", | ||||
|             message: "取消", | ||||
|           }); | ||||
|         }); | ||||
|     }, | ||||
|     // 确认单个发放 | ||||
|     sendGoldOneFun(val) { | ||||
|       ElMessageBox.confirm("确定发放奖励吗?", "提示", { | ||||
|         confirmButtonText: "确定", | ||||
|         cancelButtonText: "取消", | ||||
|         type: "warning", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           sendGold({ ids: val.id }) | ||||
|             .then((res) => { | ||||
|               if (res.code == 200) { | ||||
|                 ElMessage({ | ||||
|                   showClose: true, | ||||
|                   message: "发放成功", | ||||
|                   type: "success", | ||||
|                 }); | ||||
|                 this.getData(); | ||||
|               } else { | ||||
|                 ElMessage({ | ||||
|                   showClose: true, | ||||
|                   message: res.message, | ||||
|                   type: "error", | ||||
|                 }); | ||||
|               } | ||||
|             }) | ||||
|             .catch((err) => { | ||||
|               console.error(err); // 打印错误信息 | ||||
|               ElMessage.error("发放失败"); | ||||
|             }); | ||||
|         }) | ||||
|         .catch(() => { | ||||
|           ElMessage({ | ||||
|             type: "info", | ||||
|             message: "取消", | ||||
|           }); | ||||
|         }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| .selectBox { | ||||
|   display: flex; | ||||
|   height: 35px; | ||||
|   line-height: 35px; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| .selectBoxImg { | ||||
|   height: 150px; | ||||
| } | ||||
| </style> | ||||
| @@ -103,6 +103,7 @@ export default { | ||||
|             { field: 'googleUsd', title: 'google充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'payermaxUsd', title: 'payermax充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'myCardUsd', title: 'myCard充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'startPayUsd', title: 'startPay充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'iosUsd', title: 'ios充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'companyUsd', title: '对公打款美元', align: 'center', width: '14%' }, | ||||
|             { field: 'totalUsd', title: '总充值美元', align: 'center', width: '14%' }, | ||||
|   | ||||
| @@ -1,24 +1,29 @@ | ||||
| <template> | ||||
|     <section class="content"> | ||||
|         <div class="box box-primary"> | ||||
|             <div class="box-body"> | ||||
|                 <!-- Content Header (Page header) --> | ||||
|                 <section class="content-header"> | ||||
|                     <h1 id="itemTitle"></h1> | ||||
|                 </section> | ||||
|                 <div id="toolbar"> | ||||
|                     <form class="col-sm-12" id="searchForm" action="/admin/chargeRecord/dailyexport" method="get" | ||||
|                         target="_blank"> | ||||
|   <section class="content"> | ||||
|     <div class="box box-primary"> | ||||
|       <div class="box-body"> | ||||
|         <!-- Content Header (Page header) --> | ||||
|         <section class="content-header"> | ||||
|           <h1 id="itemTitle"></h1> | ||||
|         </section> | ||||
|         <div id="toolbar"> | ||||
|           <form class="col-sm-12" | ||||
|                 id="searchForm" | ||||
|                 action="/admin/chargeRecord/dailyexport" | ||||
|                 method="get" | ||||
|                 target="_blank"> | ||||
|  | ||||
|                     </form> | ||||
|                     <div class="col-sm-12 pull-left"> | ||||
|                         <h4> | ||||
|                             今日充值数据:<span class="totalAmount" style="color: red">0</span>(总金额)/ | ||||
|                             <span class="totalCount" style="color: red">0</span>(总笔数) | ||||
|                             <span style="color: red">(单位:美元)</span> | ||||
|                         </h4> | ||||
|                     </div> | ||||
|                     <!-- <div class="col-sm-3 pull-right"> | ||||
|           </form> | ||||
|           <div class="col-sm-12 pull-left"> | ||||
|             <h4> | ||||
|               今日充值数据:<span class="totalAmount" | ||||
|                     style="color: red">0</span>(总金额)/ | ||||
|               <span class="totalCount" | ||||
|                     style="color: red">0</span>(总笔数) | ||||
|               <span style="color: red">(单位:美元)</span> | ||||
|             </h4> | ||||
|           </div> | ||||
|           <!-- <div class="col-sm-3 pull-right"> | ||||
|                      <button id="btnSearch" class="btn btn-default"> | ||||
|                          <i class="glyphicon glyphicon-search"></i>查询 | ||||
|                      </button> | ||||
| @@ -26,185 +31,194 @@ | ||||
|                          <i class="glyphicon glyphicon-export"></i>导出 | ||||
|                      </button> | ||||
|                  </div>--> | ||||
|                 </div> | ||||
|                 <!-- .content --> | ||||
|                 <div id="table"></div> | ||||
|  | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|         <!-- .content --> | ||||
|         <div id="table"></div> | ||||
|  | ||||
|     <div class="modal fade" id="recordDetail" tabindex="-1" role="dialog" aria-labelledby="modalLabel"> | ||||
|         <div class="modal-dialog" role="document"> | ||||
|             <div class="modal-content"> | ||||
|                 <div class="modal-header"> | ||||
|                     <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span | ||||
|                             aria-hidden="true">×</span> | ||||
|                     </button> | ||||
|                     <h4 class="modal-title" id="modalLabel"></h4> | ||||
|                 </div> | ||||
|                 <div class="modal-body"> | ||||
|                     <div id="detailtable"></div> | ||||
|                 </div> | ||||
|  | ||||
|             </div> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|   </section> | ||||
|  | ||||
|   <div class="modal fade" | ||||
|        id="recordDetail" | ||||
|        tabindex="-1" | ||||
|        role="dialog" | ||||
|        aria-labelledby="modalLabel"> | ||||
|     <div class="modal-dialog" | ||||
|          role="document"> | ||||
|       <div class="modal-content"> | ||||
|         <div class="modal-header"> | ||||
|           <button type="button" | ||||
|                   class="close" | ||||
|                   data-dismiss="modal" | ||||
|                   aria-label="Close"><span aria-hidden="true">×</span> | ||||
|           </button> | ||||
|           <h4 class="modal-title" | ||||
|               id="modalLabel"></h4> | ||||
|         </div> | ||||
|         <div class="modal-body"> | ||||
|           <div id="detailtable"></div> | ||||
|         </div> | ||||
|  | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
|  | ||||
| export default { | ||||
|     name: "ChargeRecordDailyStatisticsView", | ||||
|     setup() { | ||||
|         return {}; | ||||
|     }, | ||||
|     created() { | ||||
|         this.$nextTick(function () { | ||||
|             this.initData(); | ||||
|   name: "ChargeRecordDailyStatisticsView", | ||||
|   setup () { | ||||
|     return {}; | ||||
|   }, | ||||
|   created () { | ||||
|     this.$nextTick(function () { | ||||
|       this.initData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     initData () { | ||||
|       $(function () { | ||||
|         $('#table').bootstrapTable('destroy'); | ||||
|         $('#table').bootstrapTable({ | ||||
|           columns: [ | ||||
|             { field: 'timeStr', title: '日期', align: 'center', width: '5%' }, | ||||
|             /*{field: 'wxAmount', title: '微信支付', align: 'center', width: '5%'}, | ||||
|             {field: 'wxWapAmount', title: '微信H5支付', align: 'center', width: '5%'}, | ||||
|             {field: 'wxPubAmount', title: '微信公众号', align: 'center', width: '5%'}, | ||||
|             {field: 'wxMicroMallPubAmount', title: '微商城公众号', align: 'center', width: '5%'}, | ||||
|             {field: 'wxPub2Amount', title: '平台公众号', align: 'center', width: '5%'}, | ||||
|             {field: 'wxPub2H5Amount', title: '平台公众号H5支付', align: 'center', width: '5%'}, | ||||
|             {field: 'alipayAmount', title: '支付宝', align: 'center', width: '5%'}, | ||||
|             {field: 'alipayWapAmount', title: '支付宝H5', align: 'center', width: '5%'}, | ||||
|             {field: 'iosPayAmount', title: 'IOS支付', align: 'center', width: '5%'}, | ||||
|             {field: 'wxMiniAppAmount', title: '小程序支付', align: 'center', width: '5%'},*/ | ||||
|             { field: 'googleAmount', title: 'google支付', align: 'center', width: '5%' }, | ||||
|             { field: 'payermaxAmount', title: 'payermax支付', align: 'center', width: '5%' }, | ||||
|             { field: 'myCardAmount', title: 'MyCard支付', align: 'center', width: '5%' }, | ||||
|             { field: 'startPayAmount', title: 'startPay支付', align: 'center', width: '5%' }, | ||||
|             { field: 'iosPayAmount', title: 'ios支付', align: 'center', width: '5%' }, | ||||
|             { field: 'companyAccount', title: '充值打公账', align: 'center', width: '5%' }, | ||||
|             { | ||||
|               field: 'time', | ||||
|               title: '操作', | ||||
|               align: 'center', | ||||
|               width: '5%', | ||||
|               formatter: function (val, row, index) { | ||||
|                 return '<button id="btnDetail" name="btnDetail" class="btn btn-sm btn-success opt-detail" data-id=' + val + '>' + | ||||
|                   '<i class="glyphicon glyphicon-edit"></i> 明细</button>'; | ||||
|               } | ||||
|             } | ||||
|           ], | ||||
|           undefinedText: 0, | ||||
|           cache: false, | ||||
|           striped: true, | ||||
|           showRefresh: false, | ||||
|           pageSize: 20, | ||||
|           pagination: true, | ||||
|           pageList: [20, 50, 100, 200, 300, 500], | ||||
|           search: false, | ||||
|           sidePagination: "client", //表示服务端请求 | ||||
|           queryParamsType: "undefined", | ||||
|           queryParams: function queryParams (params) {   //设置查询参数 | ||||
|             var param = { | ||||
|               pageNum: params.pageNumber, | ||||
|               pageSize: params.pageSize | ||||
|             }; | ||||
|             return param; | ||||
|           }, | ||||
|           toolbar: '#toolbar', | ||||
|           url: '/admin/chargeRecord/dailylist', | ||||
|           onLoadSuccess: function () {  //加载成功时执行 | ||||
|             console.log("load success"); | ||||
|             getTotalStatis(); | ||||
|           }, | ||||
|           onLoadError: function () {  //加载失败时执行 | ||||
|             console.log("load fail"); | ||||
|           } | ||||
|         }); | ||||
|     }, | ||||
|     methods: { | ||||
|         initData() { | ||||
|             $(function () { | ||||
|                 $('#table').bootstrapTable('destroy'); | ||||
|                 $('#table').bootstrapTable({ | ||||
|                     columns: [ | ||||
|                         { field: 'timeStr', title: '日期', align: 'center', width: '5%' }, | ||||
|                         /*{field: 'wxAmount', title: '微信支付', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxWapAmount', title: '微信H5支付', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxPubAmount', title: '微信公众号', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxMicroMallPubAmount', title: '微商城公众号', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxPub2Amount', title: '平台公众号', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxPub2H5Amount', title: '平台公众号H5支付', align: 'center', width: '5%'}, | ||||
|                         {field: 'alipayAmount', title: '支付宝', align: 'center', width: '5%'}, | ||||
|                         {field: 'alipayWapAmount', title: '支付宝H5', align: 'center', width: '5%'}, | ||||
|                         {field: 'iosPayAmount', title: 'IOS支付', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxMiniAppAmount', title: '小程序支付', align: 'center', width: '5%'},*/ | ||||
|                         { field: 'googleAmount', title: 'google支付', align: 'center', width: '5%' }, | ||||
|                         { field: 'payermaxAmount', title: 'payermax支付', align: 'center', width: '5%' }, | ||||
|                         { field: 'myCardAmount', title: 'MyCard支付', align: 'center', width: '5%' }, | ||||
|                         { field: 'iosPayAmount', title: 'ios支付', align: 'center', width: '5%' }, | ||||
|                         { field: 'companyAccount', title: '充值打公账', align: 'center', width: '5%' }, | ||||
|                         { | ||||
|                             field: 'time', | ||||
|                             title: '操作', | ||||
|                             align: 'center', | ||||
|                             width: '5%', | ||||
|                             formatter: function (val, row, index) { | ||||
|                                 return '<button id="btnDetail" name="btnDetail" class="btn btn-sm btn-success opt-detail" data-id=' + val + '>' + | ||||
|                                     '<i class="glyphicon glyphicon-edit"></i> 明细</button>'; | ||||
|                             } | ||||
|                         } | ||||
|                     ], | ||||
|                     undefinedText: 0, | ||||
|                     cache: false, | ||||
|                     striped: true, | ||||
|                     showRefresh: false, | ||||
|                     pageSize: 20, | ||||
|                     pagination: true, | ||||
|                     pageList: [20, 50, 100, 200, 300, 500], | ||||
|                     search: false, | ||||
|                     sidePagination: "client", //表示服务端请求 | ||||
|                     queryParamsType: "undefined", | ||||
|                     queryParams: function queryParams(params) {   //设置查询参数 | ||||
|                         var param = { | ||||
|                             pageNum: params.pageNumber, | ||||
|                             pageSize: params.pageSize | ||||
|                         }; | ||||
|                         return param; | ||||
|                     }, | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/chargeRecord/dailylist', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                         getTotalStatis(); | ||||
|                     }, | ||||
|                     onLoadError: function () {  //加载失败时执行 | ||||
|                         console.log("load fail"); | ||||
|                     } | ||||
|                 }); | ||||
|  | ||||
|                 // 导出EXCEL | ||||
|                 $('#btnExport').on('click', function () { | ||||
|                     $("#searchForm").submit(); | ||||
|                 }); | ||||
|         // 导出EXCEL | ||||
|         $('#btnExport').on('click', function () { | ||||
|           $("#searchForm").submit(); | ||||
|         }); | ||||
|  | ||||
|                 // 查询刷新 | ||||
|                 $('#btnSearch').on('click', function () { | ||||
|                     TableHelper.doRefresh('#table'); | ||||
|                 }); | ||||
|         // 查询刷新 | ||||
|         $('#btnSearch').on('click', function () { | ||||
|           TableHelper.doRefresh('#table'); | ||||
|         }); | ||||
|  | ||||
|                 $("#table").on("click", '.opt-detail', function () { | ||||
|         $("#table").on("click", '.opt-detail', function () { | ||||
|  | ||||
|                     $("#recordDetail").modal('show'); | ||||
|                     var time = $(this).attr("data-id"); | ||||
|           $("#recordDetail").modal('show'); | ||||
|           var time = $(this).attr("data-id"); | ||||
|  | ||||
|                     var date = new Date().format("yyyy-MM-dd "); | ||||
|                     $("#modalLabel").html(date + parseTime(time)); | ||||
|           var date = new Date().format("yyyy-MM-dd "); | ||||
|           $("#modalLabel").html(date + parseTime(time)); | ||||
|  | ||||
|                     $('#detailtable').bootstrapTable('destroy'); | ||||
|                     $('#detailtable').bootstrapTable({ | ||||
|                         columns: [ | ||||
|                             { field: 'channel', title: '渠道', align: 'center', width: '5%' }, | ||||
|                             { field: 'amount', title: '充值金额', align: 'center', width: '5%' }, | ||||
|                             { field: 'count', title: '充值笔数', align: 'center', width: '5%' } | ||||
|           $('#detailtable').bootstrapTable('destroy'); | ||||
|           $('#detailtable').bootstrapTable({ | ||||
|             columns: [ | ||||
|               { field: 'channel', title: '渠道', align: 'center', width: '5%' }, | ||||
|               { field: 'amount', title: '充值金额', align: 'center', width: '5%' }, | ||||
|               { field: 'count', title: '充值笔数', align: 'center', width: '5%' } | ||||
|  | ||||
|                         ], | ||||
|                         undefinedText: 0, | ||||
|                         height: 600, | ||||
|                         cache: false, | ||||
|                         striped: true, | ||||
|                         showRefresh: false, | ||||
|                         pageSize: 20, | ||||
|                         pagination: false, | ||||
|                         pageList: [20, 50, 100, 200, 300, 500], | ||||
|                         search: false, | ||||
|                         sidePagination: "client", //表示服务端请求 | ||||
|                         queryParamsType: "undefined", | ||||
|                         queryParams: function queryParams(params) {   //设置查询参数 | ||||
|                             var param = { | ||||
|                                 pageNum: params.pageNumber, | ||||
|                                 pageSize: params.pageSize, | ||||
|                                 time: time | ||||
|                             }; | ||||
|                             return param; | ||||
|                         }, | ||||
|                         url: '/admin/chargeRecord/dailydetail', | ||||
|                         onLoadSuccess: function () {  //加载成功时执行 | ||||
|                             console.log("load success"); | ||||
|                         }, | ||||
|                         onLoadError: function () {  //加载失败时执行 | ||||
|                             console.log("load fail"); | ||||
|                         } | ||||
|                     }); | ||||
|                 }); | ||||
|             ], | ||||
|             undefinedText: 0, | ||||
|             height: 600, | ||||
|             cache: false, | ||||
|             striped: true, | ||||
|             showRefresh: false, | ||||
|             pageSize: 20, | ||||
|             pagination: false, | ||||
|             pageList: [20, 50, 100, 200, 300, 500], | ||||
|             search: false, | ||||
|             sidePagination: "client", //表示服务端请求 | ||||
|             queryParamsType: "undefined", | ||||
|             queryParams: function queryParams (params) {   //设置查询参数 | ||||
|               var param = { | ||||
|                 pageNum: params.pageNumber, | ||||
|                 pageSize: params.pageSize, | ||||
|                 time: time | ||||
|               }; | ||||
|               return param; | ||||
|             }, | ||||
|             url: '/admin/chargeRecord/dailydetail', | ||||
|             onLoadSuccess: function () {  //加载成功时执行 | ||||
|               console.log("load success"); | ||||
|             }, | ||||
|             onLoadError: function () {  //加载失败时执行 | ||||
|               console.log("load fail"); | ||||
|             } | ||||
|           }); | ||||
|         }); | ||||
|  | ||||
|  | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
|       }); | ||||
|     } | ||||
|   }, | ||||
|  | ||||
| }; | ||||
|  | ||||
| function parseTime(val) { | ||||
|     if (val < 10) { | ||||
|         return '0' + val + ':00-0' + val + ':59'; | ||||
|     } else { | ||||
|         return val + ':00-' + val + ':59'; | ||||
|     } | ||||
| function parseTime (val) { | ||||
|   if (val < 10) { | ||||
|     return '0' + val + ':00-0' + val + ':59'; | ||||
|   } else { | ||||
|     return val + ':00-' + val + ':59'; | ||||
|   } | ||||
| } | ||||
| function getTotalStatis() { | ||||
|     $.get('/admin/chargeRecord/dailytotal', function (res) { | ||||
|         if (res.code == 200) { | ||||
|             console.log(res.data); | ||||
|             if (res.data) { | ||||
|                 $('.totalAmount').html(res.data.amount); | ||||
|                 $('.totalCount').html(res.data.count); | ||||
|             } | ||||
|         } | ||||
|     }) | ||||
| function getTotalStatis () { | ||||
|   $.get('/admin/chargeRecord/dailytotal', function (res) { | ||||
|     if (res.code == 200) { | ||||
|       console.log(res.data); | ||||
|       if (res.data) { | ||||
|         $('.totalAmount').html(res.data.amount); | ||||
|         $('.totalCount').html(res.data.count); | ||||
|       } | ||||
|     } | ||||
|   }) | ||||
| } | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -103,6 +103,7 @@ export default { | ||||
|             { field: 'googleUsd', title: 'google充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'payermaxUsd', title: 'payermax充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'myCardUsd', title: 'myCard充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'startPayUsd', title: 'startPay充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'iosUsd', title: 'ios充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'companyUsd', title: '对公打款美元', align: 'center', width: '14%' }, | ||||
|             { field: 'totalUsd', title: '总充值美元', align: 'center', width: '14%' }, | ||||
|   | ||||
| @@ -1,228 +1,250 @@ | ||||
| <template> | ||||
|     <section class="content"> | ||||
|         <div class="box box-primary"> | ||||
|             <div class="box-body"> | ||||
|                 <!-- Content Header (Page header) --> | ||||
|                 <section class="content-header"> | ||||
|                     <h1 id="itemTitle"></h1> | ||||
|                 </section> | ||||
|                 <div id="toolbar"> | ||||
|                     <div class="col-sm-12"> | ||||
|                         <div class="pull-left"> | ||||
|                             <form id="searchForm" class="col-sm-pull-12" action="/admin/chargeRecord/totalexport" | ||||
|                                 method="get" target="_blank"> | ||||
|                                 <div class="col-sm-11"> | ||||
|                                     <label for="beginDate" class="col-sm-2 control-label">开始日期:</label> | ||||
|                                     <div class="col-sm-4"><input type="text" class="form-control" name="beginDate" | ||||
|                                             id="beginDate" placeholder="必填"> | ||||
|                                     </div> | ||||
|                                     <label for="endDate" class="col-sm-2 control-label">结束日期:</label> | ||||
|                                     <div class="col-sm-4"><input type="text" class="form-control" name="endDate" | ||||
|                                             id="endDate" placeholder="必填"></div> | ||||
|   <section class="content"> | ||||
|     <div class="box box-primary"> | ||||
|       <div class="box-body"> | ||||
|         <!-- Content Header (Page header) --> | ||||
|         <section class="content-header"> | ||||
|           <h1 id="itemTitle"></h1> | ||||
|         </section> | ||||
|         <div id="toolbar"> | ||||
|           <div class="col-sm-12"> | ||||
|             <div class="pull-left"> | ||||
|               <form id="searchForm" | ||||
|                     class="col-sm-pull-12" | ||||
|                     action="/admin/chargeRecord/totalexport" | ||||
|                     method="get" | ||||
|                     target="_blank"> | ||||
|                 <div class="col-sm-11"> | ||||
|                   <label for="beginDate" | ||||
|                          class="col-sm-2 control-label">开始日期:</label> | ||||
|                   <div class="col-sm-4"><input type="text" | ||||
|                            class="form-control" | ||||
|                            name="beginDate" | ||||
|                            id="beginDate" | ||||
|                            placeholder="必填"> | ||||
|                   </div> | ||||
|                   <label for="endDate" | ||||
|                          class="col-sm-2 control-label">结束日期:</label> | ||||
|                   <div class="col-sm-4"><input type="text" | ||||
|                            class="form-control" | ||||
|                            name="endDate" | ||||
|                            id="endDate" | ||||
|                            placeholder="必填"></div> | ||||
|  | ||||
|                                 </div> | ||||
|                             </form> | ||||
|                         </div> | ||||
|                         <div class="pull-right"> | ||||
|  | ||||
|                             <button id="btnSearch" class="btn btn-default"> | ||||
|                                 <i class="glyphicon glyphicon-search"></i>查询 | ||||
|                             </button> | ||||
|                             <button id="btnExport" class="btn btn-default"> | ||||
|                                 <i class="glyphicon glyphicon-export"></i>导出 | ||||
|                             </button> | ||||
|                             <span style="color: red">(单位:美元)</span> | ||||
|                         </div> | ||||
|  | ||||
|                     </div> | ||||
|                 </div> | ||||
|  | ||||
|                 <!-- .content --> | ||||
|                 <div id="table"></div> | ||||
|  | ||||
|               </form> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|  | ||||
|     <div class="modal fade" id="recordDetail" tabindex="-1" role="dialog" aria-labelledby="modalLabel"> | ||||
|         <div class="modal-dialog" role="document"> | ||||
|             <div class="modal-content"> | ||||
|                 <div class="modal-header"> | ||||
|                     <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span | ||||
|                             aria-hidden="true">×</span> | ||||
|                     </button> | ||||
|                     <h4 class="modal-title" id="modalLabel"></h4> | ||||
|                 </div> | ||||
|                 <div class="modal-body"> | ||||
|                     <div id="detailtable"></div> | ||||
|                 </div> | ||||
|             <div class="pull-right"> | ||||
|  | ||||
|               <button id="btnSearch" | ||||
|                       class="btn btn-default"> | ||||
|                 <i class="glyphicon glyphicon-search"></i>查询 | ||||
|               </button> | ||||
|               <button id="btnExport" | ||||
|                       class="btn btn-default"> | ||||
|                 <i class="glyphicon glyphicon-export"></i>导出 | ||||
|               </button> | ||||
|               <span style="color: red">(单位:美元)</span> | ||||
|             </div> | ||||
|  | ||||
|           </div> | ||||
|         </div> | ||||
|  | ||||
|         <!-- .content --> | ||||
|         <div id="table"></div> | ||||
|  | ||||
|       </div> | ||||
|     </div> | ||||
|   </section> | ||||
|  | ||||
|   <div class="modal fade" | ||||
|        id="recordDetail" | ||||
|        tabindex="-1" | ||||
|        role="dialog" | ||||
|        aria-labelledby="modalLabel"> | ||||
|     <div class="modal-dialog" | ||||
|          role="document"> | ||||
|       <div class="modal-content"> | ||||
|         <div class="modal-header"> | ||||
|           <button type="button" | ||||
|                   class="close" | ||||
|                   data-dismiss="modal" | ||||
|                   aria-label="Close"><span aria-hidden="true">×</span> | ||||
|           </button> | ||||
|           <h4 class="modal-title" | ||||
|               id="modalLabel"></h4> | ||||
|         </div> | ||||
|         <div class="modal-body"> | ||||
|           <div id="detailtable"></div> | ||||
|         </div> | ||||
|  | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
|  | ||||
| export default { | ||||
|     name: "ChargeRecordTotalStatisticsView", | ||||
|     setup() { | ||||
|         return {}; | ||||
|     }, | ||||
|     created() { | ||||
|         this.$nextTick(function () { | ||||
|             this.initData(); | ||||
|   name: "ChargeRecordTotalStatisticsView", | ||||
|   setup () { | ||||
|     return {}; | ||||
|   }, | ||||
|   created () { | ||||
|     this.$nextTick(function () { | ||||
|       this.initData(); | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     initData () { | ||||
|       $(function () { | ||||
|         $('#table').bootstrapTable('destroy'); | ||||
|         $('#table').bootstrapTable({ | ||||
|           columns: [ | ||||
|             { field: 'timeStr', title: '日期', align: 'center', width: '5%' }, | ||||
|             /*{field: 'wxAmount', title: '微信支付', align: 'center', width: '5%'}, | ||||
|             {field: 'wxWapAmount', title: '微信H5支付', align: 'center', width: '5%'}, | ||||
|             {field: 'wxPubAmount', title: '微信公众号', align: 'center', width: '5%'}, | ||||
|             {field: 'alipayAmount', title: '支付宝', align: 'center', width: '5%'}, | ||||
|             {field: 'alipayV2Amount', title: '支付宝V2', align: 'center', width: '5%'}, | ||||
|             {field: 'wxMicroMallPubAmount', title: '微商城公众号', align: 'center', width: '5%'}, | ||||
|             {field: 'wxPub2Amount', title: '平台公众号', align: 'center', width: '5%'}, | ||||
|             {field: 'wxPub2H5Amount', title: '平台公众号H5支付', align: 'center', width: '5%'}, | ||||
|             {field: 'alipayWapAmount', title: '支付宝H5', align: 'center', width: '5%'}, | ||||
|             {field: 'iosPayAmount', title: 'IOS支付', align: 'center', width: '5%'}, | ||||
|             {field: 'wxMiniAppAmount', title: '小程序支付', align: 'center', width: '5%'},*/ | ||||
|             { field: 'googleAmount', title: 'google支付', align: 'center', width: '5%' }, | ||||
|             { field: 'payermaxAmount', title: 'payermax支付', align: 'center', width: '5%' }, | ||||
|             { field: 'myCardAmount', title: 'myCard支付', align: 'center', width: '5%' }, | ||||
|             { field: 'startPayAmount', title: 'startPay支付', align: 'center', width: '5%' }, | ||||
|             { field: 'iosPayAmount', title: 'ios支付', align: 'center', width: '5%' }, | ||||
|             { field: 'companyAccount', title: '充值打公账', align: 'center', width: '5%' }, | ||||
|             { field: 'totalAmount', title: '总计充值金额数', align: 'center', width: '5%' }, | ||||
|             { | ||||
|               field: 'timeStr', | ||||
|               title: '操作', | ||||
|               align: 'center', | ||||
|               width: '5%', | ||||
|               formatter: function (val, row, index) { | ||||
|                 return '<button id="btnDetail" name="btnDetail" class="btn btn-sm btn-success opt-detail" data-id=' + val + '>' + | ||||
|                   '<i class="glyphicon glyphicon-edit"></i> 明细</button>'; | ||||
|               } | ||||
|             } | ||||
|           ], | ||||
|           undefinedText: 0, | ||||
|           cache: false, | ||||
|           striped: true, | ||||
|           showRefresh: false, | ||||
|           pageSize: 20, | ||||
|           pagination: true, | ||||
|           pageList: [20, 50, 100, 200, 300, 500], | ||||
|           search: false, | ||||
|           sidePagination: "server", //表示服务端请求 | ||||
|           queryParamsType: "undefined", | ||||
|           queryParams: function queryParams (params) {   //设置查询参数 | ||||
|             var param = { | ||||
|               pageNum: params.pageNumber, | ||||
|               pageSize: params.pageSize, | ||||
|               beginDate: $('#beginDate').val(), | ||||
|               endDate: $('#endDate').val() | ||||
|             }; | ||||
|             return param; | ||||
|           }, | ||||
|           toolbar: '#toolbar', | ||||
|           url: '/admin/chargeRecord/totallist', | ||||
|           onLoadSuccess: function () {  //加载成功时执行 | ||||
|             console.log("load success"); | ||||
|           }, | ||||
|           onLoadError: function () {  //加载失败时执行 | ||||
|             console.log("load fail"); | ||||
|           } | ||||
|         }); | ||||
|     }, | ||||
|     methods: { | ||||
|         initData() { | ||||
|             $(function () { | ||||
|                 $('#table').bootstrapTable('destroy'); | ||||
|                 $('#table').bootstrapTable({ | ||||
|                     columns: [ | ||||
|                         { field: 'timeStr', title: '日期', align: 'center', width: '5%' }, | ||||
|                         /*{field: 'wxAmount', title: '微信支付', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxWapAmount', title: '微信H5支付', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxPubAmount', title: '微信公众号', align: 'center', width: '5%'}, | ||||
|                         {field: 'alipayAmount', title: '支付宝', align: 'center', width: '5%'}, | ||||
|                         {field: 'alipayV2Amount', title: '支付宝V2', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxMicroMallPubAmount', title: '微商城公众号', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxPub2Amount', title: '平台公众号', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxPub2H5Amount', title: '平台公众号H5支付', align: 'center', width: '5%'}, | ||||
|                         {field: 'alipayWapAmount', title: '支付宝H5', align: 'center', width: '5%'}, | ||||
|                         {field: 'iosPayAmount', title: 'IOS支付', align: 'center', width: '5%'}, | ||||
|                         {field: 'wxMiniAppAmount', title: '小程序支付', align: 'center', width: '5%'},*/ | ||||
|                         { field: 'googleAmount', title: 'google支付', align: 'center', width: '5%' }, | ||||
|                         { field: 'payermaxAmount', title: 'payermax支付', align: 'center', width: '5%' }, | ||||
|                         { field: 'myCardAmount', title: 'myCard支付', align: 'center', width: '5%' }, | ||||
|                         { field: 'iosPayAmount', title: 'ios支付', align: 'center', width: '5%' }, | ||||
|                         { field: 'companyAccount', title: '充值打公账', align: 'center', width: '5%' }, | ||||
|                         { field: 'totalAmount', title: '总计充值金额数', align: 'center', width: '5%' }, | ||||
|                         { | ||||
|                             field: 'timeStr', | ||||
|                             title: '操作', | ||||
|                             align: 'center', | ||||
|                             width: '5%', | ||||
|                             formatter: function (val, row, index) { | ||||
|                                 return '<button id="btnDetail" name="btnDetail" class="btn btn-sm btn-success opt-detail" data-id=' + val + '>' + | ||||
|                                     '<i class="glyphicon glyphicon-edit"></i> 明细</button>'; | ||||
|                             } | ||||
|                         } | ||||
|                     ], | ||||
|                     undefinedText: 0, | ||||
|                     cache: false, | ||||
|                     striped: true, | ||||
|                     showRefresh: false, | ||||
|                     pageSize: 20, | ||||
|                     pagination: true, | ||||
|                     pageList: [20, 50, 100, 200, 300, 500], | ||||
|                     search: false, | ||||
|                     sidePagination: "server", //表示服务端请求 | ||||
|                     queryParamsType: "undefined", | ||||
|                     queryParams: function queryParams(params) {   //设置查询参数 | ||||
|                         var param = { | ||||
|                             pageNum: params.pageNumber, | ||||
|                             pageSize: params.pageSize, | ||||
|                             beginDate: $('#beginDate').val(), | ||||
|                             endDate: $('#endDate').val() | ||||
|                         }; | ||||
|                         return param; | ||||
|                     }, | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/chargeRecord/totallist', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
|                     onLoadError: function () {  //加载失败时执行 | ||||
|                         console.log("load fail"); | ||||
|                     } | ||||
|                 }); | ||||
|  | ||||
|                 // 导出EXCEL | ||||
|                 $('#btnExport').on('click', function () { | ||||
|                     if (!$('#beginDate').val() || !$('#endDate').val()) { | ||||
|                         $("#tipMsg").text("请输入必填的信息"); | ||||
|                         $("#tipModal").modal('show'); | ||||
|                         return; | ||||
|                     } | ||||
|                     $("#searchForm").submit(); | ||||
|                 }); | ||||
|         // 导出EXCEL | ||||
|         $('#btnExport').on('click', function () { | ||||
|           if (!$('#beginDate').val() || !$('#endDate').val()) { | ||||
|             $("#tipMsg").text("请输入必填的信息"); | ||||
|             $("#tipModal").modal('show'); | ||||
|             return; | ||||
|           } | ||||
|           $("#searchForm").submit(); | ||||
|         }); | ||||
|  | ||||
|                 // 查询刷新 | ||||
|                 $('#btnSearch').on('click', function () { | ||||
|                     if (!$('#beginDate').val() || !$('#endDate').val()) { | ||||
|                         $("#tipMsg").text("请输入必填的信息"); | ||||
|                         $("#tipModal").modal('show'); | ||||
|                         return; | ||||
|                     } | ||||
|                     TableHelper.doRefresh('#table'); | ||||
|                 }); | ||||
|                 var chargeStart = $('#beginDate').datepicker({ | ||||
|                     format: 'yyyy-mm-dd', | ||||
|                     autoclose: true | ||||
|                 }); | ||||
|         // 查询刷新 | ||||
|         $('#btnSearch').on('click', function () { | ||||
|           if (!$('#beginDate').val() || !$('#endDate').val()) { | ||||
|             $("#tipMsg").text("请输入必填的信息"); | ||||
|             $("#tipModal").modal('show'); | ||||
|             return; | ||||
|           } | ||||
|           TableHelper.doRefresh('#table'); | ||||
|         }); | ||||
|         var chargeStart = $('#beginDate').datepicker({ | ||||
|           format: 'yyyy-mm-dd', | ||||
|           autoclose: true | ||||
|         }); | ||||
|  | ||||
|                 var chargeEnd = $('#endDate').datepicker({ | ||||
|                     format: 'yyyy-mm-dd', | ||||
|                     autoclose: true | ||||
|                 }); | ||||
|                 chargeStart.on('changeDate', function () { | ||||
|                     var date = $('#beginDate').datepicker('getDate'); | ||||
|                     chargeEnd.datepicker('setStartDate', date); | ||||
|                 }); | ||||
|                 chargeEnd.on('changeDate', function () { | ||||
|                     var date = $('#endDate').datepicker('getDate'); | ||||
|                     chargeStart.datepicker('setEndDate', date); | ||||
|                 }); | ||||
|         var chargeEnd = $('#endDate').datepicker({ | ||||
|           format: 'yyyy-mm-dd', | ||||
|           autoclose: true | ||||
|         }); | ||||
|         chargeStart.on('changeDate', function () { | ||||
|           var date = $('#beginDate').datepicker('getDate'); | ||||
|           chargeEnd.datepicker('setStartDate', date); | ||||
|         }); | ||||
|         chargeEnd.on('changeDate', function () { | ||||
|           var date = $('#endDate').datepicker('getDate'); | ||||
|           chargeStart.datepicker('setEndDate', date); | ||||
|         }); | ||||
|  | ||||
|                 $("#table").on("click", '.opt-detail', function () { | ||||
|         $("#table").on("click", '.opt-detail', function () { | ||||
|  | ||||
|                     $("#recordDetail").modal('show'); | ||||
|                     var time = $(this).attr("data-id"); | ||||
|           $("#recordDetail").modal('show'); | ||||
|           var time = $(this).attr("data-id"); | ||||
|  | ||||
|                     $("#modalLabel").html(time); | ||||
|           $("#modalLabel").html(time); | ||||
|  | ||||
|                     $('#detailtable').bootstrapTable('destroy'); | ||||
|                     $('#detailtable').bootstrapTable({ | ||||
|                         columns: [ | ||||
|                             { field: 'channel', title: '渠道', align: 'center', width: '5%' }, | ||||
|                             { field: 'amount', title: '充值金额', align: 'center', width: '5%' }, | ||||
|                             { field: 'count', title: '充值笔数', align: 'center', width: '5%' } | ||||
|           $('#detailtable').bootstrapTable('destroy'); | ||||
|           $('#detailtable').bootstrapTable({ | ||||
|             columns: [ | ||||
|               { field: 'channel', title: '渠道', align: 'center', width: '5%' }, | ||||
|               { field: 'amount', title: '充值金额', align: 'center', width: '5%' }, | ||||
|               { field: 'count', title: '充值笔数', align: 'center', width: '5%' } | ||||
|  | ||||
|                         ], | ||||
|                         undefinedText: 0, | ||||
|                         height: 600, | ||||
|                         cache: false, | ||||
|                         striped: true, | ||||
|                         showRefresh: false, | ||||
|                         pageSize: 20, | ||||
|                         pagination: false, | ||||
|                         pageList: [20, 50, 100, 200, 300, 500], | ||||
|                         search: false, | ||||
|                         sidePagination: "client", //表示服务端请求 | ||||
|                         queryParamsType: "undefined", | ||||
|                         queryParams: function queryParams(params) {   //设置查询参数 | ||||
|                             var param = { | ||||
|                                 pageNum: params.pageNumber, | ||||
|                                 pageSize: params.pageSize, | ||||
|                                 time: time | ||||
|                             }; | ||||
|                             return param; | ||||
|                         }, | ||||
|                         url: '/admin/chargeRecord/totaldetail', | ||||
|                         onLoadSuccess: function () {  //加载成功时执行 | ||||
|                             console.log("load success"); | ||||
|                         }, | ||||
|                         onLoadError: function () {  //加载失败时执行 | ||||
|                             console.log("load fail"); | ||||
|                         } | ||||
|                     }); | ||||
|                 }); | ||||
|             }); | ||||
|             ], | ||||
|             undefinedText: 0, | ||||
|             height: 600, | ||||
|             cache: false, | ||||
|             striped: true, | ||||
|             showRefresh: false, | ||||
|             pageSize: 20, | ||||
|             pagination: false, | ||||
|             pageList: [20, 50, 100, 200, 300, 500], | ||||
|             search: false, | ||||
|             sidePagination: "client", //表示服务端请求 | ||||
|             queryParamsType: "undefined", | ||||
|             queryParams: function queryParams (params) {   //设置查询参数 | ||||
|               var param = { | ||||
|                 pageNum: params.pageNumber, | ||||
|                 pageSize: params.pageSize, | ||||
|                 time: time | ||||
|               }; | ||||
|               return param; | ||||
|             }, | ||||
|             url: '/admin/chargeRecord/totaldetail', | ||||
|             onLoadSuccess: function () {  //加载成功时执行 | ||||
|               console.log("load success"); | ||||
|             }, | ||||
|             onLoadError: function () {  //加载失败时执行 | ||||
|               console.log("load fail"); | ||||
|             } | ||||
|           }); | ||||
|         }); | ||||
|       }); | ||||
|  | ||||
|         } | ||||
|     }, | ||||
|     } | ||||
|   }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|   | ||||
| @@ -103,6 +103,7 @@ export default { | ||||
|             { field: 'googleUsd', title: 'google充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'payermaxUsd', title: 'payermax充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'myCardUsd', title: 'myCard充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'startPayUsd', title: 'startPay充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'iosUsd', title: 'ios充值美元', align: 'center', width: '14%' }, | ||||
|             { field: 'companyUsd', title: '对公打款美元', align: 'center', width: '14%' }, | ||||
|             { field: 'totalUsd', title: '总充值美元', align: 'center', width: '14%' }, | ||||
|   | ||||
| @@ -24,6 +24,7 @@ | ||||
|                                     <option value="">请选择...</option> | ||||
|                                     <option value="0">金币</option> | ||||
|                                     <option value="1">背包礼物</option> | ||||
|                                     <option value="2">web-api金币</option> | ||||
|                                 </select> | ||||
|                             </div> | ||||
|  | ||||
| @@ -163,6 +164,8 @@ export default { | ||||
|                             formatter: function (val, row, index) { | ||||
|                                 if (row.type == 0) { | ||||
|                                     return '金币' | ||||
|                                 }else if(row.type == 2){ | ||||
|                                     return 'web-api金币'; | ||||
|                                 } else { | ||||
|                                     return '背包礼物'; | ||||
|                                 } | ||||
|   | ||||
| @@ -69,7 +69,7 @@ | ||||
|           :src="scope.row.screenUrl" | ||||
|           :zoom-rate="1.1" | ||||
|           :preview-src-list="scope.row.screenUrl" | ||||
|           fit="cover" | ||||
|           fit="scale-down" | ||||
|           preview-teleported="true" | ||||
|           hide-on-click-modal="true" | ||||
|         /> | ||||
|   | ||||
| @@ -65,6 +65,10 @@ | ||||
|                                     <option value="11">个播人气礼物</option> | ||||
|                                     <option value="15">线性福袋礼物</option> | ||||
|                                     <option value="16">超级幸运礼物</option> | ||||
|                                     <option value="17">国家礼物</option> | ||||
|                                     <option value="18">幸运礼物</option> | ||||
|                                     <option value="19">CP礼物</option> | ||||
|                                     <option value="20">定制礼物</option> | ||||
|                                 </select> | ||||
|                             </div> | ||||
|                             <label for="partitionId" class="col-sm-1 control-label">地区:</label> | ||||
| @@ -206,6 +210,10 @@ | ||||
|                                     <option value="11">个播人气礼物</option> | ||||
|                                     <option value="15">线性福袋礼物</option> | ||||
|                                     <option value="16">超级幸运礼物</option> | ||||
|                                     <option value="17">国家礼物</option> | ||||
|                                     <option value="18">幸运礼物</option> | ||||
|                                     <option value="19">CP礼物</option> | ||||
|                                     <option value="20">定制礼物</option> | ||||
|                                 </select> | ||||
|                             </div> | ||||
|                         </div> | ||||
|   | ||||
							
								
								
									
										348
									
								
								src/views/vip/VipGive.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										348
									
								
								src/views/vip/VipGive.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,348 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 查询 --> | ||||
|     <div class="inquire"> | ||||
|       <span>ID</span> | ||||
|       <el-input | ||||
|         v-model="inquire.userId" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" type="primary" @click="getData()" | ||||
|       >查询 | ||||
|     </el-button> | ||||
|     <el-button class="primary" type="primary" @click="editDialog = true" | ||||
|       >赠送VIP | ||||
|     </el-button> | ||||
|  | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="erbanNo" align="center" label="平台号" /> | ||||
|       <el-table-column prop="nick" align="center" label="昵称" /> | ||||
|       <el-table-column | ||||
|         prop="registerTime" | ||||
|         align="center" | ||||
|         label="用户注册时间" | ||||
|       /> | ||||
|       <el-table-column prop="createTime" align="center" label="赠送贵族时间" /> | ||||
|       <el-table-column prop="vipLevel" align="center" label="赠送贵族等级"> | ||||
|         <template v-slot="scope">VIP{{ scope.row.vipLevel }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="adminName" align="center" label="操作人" /> | ||||
|     </el-table> | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|  | ||||
|     <!-- 赠送VIP弹窗 --> | ||||
|     <el-dialog | ||||
|       v-model="editDialog" | ||||
|       title="赠送VIP(点击确认直接赠送,请认真核对谨慎操作!!)" | ||||
|       width="36%" | ||||
|       center | ||||
|     > | ||||
|       <!-- 赠送用户平台ID --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >赠送用户平台ID</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="editObj.userId" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|           placeholder="请输入赠送用户平台ID" | ||||
|           @input="inputFun()" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 赠送等级 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >赠送VIP等级</span | ||||
|         > | ||||
|         <el-select v-model="editObj.value" placeholder="请选择"> | ||||
|           <el-option | ||||
|             v-for="item in editObj.options" | ||||
|             :key="item.vipLevel" | ||||
|             :label="item.vipName" | ||||
|             :value="item.vipLevel" | ||||
|           > | ||||
|           </el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|  | ||||
|       <!-- 赠送天数 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; margin-right: 20px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >赠送天数</span | ||||
|         > | ||||
|         <el-select v-model="editObj.value2" placeholder="请选择"> | ||||
|           <el-option | ||||
|             v-for="item in editObj.options2" | ||||
|             :key="item.day" | ||||
|             :label="item.dayName" | ||||
|             :value="item.day" | ||||
|           > | ||||
|           </el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|  | ||||
|       <div> | ||||
|         <!-- 用户昵称 --> | ||||
|         <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|           <span | ||||
|             style="display: inline-block; margin-right: 20px" | ||||
|             class="col-sm-2 control-label" | ||||
|             >用户昵称</span | ||||
|           > | ||||
|           <el-input | ||||
|             v-model="editObj.nick" | ||||
|             style="width: 75%" | ||||
|             class="input" | ||||
|             placeholder="请先输入用户平台id" | ||||
|             disabled | ||||
|           ></el-input> | ||||
|         </div> | ||||
|         <!-- 用户地区 --> | ||||
|         <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|           <span | ||||
|             style="display: inline-block; margin-right: 20px" | ||||
|             class="col-sm-2 control-label" | ||||
|             >用户地区</span | ||||
|           > | ||||
|           <el-input | ||||
|             v-model="editObj.region" | ||||
|             style="width: 75%" | ||||
|             class="input" | ||||
|             placeholder="请先输入用户平台id" | ||||
|             disabled | ||||
|           ></el-input> | ||||
|         </div> | ||||
|         <!-- 用户注册时间 --> | ||||
|         <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|           <span | ||||
|             style="display: inline-block; margin-right: 20px" | ||||
|             class="col-sm-2 control-label" | ||||
|             >用户注册时间</span | ||||
|           > | ||||
|           <el-input | ||||
|             v-model="editObj.time" | ||||
|             style="width: 75%" | ||||
|             class="input" | ||||
|             placeholder="请先输入用户平台id" | ||||
|             disabled | ||||
|           ></el-input> | ||||
|         </div> | ||||
|       </div> | ||||
|  | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="editDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="editDialogClick()"> | ||||
|             确认 | ||||
|           </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   getByErbanNo, | ||||
|   listAll, | ||||
|   pageRecord, | ||||
|   vipSendSend, | ||||
| } from "@/api/VipGive/VipGive"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "VipGive", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         userId: "", | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 分页 | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|       //   赠送VIP | ||||
|       editDialog: false, | ||||
|       timeout: "", | ||||
|       editObj: { | ||||
|         userId: "", | ||||
|         value: "", | ||||
|         options: [], | ||||
|         value2: "", | ||||
|         options2: [ | ||||
|           { | ||||
|             dayName: "1天", | ||||
|             day: 1, | ||||
|           }, | ||||
|           { | ||||
|             dayName: "3天", | ||||
|             day: 3, | ||||
|           }, | ||||
|           { | ||||
|             dayName: "5天", | ||||
|             day: 5, | ||||
|           }, | ||||
|           { | ||||
|             dayName: "7天", | ||||
|             day: 7, | ||||
|           }, | ||||
|           { | ||||
|             dayName: "15天", | ||||
|             day: 15, | ||||
|           }, | ||||
|           { | ||||
|             dayName: "30天", | ||||
|             day: 30, | ||||
|           }, | ||||
|         ], | ||||
|         nick: "", | ||||
|         time: "", | ||||
|         region: "", | ||||
|         uid: "", | ||||
|       }, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getData(); | ||||
|     listAll().then((res) => { | ||||
|       this.editObj.options = res.data; | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       pageRecord({ | ||||
|         erbanNo: this.inquire.userId, | ||||
|         current: this.currentPage, | ||||
|         size: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         this.total = res.data.total; | ||||
|         this.tableData = res.data.rows; | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 监听弹窗用户id输入 | ||||
|     inputFun() { | ||||
|       var than = this; | ||||
|       clearTimeout(than.timeout); | ||||
|       than.timeout = setTimeout(function () { | ||||
|         ElMessage({ | ||||
|           showClose: true, | ||||
|           message: "查询中~", | ||||
|           type: "warning", | ||||
|         }); | ||||
|         getByErbanNo({ | ||||
|           erbanNo: than.editObj.userId, | ||||
|         }).then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             than.editObj.nick = res.data.nick; | ||||
|             than.editObj.region = res.data.partitionName; | ||||
|             than.editObj.time = res.data.createTime; | ||||
|             than.editObj.uid = res.data.uid; | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: "查询成功", | ||||
|               type: "success", | ||||
|             }); | ||||
|           } else { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "error", | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       }, 1000); | ||||
|     }, | ||||
|     // 赠送按钮 | ||||
|     editDialogClick() { | ||||
|       vipSendSend({ | ||||
|         uid: this.editObj.uid, | ||||
|         vipLevel: this.editObj.value, | ||||
|         days: this.editObj.value2, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           this.getData(); | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "赠送成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.editDialog = false; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
| @@ -52,7 +52,7 @@ | ||||
|             :src="scope.row.giftUrl" | ||||
|             :zoom-rate="1.1" | ||||
|             :preview-src-list="[scope.row.giftUrl]" | ||||
|             fit="cover" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|           /> | ||||
|   | ||||
| @@ -42,7 +42,7 @@ | ||||
|             :src="scope.row.giftUrl" | ||||
|             :zoom-rate="1.1" | ||||
|             :preview-src-list="[scope.row.giftUrl]" | ||||
|             fit="cover" | ||||
|             fit="scale-down" | ||||
|             preview-teleported="true" | ||||
|             hide-on-click-modal="true" | ||||
|           /> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user