Compare commits
	
		
			42 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 73eea6d101 | ||
|   | c51d205a42 | ||
|   | 8c1cd51293 | ||
|   | b8ad4f0234 | ||
|   | 8226604c00 | ||
|   | c23afafdc5 | ||
|   | 6b7aa99419 | ||
|   | dd95a1d64e | ||
|   | ec90636760 | ||
|   | 5d6d22a0af | ||
|   | 50343e2aa9 | ||
|   | 701bcb772a | ||
|   | 55d1e6fc43 | ||
|   | 642664edce | ||
|   | 7121ef5169 | ||
|   | 0388afa78e | ||
|   | 5bd9d0ead2 | ||
|   | fe0f0dc186 | ||
|   | 1a61a57c5a | ||
|   | d514f71968 | ||
|   | b56d879298 | ||
|   | 36083a6382 | ||
|   | 7602628333 | ||
|   | 52da350b0f | ||
|   | 839917da12 | ||
|   | 7a3d3b054a | ||
|   | 786edc9294 | ||
|   | 3ba46dfc9b | ||
|   | f865e989b9 | ||
|   | 4d877b9074 | ||
|   | 0b391b3b9d | ||
|   | dc45af7c97 | ||
|   | df0980565c | ||
|   | 059d43db48 | ||
|   | 815356ce7f | ||
|   | 0293f24864 | ||
|   | d1b239c91c | ||
|   | adc1f06401 | ||
|   | eb23708953 | ||
|   | 40344ec61c | ||
|   | 8c9016246f | ||
|   | 6502e1443b | 
							
								
								
									
										316
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										316
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -8,10 +8,10 @@ | ||||
|       "name": "peko-admin-web", | ||||
|       "version": "0.1.0", | ||||
|       "dependencies": { | ||||
|         "@element-plus/icons-vue": "^2.1.0", | ||||
|         "admin-lte": "^2.3.2", | ||||
|         "axios": "^1.5.0", | ||||
|         "bootstrap": "^3.3.5", | ||||
|         "bootstrap-table": "^1.10.1", | ||||
|         "core-js": "^3.8.3", | ||||
|         "element-plus": "^2.3.14", | ||||
|         "font-awesome": "^4.6.3", | ||||
| @@ -38,7 +38,10 @@ | ||||
|         "@vue/cli-service": "~5.0.0", | ||||
|         "eslint": "^7.32.0", | ||||
|         "eslint-plugin-vue": "^8.0.3", | ||||
|         "unplugin-auto-import": "^0.16.7", | ||||
|         "unplugin-vue-components": "^0.25.2", | ||||
|         "vue": "^3.2.13", | ||||
|         "webpack-bundle-analyzer": "^4.9.1", | ||||
|         "webpack-cli": "^5.1.4" | ||||
|       } | ||||
|     }, | ||||
| @@ -78,6 +81,12 @@ | ||||
|         "node": ">=6.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@antfu/utils": { | ||||
|       "version": "0.7.6", | ||||
|       "resolved": "https://registry.npmmirror.com/@antfu/utils/-/utils-0.7.6.tgz", | ||||
|       "integrity": "sha512-pvFiLP2BeOKA/ZOS6jxx4XhKzdVLHDhGlFEaZ2flWWYf2xOqVniqpk38I04DFRyz+L0ASggl7SkItTc+ZLju4w==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/@babel/code-frame": { | ||||
|       "version": "7.22.13", | ||||
|       "resolved": "https://registry.npmmirror.com/@babel/code-frame/-/code-frame-7.22.13.tgz", | ||||
| @@ -2180,6 +2189,28 @@ | ||||
|       "resolved": "https://registry.npmmirror.com/@sxzz/popperjs-es/-/popperjs-es-2.11.7.tgz", | ||||
|       "integrity": "sha512-Ccy0NlLkzr0Ex2FKvh2X+OyERHXJ88XJ1MXtsI9y9fGexlaXaVTPzBCRBwIxFkORuOb+uBqeu+RqnpgYTEZRUQ==" | ||||
|     }, | ||||
|     "node_modules/@rollup/pluginutils": { | ||||
|       "version": "5.0.5", | ||||
|       "resolved": "https://registry.npmmirror.com/@rollup/pluginutils/-/pluginutils-5.0.5.tgz", | ||||
|       "integrity": "sha512-6aEYR910NyP73oHiJglti74iRyOwgFU4x3meH/H8OJx6Ry0j6cOVZ5X/wTvub7G7Ao6qaHBEaNsV3GLJkSsF+Q==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "@types/estree": "^1.0.0", | ||||
|         "estree-walker": "^2.0.2", | ||||
|         "picomatch": "^2.3.1" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=14.0.0" | ||||
|       }, | ||||
|       "peerDependencies": { | ||||
|         "rollup": "^1.20.0||^2.0.0||^3.0.0||^4.0.0" | ||||
|       }, | ||||
|       "peerDependenciesMeta": { | ||||
|         "rollup": { | ||||
|           "optional": true | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@sideway/address": { | ||||
|       "version": "4.1.4", | ||||
|       "resolved": "https://registry.npmmirror.com/@sideway/address/-/address-4.1.4.tgz", | ||||
| @@ -4171,11 +4202,6 @@ | ||||
|         "node": ">=0.10.1" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/bootstrap-table": { | ||||
|       "version": "1.10.1", | ||||
|       "resolved": "https://registry.npmmirror.com/bootstrap-table/-/bootstrap-table-1.10.1.tgz", | ||||
|       "integrity": "sha512-jaRE6H4M3sSTEwe5g9PYVuDQW2ClHsnlB7grwfOD1Hk9Flv3gpwRcrkGZmGZ4+pzK4R41g5MRboFZ739xIIufw==" | ||||
|     }, | ||||
|     "node_modules/brace-expansion": { | ||||
|       "version": "1.1.11", | ||||
|       "resolved": "https://registry.npmmirror.com/brace-expansion/-/brace-expansion-1.1.11.tgz", | ||||
| @@ -7831,6 +7857,12 @@ | ||||
|         "node": ">=6" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/jsonc-parser": { | ||||
|       "version": "3.2.0", | ||||
|       "resolved": "https://registry.npmmirror.com/jsonc-parser/-/jsonc-parser-3.2.0.tgz", | ||||
|       "integrity": "sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/jsonfile": { | ||||
|       "version": "6.1.0", | ||||
|       "resolved": "https://registry.npmmirror.com/jsonfile/-/jsonfile-6.1.0.tgz", | ||||
| @@ -8001,6 +8033,19 @@ | ||||
|         "node": ">=8.9.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/local-pkg": { | ||||
|       "version": "0.5.0", | ||||
|       "resolved": "https://registry.npmmirror.com/local-pkg/-/local-pkg-0.5.0.tgz", | ||||
|       "integrity": "sha512-ok6z3qlYyCDS4ZEU27HaU6x/xZa9Whf8jD4ptH5UZTQYZVYeb9bnZ3ojVhiJNLiXK1Hfc0GNbLXcmZ5plLDDBg==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "mlly": "^1.4.2", | ||||
|         "pkg-types": "^1.0.3" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=14" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/locate-path": { | ||||
|       "version": "5.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/locate-path/-/locate-path-5.0.0.tgz", | ||||
| @@ -8819,6 +8864,18 @@ | ||||
|         "mkdirp": "bin/cmd.js" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/mlly": { | ||||
|       "version": "1.4.2", | ||||
|       "resolved": "https://registry.npmmirror.com/mlly/-/mlly-1.4.2.tgz", | ||||
|       "integrity": "sha512-i/Ykufi2t1EZ6NaPLdfnZk2AX8cs0d+mTzVKuPfqPKPatxLApaBoxJQ9x1/uckXtrS/U5oisPMDkNs0yQTaBRg==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "acorn": "^8.10.0", | ||||
|         "pathe": "^1.1.1", | ||||
|         "pkg-types": "^1.0.3", | ||||
|         "ufo": "^1.3.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/module-alias": { | ||||
|       "version": "2.2.3", | ||||
|       "resolved": "https://registry.npmmirror.com/module-alias/-/module-alias-2.2.3.tgz", | ||||
| @@ -9847,6 +9904,12 @@ | ||||
|         "node": ">=8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/pathe": { | ||||
|       "version": "1.1.1", | ||||
|       "resolved": "https://registry.npmmirror.com/pathe/-/pathe-1.1.1.tgz", | ||||
|       "integrity": "sha512-d+RQGp0MAYTIaDBIMmOfMwz3E+LOZnxx1HZd5R18mmCZY0QBlK0LDZfPc8FW8Ed2DlvsuE6PRjroDY+wg4+j/Q==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/picocolors": { | ||||
|       "version": "1.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/picocolors/-/picocolors-1.0.0.tgz", | ||||
| @@ -9881,6 +9944,17 @@ | ||||
|         "node": ">=8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/pkg-types": { | ||||
|       "version": "1.0.3", | ||||
|       "resolved": "https://registry.npmmirror.com/pkg-types/-/pkg-types-1.0.3.tgz", | ||||
|       "integrity": "sha512-nN7pYi0AQqJnoLPC9eHFQ8AcyaixBUOwvqc5TDnIKCMEE6I0y8P7OKA7fPexsXGCGxQDl/cmrLAp26LhcwxZ4A==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "jsonc-parser": "^3.2.0", | ||||
|         "mlly": "^1.2.0", | ||||
|         "pathe": "^1.1.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/popper.js": { | ||||
|       "version": "1.16.1", | ||||
|       "resolved": "https://registry.npmmirror.com/popper.js/-/popper.js-1.16.1.tgz", | ||||
| @@ -11134,6 +11208,12 @@ | ||||
|         "node": ">= 8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/scule": { | ||||
|       "version": "1.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/scule/-/scule-1.0.0.tgz", | ||||
|       "integrity": "sha512-4AsO/FrViE/iDNEPaAQlb77tf0csuq27EsVpy6ett584EcRTp6pTDLoGWVxCD77y5iU5FauOvhsI4o1APwPoSQ==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/select-hose": { | ||||
|       "version": "2.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/select-hose/-/select-hose-2.0.0.tgz", | ||||
| @@ -11717,6 +11797,15 @@ | ||||
|         "node": ">=8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/strip-literal": { | ||||
|       "version": "1.3.0", | ||||
|       "resolved": "https://registry.npmmirror.com/strip-literal/-/strip-literal-1.3.0.tgz", | ||||
|       "integrity": "sha512-PugKzOsyXpArk0yWmUwqOZecSO0GH0bPoctLcqNDH9J04pVW3lflYE0ujElBGTloevcxF5MofAOZ7C5l2b+wLg==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "acorn": "^8.10.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/stylehacks": { | ||||
|       "version": "5.1.1", | ||||
|       "resolved": "https://registry.npmmirror.com/stylehacks/-/stylehacks-5.1.1.tgz", | ||||
| @@ -12090,6 +12179,12 @@ | ||||
|         "node": ">= 0.6" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/ufo": { | ||||
|       "version": "1.3.1", | ||||
|       "resolved": "https://registry.npmmirror.com/ufo/-/ufo-1.3.1.tgz", | ||||
|       "integrity": "sha512-uY/99gMLIOlJPwATcMVYfqDSxUR9//AUcgZMzwfSTJPDKzA1S8mX4VLqa+fiAtveraQUBCz4FFcwVZBGbwBXIw==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/unicode-canonical-property-names-ecmascript": { | ||||
|       "version": "2.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz", | ||||
| @@ -12130,6 +12225,55 @@ | ||||
|         "node": ">=4" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unimport": { | ||||
|       "version": "3.4.0", | ||||
|       "resolved": "https://registry.npmmirror.com/unimport/-/unimport-3.4.0.tgz", | ||||
|       "integrity": "sha512-M/lfFEgufIT156QAr/jWHLUn55kEmxBBiQsMxvRSIbquwmeJEyQYgshHDEvQDWlSJrVOOTAgnJ3FvlsrpGkanA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "@rollup/pluginutils": "^5.0.4", | ||||
|         "escape-string-regexp": "^5.0.0", | ||||
|         "fast-glob": "^3.3.1", | ||||
|         "local-pkg": "^0.4.3", | ||||
|         "magic-string": "^0.30.3", | ||||
|         "mlly": "^1.4.2", | ||||
|         "pathe": "^1.1.1", | ||||
|         "pkg-types": "^1.0.3", | ||||
|         "scule": "^1.0.0", | ||||
|         "strip-literal": "^1.3.0", | ||||
|         "unplugin": "^1.5.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unimport/node_modules/escape-string-regexp": { | ||||
|       "version": "5.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz", | ||||
|       "integrity": "sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw==", | ||||
|       "dev": true, | ||||
|       "engines": { | ||||
|         "node": ">=12" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unimport/node_modules/local-pkg": { | ||||
|       "version": "0.4.3", | ||||
|       "resolved": "https://registry.npmmirror.com/local-pkg/-/local-pkg-0.4.3.tgz", | ||||
|       "integrity": "sha512-SFppqq5p42fe2qcZQqqEOiVRXl+WCP1MdT6k7BDEW1j++sp5fIY+/fdRQitvKgB5BrBcmrs5m/L0v2FrU5MY1g==", | ||||
|       "dev": true, | ||||
|       "engines": { | ||||
|         "node": ">=14" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unimport/node_modules/magic-string": { | ||||
|       "version": "0.30.5", | ||||
|       "resolved": "https://registry.npmmirror.com/magic-string/-/magic-string-0.30.5.tgz", | ||||
|       "integrity": "sha512-7xlpfBaQaP/T6Vh8MO/EqXSW5En6INHEvEXQiuff7Gku0PWjU3uf6w/j9o7O+SpB5fOAkrI5HeoNgwjEO0pFsA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "@jridgewell/sourcemap-codec": "^1.4.15" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=12" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unique-filename": { | ||||
|       "version": "2.0.1", | ||||
|       "resolved": "https://registry.npmmirror.com/unique-filename/-/unique-filename-2.0.1.tgz", | ||||
| @@ -12170,6 +12314,164 @@ | ||||
|         "node": ">= 0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin": { | ||||
|       "version": "1.5.0", | ||||
|       "resolved": "https://registry.npmmirror.com/unplugin/-/unplugin-1.5.0.tgz", | ||||
|       "integrity": "sha512-9ZdRwbh/4gcm1JTOkp9lAkIDrtOyOxgHmY7cjuwI8L/2RTikMcVG25GsZwNAgRuap3iDw2jeq7eoqtAsz5rW3A==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "acorn": "^8.10.0", | ||||
|         "chokidar": "^3.5.3", | ||||
|         "webpack-sources": "^3.2.3", | ||||
|         "webpack-virtual-modules": "^0.5.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin-auto-import": { | ||||
|       "version": "0.16.7", | ||||
|       "resolved": "https://registry.npmmirror.com/unplugin-auto-import/-/unplugin-auto-import-0.16.7.tgz", | ||||
|       "integrity": "sha512-w7XmnRlchq6YUFJVFGSvG1T/6j8GrdYN6Em9Wf0Ye+HXgD/22kont+WnuCAA0UaUoxtuvRR1u/mXKy63g/hfqQ==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "@antfu/utils": "^0.7.6", | ||||
|         "@rollup/pluginutils": "^5.0.5", | ||||
|         "fast-glob": "^3.3.1", | ||||
|         "local-pkg": "^0.5.0", | ||||
|         "magic-string": "^0.30.5", | ||||
|         "minimatch": "^9.0.3", | ||||
|         "unimport": "^3.4.0", | ||||
|         "unplugin": "^1.5.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=14" | ||||
|       }, | ||||
|       "peerDependencies": { | ||||
|         "@nuxt/kit": "^3.2.2", | ||||
|         "@vueuse/core": "*" | ||||
|       }, | ||||
|       "peerDependenciesMeta": { | ||||
|         "@nuxt/kit": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "@vueuse/core": { | ||||
|           "optional": true | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin-auto-import/node_modules/brace-expansion": { | ||||
|       "version": "2.0.1", | ||||
|       "resolved": "https://registry.npmmirror.com/brace-expansion/-/brace-expansion-2.0.1.tgz", | ||||
|       "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "balanced-match": "^1.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin-auto-import/node_modules/magic-string": { | ||||
|       "version": "0.30.5", | ||||
|       "resolved": "https://registry.npmmirror.com/magic-string/-/magic-string-0.30.5.tgz", | ||||
|       "integrity": "sha512-7xlpfBaQaP/T6Vh8MO/EqXSW5En6INHEvEXQiuff7Gku0PWjU3uf6w/j9o7O+SpB5fOAkrI5HeoNgwjEO0pFsA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "@jridgewell/sourcemap-codec": "^1.4.15" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=12" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin-auto-import/node_modules/minimatch": { | ||||
|       "version": "9.0.3", | ||||
|       "resolved": "https://registry.npmmirror.com/minimatch/-/minimatch-9.0.3.tgz", | ||||
|       "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "brace-expansion": "^2.0.1" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=16 || 14 >=14.17" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin-vue-components": { | ||||
|       "version": "0.25.2", | ||||
|       "resolved": "https://registry.npmmirror.com/unplugin-vue-components/-/unplugin-vue-components-0.25.2.tgz", | ||||
|       "integrity": "sha512-OVmLFqILH6w+eM8fyt/d/eoJT9A6WO51NZLf1vC5c1FZ4rmq2bbGxTy8WP2Jm7xwFdukaIdv819+UI7RClPyCA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "@antfu/utils": "^0.7.5", | ||||
|         "@rollup/pluginutils": "^5.0.2", | ||||
|         "chokidar": "^3.5.3", | ||||
|         "debug": "^4.3.4", | ||||
|         "fast-glob": "^3.3.0", | ||||
|         "local-pkg": "^0.4.3", | ||||
|         "magic-string": "^0.30.1", | ||||
|         "minimatch": "^9.0.3", | ||||
|         "resolve": "^1.22.2", | ||||
|         "unplugin": "^1.4.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=14" | ||||
|       }, | ||||
|       "peerDependencies": { | ||||
|         "@babel/parser": "^7.15.8", | ||||
|         "@nuxt/kit": "^3.2.2", | ||||
|         "vue": "2 || 3" | ||||
|       }, | ||||
|       "peerDependenciesMeta": { | ||||
|         "@babel/parser": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "@nuxt/kit": { | ||||
|           "optional": true | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin-vue-components/node_modules/brace-expansion": { | ||||
|       "version": "2.0.1", | ||||
|       "resolved": "https://registry.npmmirror.com/brace-expansion/-/brace-expansion-2.0.1.tgz", | ||||
|       "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "balanced-match": "^1.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin-vue-components/node_modules/local-pkg": { | ||||
|       "version": "0.4.3", | ||||
|       "resolved": "https://registry.npmmirror.com/local-pkg/-/local-pkg-0.4.3.tgz", | ||||
|       "integrity": "sha512-SFppqq5p42fe2qcZQqqEOiVRXl+WCP1MdT6k7BDEW1j++sp5fIY+/fdRQitvKgB5BrBcmrs5m/L0v2FrU5MY1g==", | ||||
|       "dev": true, | ||||
|       "engines": { | ||||
|         "node": ">=14" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin-vue-components/node_modules/magic-string": { | ||||
|       "version": "0.30.5", | ||||
|       "resolved": "https://registry.npmmirror.com/magic-string/-/magic-string-0.30.5.tgz", | ||||
|       "integrity": "sha512-7xlpfBaQaP/T6Vh8MO/EqXSW5En6INHEvEXQiuff7Gku0PWjU3uf6w/j9o7O+SpB5fOAkrI5HeoNgwjEO0pFsA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "@jridgewell/sourcemap-codec": "^1.4.15" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=12" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin-vue-components/node_modules/minimatch": { | ||||
|       "version": "9.0.3", | ||||
|       "resolved": "https://registry.npmmirror.com/minimatch/-/minimatch-9.0.3.tgz", | ||||
|       "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "brace-expansion": "^2.0.1" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=16 || 14 >=14.17" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin/node_modules/webpack-virtual-modules": { | ||||
|       "version": "0.5.0", | ||||
|       "resolved": "https://registry.npmmirror.com/webpack-virtual-modules/-/webpack-virtual-modules-0.5.0.tgz", | ||||
|       "integrity": "sha512-kyDivFZ7ZM0BVOUteVbDFhlRt7Ah/CSPwJdi8hBpkK7QLumUqdLtVfm/PX/hkcnrvr0i77fO5+TjZ94Pe+C9iw==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/update-browserslist-db": { | ||||
|       "version": "1.0.13", | ||||
|       "resolved": "https://registry.npmmirror.com/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", | ||||
| @@ -12513,7 +12815,7 @@ | ||||
|     }, | ||||
|     "node_modules/webpack-bundle-analyzer": { | ||||
|       "version": "4.9.1", | ||||
|       "resolved": "https://registry.npmmirror.com/webpack-bundle-analyzer/-/webpack-bundle-analyzer-4.9.1.tgz", | ||||
|       "resolved": "https://registry.npmjs.org/webpack-bundle-analyzer/-/webpack-bundle-analyzer-4.9.1.tgz", | ||||
|       "integrity": "sha512-jnd6EoYrf9yMxCyYDPj8eutJvtjQNp8PHmni/e/ulydHBWhT5J3menXt3HEkScsu9YqMAcG4CfFjs3rj5pVU1w==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|   | ||||
| @@ -3,15 +3,15 @@ | ||||
|   "version": "0.1.0", | ||||
|   "private": true, | ||||
|   "scripts": { | ||||
|     "dev": "vue-cli-service serve --mode development", | ||||
|     "dev": "vue-cli-service serve --mode development --report", | ||||
|     "build": "vue-cli-service build --mode production", | ||||
|     "lint": "vue-cli-service lint" | ||||
|   }, | ||||
|   "dependencies": { | ||||
|     "@element-plus/icons-vue": "^2.1.0", | ||||
|     "admin-lte": "^2.3.2", | ||||
|     "axios": "^1.5.0", | ||||
|     "bootstrap": "^3.3.5", | ||||
|     "bootstrap-table": "^1.10.1", | ||||
|     "core-js": "^3.8.3", | ||||
|     "element-plus": "^2.3.14", | ||||
|     "font-awesome": "^4.6.3", | ||||
| @@ -38,7 +38,10 @@ | ||||
|     "@vue/cli-service": "~5.0.0", | ||||
|     "eslint": "^7.32.0", | ||||
|     "eslint-plugin-vue": "^8.0.3", | ||||
|     "unplugin-auto-import": "^0.16.7", | ||||
|     "unplugin-vue-components": "^0.25.2", | ||||
|     "vue": "^3.2.13", | ||||
|     "webpack-bundle-analyzer": "^4.9.1", | ||||
|     "webpack-cli": "^5.1.4" | ||||
|   } | ||||
| } | ||||
|   | ||||
							
								
								
									
										60
									
								
								src/api/roomAlbumPower/RoomRed.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								src/api/roomAlbumPower/RoomRed.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
|  | ||||
| // 获取房间权限列表 | ||||
| export const redEnvelopePage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/redEnvelope/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 新增 | ||||
| export const redEnvelopeSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/redEnvelope/save', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 删除 | ||||
| export const delRoomRedEnvelope = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/redEnvelope/delRoomRedEnvelope', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 弹窗列表 | ||||
| export const userPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/redEnvelope/userPage', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 弹窗新增 | ||||
| export const saveManager = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/redEnvelope/saveManager', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 弹窗编辑 | ||||
| export const redEnvelopeUpdate = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/redEnvelope/update', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 弹窗删除 | ||||
| export const delUserRoomRedEnvelope = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/redEnvelope/delUserRoomRedEnvelope', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										29
									
								
								src/api/sysconfAdminView/sysconfAdminView.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								src/api/sysconfAdminView/sysconfAdminView.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 获取列表 | ||||
| export const getList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/sysConf/getList', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 保存新增 | ||||
| export const sysConfSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/sysConf/save', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // 删除 | ||||
| export const sysConfDel = query => { | ||||
|     return request({ | ||||
|         url: '/admin/sysConf/del', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| @@ -32,10 +32,10 @@ export default { | ||||
|     build: function (val, idstr, defval) { | ||||
|         var _this = this; | ||||
|         if (val) { | ||||
|             if (Object.prototype.toString.call(val) === '[object Object]') { | ||||
|             if (Object.prototype.toString.call(val) === '[object Array]') { | ||||
|                 $(idstr).empty(); | ||||
|                 $.each(val, function (n, value) { | ||||
|                     $(idstr).append("<option value='" + value.oval + "' data-value='" + value.oval + "'>" + value.otxt + "</option>"); | ||||
|                 $.each(val, function (n, obj) { | ||||
|                     $(idstr).append("<option value='" + obj.value + "' data-value='" + obj.value + "'>" + obj.text + "</option>"); | ||||
|                 }); | ||||
|                 $(idstr).btComboBox(); | ||||
|                 _this.setDef(idstr, defval); | ||||
|   | ||||
| @@ -52,7 +52,7 @@ | ||||
|         define(['jquery', 'knockout'], factory); | ||||
|     } else { | ||||
|         // Browser globals | ||||
|         factory(root.jQuery, root.ko); | ||||
|         factory(require("jquery"), root.ko); | ||||
|     } | ||||
| })(this, function ($, ko) { | ||||
|     "use strict";// jshint ;_; | ||||
|   | ||||
							
								
								
									
										303
									
								
								src/assets/plugins/bootstrap-table/css/bootstrap-table.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										303
									
								
								src/assets/plugins/bootstrap-table/css/bootstrap-table.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,303 @@ | ||||
| /** | ||||
|  * @author zhixin wen <wenzhixin2010@gmail.com> | ||||
|  * version: 1.10.1 | ||||
|  * https://github.com/wenzhixin/bootstrap-table/ | ||||
|  */ | ||||
|  | ||||
| .bootstrap-table .table { | ||||
|     margin-bottom: 0 !important; | ||||
|     border-bottom: 1px solid #dddddd; | ||||
|     border-collapse: collapse !important; | ||||
|     border-radius: 1px; | ||||
| } | ||||
|  | ||||
| .bootstrap-table .table:not(.table-condensed), | ||||
| .bootstrap-table .table:not(.table-condensed)>tbody>tr>th, | ||||
| .bootstrap-table .table:not(.table-condensed)>tfoot>tr>th, | ||||
| .bootstrap-table .table:not(.table-condensed)>thead>tr>td, | ||||
| .bootstrap-table .table:not(.table-condensed)>tbody>tr>td, | ||||
| .bootstrap-table .table:not(.table-condensed)>tfoot>tr>td { | ||||
|     padding: 8px; | ||||
| } | ||||
|  | ||||
| .bootstrap-table .table.table-no-bordered>thead>tr>th, | ||||
| .bootstrap-table .table.table-no-bordered>tbody>tr>td { | ||||
|     border-right: 2px solid transparent; | ||||
| } | ||||
|  | ||||
| .fixed-table-container { | ||||
|     position: relative; | ||||
|     clear: both; | ||||
|     border: 1px solid #dddddd; | ||||
|     border-radius: 4px; | ||||
|     -webkit-border-radius: 4px; | ||||
|     -moz-border-radius: 4px; | ||||
| } | ||||
|  | ||||
| .fixed-table-container.table-no-bordered { | ||||
|     border: 1px solid transparent; | ||||
| } | ||||
|  | ||||
| .fixed-table-footer, | ||||
| .fixed-table-header { | ||||
|     overflow: hidden; | ||||
| } | ||||
|  | ||||
| .fixed-table-footer { | ||||
|     border-top: 1px solid #dddddd; | ||||
| } | ||||
|  | ||||
| .fixed-table-body { | ||||
|     overflow-x: auto; | ||||
|     overflow-y: auto; | ||||
|     height: 100%; | ||||
| } | ||||
|  | ||||
| .fixed-table-container table { | ||||
|     width: 100%; | ||||
| } | ||||
|  | ||||
| .fixed-table-container thead th { | ||||
|     height: 0; | ||||
|     padding: 0; | ||||
|     margin: 0; | ||||
|     border-left: 1px solid #dddddd; | ||||
| } | ||||
|  | ||||
| .fixed-table-container thead th:focus { | ||||
|     outline: 0 solid transparent; | ||||
| } | ||||
|  | ||||
| .fixed-table-container thead th:first-child { | ||||
|     border-left: none; | ||||
|     border-top-left-radius: 4px; | ||||
|     -webkit-border-top-left-radius: 4px; | ||||
|     -moz-border-radius-topleft: 4px; | ||||
| } | ||||
|  | ||||
| .fixed-table-container thead th .th-inner, | ||||
| .fixed-table-container tbody td .th-inner { | ||||
|     padding: 8px; | ||||
|     line-height: 24px; | ||||
|     vertical-align: top; | ||||
|     overflow: hidden; | ||||
|     text-overflow: ellipsis; | ||||
|     white-space: nowrap; | ||||
| } | ||||
|  | ||||
| .fixed-table-container thead th .sortable { | ||||
|     cursor: pointer; | ||||
|     background-position: right; | ||||
|     background-repeat: no-repeat; | ||||
|     padding-right: 30px; | ||||
| } | ||||
|  | ||||
| .fixed-table-container thead th .both { | ||||
|     background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABMAAAATCAQAAADYWf5HAAAAkElEQVQoz7X QMQ5AQBCF4dWQSJxC5wwax1Cq1e7BAdxD5SL+Tq/QCM1oNiJidwox0355mXnG/DrEtIQ6azioNZQxI0ykPhTQIwhCR+BmBYtlK7kLJYwWCcJA9M4qdrZrd8pPjZWPtOqdRQy320YSV17OatFC4euts6z39GYMKRPCTKY9UnPQ6P+GtMRfGtPnBCiqhAeJPmkqAAAAAElFTkSuQmCC'); | ||||
| } | ||||
|  | ||||
| .fixed-table-container thead th .asc { | ||||
|     background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABMAAAATCAYAAAByUDbMAAAAZ0lEQVQ4y2NgGLKgquEuFxBPAGI2ahhWCsS/gDibUoO0gPgxEP8H4ttArEyuQYxAPBdqEAxPBImTY5gjEL9DM+wTENuQahAvEO9DMwiGdwAxOymGJQLxTyD+jgWDxCMZRsEoGAVoAADeemwtPcZI2wAAAABJRU5ErkJggg=='); | ||||
| } | ||||
|  | ||||
| .fixed-table-container thead th .desc { | ||||
|     background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABMAAAATCAYAAAByUDbMAAAAZUlEQVQ4y2NgGAWjYBSggaqGu5FA/BOIv2PBIPFEUgxjB+IdQPwfC94HxLykus4GiD+hGfQOiB3J8SojEE9EM2wuSJzcsFMG4ttQgx4DsRalkZENxL+AuJQaMcsGxBOAmGvopk8AVz1sLZgg0bsAAAAASUVORK5CYII= '); | ||||
| } | ||||
|  | ||||
| .fixed-table-container th.detail { | ||||
|     width: 30px; | ||||
| } | ||||
|  | ||||
| .fixed-table-container tbody td { | ||||
|     border-left: 1px solid #dddddd; | ||||
| } | ||||
|  | ||||
| .fixed-table-container tbody tr:first-child td { | ||||
|     border-top: none; | ||||
| } | ||||
|  | ||||
| .fixed-table-container tbody td:first-child { | ||||
|     border-left: none; | ||||
| } | ||||
|  | ||||
| /* the same color with .active */ | ||||
| .fixed-table-container tbody .selected td { | ||||
|     background-color: #f5f5f5; | ||||
| } | ||||
|  | ||||
| .fixed-table-container .bs-checkbox { | ||||
|     text-align: center; | ||||
| } | ||||
|  | ||||
| .fixed-table-container .bs-checkbox .th-inner { | ||||
|     padding: 8px 0; | ||||
| } | ||||
|  | ||||
| .fixed-table-container input[type="radio"], | ||||
| .fixed-table-container input[type="checkbox"] { | ||||
|     margin: 0 auto !important; | ||||
| } | ||||
|  | ||||
| .fixed-table-container .no-records-found { | ||||
|     text-align: center; | ||||
| } | ||||
|  | ||||
| .fixed-table-pagination div.pagination, | ||||
| .fixed-table-pagination .pagination-detail { | ||||
|     margin-top: 10px; | ||||
|     margin-bottom: 10px; | ||||
| } | ||||
|  | ||||
| .fixed-table-pagination div.pagination .pagination { | ||||
|     margin: 0; | ||||
| } | ||||
|  | ||||
| .fixed-table-pagination .pagination a { | ||||
|     padding: 6px 12px; | ||||
|     line-height: 1.428571429; | ||||
| } | ||||
|  | ||||
| .fixed-table-pagination .pagination-info { | ||||
|     line-height: 34px; | ||||
|     margin-right: 5px; | ||||
| } | ||||
|  | ||||
| .fixed-table-pagination .btn-group { | ||||
|     position: relative; | ||||
|     display: inline-block; | ||||
|     vertical-align: middle; | ||||
| } | ||||
|  | ||||
| .fixed-table-pagination .dropup .dropdown-menu { | ||||
|     margin-bottom: 0; | ||||
| } | ||||
|  | ||||
| .fixed-table-pagination .page-list { | ||||
|     display: inline-block; | ||||
| } | ||||
|  | ||||
| .fixed-table-toolbar .columns-left { | ||||
|     margin-right: 5px; | ||||
| } | ||||
|  | ||||
| .fixed-table-toolbar .columns-right { | ||||
|     margin-left: 5px; | ||||
| } | ||||
|  | ||||
| .fixed-table-toolbar .columns label { | ||||
|     display: block; | ||||
|     padding: 3px 20px; | ||||
|     clear: both; | ||||
|     font-weight: normal; | ||||
|     line-height: 1.428571429; | ||||
| } | ||||
|  | ||||
| .fixed-table-toolbar .bars, | ||||
| .fixed-table-toolbar .search, | ||||
| .fixed-table-toolbar .columns { | ||||
|     position: relative; | ||||
|     margin-top: 10px; | ||||
|     margin-bottom: 10px; | ||||
|     line-height: 34px; | ||||
| } | ||||
|  | ||||
| .fixed-table-pagination li.disabled a { | ||||
|     pointer-events: none; | ||||
|     cursor: default; | ||||
| } | ||||
|  | ||||
| .fixed-table-loading { | ||||
|     display: none; | ||||
|     position: absolute; | ||||
|     top: 42px; | ||||
|     right: 0; | ||||
|     bottom: 0; | ||||
|     left: 0; | ||||
|     z-index: 99; | ||||
|     background-color: #fff; | ||||
|     text-align: center; | ||||
| } | ||||
|  | ||||
| .fixed-table-body .card-view .title { | ||||
|     font-weight: bold; | ||||
|     display: inline-block; | ||||
|     min-width: 30%; | ||||
|     text-align: left !important; | ||||
| } | ||||
|  | ||||
| /* support bootstrap 2 */ | ||||
| .fixed-table-body thead th .th-inner { | ||||
|     box-sizing: border-box; | ||||
| } | ||||
|  | ||||
| .table th, | ||||
| .table td { | ||||
|     vertical-align: middle; | ||||
|     box-sizing: border-box; | ||||
| } | ||||
|  | ||||
| .fixed-table-toolbar .dropdown-menu { | ||||
|     text-align: left; | ||||
|     max-height: 300px; | ||||
|     overflow: auto; | ||||
| } | ||||
|  | ||||
| .fixed-table-toolbar .btn-group>.btn-group { | ||||
|     display: inline-block; | ||||
|     margin-left: -1px !important; | ||||
| } | ||||
|  | ||||
| .fixed-table-toolbar .btn-group>.btn-group>.btn { | ||||
|     border-radius: 0; | ||||
| } | ||||
|  | ||||
| .fixed-table-toolbar .btn-group>.btn-group:first-child>.btn { | ||||
|     border-top-left-radius: 4px; | ||||
|     border-bottom-left-radius: 4px; | ||||
| } | ||||
|  | ||||
| .fixed-table-toolbar .btn-group>.btn-group:last-child>.btn { | ||||
|     border-top-right-radius: 4px; | ||||
|     border-bottom-right-radius: 4px; | ||||
| } | ||||
|  | ||||
| .bootstrap-table .table>thead>tr>th { | ||||
|     vertical-align: bottom; | ||||
|     border-bottom: 1px solid #ddd; | ||||
| } | ||||
|  | ||||
| /* support bootstrap 3 */ | ||||
| .bootstrap-table .table thead>tr>th { | ||||
|     padding: 0; | ||||
|     margin: 0; | ||||
| } | ||||
|  | ||||
| .bootstrap-table .fixed-table-footer tbody>tr>td { | ||||
|     padding: 0 !important; | ||||
| } | ||||
|  | ||||
| .bootstrap-table .fixed-table-footer .table { | ||||
|     border-bottom: none; | ||||
|     border-radius: 0; | ||||
|     padding: 0 !important; | ||||
| } | ||||
|  | ||||
| .pull-right .dropdown-menu { | ||||
|     right: 0; | ||||
|     left: auto; | ||||
| } | ||||
|  | ||||
| /* calculate scrollbar width */ | ||||
| p.fixed-table-scroll-inner { | ||||
|     width: 100%; | ||||
|     height: 200px; | ||||
| } | ||||
|  | ||||
| div.fixed-table-scroll-outer { | ||||
|     top: 0; | ||||
|     left: 0; | ||||
|     visibility: hidden; | ||||
|     width: 200px; | ||||
|     height: 150px; | ||||
|     overflow: hidden; | ||||
| } | ||||
							
								
								
									
										2823
									
								
								src/assets/plugins/bootstrap-table/js/bootstrap-table.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2823
									
								
								src/assets/plugins/bootstrap-table/js/bootstrap-table.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										146
									
								
								src/assets/plugins/bootstrap-table/js/extensions/editable/bootstrap-table-editable.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								src/assets/plugins/bootstrap-table/js/extensions/editable/bootstrap-table-editable.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,146 @@ | ||||
| /** | ||||
|  * @author zhixin wen <wenzhixin2010@gmail.com> | ||||
|  * extensions: https://github.com/vitalets/x-editable | ||||
|  */ | ||||
|  | ||||
| (function (root, factory) { | ||||
|     var define; | ||||
|     if (typeof define === 'function' && define.amd) { | ||||
|         // AMD. Register as an anonymous module unless amdModuleId is set | ||||
|         define(["jquery"], function (a0) { | ||||
|             return (factory(a0)); | ||||
|         }); | ||||
|     } else if (typeof exports === 'object') { | ||||
|         // Node. Does not work with strict CommonJS, but | ||||
|         // only CommonJS-like environments that support module.exports, | ||||
|         // like Node. | ||||
|         module.exports = factory(require("jquery")); | ||||
|     } else { | ||||
|         factory(jQuery); | ||||
|     } | ||||
| }(this, function (jQuery) { | ||||
|  | ||||
|     !function ($) { | ||||
|  | ||||
|         'use strict'; | ||||
|  | ||||
|         $.extend($.fn.bootstrapTable.defaults, { | ||||
|             editable: true, | ||||
|             onEditableInit: function () { | ||||
|                 return false; | ||||
|             }, | ||||
|             onEditableSave: function (field, row, oldValue, $el) { | ||||
|                 return false; | ||||
|             }, | ||||
|             onEditableShown: function (field, row, $el, editable) { | ||||
|                 return false; | ||||
|             }, | ||||
|             onEditableHidden: function (field, row, $el, reason) { | ||||
|                 return false; | ||||
|             } | ||||
|         }); | ||||
|  | ||||
|         $.extend($.fn.bootstrapTable.Constructor.EVENTS, { | ||||
|             'editable-init.bs.table': 'onEditableInit', | ||||
|             'editable-save.bs.table': 'onEditableSave', | ||||
|             'editable-shown.bs.table': 'onEditableShown', | ||||
|             'editable-hidden.bs.table': 'onEditableHidden' | ||||
|         }); | ||||
|  | ||||
|         var BootstrapTable = $.fn.bootstrapTable.Constructor, | ||||
|             _initTable = BootstrapTable.prototype.initTable, | ||||
|             _initBody = BootstrapTable.prototype.initBody; | ||||
|  | ||||
|         BootstrapTable.prototype.initTable = function () { | ||||
|             var that = this; | ||||
|             _initTable.apply(this, Array.prototype.slice.apply(arguments)); | ||||
|  | ||||
|             if (!this.options.editable) { | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             $.each(this.columns, function (i, column) { | ||||
|                 if (!column.editable) { | ||||
|                     return; | ||||
|                 } | ||||
|  | ||||
|                 var editableOptions = {}, editableDataMarkup = [], editableDataPrefix = 'editable-'; | ||||
|  | ||||
|                 var processDataOptions = function (key, value) { | ||||
|                     // Replace camel case with dashes. | ||||
|                     var dashKey = key.replace(/([A-Z])/g, function ($1) { return "-" + $1.toLowerCase(); }); | ||||
|                     if (dashKey.slice(0, editableDataPrefix.length) == editableDataPrefix) { | ||||
|                         var dataKey = dashKey.replace(editableDataPrefix, 'data-'); | ||||
|                         editableOptions[dataKey] = value; | ||||
|                     } | ||||
|                 }; | ||||
|  | ||||
|                 $.each(that.options, processDataOptions); | ||||
|  | ||||
|                 var _formatter = column.formatter; | ||||
|                 column.formatter = function (value, row, index) { | ||||
|                     var result = _formatter ? _formatter(value, row, index) : value; | ||||
|  | ||||
|                     $.each(column, processDataOptions); | ||||
|  | ||||
|                     $.each(editableOptions, function (key, value) { | ||||
|                         editableDataMarkup.push(' ' + key + '="' + value + '"'); | ||||
|                     }); | ||||
|  | ||||
|                     return ['<a href="javascript:void(0)"', | ||||
|                         ' data-name="' + column.field + '"', | ||||
|                         ' data-pk="' + row[that.options.idField] + '"', | ||||
|                         ' data-value="' + result + '"', | ||||
|                         editableDataMarkup.join(''), | ||||
|                         '>' + '</a>' | ||||
|                     ].join(''); | ||||
|                 }; | ||||
|             }); | ||||
|         }; | ||||
|  | ||||
|         BootstrapTable.prototype.initBody = function () { | ||||
|             var that = this; | ||||
|             _initBody.apply(this, Array.prototype.slice.apply(arguments)); | ||||
|  | ||||
|             if (!this.options.editable) { | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             $.each(this.columns, function (i, column) { | ||||
|                 if (!column.editable) { | ||||
|                     return; | ||||
|                 } | ||||
|  | ||||
|                 that.$body.find('a[data-name="' + column.field + '"]').editable(column.editable) | ||||
|                     .off('save').on('save', function (e, params) { | ||||
|                         var data = that.getData(), | ||||
|                             index = $(this).parents('tr[data-index]').data('index'), | ||||
|                             row = data[index], | ||||
|                             oldValue = row[column.field]; | ||||
|  | ||||
|                         $(this).data('value', params.submitValue); | ||||
|                         row[column.field] = params.submitValue; | ||||
|                         that.trigger('editable-save', column.field, row, oldValue, $(this)); | ||||
|                     }); | ||||
|                 that.$body.find('a[data-name="' + column.field + '"]').editable(column.editable) | ||||
|                     .off('shown').on('shown', function (e, editable) { | ||||
|                         var data = that.getData(), | ||||
|                             index = $(this).parents('tr[data-index]').data('index'), | ||||
|                             row = data[index]; | ||||
|  | ||||
|                         that.trigger('editable-shown', column.field, row, $(this), editable); | ||||
|                     }); | ||||
|                 that.$body.find('a[data-name="' + column.field + '"]').editable(column.editable) | ||||
|                     .off('hidden').on('hidden', function (e, reason) { | ||||
|                         var data = that.getData(), | ||||
|                             index = $(this).parents('tr[data-index]').data('index'), | ||||
|                             row = data[index]; | ||||
|  | ||||
|                         that.trigger('editable-hidden', column.field, row, $(this), reason); | ||||
|                     }); | ||||
|             }); | ||||
|             this.trigger('editable-init'); | ||||
|         }; | ||||
|  | ||||
|     }(jQuery); | ||||
| })); | ||||
							
								
								
									
										60
									
								
								src/assets/plugins/bootstrap-table/js/locale/bootstrap-table-zh-CN.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								src/assets/plugins/bootstrap-table/js/locale/bootstrap-table-zh-CN.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | ||||
| /** | ||||
|  * Bootstrap Table Chinese translation | ||||
|  * Author: Zhixin Wen<wenzhixin2010@gmail.com> | ||||
|  */ | ||||
|  | ||||
| (function (root, factory) { | ||||
|     var define; | ||||
|     if (typeof define === 'function' && define.amd) { | ||||
|         // AMD. Register as an anonymous module unless amdModuleId is set | ||||
|         define(["jquery"], function (a0) { | ||||
|             return (factory(a0)); | ||||
|         }); | ||||
|     } else if (typeof exports === 'object') { | ||||
|         // Node. Does not work with strict CommonJS, but | ||||
|         // only CommonJS-like environments that support module.exports, | ||||
|         // like Node. | ||||
|         module.exports = factory(require("jquery")); | ||||
|     } else { | ||||
|         factory(jQuery); | ||||
|     } | ||||
| }(this, function (jQuery) { | ||||
|  | ||||
|     (function ($) { | ||||
|         'use strict'; | ||||
|  | ||||
|         $.fn.bootstrapTable.locales['zh-CN'] = { | ||||
|             formatLoadingMessage: function () { | ||||
|                 return '正在努力地加载数据中,请稍候……'; | ||||
|             }, | ||||
|             formatRecordsPerPage: function (pageNumber) { | ||||
|                 return '每页显示 ' + pageNumber + ' 条记录'; | ||||
|             }, | ||||
|             formatShowingRows: function (pageFrom, pageTo, totalRows) { | ||||
|                 return '显示第 ' + pageFrom + ' 到第 ' + pageTo + ' 条记录,总共 ' + totalRows + ' 条记录'; | ||||
|             }, | ||||
|             formatSearch: function () { | ||||
|                 return '搜索'; | ||||
|             }, | ||||
|             formatNoMatches: function () { | ||||
|                 return '没有找到匹配的记录'; | ||||
|             }, | ||||
|             formatPaginationSwitch: function () { | ||||
|                 return '隐藏/显示分页'; | ||||
|             }, | ||||
|             formatRefresh: function () { | ||||
|                 return '刷新'; | ||||
|             }, | ||||
|             formatToggle: function () { | ||||
|                 return '切换'; | ||||
|             }, | ||||
|             formatColumns: function () { | ||||
|                 return '列'; | ||||
|             } | ||||
|         }; | ||||
|  | ||||
|         $.extend($.fn.bootstrapTable.defaults, $.fn.bootstrapTable.locales['zh-CN']); | ||||
|  | ||||
|     })(jQuery); | ||||
| })); | ||||
|  | ||||
							
								
								
									
										14
									
								
								src/main.js
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								src/main.js
									
									
									
									
									
								
							| @@ -14,10 +14,10 @@ import 'admin-lte/dist/css/AdminLTE.min.css' | ||||
| import 'admin-lte/dist/css/skins/skin-purple-light.min.css' | ||||
| import 'admin-lte/dist/js/app.min.js' | ||||
|  | ||||
| import 'bootstrap-table/dist/bootstrap-table.css' | ||||
| import 'bootstrap-table/dist/bootstrap-table.js' | ||||
| import 'bootstrap-table/dist/locale/bootstrap-table-zh-CN.js' | ||||
| import 'bootstrap-table/dist/extensions/editable/bootstrap-table-editable.js' | ||||
| import '@/assets/plugins/bootstrap-table/css/bootstrap-table.css' | ||||
| import '@/assets/plugins/bootstrap-table/js/bootstrap-table.js' | ||||
| import '@/assets/plugins/bootstrap-table/js/locale/bootstrap-table-zh-CN.js' | ||||
| import '@/assets/plugins/bootstrap-table/js/extensions/editable/bootstrap-table-editable.js' | ||||
|  | ||||
| import '@/assets/plugins/jquery/jquery.form.js' | ||||
|  | ||||
| @@ -47,8 +47,8 @@ import '@/assets/plugins/bootstrap-treeview/js/bootstrap-treeview.min.js' | ||||
|  | ||||
| import components from '@/utils/components.js' | ||||
|  | ||||
| import ElementPlus from 'element-plus' | ||||
| import 'element-plus/dist/index.css' | ||||
| // import ElementPlus from 'element-plus' | ||||
| // import 'element-plus/dist/index.css' | ||||
| import '@/css/public.css' | ||||
|  | ||||
| createApp(App).use(store).use(router).use(components).use(ElementPlus).mount('#app') | ||||
| createApp(App).use(store).use(router).use(components).mount('#app') | ||||
|   | ||||
| @@ -35,7 +35,7 @@ export default { | ||||
|             let userAvatar = user.avatar; | ||||
|             if (userAvatar) { | ||||
|                 if (userAvatar != "") { | ||||
|                     userAvatar = userAvatar.startsWith('https') || userAvatar.startsWith('http') || avatar; | ||||
|                     userAvatar = (userAvatar.startsWith('https') || userAvatar.startsWith('http')) ? userAvatar : avatar; | ||||
|                 } | ||||
|                 state.avatar = userAvatar; | ||||
|                 setStore({ | ||||
|   | ||||
| @@ -1,29 +1,3 @@ | ||||
| /** | ||||
|  * 扩展date函数 | ||||
|  * author:c3gen | ||||
|  */ | ||||
|  | ||||
| export default Date.prototype.format = function (format) { | ||||
|     var o = { | ||||
|         "M+": this.getMonth() + 1, | ||||
|         "d+": this.getDate(), | ||||
|         "h+": this.getHours(), | ||||
|         "m+": this.getMinutes(), | ||||
|         "s+": this.getSeconds(), | ||||
|         "q+": Math.floor((this.getMonth() + 3) / 3), | ||||
|         "S": this.getMilliseconds() | ||||
|     } | ||||
|     if (/(y+)/.test(format)) { | ||||
|         format = format.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length)); | ||||
|     } | ||||
|     for (var k in o) { | ||||
|         if (new RegExp("(" + k + ")").test(format)) { | ||||
|             format = format.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length)); | ||||
|         } | ||||
|     } | ||||
|     return format; | ||||
| } | ||||
|  | ||||
| export function showLoading() { | ||||
|     $(".loadingGif").css('top', window.innerHeight / 2); | ||||
|     $(".loadingGif").css('left', window.innerWidth / 2); | ||||
|   | ||||
| @@ -3,15 +3,28 @@ import store from "@/store"; | ||||
| import global from "@/constants/global"; | ||||
|  | ||||
| const service = axios.create(); | ||||
|  | ||||
| import { ElMessage } from 'element-plus' | ||||
| service.interceptors.request.use(config => { | ||||
|     console.log('config', config); | ||||
|     return config; | ||||
| }, error => { | ||||
|     Promise.reject(error); | ||||
| }); | ||||
|  | ||||
| service.interceptors.response.use(res => { | ||||
|     userLogout(res.headers[global.NEED_LOGOUT]); | ||||
|     userLogout(res.headers[global.NEED_LOGOUT.toLowerCase()]); | ||||
|     console.log('res.data', res); | ||||
|     // if (res.data.code == 200) { | ||||
|         // ElMessage({ | ||||
|         //     message: "成功", | ||||
|         //     type: 'success' | ||||
|         // }); | ||||
|     // } else { | ||||
|         // ElMessage({ | ||||
|         //     message: res.data.message, | ||||
|         //     type: 'error' | ||||
|         //   }); | ||||
|     // } | ||||
|     return res.data; | ||||
| }, error => { | ||||
|     return Promise.reject(error); | ||||
| @@ -21,11 +34,11 @@ $.ajaxSetup({ | ||||
|     headers: { | ||||
|         'Access-Control-Allow-Origin': '*', | ||||
|     }, | ||||
|     beforeSend: function(xhr) { | ||||
|     beforeSend: function (xhr) { | ||||
|         console.log(xhr); | ||||
|     }, | ||||
|     complete: function(xhr) { | ||||
|         if (xhr && typeof(xhr.getResponseHeader) == 'function') { | ||||
|     complete: function (xhr) { | ||||
|         if (xhr && typeof (xhr.getResponseHeader) == 'function') { | ||||
|             userLogout(xhr.getResponseHeader(global.NEED_LOGOUT)); | ||||
|         } | ||||
|     } | ||||
| @@ -34,7 +47,7 @@ $.ajaxSetup({ | ||||
| /** | ||||
|  * 强制退出 | ||||
|  */ | ||||
| function userLogout(needLogout) { | ||||
| function userLogout (needLogout) { | ||||
|     try { | ||||
|         if (global.NEED_LOGOUT == needLogout) { | ||||
|             var win = window; | ||||
|   | ||||
| @@ -218,9 +218,9 @@ export default { | ||||
|                     cache: false, | ||||
|                     striped: true, | ||||
|                     showRefresh: false, | ||||
|                     pageSize: 20, | ||||
|                     pageSize: 10, | ||||
|                     pagination: true, | ||||
|                     pageList: [20, 50, 100], | ||||
|                     pageList: [10, 20, 50, 100], | ||||
|                     search: false, | ||||
|                     sidePagination: "server", //表示服务端请求 | ||||
|                     //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder | ||||
|   | ||||
| @@ -206,6 +206,8 @@ export default { | ||||
|                         { field: 'totalChargeAmount', title: '累计充值(美元)', align: 'center', width: '5%', }, | ||||
|                         { field: 'totalChargeUserNum', title: '累计充值人数', align: 'center', width: '5%', }, | ||||
|                         { field: 'totalChargeNum', title: '累计充值次数', align: 'center', width: '5%', }, | ||||
|                         { field: 'totalGiveNum', title: '累计收到转赠次数', align: 'center', width: '5%', }, | ||||
|                         { field: 'totalGiveAmount', title: '累计收到转赠金额', align: 'center', width: '5%', }, | ||||
|                         { | ||||
|                             field: 'month', | ||||
|                             title: '操作', | ||||
|   | ||||
| @@ -359,6 +359,8 @@ export default { | ||||
|                             { field: 'chargeCount', title: '充值次数', align: 'center', width: '5%', }, | ||||
|                             { field: 'chargeMoney', title: '充值金额(美元)', align: 'center', width: '5%', }, | ||||
|                             { field: 'sendGiftMony', title: '送礼钻石数', align: 'center', width: '5%', }, | ||||
|                             { field: 'giveCount', title: '累计收到转赠次数', align: 'center', width: '5%', }, | ||||
|                             { field: 'giveMoney', title: '累计收到转赠金额', align: 'center', width: '5%', }, | ||||
|                             { field: 'arpu', title: 'Arpu', align: 'center', width: '5%', }, | ||||
|                             { field: 'twoRemainCount', title: '次留', align: 'center', width: '5%', }, | ||||
|                             { field: 'sevenRemainCount', title: '七留', align: 'center', width: '5%', }, | ||||
| @@ -453,6 +455,8 @@ export default { | ||||
|                     let tchargeCount = 0; | ||||
|                     let tchargeMoney = 0; | ||||
|                     let tsendGiftMony = 0; | ||||
|                     let tgiveCount = 0; | ||||
|                     let tgiveMoney = 0; | ||||
|                     for (let i = 0; i < data.length; i++) { | ||||
|                         const team = data[i] | ||||
|                         tmemberCount += team.memberCount; | ||||
| @@ -461,6 +465,8 @@ export default { | ||||
|                         tchargeCount += team.chargeCount; | ||||
|                         tchargeMoney += team.chargeMoney; | ||||
|                         tsendGiftMony += team.sendGiftMony; | ||||
|                         tgiveCount += team.giveCount; | ||||
|                         tgiveMoney += team.giveMoney; | ||||
|                     } | ||||
|                     groupData.groupId = $('#query-groupSelector').val(); | ||||
|                     groupData.tmemberCount = tmemberCount; | ||||
| @@ -470,6 +476,8 @@ export default { | ||||
|                     groupData.tchargeCount = tchargeCount; | ||||
|                     groupData.tchargeMoney = tchargeMoney; | ||||
|                     groupData.tsendGiftMony = tsendGiftMony; | ||||
|                     groupData.tgiveCount = tgiveCount;  | ||||
|                     groupData.tgiveMoney = tgiveMoney; | ||||
|                     groupData.tarpu = (tchargeMoney / tnewUserCount).toFixed(2); | ||||
|                     groupDataList.push(groupData); | ||||
|                 } | ||||
| @@ -500,9 +508,11 @@ export default { | ||||
|                             { field: 'tchargeCount', title: '充值次数', align: 'center', width: '5%', }, | ||||
|                             { field: 'tchargeMoney', title: '充值金额(美元)', align: 'center', width: '5%', }, | ||||
|                             { field: 'tsendGiftMony', title: '送礼钻石数', align: 'center', width: '5%', }, | ||||
|                             { field: 'tgiveCount', title: '累计收到转赠次数', align: 'center', width: '5%', }, | ||||
|                             { field: 'tgiveMoney', title: '累计收到转赠金额', align: 'center', width: '5%', }, | ||||
|                             { field: 'tarpu', title: 'Arpu', align: 'center', width: '5%', }, | ||||
|                         ], | ||||
|                         height: 100, | ||||
|                         // height: 100, | ||||
|                         data: groupDataList, | ||||
|                         undefinedText: 0, | ||||
|                         cache: false, | ||||
| @@ -780,7 +790,6 @@ export default { | ||||
|                 $("#exportGroupDetail").on("click", function () { | ||||
|                     window.location.href = '/admin/flowTeam/exportUserStatisticDetails?' + param(groupDetailQueryParams); | ||||
|                 }); | ||||
|  | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
|   | ||||
| @@ -20,6 +20,31 @@ export default { | ||||
|     FooterView | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * 扩展date函数 | ||||
|  * author:c3gen | ||||
|  */ | ||||
|  Date.prototype.format = function (format) { | ||||
|     var o = { | ||||
|         "M+": this.getMonth() + 1, | ||||
|         "d+": this.getDate(), | ||||
|         "h+": this.getHours(), | ||||
|         "m+": this.getMinutes(), | ||||
|         "s+": this.getSeconds(), | ||||
|         "q+": Math.floor((this.getMonth() + 3) / 3), | ||||
|         "S": this.getMilliseconds() | ||||
|     } | ||||
|     if (/(y+)/.test(format)) { | ||||
|         format = format.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length)); | ||||
|     } | ||||
|     for (var k in o) { | ||||
|         if (new RegExp("(" + k + ")").test(format)) { | ||||
|             format = format.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length)); | ||||
|         } | ||||
|     } | ||||
|     return format; | ||||
| } | ||||
| </script> | ||||
|  | ||||
| <style scoped> | ||||
|   | ||||
| @@ -7,33 +7,35 @@ | ||||
|                     <h1 id="itemTitle"></h1> | ||||
|                 </section> | ||||
|                 <div id="toolbar"> | ||||
|                     <form id="searchForm" action="/admin/redEnvelope/export" method="get" target="_blank"> | ||||
|                         平台号:<input type="text" name="erbanNo" id="qErbanNo" class="input-sm" placeholder="" /> | ||||
|                         昵称:<input type="text" name="nick" id="qNick" class="input-sm" placeholder="" /> | ||||
|                     创建时间:<input type="text" name="startTime" id="qStartTime" class="input-sm datetime" placeholder="开始时间"> | ||||
|                         创建时间:<input type="text" name="startTime" id="qStartTime" class="input-sm datetime" | ||||
|                             placeholder="开始时间"> | ||||
|                         - <input type="text" name="endTime" id="qEndTime" class="input-sm datetime" placeholder="结束时间"> | ||||
|                         红包金额:<input type="text" name="minAmount" id="qMinAmount" class="input-sm" placeholder=""> | ||||
|                         - <input type="text" name="maxAmount" id="qMaxAmount" class="input-sm" placeholder=""> | ||||
|                     红包状态:<select name="redEnvelopeStatus" id="qRedEnvelopeStatus"> | ||||
|                         红包状态:<select name="redEnvelopeStatus" id="qRedEnvelopeStatus" class="input-sm"> | ||||
|                             <option value="">全部</option> | ||||
|                             <option value="0">未开始</option> | ||||
|                             <option value="1">进行中</option> | ||||
|                             <option value="2">已结束</option> | ||||
|                         </select> | ||||
|                     红包类型:<select name="redEnvelopeType" id="qRedEnvelopeType"> | ||||
|                         红包互动:<select name="redEnvelopeKind" id="qRedEnvelopeKind" class="input-sm" > | ||||
|                             <option value="">全部</option> | ||||
|                         <option value="0">房间手气红包</option> | ||||
|                         <option value="1">全服手气红包</option> | ||||
|                         <option value="2">房间礼物红包</option> | ||||
|                         <option value="3">全服礼物红包</option> | ||||
|                             <option value="0">旧版本红包</option> | ||||
|                             <option value="1">无门槛红包</option> | ||||
|                             <option value="2">关注红包</option> | ||||
|                             <option value="3">分享红包</option> | ||||
|                             <option value="4">弹幕红包</option> | ||||
|                         </select> | ||||
|                     </form> | ||||
|                     <button id="btnSearch" class="btn btn-sm btn-primary">查询</button> | ||||
|  | ||||
|                     <button id="btnExport" class="btn btn-sm btn-primary">导出</button> | ||||
|                 </div> | ||||
|             </div> | ||||
|  | ||||
|             <!-- .content --> | ||||
|             <div id="table"></div> | ||||
|  | ||||
|         </div> | ||||
|     </section> | ||||
|  | ||||
| @@ -94,12 +96,24 @@ export default { | ||||
|                         { field: 'userId', title: 'UID', align: 'center', width: '5%' }, | ||||
|                         { field: 'message', title: '标题', align: 'center', width: '10%' }, | ||||
|                         { | ||||
|                             field: 'redEnvelopeType', | ||||
|                             title: '类型', | ||||
|                             field: 'redEnvelopeKind', | ||||
|                             title: '互动', | ||||
|                             align: 'center', | ||||
|                             width: '5%', | ||||
|                             formatter: function (val, row, index) { | ||||
|                                 return redEnvelopeTypeMap[val] | ||||
|                                 let value = ''; | ||||
|                                 if (val == 0) { | ||||
|                                     value = redEnvelopeTypeMap[row.redEnvelopeType]; | ||||
|                                 } else if (val == 1) { | ||||
|                                     value = '无门槛红包'; | ||||
|                                 } else if (val == 2) { | ||||
|                                     value = '关注红包'; | ||||
|                                 } else if (val == 3) { | ||||
|                                     value = '分享红包'; | ||||
|                                 } else if (val == 4) { | ||||
|                                     value = '弹幕红包'; | ||||
|                                 } | ||||
|                                 return value; | ||||
|                             } | ||||
|                         }, | ||||
|                         { | ||||
| @@ -145,8 +159,13 @@ export default { | ||||
|                             align: 'center', | ||||
|                             width: '10%', | ||||
|                             formatter: function (val, row, index) { | ||||
|                                 return '<button id="btnEdit" name="btnEdit" class="btn btn-sm btn-success opt-edit" data-id=' + val + '>' + | ||||
|                                     '<i class="glyphicon glyphicon-edit"></i> 查看领取名单</button>'; | ||||
|                                 let value = '<button id="btnEdit" name="btnEdit" class="btn btn-sm btn-success opt-edit" data-id="' + val + '">' | ||||
|                                     + '<i class="glyphicon glyphicon-edit"></i> 查看领取名单</button>'; | ||||
|                                 let status = row.redEnvelopeStatus; | ||||
|                                 if (status == 0 || status == 1) { | ||||
|                                     value += '<button class="btn btn-sm btn-danger opt-close" data-index="' + index + '" data-id="' + val + '">关闭红包</button>'; | ||||
|                                 } | ||||
|                                 return value; | ||||
|                             } | ||||
|                         } | ||||
|                     ], | ||||
| @@ -168,7 +187,7 @@ export default { | ||||
|                             nick: $('#qNick').val(), | ||||
|                             startTime: $('#qStartTime').val(), | ||||
|                             endTime: $('#qEndTime').val(), | ||||
|                             redEnvelopeType: $('#qRedEnvelopeType').val(), | ||||
|                             redEnvelopeKind: $('#qRedEnvelopeKind').val(), | ||||
|                             redEnvelopeStatus: $('#qRedEnvelopeStatus').val(), | ||||
|                             minAmount: $('#qMinAmount').val(), | ||||
|                             maxAmount: $('#qMaxAmount').val(), | ||||
| @@ -209,6 +228,35 @@ export default { | ||||
|                     TableHelper.doRefresh('#table'); | ||||
|                 }); | ||||
|  | ||||
|                 // 导出 | ||||
|                 $('#btnExport').on('click', function () { | ||||
|                     $("#searchForm").submit(); | ||||
|                 }); | ||||
|  | ||||
|                 //关闭红包 | ||||
|                 $("#table").on("click", '.opt-close', function () { | ||||
|                     let id = $(this).attr("data-id"); | ||||
|                     const msg = '确定要关闭吗?'; | ||||
|                     if (confirm(msg)) { | ||||
|                         $.ajax({ | ||||
|                             type: "get", | ||||
|                             url: "/admin/redEnvelope/close?redEnvelopeId=" + id, | ||||
|                             dataType: "json", | ||||
|                             success: function (json) { | ||||
|                                 if (json.success == 'true' || json.code == 200) { | ||||
|                                     $("#tipMsg").text("关闭成功"); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                     TableHelper.doRefresh("#table"); | ||||
|                                 } else { | ||||
|                                     $("#tipMsg").text("保关闭失败." + json.message); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                 } | ||||
|                             } | ||||
|                         }); | ||||
|                     } | ||||
|                      | ||||
|                 }); | ||||
|  | ||||
|                 // 编辑获取信息 | ||||
|                 $("#table").on("click", '.opt-edit', function () { | ||||
|                     let id = $(this).attr("data-id"); | ||||
|   | ||||
							
								
								
									
										511
									
								
								src/views/room/RoomRed.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										511
									
								
								src/views/room/RoomRed.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,511 @@ | ||||
| <template> | ||||
|   <div class="outer"> | ||||
|     <!-- 顶部搜索条件 --> | ||||
|     <div class="search"> | ||||
|       <div class="searchLeft"> | ||||
|         <span>房间ID</span> | ||||
|         <el-input | ||||
|           v-model="roomId" | ||||
|           size="default" | ||||
|           placeholder="权限房间号" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <div class="searchRight"> | ||||
|         <span>用户ID</span> | ||||
|         <el-input | ||||
|           v-model="userId" | ||||
|           size="default" | ||||
|           placeholder="权限用户id" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 按钮 --> | ||||
|     <div class="buttonBox"> | ||||
|       <el-button class="primary" type="primary" size="default" @click="search()" | ||||
|         >查询</el-button | ||||
|       > | ||||
|       <el-button | ||||
|         @click="authority = true" | ||||
|         class="primary" | ||||
|         type="primary" | ||||
|         size="default" | ||||
|         style="margin-right: 10px" | ||||
|         >添加</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <!-- 增加权限弹窗 --> | ||||
|     <el-dialog v-model="authority" title="增加房间红包权限" width="30%" center> | ||||
|       <div class="authorityBox"> | ||||
|         <span class="authoritySpan">房间ID</span> | ||||
|         <el-input | ||||
|           v-model="addRoomId" | ||||
|           size="default" | ||||
|           placeholder="输入房间ID多个请用英文 , 来分别" | ||||
|           class="authorityInpput" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="authority = false">取消</el-button> | ||||
|           <el-button type="primary" @click="addAuthority()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 表格 --> | ||||
|     <el-table :data="tableData" border style="width: 100%; margin-top: 25px"> | ||||
|       <el-table-column prop="roomErBanNo" align="center" label="权限房间号" /> | ||||
|       <el-table-column prop="title" align="center" label="房间名称" /> | ||||
|       <el-table-column prop="createTime" align="center" label="房间获得权限时间" /> | ||||
|       <el-table-column | ||||
|         prop="userCount" | ||||
|         align="center" | ||||
|         label="该房间的房间红包权限用户数" | ||||
|       /> | ||||
|       <el-table-column align="center" label="操作" width="400"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="modifyUserPower(scope.row)" | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             size="default" | ||||
|             >管理权限用户</el-button | ||||
|           > | ||||
|           <el-button | ||||
|             @click="delRoomPower(scope.row)" | ||||
|             class="danger" | ||||
|             type="danger" | ||||
|             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="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500]" | ||||
|       :small="small" | ||||
|       :disabled="disabled" | ||||
|       :background="background" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|     <!-- 管理权限弹窗 --> | ||||
|     <el-dialog v-model="dialogTableVisible" :title="dialogTableVisibleTitle"> | ||||
|       <el-button | ||||
|         class="dialogTableVisibleBut primary" | ||||
|         type="primary" | ||||
|         @click=" | ||||
|           authorityLimits = true; | ||||
|           radioFull = false; | ||||
|           radioHall = false; | ||||
|           typeRadio = 0; | ||||
|         " | ||||
|       > | ||||
|         新增 | ||||
|       </el-button> | ||||
|  | ||||
|       <el-table style="width: 100%" :data="authorityData" border> | ||||
|         <el-table-column | ||||
|           align="center" | ||||
|           property="userErBanNo" | ||||
|           label="用户id" | ||||
|           min-width="100px" | ||||
|         /> | ||||
|         <el-table-column | ||||
|           align="center" | ||||
|           property="nick" | ||||
|           label="用户昵称" | ||||
|           min-width="100px" | ||||
|         /> | ||||
|         <el-table-column | ||||
|           align="center" | ||||
|           property="createTime" | ||||
|           label="获得权限时间" | ||||
|           min-width="100px" | ||||
|         /> | ||||
|         <el-table-column | ||||
|           align="center" | ||||
|           property="type" | ||||
|           label="开启的权限" | ||||
|           min-width="100px" | ||||
|         > | ||||
|           <template v-slot="scope">{{ | ||||
|             scope.row.type == 1 | ||||
|               ? "厅内红包" | ||||
|               : scope.row.type == 2 | ||||
|               ? "全服红包" | ||||
|               : scope.row.type == 3 | ||||
|               ? "厅内红包&全服红包" | ||||
|               : "空或未知类型" | ||||
|           }}</template> | ||||
|         </el-table-column> | ||||
|         <el-table-column align="center" label="操作" width="200px"> | ||||
|           <template v-slot="scope"> | ||||
|             <el-button | ||||
|               @click="editTablePower(scope.row)" | ||||
|               class="primary" | ||||
|               type="primary" | ||||
|               size="default" | ||||
|               :disabled="!(scope.row.roomUid === scope.row.uid) ? false : true" | ||||
|               >编辑</el-button | ||||
|             > | ||||
|             <el-button | ||||
|               @click="delTablePower(scope.row)" | ||||
|               class="danger" | ||||
|               type="danger" | ||||
|               size="default" | ||||
|               :disabled="!(scope.row.roomUid === scope.row.uid) ? false : true" | ||||
|               >删除权限</el-button | ||||
|             > | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|       </el-table> | ||||
|       <!-- 分页2 --> | ||||
|       <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]" | ||||
|         :small="small" | ||||
|         :disabled="disabled" | ||||
|         :background="background" | ||||
|         layout="sizes, prev, pager, next" | ||||
|         :total="total2" | ||||
|         @size-change="handleSizeChange2" | ||||
|         @current-change="handleCurrentChange2" | ||||
|       /> | ||||
|     </el-dialog> | ||||
|     <!-- 增加房间红包管理权限弹窗 --> | ||||
|     <el-dialog v-model="authorityLimits" title="增加房间红包管理权限" width="30%" center> | ||||
|       <div class="authorityBox"> | ||||
|         <span class="authoritySpan">用户ID</span> | ||||
|         <el-input | ||||
|           v-model="addLimits" | ||||
|           size="default" | ||||
|           placeholder="输入用户ID多个请用英文 , 来分别" | ||||
|           class="authorityInpput" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <div class="optionBox"> | ||||
|         <el-checkbox | ||||
|           v-model="radioHall" | ||||
|           @change="checkBoxChange()" | ||||
|           label="厅内红包" | ||||
|           size="large" | ||||
|         /> | ||||
|         <el-checkbox | ||||
|           v-model="radioFull" | ||||
|           @change="checkBoxChange()" | ||||
|           label="全服红包" | ||||
|           size="large" | ||||
|         /> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="authorityLimits = false">取消</el-button> | ||||
|           <el-button type="primary" @click="addAuthorityLimits()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 编辑弹窗 --> | ||||
|     <el-dialog v-model="editDialog" title="编辑" width="30%" center> | ||||
|       <div class="optionBox"> | ||||
|         <el-checkbox | ||||
|           v-model="radioHall" | ||||
|           @change="checkBoxChange()" | ||||
|           label="厅内红包" | ||||
|           size="large" | ||||
|         /> | ||||
|         <el-checkbox | ||||
|           v-model="radioFull" | ||||
|           @change="checkBoxChange()" | ||||
|           label="全服红包" | ||||
|           size="large" | ||||
|         /> | ||||
|       </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> {{ delDialogText }}</span> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="delDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="delClick(val, type)"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   redEnvelopePage, | ||||
|   redEnvelopeSave, | ||||
|   delRoomRedEnvelope, | ||||
|   delUserRoomRedEnvelope, | ||||
|   userPage, | ||||
|   saveManager, | ||||
|   redEnvelopeUpdate, | ||||
| } from "@/api/roomAlbumPower/RoomRed"; | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "RoomRed", | ||||
|   data() { | ||||
|     return { | ||||
|       editDialog: false, | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|       total2: 10, //总页数 | ||||
|       currentPage2: 1, //页码 | ||||
|       pageSize2: 10, //条数 | ||||
|       roomId: "", //房间id | ||||
|       userId: "", //用户id | ||||
|       authority: false, //控制新增房间红包弹窗 | ||||
|       addRoomId: "", //新增房间id | ||||
|       dialogTableVisible: false, //控制权限管理弹窗 | ||||
|       dialogTableVisibleTitle: "房间ID:123 的房间红包权限", | ||||
|       authorityLimits: false, //控制新增房间红包权限管理弹窗 | ||||
|       addLimits: "", //弹窗新增ID | ||||
|       delType: null, | ||||
|       delroomUid: null, | ||||
|       tableData: [], | ||||
|       authorityData: [], | ||||
|       //公共二次确认弹窗 | ||||
|       delDialog: false, | ||||
|       delDialogText: "提示", | ||||
|       radioHall: false, | ||||
|       radioFull: false, | ||||
|       typeRadio: 0, | ||||
|       public: null, | ||||
|       delTablePowerRoomUid: null, | ||||
|       delTablePowerUid: null, | ||||
|       editTableData: {}, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 获取外表格数据接口 | ||||
|     getData() { | ||||
|       redEnvelopePage({ | ||||
|         roomErBanNo: this.roomId, | ||||
|         userErBanNo: this.userId, | ||||
|         page: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|       }).then((res) => { | ||||
|         this.roomId = ""; | ||||
|         this.userId = ""; | ||||
|         this.addRoomId = ""; | ||||
|         this.total = res.total; | ||||
|         this.tableData = res.rows; | ||||
|       }); | ||||
|     }, | ||||
|     // 查询按钮 | ||||
|     search() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // 管理权限用户按钮 | ||||
|     modifyUserPower(row) { | ||||
|       console.log(row); | ||||
|       this.public = row; | ||||
|       this.saveManagerRoomUid = row.roomUid; | ||||
|       this.dialogTableVisibleTitle = `房间ID:${row.roomErBanNo} 的房间红包权限`; | ||||
|       this.getUserPage(row.roomUid); | ||||
|     }, | ||||
|     // 弹窗列表 | ||||
|     getUserPage(val) { | ||||
|       userPage({ roomUid: val, page: this.currentPage2, pageSize: this.pageSize2 }).then( | ||||
|         (res) => { | ||||
|           this.total2 = res.total; | ||||
|           this.authorityData = res.rows; | ||||
|           this.dialogTableVisible = true; | ||||
|         } | ||||
|       ); | ||||
|     }, | ||||
|     // 删除权限 | ||||
|     delRoomPower(row) { | ||||
|       console.log(row); | ||||
|       this.delType = 1; | ||||
|       this.delDialog = true; | ||||
|       this.delDialogText = "确定要删除该房间红包权限吗?"; | ||||
|       this.delroomUid = row.roomUid; | ||||
|     }, | ||||
|     // 二次确认 | ||||
|     delClick(val, type) { | ||||
|       if (this.delType == 1) { | ||||
|         //delType 1:删除该房间权限 2:删除房间内用户权限 | ||||
|         delRoomRedEnvelope({ roomUid: this.delroomUid }).then((res) => { | ||||
|           this.getData(); | ||||
|         }); | ||||
|       } else { | ||||
|         delUserRoomRedEnvelope({ | ||||
|           roomUid: this.delTablePowerRoomUid, | ||||
|           uid: this.delTablePowerUid, | ||||
|         }).then((res) => { | ||||
|           this.getUserPage(this.delTablePowerRoomUid); | ||||
|         }); | ||||
|       } | ||||
|       this.delDialog = false; | ||||
|     }, | ||||
|     // 删除弹窗权限 | ||||
|     delTablePower(row) { | ||||
|       console.log(row); | ||||
|       this.delType = 2; | ||||
|       this.delDialog = true; | ||||
|       this.delDialogText = "确定要删除该房间红包权限吗?"; | ||||
|       this.delTablePowerRoomUid = row.roomUid; | ||||
|       this.delTablePowerUid = row.uid; | ||||
|     }, | ||||
|     // 编辑弹窗权限 | ||||
|     editTablePower(row) { | ||||
|       if (row.type == 1) { | ||||
|         this.radioHall = true; | ||||
|         this.radioFull = false; | ||||
|       } else if (row.type == 2) { | ||||
|         this.radioHall = false; | ||||
|         this.radioFull = true; | ||||
|       } else if (row.type == 3) { | ||||
|         this.radioHall = true; | ||||
|         this.radioFull = true; | ||||
|       } | ||||
|       this.editTableData = row; | ||||
|       this.editDialog = true; | ||||
|     }, | ||||
|     // 确认编辑按钮 | ||||
|     editDialogClick() { | ||||
|       if (this.radioHall && this.radioFull) { | ||||
|         this.typeRadio = 3; | ||||
|       } else if (this.radioHall && this.radioFull == false) { | ||||
|         this.typeRadio = 1; | ||||
|       } else if (this.radioFull && this.radioHall == false) { | ||||
|         this.typeRadio = 2; | ||||
|       } else { | ||||
|         this.typeRadio = 0; | ||||
|       } | ||||
|       if (this.typeRadio == 0) { | ||||
|         ElMessage({ | ||||
|           message: "请勾选开启的权限", | ||||
|           type: "error", | ||||
|         }); | ||||
|         return; | ||||
|       } | ||||
|       redEnvelopeUpdate({ | ||||
|         id: this.editTableData.id, | ||||
|         roomUid: this.editTableData.roomUid, | ||||
|         uid: this.editTableData.uid, | ||||
|         type: this.typeRadio, | ||||
|       }).then((res) => { | ||||
|       this.editDialog = false; | ||||
|         this.getUserPage(this.editTableData.roomUid); | ||||
|       }); | ||||
|     }, | ||||
|     // 确认新增房间红包弹窗按钮 | ||||
|     addAuthority() { | ||||
|       redEnvelopeSave({ | ||||
|         roomErBanNoStr: this.addRoomId, | ||||
|       }).then((res) => { | ||||
|         this.authority = false; | ||||
|         this.getData(); | ||||
|       }); | ||||
|     }, | ||||
|     // 监听多选框 | ||||
|     checkBoxChange() { | ||||
|       if (this.radioHall && this.radioFull) { | ||||
|         this.typeRadio = 3; | ||||
|       } else if (this.radioHall && this.radioFull == false) { | ||||
|         this.typeRadio = 1; | ||||
|       } else if (this.radioFull && this.radioHall == false) { | ||||
|         this.typeRadio = 2; | ||||
|       } else { | ||||
|         this.typeRadio = 0; | ||||
|       } | ||||
|     }, | ||||
|     // 确认弹窗新增按钮 | ||||
|     addAuthorityLimits() { | ||||
|       console.log(this.typeRadio); | ||||
|       if (this.typeRadio == 0) { | ||||
|         ElMessage({ | ||||
|           message: "请勾选开启的权限", | ||||
|           type: "error", | ||||
|         }); | ||||
|         return; | ||||
|       } | ||||
|       saveManager({ | ||||
|         roomUid: this.public.roomUid, | ||||
|         type: this.typeRadio, | ||||
|         userErBanNoStr: this.addLimits, | ||||
|       }).then((res) => { | ||||
|         this.addLimits = ""; | ||||
|         this.authorityLimits = false; | ||||
|         this.getUserPage(this.public.roomUid); | ||||
|       }); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange(val) { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange(val) { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // 分页导航2 | ||||
|     handleSizeChange2(val) { | ||||
|       this.getUserPage(this.saveManagerRoomUid); | ||||
|     }, | ||||
|     handleCurrentChange2(val) { | ||||
|       this.getUserPage(this.saveManagerRoomUid); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .outer { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   border-top: 3px solid #d2d6de; | ||||
|   .search { | ||||
|     width: 100%; | ||||
|     height: 41px; | ||||
|     .searchLeft, | ||||
|     .searchRight { | ||||
|       width: 20%; | ||||
|       float: left; | ||||
|       span { | ||||
|         margin-right: 10px; | ||||
|       } | ||||
|       .input { | ||||
|         width: 75%; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   .buttonBox { | ||||
|     margin-top: 10px; | ||||
|   } | ||||
|   .authorityBox { | ||||
|     .authoritySpan { | ||||
|       margin-right: 20px; | ||||
|     } | ||||
|     .authorityInpput { | ||||
|       width: 50%; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     margin: -25px 0 20px 0px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
| @@ -1,305 +1,350 @@ | ||||
| <!-- eslint-disable vue/no-unused-components --> | ||||
| <!-- eslint-disable vue/valid-v-slot --> | ||||
| <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"> | ||||
|                         <button id="sysConf-add" class="btn btn-default"> | ||||
|                             <i class="glyphicon glyphicon-plus"></i>增加 | ||||
|                         </button> | ||||
|  | ||||
|                         <button id="sysConf-multiDel" class="btn btn-default"> | ||||
|                             <i class="glyphicon glyphicon-wrench"></i>批量删除 | ||||
|                         </button> | ||||
|   <div class="box"> | ||||
|     <!-- 按钮 --> | ||||
|     <div class="but"> | ||||
|       <el-button @click="addConfig()" type="primary" class="primary butIn" | ||||
|         >添加</el-button | ||||
|       > | ||||
|       <el-button @click="multipleDel()" type="danger" class="danger butIn" | ||||
|         >批量删除</el-button | ||||
|       > | ||||
|       <el-input | ||||
|         @input="handlerChange" | ||||
|         v-model="valsen" | ||||
|         type="text" | ||||
|         placeholder="请输入关键字进行搜索配置" | ||||
|         class="inputs" | ||||
|       /> | ||||
|     </div> | ||||
|                 </section><!-- .content --> | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       ref="multipleTable" | ||||
|       :data="tableData.slice((currentPage - 1) * pageSize, currentPage * pageSize)" | ||||
|       tooltip-effect="dark" | ||||
|       style="margin-top: 25px; width: 100%" | ||||
|       border | ||||
|       @selection-change="handleSelectionChange" | ||||
|     > | ||||
|       <el-table-column align="center" type="selection"> </el-table-column> | ||||
|       <el-table-column align="center" prop="configId" label="ID"> </el-table-column> | ||||
|       <el-table-column | ||||
|         show-overflow-tooltip="true" | ||||
|         align="center" | ||||
|         prop="configName" | ||||
|         label="名称" | ||||
|       ></el-table-column> | ||||
|       <el-table-column | ||||
|         show-overflow-tooltip="true" | ||||
|         align="center" | ||||
|         prop="configValue" | ||||
|         label="值" | ||||
|       ></el-table-column> | ||||
|       <el-table-column | ||||
|         show-overflow-tooltip="true" | ||||
|         align="center" | ||||
|         prop="nameSpace" | ||||
|         label="命名空间" | ||||
|       ></el-table-column> | ||||
|       <el-table-column align="center" label="状态"> | ||||
|         <template v-slot="scope">{{ | ||||
|           scope.row.configStatus == 1 ? "有效" : "无效" | ||||
|         }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="操作"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button @click="modifyTible(scope.row)" type="primary" class="primary" | ||||
|             >编辑</el-button | ||||
|           > | ||||
|           <el-button @click="delTible(scope.row)" type="danger" class="danger" | ||||
|             >删除</el-button | ||||
|           > | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500]" | ||||
|       :small="small" | ||||
|       :disabled="disabled" | ||||
|       :background="background" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="tableData.length" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|       style="margin-top: 25px" | ||||
|     /> | ||||
|     <!-- 弹窗 --> | ||||
|     <el-dialog | ||||
|       v-model="dialogTableVisible" | ||||
|       :title="dialogTableVisibleTitle" | ||||
|       width="500px" | ||||
|     > | ||||
|       <div class="userId"> | ||||
|         <span>id</span> | ||||
|         <el-input | ||||
|           v-model="configId" | ||||
|           style="width: 75%" | ||||
|           class="input" | ||||
|           :disabled="disabledPub" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <div class="userId"> | ||||
|         <span>名称</span> | ||||
|         <el-input v-model="configName" style="width: 75%" class="input"></el-input> | ||||
|       </div> | ||||
|     </section> | ||||
|     <div class="modal fade" id="sysConfModal" 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 class="userId"> | ||||
|         <span>状态</span> | ||||
|         <el-radio-group v-model="radio" class="ml-4"> | ||||
|           <el-radio :label="1" size="large">有效</el-radio> | ||||
|           <el-radio :label="2" size="large">无效</el-radio> | ||||
|         </el-radio-group> | ||||
|       </div> | ||||
|                 <div class="modal-body"> | ||||
|                     <form class="form-horizontal" id="sysConfForm"> | ||||
|                         <div class="form-group"> | ||||
|                             <label for="configId" class="col-sm-2 control-label">id</label> | ||||
|                             <div class="col-sm-10"> | ||||
|                                 <input type="text" class="form-control validate[required]" name="configId" id="configId"> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                         <div class="form-group"> | ||||
|                             <label for="configName" class="col-sm-2 control-label">名称</label> | ||||
|                             <div class="col-sm-10"> | ||||
|                                 <input type="text" class="form-control validate[required]" name="configName" | ||||
|                                     id="configName"> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                         <div class="form-group"> | ||||
|                             <label class="col-sm-2 control-label">状态</label> | ||||
|                             <div class="col-sm-10"> | ||||
|                                 <label class="radio-inline"><input type="radio" name="configStatus" value="1" | ||||
|                                         checked>有效</label> | ||||
|                                 <label class="radio-inline"><input type="radio" name="configStatus" value="2">无效</label> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                         <div class="form-group"> | ||||
|                             <label for="configValue" class="col-sm-2 control-label">值</label> | ||||
|                             <div class="col-sm-10"> | ||||
|                                 <input type="text" class="form-control" name="configValue" id="configValue"> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                         <div class="form-group"> | ||||
|                             <label for="nameSpace" class="col-sm-2 control-label">命名空间</label> | ||||
|                             <div class="col-sm-10"> | ||||
|                                 <input type="text" class="form-control validate[required]" name="nameSpace" id="nameSpace"> | ||||
|                             </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> | ||||
|     <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="userId"> | ||||
|         <span>值</span> | ||||
|         <el-input v-model="configValue" style="width: 75%" class="input"></el-input> | ||||
|       </div> | ||||
|       <div class="userId"> | ||||
|         <span>命名空间</span> | ||||
|         <el-input v-model="nameSpace" style="width: 75%" class="input"></el-input> | ||||
|       </div> | ||||
|       <el-button | ||||
|         class="dialogTableVisibleBut" | ||||
|         type="info" | ||||
|         @click="dialogTableVisible = false" | ||||
|       > | ||||
|         关闭 | ||||
|       </el-button> | ||||
|       <el-button class="dialogTableVisibleBut" type="primary" @click="saveBut()"> | ||||
|         保存 | ||||
|       </el-button> | ||||
|     </el-dialog> | ||||
|     <!-- 二次确认解除风险弹窗 --> | ||||
|     <el-dialog v-model="centerDialogVisible" title="提示" width="30%" center> | ||||
|       <span> 你确定删除该记录吗? 删除后再也不能找回,请谨慎操作! ! ! </span> | ||||
|       <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> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
| import { getSysConfList } from '@/api/system/sysconf'; | ||||
|  | ||||
| import { | ||||
|   getList, | ||||
|   sysConfSave, | ||||
|   sysConfDel, | ||||
| } from "@/api/sysconfAdminView/sysconfAdminView"; | ||||
| import { ElMessage } from "element-plus"; | ||||
| import qs from "qs"; | ||||
| export default { | ||||
|   name: "SysconfAdminView", | ||||
|     setup() { | ||||
|         return {}; | ||||
|   data() { | ||||
|     return { | ||||
|       valsen: "", | ||||
|       loading: false, | ||||
|       multipleSelection: null, //选中表格存储 | ||||
|       tableData: [], //表格数据 | ||||
|       tableData2: [], //表格数据 | ||||
|       tableData3: [], //表格数据 | ||||
|       //分页 | ||||
|       totals: 0, | ||||
|       currentPage: 1, | ||||
|       pageSize: 10, | ||||
|       dialogTableVisibleTitle: "字典信息", //弹窗标题 | ||||
|       dialogTableVisible: false, //弹窗控制 | ||||
|       configId: "", //弹窗id | ||||
|       configName: "", //弹窗名称 | ||||
|       radio: 1, //弹窗参单选 | ||||
|       configValue: "", //弹窗值 | ||||
|       nameSpace: "", //弹窗命名空间 | ||||
|       disabledPub: true, //控制弹窗id是否禁用 | ||||
|       type: null, //   控制是新增或者编辑 type 1:新增2:保存 | ||||
|       delArr: [], //删除暂存 | ||||
|       centerDialogVisible: false, //二次删除确认 | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|         this.$nextTick(function () { | ||||
|             this.initData(); | ||||
|             this.getSysConf(); | ||||
|         }); | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|         getSysConf() { | ||||
|             getSysConfList().then(res => { | ||||
|                 $('#table').bootstrapTable('load', res.rows); | ||||
|     // 获取列表 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       getList().then((res) => { | ||||
|         console.log(res); | ||||
|         this.totals = res.total; | ||||
|         this.tableData = res.rows; | ||||
|         this.tableData3 = res.rows; | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|         initData() { | ||||
|             $(function () { | ||||
|                 $('#table').bootstrapTable('destroy'); | ||||
|                 $('#table').bootstrapTable({ | ||||
|                     columns: [ | ||||
|                         { field: 'tmp', title: 'ID', align: 'center', checkbox: true }, | ||||
|                         { field: 'configId', title: 'id', align: 'center', width: '20%' }, | ||||
|                         { field: 'configName', title: '名称', align: 'center', width: '25%' }, | ||||
|                         { field: 'configValue', title: '值', align: 'center', width: '20%' }, | ||||
|                         { | ||||
|                             field: 'configStatus', title: '状态', align: 'center', width: '5%', formatter: function (val, row, index) { | ||||
|                                 if (val == 1) { | ||||
|                                     return '有效'; | ||||
|                                 } | ||||
|                                 else if (val == 2) { | ||||
|                                     return '无效'; | ||||
|                                 } | ||||
|                             } | ||||
|     // 添加按钮 | ||||
|     addConfig() { | ||||
|       this.type = 1; | ||||
|       this.disabledPub = false; | ||||
|       this.configId = ""; | ||||
|       this.configName = ""; | ||||
|       this.radio = 1; | ||||
|       this.configValue = ""; | ||||
|       this.nameSpace = ""; | ||||
|       this.dialogTableVisible = true; | ||||
|     }, | ||||
|                         { field: 'nameSpace', title: '命名空间', align: 'center', width: '5%' }, | ||||
|                         { | ||||
|                             field: 'configId', title: '操作', align: 'center', width: '25%', formatter: function (val, row, index) { | ||||
|                                 return '<button class="btn btn-sm btn-success opt-edit" data-id=' + val + '>' + | ||||
|                                     '<i class="glyphicon glyphicon-edit"></i>编辑</button>' + | ||||
|                                     '  <button class="btn btn-sm btn-danger opt-remove" data-id=' + val + | ||||
|                                     '><i class="glyphicon glyphicon-remove"></i>删除</button>'; | ||||
|                             } | ||||
|                         } | ||||
|                     ], | ||||
|                     cache: false, | ||||
|                     striped: true, | ||||
|                     showRefresh: true, | ||||
|                     pageNumber: 1, | ||||
|                     pageSize: 10, | ||||
|                     pagination: true, | ||||
|                     pageList: [10, 25, 50, 100], | ||||
|                     search: true, | ||||
|                     sidePagination: "client", | ||||
|                     toolbar: '#toolbar' | ||||
|     // 表格编辑按钮 | ||||
|     modifyTible(row) { | ||||
|       this.type = 2; | ||||
|       this.disabledPub = true; | ||||
|       this.configId = row.configId; | ||||
|       this.configName = row.configName; | ||||
|       this.radio = row.configStatus; | ||||
|       this.configValue = row.configValue; | ||||
|       this.nameSpace = row.nameSpace; | ||||
|       this.dialogTableVisible = true; | ||||
|     }, | ||||
|     // 保存按钮 | ||||
|     saveBut() { | ||||
|       if (this.type == 1) { | ||||
|         if (this.configId == "") { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "请输入id", | ||||
|             type: "error", | ||||
|           }); | ||||
|           return; | ||||
|         } else if (this.configName == "") { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "请输入名称", | ||||
|             type: "error", | ||||
|           }); | ||||
|           return; | ||||
|         } else if (this.configValue == "") { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "请输入值", | ||||
|             type: "error", | ||||
|           }); | ||||
|  | ||||
|                 $("#table").on("click", '.opt-remove', function () { | ||||
|                     var id = $(this).attr("data-id"); | ||||
|                     if (id == 'undefined') { | ||||
|                         $("#tipMsg").text("id参数有误"); | ||||
|                         $("#tipModal").modal('show'); | ||||
|           return; | ||||
|         } | ||||
|                     if (confirm("你确认删除该记录吗?" + | ||||
|                         "\r\n删除后再也不能找回,请谨慎操作!")) { | ||||
|                         $.ajax({ | ||||
|                             type: 'post', | ||||
|                             url: "/admin/sysConf/del.action", | ||||
|                             data: { 'ids': JSON.stringify([id]) }, | ||||
|                             dataType: "json", | ||||
|                             success: function (json) { | ||||
|                                 if (json.success == 'true') { | ||||
|                                     $("#tipMsg").text("删除成功"); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                     getSysConfList().then(res => { | ||||
|                                         $('#table').bootstrapTable('load', res.rows); | ||||
|                                     }); | ||||
|                                     TableHelper.doRefresh("#table"); | ||||
|         this.sysConfSaveFun(); | ||||
|       } else { | ||||
|                                     $("#tipMsg").text("删除失败"); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                 } | ||||
|         this.sysConfSaveFun(); | ||||
|       } | ||||
|       this.dialogTableVisible = false; | ||||
|     }, | ||||
|     // 保存接口函数 | ||||
|     sysConfSaveFun() { | ||||
|       this.loading = true; | ||||
|       sysConfSave({ | ||||
|         configId: this.configId, | ||||
|         configName: this.configName, | ||||
|         configStatus: this.radio, | ||||
|         configValue: this.configValue, | ||||
|         nameSpace: this.nameSpace, | ||||
|       }).then((res) => { | ||||
|         this.getData(); | ||||
|       }); | ||||
|                     } | ||||
|     }, | ||||
|     // 表格选中处理 | ||||
|     toggleSelection(rows) { | ||||
|       if (rows) { | ||||
|         rows.forEach((row) => { | ||||
|           this.$refs.multipleTable.toggleRowSelection(row); | ||||
|         }); | ||||
|  | ||||
|                 $("#sysConf-add").click(function () { | ||||
|                     // 打开编辑弹窗 | ||||
|                     $("#sysConfModal").modal('show'); | ||||
|                     $("#sysConfForm")[0].reset(); | ||||
|                     $("#configId").val(''); | ||||
|                     $("#configId").attr('readonly', false); | ||||
|                 }); | ||||
|  | ||||
|                 $("#sysConf-multiDel").click(function () { | ||||
|                     var rows = $("#table").bootstrapTable("getSelections"); | ||||
|                     if (rows.length == 0) { | ||||
|                         alert("请先选择要删除的记录"); | ||||
|                         return; | ||||
|                     } | ||||
|                     console.log("rows: " + rows.length); | ||||
|                     var idArr = []; | ||||
|                     for (var i = 0; i < rows.length; i++) { | ||||
|                         idArr.push(rows[i]['configId']); | ||||
|                     } | ||||
|                     console.log(idArr); | ||||
|                     if (confirm("你确认批量删除该记录吗?" + | ||||
|                         "\r\n删除后再也不能找回,请谨慎操作!")) { | ||||
|                         $.ajax({ | ||||
|                             type: 'post', | ||||
|                             url: "/admin/sysConf/del.action", | ||||
|                             data: { 'ids': JSON.stringify(idArr) }, | ||||
|                             dataType: "json", | ||||
|                             success: function (json) { | ||||
|                                 if (json.success == 'true') { | ||||
|                                     $("#tipMsg").text("删除成功"); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                     getSysConfList().then(res => { | ||||
|                                         $('#table').bootstrapTable('load', res.rows); | ||||
|                                     }); | ||||
|                                     TableHelper.doRefresh("#table"); | ||||
|       } else { | ||||
|                                     $("#tipMsg").text("删除失败"); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                 } | ||||
|                             } | ||||
|                         }); | ||||
|                     } | ||||
|                 }); | ||||
|  | ||||
|                 $("#cancel").click(function () { | ||||
|                     TableHelper.unCheckAll("#table"); | ||||
|                 }); | ||||
|  | ||||
|                 $("#table").on("click", '.opt-edit', function () { | ||||
|                     $("#configId").attr('readonly', true); | ||||
|                     var id = $(this).attr("data-id"); | ||||
|                     $.ajax({ | ||||
|                         type: "get", | ||||
|                         url: "/admin/sysConf/get.action", | ||||
|                         data: { id: id }, | ||||
|                         dataType: "json", | ||||
|                         success: function (json) { | ||||
|                             if (json.entity) { | ||||
|                                 $("#configId").val(json.entity.configId); | ||||
|                                 $("#configName").val(json.entity.configName); | ||||
|                                 $("#configValue").val(json.entity.configValue); | ||||
|                                 $("#nameSpace").val(json.entity.nameSpace); | ||||
|                                 var status = json.entity.configStatus - 1; | ||||
|                                 $("input:radio[name='configStatus']")[status].checked = true; | ||||
|                                 // 打开编辑弹窗 | ||||
|                                 $("#sysConfModal").modal('show'); | ||||
|                             } else { | ||||
|                                 $("#tipMsg").text("获取菜单信息出错"); | ||||
|                                 $("#tipModal").modal('show'); | ||||
|                             } | ||||
|                         } | ||||
|                     }); | ||||
|                 }); | ||||
|  | ||||
|                 $("#save").click(function () { | ||||
|                     if ($("#sysConfForm").validationEngine('validate')) { | ||||
|                         $.ajax({ | ||||
|                             type: "post", | ||||
|                             url: "/admin/sysConf/save.action", | ||||
|                             data: $('#sysConfForm').serialize(), | ||||
|                             dataType: "json", | ||||
|                             success: function (json) { | ||||
|                                 if (json.success == 'true') { | ||||
|                                     $("#sysConfModal").modal('hide'); | ||||
|                                     $("#tipMsg").text("保存成功"); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                     getSysConfList().then(res => { | ||||
|                                         $('#table').bootstrapTable('load', res.rows); | ||||
|                                     }); | ||||
|                                     TableHelper.doRefresh("#table"); | ||||
|                                 } else { | ||||
|                                     $("#tipMsg").text("保存失败"); | ||||
|                                     $("#tipModal").modal('show'); | ||||
|                                 } | ||||
|                             } | ||||
|                         }); | ||||
|                     } | ||||
|                 }); | ||||
|             }); | ||||
|         this.$refs.multipleTable.clearSelection(); | ||||
|       } | ||||
|     }, | ||||
|     unmounted() { | ||||
|         $('#table').bootstrapTable('destroy'); | ||||
|     } | ||||
|     // 表格选中处理 | ||||
|     handleSelectionChange(val) { | ||||
|       val.forEach((res, i) => { | ||||
|         this.delArr[i] = res.configId; | ||||
|       }); | ||||
|     }, | ||||
|     // 单个删除按钮 | ||||
|     delTible(row) { | ||||
|       this.delArr = [row.configId]; | ||||
|       this.centerDialogVisible = true; | ||||
|     }, | ||||
|     // 多个删除按钮 | ||||
|     multipleDel(row) { | ||||
|       console.log(this.delArr); | ||||
|       this.centerDialogVisible = true; | ||||
|     }, | ||||
|     // 删除函数 | ||||
|     delFun() { | ||||
|       this.loading = true; | ||||
|       sysConfDel({ ids: JSON.stringify(this.delArr) }).then((res) => { | ||||
|         this.getData(); | ||||
|       }); | ||||
|       this.centerDialogVisible = false; | ||||
|     }, | ||||
|     // 二次确认删除按钮 | ||||
|     dialogClick() { | ||||
|       this.delFun(); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange(val) { | ||||
|       this.pageSize = val; | ||||
|     }, | ||||
|     handleCurrentChange(val) { | ||||
|       this.currentPage = val; | ||||
|     }, | ||||
|     handlerChange() { | ||||
|       // console.log(this.fillist()); | ||||
|     }, | ||||
|   }, | ||||
|   watch: { | ||||
|     valsen: { | ||||
|       immediate: true, //在框的值还没变化时执行如下函数显示出所有的情况 | ||||
|       handler(val) { | ||||
|         this.tableData = this.tableData3.filter((p) => { | ||||
|           return ( | ||||
|             p.configId.indexOf(val) !== -1 || | ||||
|             p.configName.indexOf(val) !== -1 || | ||||
|             p.configValue.indexOf(val) !== -1 || | ||||
|             p.nameSpace.indexOf(val) !== -1 | ||||
|           ); | ||||
|         }); | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style scoped> | ||||
| .table_line { | ||||
|     word-break: break-all; | ||||
| } | ||||
|  | ||||
| .td_center { | ||||
|     vertical-align: middle !important; | ||||
| } | ||||
|  | ||||
| .table_line { | ||||
|     word-break: break-all; | ||||
| } | ||||
|  | ||||
| .td_center { | ||||
|     vertical-align: middle !important; | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .userId { | ||||
|     margin-bottom: 20px; | ||||
|     span { | ||||
|       width: 60px; | ||||
|       margin-right: 30px; | ||||
|       display: inline-block; | ||||
|       text-align: right; | ||||
|     } | ||||
|   } | ||||
|   .but { | ||||
|     width: 100%; | ||||
|     margin-bottom: 20px; | ||||
|     height: 30px; | ||||
|     .butIn { | ||||
|       float: left; | ||||
|     } | ||||
|     .inputs { | ||||
|       float: right; | ||||
|       width: 15%; | ||||
|       margin-right: 20px; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </style> | ||||
| @@ -165,16 +165,38 @@ import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
| import ComboboxHelper from '@/assets/plugins/bootstrap-combobox/js/bootstrap-combobox-helper'; | ||||
| import { showLoading, hideLoading } from '@/utils/maintainer'; | ||||
|  | ||||
| var publishTimePicker = $('#publishTime').datetimepicker({ | ||||
|     format: 'yyyy-mm-dd hh:ii:00', | ||||
|     autoclose: true, | ||||
|     startDate: new Date() | ||||
| }) | ||||
| //ComboboxHelper.build(null,'#status'); | ||||
| export default { | ||||
|     name: "VersionAdminView", | ||||
|     setup() { | ||||
|         return {}; | ||||
|  | ||||
|         function setSelectOption(id, obj) { | ||||
|             var os = $(obj).val(); | ||||
|             var channel = $("#old_" + id).val(); | ||||
|             $.ajax({ | ||||
|                 type: "get", | ||||
|                 url: '/admin/version/getPlatform.action', | ||||
|                 data: { | ||||
|                     os: os | ||||
|                 }, | ||||
|                 dataType: 'json', | ||||
|                 success: function (json) { | ||||
|                     if (json.data) { | ||||
|                         makeOption(id, json.data, channel); | ||||
|                         if (channel != '' && channel != 'undefined') { | ||||
|                             $('.selectpicker').selectpicker('val', channel); | ||||
|                         } else { | ||||
|                             $('.selectpicker').selectpicker('val', ''); | ||||
|                         } | ||||
|                         $('.selectpicker').selectpicker('refresh'); | ||||
|                     } | ||||
|                 } | ||||
|             }) | ||||
|         } | ||||
|         window.setSelectOption = setSelectOption; | ||||
|         return { | ||||
|             setSelectOption | ||||
|         }; | ||||
|     }, | ||||
|     created() { | ||||
|         this.$nextTick(function () { | ||||
| @@ -184,6 +206,12 @@ export default { | ||||
|     methods: { | ||||
|         initData() { | ||||
|             $(function () { | ||||
|                 var publishTimePicker = $('#publishTime').datetimepicker({ | ||||
|                     format: 'yyyy-mm-dd hh:ii:00', | ||||
|                     autoclose: true, | ||||
|                     startDate: new Date() | ||||
|                 }) | ||||
|  | ||||
|                 $('#platform').selectpicker({ | ||||
|                     'selectedText': 'cat' | ||||
|                 }) | ||||
| @@ -196,7 +224,7 @@ export default { | ||||
|                     initTable(); | ||||
|                 }); | ||||
|  | ||||
|                 setSelectOption("platform_query", $("#os_query")); | ||||
|                 window.setSelectOption("platform_query", $("#os_query")); | ||||
|  | ||||
|                 $("#table").on("click", '.opt-remove', function () { | ||||
|                     var id = $(this).attr("data-id"); | ||||
| @@ -238,7 +266,7 @@ export default { | ||||
|                     $("#version").removeAttr("disabled", "disabled"); | ||||
|                     $("#platform").removeAttr("disabled", "disabled"); | ||||
|                     $('#save').attr("disabled", false); | ||||
|                     setSelectOption("platform", $("#os")); | ||||
|                     window.setSelectOption("platform", $("#os")); | ||||
|                 }); | ||||
|  | ||||
|                 $("#multiDel").click(function () { | ||||
| @@ -405,7 +433,7 @@ export default { | ||||
|                                 $("#description").val(json.entity.description); | ||||
|                                 $("#status").val(json.entity.status); | ||||
|                                 ComboboxHelper.setDef("#status", json.entity.status); | ||||
|                                 setSelectOption("platform", $("#os")); | ||||
|                                 window.setSelectOption("platform", $("#os")); | ||||
|                                 $("#publishTime").val(publishDate); | ||||
|                                 $("#downloadLink").val(json.entity.downloadLink); | ||||
|                                 $("#fileMd5").val(json.entity.fileMd5); | ||||
| @@ -475,30 +503,6 @@ export default { | ||||
|     } | ||||
| }; | ||||
|  | ||||
| function setSelectOption(id, obj) { | ||||
|     var os = $(obj).val(); | ||||
|     var channel = $("#old_" + id).val(); | ||||
|     $.ajax({ | ||||
|         type: "get", | ||||
|         url: '/admin/version/getPlatform.action', | ||||
|         data: { | ||||
|             os: os | ||||
|         }, | ||||
|         dataType: 'json', | ||||
|         success: function (json) { | ||||
|             if (json.data) { | ||||
|                 makeOption(id, json.data, channel); | ||||
|                 if (channel != '' && channel != 'undefined') { | ||||
|                     $('.selectpicker').selectpicker('val', channel); | ||||
|                 } else { | ||||
|                     $('.selectpicker').selectpicker('val', ''); | ||||
|                 } | ||||
|                 $('.selectpicker').selectpicker('refresh'); | ||||
|             } | ||||
|         } | ||||
|     }) | ||||
| } | ||||
|  | ||||
| function makeOption(id, data, channel) { | ||||
|     console.log("id=" + id + ",channel=" + channel); | ||||
|     var str = ""; | ||||
|   | ||||
| @@ -9,11 +9,11 @@ | ||||
|                 <div id="toolbar"> | ||||
|                     <div class="form-group col-sm-3"> | ||||
|                             <label for="queryStartDate" class="control-label">开始时间:</label> | ||||
|                         <input type="text" class="input-sm datetime" id="queryStartDate" placeholder="开始时间"> | ||||
|                             <input type="text" class="input-sm datetime" name="startTime" id="queryStartDate" placeholder="开始时间"> | ||||
|                         </div> | ||||
|                         <div class="form-group col-sm-3"> | ||||
|                             <label for="queryEndDate" class="control-label">结束时间:</label> | ||||
|                         <input type="text" class="input-sm datetime" id="queryEndDate" placeholder="结束时间"> | ||||
|                             <input type="text" class="input-sm datetime" name="endTime" id="queryEndDate" placeholder="结束时间"> | ||||
|                         </div> | ||||
|                         <div class="form-group col-sm-3"> | ||||
|                             <label for="erbanNo" class="control-label">用户ID:</label> | ||||
| @@ -21,7 +21,8 @@ | ||||
|                         </div> | ||||
|                     <div class="row"></div> | ||||
|                     <div> | ||||
|                         <button class="btn btn-primary" id="searchBtn">查询</button> | ||||
|                         <button id="searchBtn" class="btn btn-sm btn-primary">查询</button> | ||||
|                         <button id="btnExport" class="btn btn-sm btn-primary">导出</button> | ||||
|                     </div> | ||||
|                 </div> | ||||
|                 <div id="table"></div> | ||||
| @@ -31,7 +32,7 @@ | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
| import { cleanArray } from '@/utils/maintainer'; | ||||
|  | ||||
| export default { | ||||
|     name: "SeizeTreasureRecordAdminView", | ||||
| @@ -87,6 +88,39 @@ export default { | ||||
|                 }; | ||||
|                 main.init(); | ||||
|  | ||||
|                 // 导出 | ||||
|                 $('#btnExport').on('click', function () { | ||||
|                     var poolTypeList; | ||||
|                     if ($("#poolTypeList").val() && $("#poolTypeList").val().length) { | ||||
|                         poolTypeList = $("#poolTypeList").val().join(); | ||||
|                     } | ||||
|                     var poolGroupList; | ||||
|                     if ($("#poolGroupList").val() && $("#poolGroupList").val().length) { | ||||
|                         poolGroupList = $("#poolGroupList").val().join(); | ||||
|                     } | ||||
|                     var poolLevelList; | ||||
|                     if ($("#poolLevelList").val() && $("#poolLevelList").val().length) { | ||||
|                         poolLevelList = $("#poolLevelList").val().join(); | ||||
|                     } | ||||
|                     var obj = { | ||||
|                         startTime: $('#queryStartDate').val(), | ||||
|                         endTime: $('#queryEndDate').val(), | ||||
|                         erbanNo: $('#erbanNo').val(), | ||||
|                         poolTypeList: poolTypeList, | ||||
|                         poolGroupList: poolGroupList, | ||||
|                         poolLevelList: poolLevelList, | ||||
|                     }; | ||||
|                     function param(json) { | ||||
|                         if (!json) return '' | ||||
|                         return cleanArray(Object.keys(json).map(key => { | ||||
|                             if (json[key] === undefined) return '' | ||||
|                             return encodeURIComponent(key) + '=' + | ||||
|                                 encodeURIComponent(json[key]) | ||||
|                         })).join('&') | ||||
|                     } | ||||
|                     window.location.href = `/admin/seize-treasure/treasure/record/export?${param(obj)}`; | ||||
|                 }); | ||||
|  | ||||
|                 function tableRefresh() { | ||||
|                     $('#table').bootstrapTable('destroy'); | ||||
|                     $('#table').bootstrapTable({ | ||||
|   | ||||
| @@ -93,6 +93,7 @@ | ||||
|                             <label for="rewardLevel" class="col-sm-3 control-label">奖品等级:</label> | ||||
|                             <div class="col-sm-9"> | ||||
|                                 <select name="rewardLevel" id="rewardLevel" class="form-control"> | ||||
|                                     <option value="0">0</option> | ||||
|                                     <option value="1">1</option> | ||||
|                                     <option value="2">2</option> | ||||
|                                     <option value="3">3</option> | ||||
| @@ -131,6 +132,7 @@ | ||||
|  | ||||
| <script> | ||||
| import TableHelper from '@/utils/bootstrap-table-helper'; | ||||
| import ComboboxHelper from '@/assets/plugins/bootstrap-combobox/js/bootstrap-combobox-helper'; | ||||
| import { isNumber } from '@/utils/string'; | ||||
|  | ||||
| export default { | ||||
| @@ -238,7 +240,7 @@ export default { | ||||
|             } else if (rewardType == 'infoCard') { | ||||
|                 console.log(rewardType); | ||||
|             } | ||||
|             $('#rewardRefId').remove(); | ||||
|             $('#rewardDiv').children().remove(); | ||||
|             var $div = $('#rewardDiv'); | ||||
|             console.log(options); | ||||
|             if (options.length > 0) { | ||||
| @@ -258,6 +260,7 @@ export default { | ||||
|                     $select.append($option); | ||||
|                 } | ||||
|                 $div.append($select); | ||||
|                 ComboboxHelper.build(options, '#rewardRefId', rewardRefId); | ||||
|             } else { | ||||
|                 var $input = $('<input/>'); | ||||
|                 $input.attr('type', 'text'); | ||||
| @@ -460,6 +463,12 @@ export default { | ||||
|                         var rewardShowValue = $("#rewardShowValue").val(); | ||||
|                         var rewardLevel = $("#rewardLevel").val(); | ||||
|                         var rewardOrder = $("#rewardOrder").val(); | ||||
|                         console.log(rewardRefId); | ||||
|                         if (rewardRefId == null || rewardRefId == '0') { | ||||
|                             $("#tipMsg").text("奖品设置出错,请重新配置!!!"); | ||||
|                             $("#tipModal").modal('show'); | ||||
|                             return; | ||||
|                         } | ||||
|                         let rewardName; | ||||
|                         if (!isNumber(rewardRefId)) { | ||||
|                             rewardName = rewardRefId; | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|                 <!-- .content --> | ||||
|                 <div id="table"></div> | ||||
|                 <div id="toolbar"> | ||||
|                     <form id="searchForm" action="/admin/seize-treasure/user/prop/record/export" method="get" | ||||
|                     <form id="searchForm" action="/admin/seize-treasure/user/prop/record/export" method="post" | ||||
|                         target="_blank"> | ||||
|                         <div class="col-sm-12"> | ||||
|                             <label for="erbanNo" class="col-sm-2 control-label">Peko号:</label> | ||||
|   | ||||
| @@ -1,5 +1,9 @@ | ||||
| const { defineConfig } = require('@vue/cli-service') | ||||
| var webpack = require('webpack') | ||||
| var AutoImport = require('unplugin-auto-import/webpack') | ||||
| var Components = require('unplugin-vue-components/webpack') | ||||
| var { ElementPlusResolver } = require('unplugin-vue-components/resolvers') | ||||
| var BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin | ||||
| module.exports = defineConfig({ | ||||
|   transpileDependencies: true, | ||||
|   chainWebpack: config => { | ||||
| @@ -18,6 +22,15 @@ module.exports = defineConfig({ | ||||
|         'windows.jQuery': 'jquery', | ||||
|         Popper: ['popper.js', 'default'] | ||||
|       }), | ||||
|       AutoImport({ | ||||
|         resolvers: [ElementPlusResolver()], | ||||
|       }), | ||||
|       Components({ | ||||
|         resolvers: [ElementPlusResolver()], | ||||
|       }), | ||||
|       new BundleAnalyzerPlugin({ | ||||
|         openAnalyzer: false | ||||
|       }) | ||||
|     ], | ||||
|   }, | ||||
|   devServer: { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user