Compare commits
	
		
			666 Commits
		
	
	
		
			iosrisk
			...
			edition102
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 3d18a53f34 | ||
|   | 627de18eaf | ||
|   | 8868f4204c | ||
|   | 38bffe26dc | ||
|   | 8a548f9a69 | ||
|   | 28b21d5c85 | ||
|   | dcdf89aa48 | ||
|   | b9dcae392a | ||
|   | ae4b9d0493 | ||
|   | 8789fdfc29 | ||
|   | 0700880ade | ||
|   | 7c042161bd | ||
|   | 431749ef28 | ||
|   | 7bb0faad23 | ||
|   | 59a2461f73 | ||
|   | 223311f321 | ||
|   | 02474473bf | ||
|   | 559fea9300 | ||
|   | ed618598c2 | ||
|   | 7610a2768f | ||
|   | eb7e9387c6 | ||
|   | 212498b6be | ||
|   | 369bf84a1f | ||
|   | a79445b9e5 | ||
|   | fda1a6aacb | ||
|   | e58363371c | ||
|   | 943518ce24 | ||
|   | df0093c4f8 | ||
|   | 19d8ac3753 | ||
|   | 9486359ddf | ||
|   | ef7c060545 | ||
|   | 350c1b0e07 | ||
|   | f9a1f6a89c | ||
|   | c7597a1b14 | ||
|   | 9b7d0132ef | ||
|   | 0dcf3594bd | ||
|   | e50a89fb0a | ||
|   | 49bd77ae3f | ||
|   | d9a6c2881b | ||
|   | 46af95e834 | ||
|   | 07543cca7d | ||
|   | a75058d202 | ||
|   | 9129e29bf3 | ||
|   | 37df3b5db1 | ||
|   | 6e841bc675 | ||
|   | 286969cdd1 | ||
|   | d3b48eea86 | ||
|   | 9e6495d807 | ||
|   | 836fb732c8 | ||
|   | 9a151fbe05 | ||
|   | 07e9a1e8b2 | ||
|   | d3c14383f8 | ||
|   | 5bba43c189 | ||
|   | 74939056ce | ||
|   | 004bf0e03a | ||
|   | b467577792 | ||
|   | 99a1c89643 | ||
|   | b043d8c06e | ||
|   | fb007e763c | ||
|   | 2fddf66a5d | ||
|   | 75bcd232a4 | ||
|   | ae0a3507a6 | ||
|   | 31d6efd60e | ||
|   | 70993f1b4d | ||
|   | e4fb991a98 | ||
|   | b84438c19d | ||
|   | ed9178a1d0 | ||
|   | 78b3a70d5f | ||
|   | baad132403 | ||
|   | c865eae77b | ||
|   | 5d296f8086 | ||
|   | 3f905c2b1e | ||
|   | 7add80a5ae | ||
|   | 0d6019e9f1 | ||
|   | 11ceac5d4f | ||
|   | 289aa70af3 | ||
|   | c8b283b0d8 | ||
|   | 9bec1ba472 | ||
|   | 2c64fc1443 | ||
|   | 097dea0693 | ||
|   | 6abde0b9ec | ||
|   | c99ee00ca8 | ||
|   | c3f70e3c9b | ||
|   | 1e4002a4fa | ||
|   | 090447e1ce | ||
|   | c847b94994 | ||
|   | f91dc1cf62 | ||
|   | 4d5fb57ddf | ||
|   | b174c9818e | ||
|   | c6f979c094 | ||
|   | 475ee45a44 | ||
|   | c4209d6c24 | ||
|   | e77165a1d7 | ||
|   | 8a2c1381e9 | ||
|   | e062c2afa3 | ||
|   | 591495edcc | ||
|   | 25e828f7e4 | ||
|   | 1ab319d372 | ||
|   | 9b6ee433d7 | ||
|   | 9c4aa4efb9 | ||
|   | f228aad967 | ||
|   | e47b57f760 | ||
|   | 4e3bbd9209 | ||
|   | 9f9e7ca81c | ||
|   | 493ad80d1c | ||
|   | a71144b735 | ||
|   | ebf22c8012 | ||
|   | 69dc2de281 | ||
|   | 520e4e4c58 | ||
|   | faa779555c | ||
|   | a62f2a5eca | ||
|   | 65cf443cb4 | ||
|   | 9f2b89d0be | ||
|   | b362a25028 | ||
|   | 3c909bdb97 | ||
|   | d79917ecca | ||
|   | b5de5e5125 | ||
|   | 8cf9dfa2bc | ||
|   | fa41f55a23 | ||
|   | c6487e78bb | ||
|   | de76dc8f56 | ||
|   | 1e67efafe7 | ||
|   | f31dcae058 | ||
|   | aa74f2ed36 | ||
|   | e4cbd9cc35 | ||
|   | 775b8abc93 | ||
|   | e1fb48d900 | ||
|   | 93aded746e | ||
|   | af1d94c1f2 | ||
|   | 89c27b28e7 | ||
|   | f34a7b9430 | ||
|   | fbd4fdcbd1 | ||
|   | 7ea73622cd | ||
|   | 6e66ca4864 | ||
|   | 12761b956c | ||
|   | 76f9bcddab | ||
|   | 3e490e2631 | ||
|   | 00b2bf5917 | ||
|   | 5b41dbabed | ||
|   | b53103c162 | ||
|   | 4fcc220759 | ||
|   | 386966a84e | ||
|   | e2c6898f16 | ||
|   | ef83e6d239 | ||
|   | 942cd1e479 | ||
|   | 939940a217 | ||
|   | de2c0fe8ea | ||
|   | ab3b8c2871 | ||
|   | 3a39476782 | ||
|   | bda30dd647 | ||
|   | e87f8e4c82 | ||
|   | 34dbcc2f2b | ||
|   | 33af99f086 | ||
|   | 4096f9be43 | ||
|   | 2210a40f67 | ||
|   | 62155cbc96 | ||
|   | 7c0438b070 | ||
|   | 40884b5b21 | ||
|   | 966cc40b3c | ||
|   | 6075a3b7ef | ||
|   | 5c54053377 | ||
|   | abcffa1cc3 | ||
|   | 1860ce0e48 | ||
|   | a9b5f44e88 | ||
|   | 0645211afc | ||
|   | 8b69be0d27 | ||
|   | 24b59255c6 | ||
|   | 79421740f9 | ||
|   | 6e3e4951aa | ||
|   | 7c06e79a8f | ||
|   | dc041fd84f | ||
|   | 1eaceed61b | ||
|   | 017bf0c641 | ||
|   | 8f9a22ffd1 | ||
|   | aba3833f5b | ||
|   | daa04b9269 | ||
|   | 4e9dbb6622 | ||
|   | 57c96c8aaf | ||
|   | 28e104e649 | ||
|   | 9c996955f2 | ||
|   | 8823ec2ec3 | ||
|   | 2cc695c978 | ||
|   | d591cfc013 | ||
|   | eec3bb54cb | ||
|   | 45ca219d0f | ||
|   | d63f15638b | ||
|   | 7b13dadd12 | ||
|   | 6f5ad0ee6a | ||
|   | d908b73193 | ||
|   | 5ac087e5aa | ||
|   | 1e1119eb35 | ||
|   | 7c62ef6549 | ||
|   | 8a3806855b | ||
|   | 2fce98c88e | ||
|   | 5680f42d06 | ||
|   | 5dc4eb5198 | ||
|   | 95382d1c87 | ||
|   | d42e95e2b3 | ||
|   | d9518f4c33 | ||
|   | 6085f5fce6 | ||
|   | eac6f613f7 | ||
|   | 80ddf7b5a5 | ||
|   | 69ec2ebef9 | ||
|   | 3062812f1f | ||
|   | 616758549b | ||
|   | 8fdb2b6c0d | ||
|   | afe984fe84 | ||
|   | 49dc775fff | ||
|   | 4077895f55 | ||
|   | a9c7ee9a47 | ||
|   | e402157726 | ||
|   | 8e01552671 | ||
|   | c27c5490b2 | ||
|   | f4f374295d | ||
|   | a514eacf81 | ||
|   | 4f7271a87b | ||
|   | f99c063b52 | ||
|   | d9aabae260 | ||
|   | 04dcb3cfa5 | ||
|   | d461f9c298 | ||
|   | 3784b748f7 | ||
|   | 85a6ea9106 | ||
|   | e4f9cfb3ec | ||
|   | 097c0b0d08 | ||
|   | c175d662e8 | ||
|   | 2d28fbcb8f | ||
|   | df9e96de9a | ||
|   | fafbd3e75c | ||
|   | a86e731633 | ||
|   | c584f0154f | ||
|   | e694f3f9a7 | ||
|   | 4b417d446f | ||
|   | 697af0c109 | ||
|   | a3d6c0c82c | ||
|   | 2ac3b75d30 | ||
|   | 6819127c40 | ||
|   | 5c67b35aaa | ||
|   | f5753982d0 | ||
|   | 22285b39c2 | ||
|   | da3e97026c | ||
|   | 5e4f13c8d9 | ||
|   | 8692437f87 | ||
|   | 5efd586524 | ||
|   | 747ef1c4f1 | ||
|   | 39040b282e | ||
|   | 2c988ee98c | ||
|   | 0ec763d122 | ||
|   | 851c1a7d55 | ||
|   | e89f73e9c8 | ||
|   | 0c28832c48 | ||
|   | fdcda4a422 | ||
|   | a62437cb4f | ||
|   | 864f0d6af8 | ||
|   | 712b14f105 | ||
|   | c0572cbb2c | ||
|   | 0fe9857c48 | ||
|   | 5f8660d4f4 | ||
|   | 9674f166b7 | ||
|   | b52bf78e63 | ||
|   | 6859f0377e | ||
|   | e42a1e7807 | ||
|   | c0e6eb60a2 | ||
|   | 69dc83b72b | ||
|   | b6300b5e58 | ||
|   | 3efb68c477 | ||
|   | 567c682a2b | ||
|   | f91c663783 | ||
|   | 62d45cb0fe | ||
|   | 54f2c29ada | ||
|   | d6e023c040 | ||
|   | c5f6d75989 | ||
|   | 8bbbaa01f1 | ||
|   | 0aa0e1560a | ||
|   | 29e3edd925 | ||
|   | d8975ca0e0 | ||
|   | 1150f56c72 | ||
|   | 4e7d8bba3e | ||
|   | 2276c55e2b | ||
|   | d1670fc22c | ||
|   | 5e48d3475e | ||
|   | 6865cbb1ee | ||
|   | 998df42200 | ||
|   | 53574cb63e | ||
|   | 2b3cd29191 | ||
|   | c3f5a03df5 | ||
|   | 7aa67988eb | ||
|   | e399826bb9 | ||
|   | 3209e05fc5 | ||
|   | d70621c8a0 | ||
|   | 29e963f98d | ||
|   | b94931d483 | ||
|   | 9bb50c750a | ||
|   | b41eaa4cda | ||
|   | a67c0ac06f | ||
|   | 53bd725166 | ||
|   | cd2bf234c3 | ||
|   | da56379b68 | ||
|   | 63cd34ba0b | ||
|   | 6749feb198 | ||
|   | 9b881b205a | ||
|   | 4c4f17ae60 | ||
|   | cc80c36d96 | ||
|   | 002022a0a6 | ||
|   | ed5aa8f19b | ||
|   | 24df62a873 | ||
|   | 85e6e7e310 | ||
|   | fe78dc545a | ||
|   | 4b057265ce | ||
|   | 03ea2e5224 | ||
|   | 617f630d9f | ||
|   | 7df38eca31 | ||
|   | 4ffe60e391 | ||
|   | 863e45d5d2 | ||
|   | 3641f36bb4 | ||
|   | bbd1b33996 | ||
|   | 788f340db5 | ||
|   | 0247de5ccc | ||
|   | 4e9c0d8649 | ||
|   | 1f26d0ed64 | ||
|   | 1c88a63fc9 | ||
|   | b1402a869e | ||
|   | 082a8c12df | ||
|   | 77201f9f18 | ||
|   | 8a895ec221 | ||
|   | 6445a5c4de | ||
|   | 6163b385ad | ||
|   | 6096ce090f | ||
|   | 97438b0045 | ||
|   | 65e5a5b15a | ||
|   | 692294dcb8 | ||
|   | 7d8f0a714c | ||
|   | 14d17603d8 | ||
|   | 7f16a7c4b3 | ||
|   | d6df754f70 | ||
|   | 4874240cdd | ||
|   | fde34bb405 | ||
|   | b2a9c4e376 | ||
|   | 08288a617c | ||
|   | 23ccbbf7b1 | ||
|   | 5cd26d2ff1 | ||
|   | 3580ed7790 | ||
|   | 2959a7ec7c | ||
|   | 0880cedd77 | ||
|   | b0fda915af | ||
|   | 1eae9577b6 | ||
|   | 8896135f72 | ||
|   | 2f6c2a03a4 | ||
|   | 8ca3bcd9fc | ||
|   | 5e421717e7 | ||
|   | 543719ecd5 | ||
|   | dd8b755aec | ||
|   | b47a506901 | ||
|   | cb7f4c519a | ||
|   | 1561657d37 | ||
|   | 3c8ef5d28e | ||
|   | 84abbe28d2 | ||
|   | cd1798c259 | ||
|   | 4fee145865 | ||
|   | 24ad849ffb | ||
|   | e1a01c39ef | ||
|   | 6ca3a71324 | ||
|   | c1be5c891d | ||
|   | 3093ed5ed3 | ||
|   | 65d9dfb5f3 | ||
|   | 7971766283 | ||
|   | 56ba1f5979 | ||
|   | ce7ed33f03 | ||
|   | d20ba9e3a3 | ||
|   | 8b744fbc0a | ||
|   | 78a0896e99 | ||
|   | c3e24aae51 | ||
|   | 3aa9d98aa2 | ||
|   | 5d13b68c5a | ||
|   | b900c5fe83 | ||
|   | cfeceed259 | ||
|   | a9fedeccf2 | ||
|   | 624afcc90a | ||
|   | 1a3f6137cb | ||
|   | 05721d3916 | ||
|   | 3a52b34239 | ||
|   | 782989b3c8 | ||
|   | e5a2bd8433 | ||
|   | 04d23c58de | ||
|   | 72649778a5 | ||
|   | e850d11175 | ||
|   | f78e1c10b7 | ||
|   | 4ed3d88e1e | ||
|   | ccc03895a7 | ||
|   | b38614c45e | ||
|   | 74b32be861 | ||
|   | e5f78df6e5 | ||
|   | 3c5ea1a5e0 | ||
|   | 8019555459 | ||
|   | a5996c3db8 | ||
|   | 681d7f7a5c | ||
|   | 52f4d6277c | ||
|   | bc4c36bdc8 | ||
|   | 5fa717465e | ||
|   | 889bb2363e | ||
|   | 1111d4782e | ||
|   | 96ad03efb9 | ||
|   | 49cdeb7407 | ||
|   | 80dca35881 | ||
|   | c7d6455c16 | ||
|   | b2cd8d5b75 | ||
|   | f6740bf1ca | ||
|   | ec30e516a0 | ||
|   | a962dbc669 | ||
|   | dab97ce8ae | ||
|   | 3fbb4e287e | ||
|   | 1096194250 | ||
|   | 6ad1b136a8 | ||
|   | f5a30e7a04 | ||
|   | 62e8a2239f | ||
|   | 0c17ceffce | ||
|   | 1cb752be00 | ||
|   | 62211d9cf4 | ||
|   | bf9de20556 | ||
|   | 7185f8f77a | ||
|   | 7d5fcd1494 | ||
|   | d462f6bbde | ||
|   | b470859daa | ||
|   | e3c82bcf92 | ||
|   | ef022da215 | ||
|   | 82dc883119 | ||
|   | bf1ae344e3 | ||
|   | eb10bdb44d | ||
|   | b52de9a90d | ||
|   | 2a4929b476 | ||
|   | 9433dd254f | ||
|   | c206b17acb | ||
|   | 8d21755335 | ||
|   | d8593c736d | ||
|   | 9258f46bdb | ||
|   | 12c3ad1e6e | ||
|   | 451f778732 | ||
|   | 68d7433a05 | ||
|   | dcc8e081ee | ||
|   | fc705cbc01 | ||
|   | 7072376da6 | ||
|   | 368550d4b8 | ||
|   | 60f349060d | ||
|   | a5b21a28e0 | ||
|   | 0b3aa136f9 | ||
|   | c46de130c6 | ||
|   | c184753083 | ||
|   | 6a55b37490 | ||
|   | 4b4185f71d | ||
|   | 7371a1654a | ||
|   | e3bb745a92 | ||
|   | eb2920b62b | ||
|   | 270ef2e0e1 | ||
|   | b7cc65001f | ||
|   | dbf84bf7c8 | ||
|   | 9d98c1afd8 | ||
|   | f6845854a1 | ||
|   | dbb193c7e9 | ||
|   | 71e44300a4 | ||
|   | 39f1ad026c | ||
|   | fdc01127e2 | ||
|   | faf0250aae | ||
|   | 1526875c7f | ||
|   | 56df854368 | ||
|   | 7f15427638 | ||
|   | 0586ef3e55 | ||
|   | d65e4eb701 | ||
|   | c050d4a338 | ||
|   | 11f0ca3dbd | ||
|   | f40a401b2b | ||
|   | 25ed55eac6 | ||
|   | 789d71d7c2 | ||
|   | 51fa966457 | ||
|   | b2334b4e5f | ||
|   | bf909cfa0f | ||
|   | 1f7dc304fd | ||
|   | b5d8eeebfe | ||
|   | 2940c9dc0a | ||
|   | e2c34e5863 | ||
|   | ac415d1bcb | ||
|   | 61f9575255 | ||
|   | ef4e04286b | ||
|   | 32ad54e4e3 | ||
|   | 6ff8e23e59 | ||
|   | c60c28efa2 | ||
|   | 86e62d8d40 | ||
|   | b25b59615e | ||
|   | ff6bd4a91f | ||
|   | d20a59e843 | ||
|   | 94dbb140fb | ||
|   | 864687bdab | ||
|   | e11bf2a439 | ||
|   | 053be766c9 | ||
|   | 3f0839f434 | ||
|   | a7a1e080f3 | ||
|   | 5171520e65 | ||
|   | 73bddf774b | ||
|   | 7d794a0fff | ||
|   | 16503488c1 | ||
|   | ff850ee37a | ||
|   | cdfecefa12 | ||
|   | abf81518fe | ||
|   | 1431dff97b | ||
|   | 8d6efb8efb | ||
|   | b3defa71d1 | ||
|   | 83a4ed0c9e | ||
|   | 1148e4b35d | ||
|   | 3aacfea299 | ||
|   | 90a732b4f4 | ||
|   | 24f6702101 | ||
|   | ddcfd8c7ec | ||
|   | 0cf6366dbd | ||
|   | ac9756cf08 | ||
|   | 6d8117050c | ||
|   | 9ee10ef721 | ||
|   | ef3a28e686 | ||
|   | fc6a53122c | ||
|   | 5179669fb1 | ||
|   | 271d3ad2b3 | ||
|   | 972816b94b | ||
|   | eea217af60 | ||
|   | 376a72fdb2 | ||
|   | fa47d94a96 | ||
|   | babe71973b | ||
|   | bbd7e21197 | ||
|   | 0356944be5 | ||
|   | c5196494ea | ||
|   | 80f5f05ea0 | ||
|   | a2f10cc41f | ||
|   | 339e3f5ba9 | ||
|   | 908047e40b | ||
|   | 545a86ed54 | ||
|   | 14c2e701a0 | ||
|   | 211f4f51fa | ||
|   | c9a6677b91 | ||
|   | c5f4861c78 | ||
|   | 2ff3cdac81 | ||
|   | 9bc44106d5 | ||
|   | ba89520f01 | ||
|   | 8a2a51b0de | ||
|   | 2c95c7fbd3 | ||
|   | 8e654d1680 | ||
|   | d168653061 | ||
|   | 7689181eb8 | ||
|   | dbe9d47065 | ||
|   | a8232182ba | ||
|   | 8065c2faca | ||
|   | 3a13518b10 | ||
|   | 2c55463d35 | ||
|   | b8568ce761 | ||
|   | 7daf9feb39 | ||
|   | 20bccaae6a | ||
|   | d392cb089f | ||
|   | 9a68bf278f | ||
|   | f8fc444e32 | ||
|   | 332edf1d0c | ||
|   | 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 | ||
|   | 3cffb075ba | ||
|   | 7a9eab4a73 | ||
|   | d808a1e99f | ||
|   | ddad65f649 | ||
|   | b6852d455b | ||
|   | f91d5d1cda | ||
|   | 5751783109 | ||
|   | 770a2f37c0 | ||
|   | 2adafe5600 | ||
|   | 96ec03e9b5 | ||
|   | 51072d93d8 | ||
|   | 599fa22de8 | ||
|   | ca99af9d9c | ||
|   | 355b68f83f | ||
|   | 28606a97ec | ||
|   | 99c15ac7ee | ||
|   | df5275e79f | ||
|   | 20de4948d2 | ||
|   | db56886866 | ||
|   | 7c7807564a | ||
|   | 45be789a40 | ||
|   | 881fd6af53 | ||
|   | e1559b65e1 | ||
|   | 485433f986 | ||
|   | 06120ffd1a | ||
|   | ab6a9dd540 | ||
|   | 121973fae1 | ||
|   | 474bbbb999 | ||
|   | 47ee800328 | ||
|   | 27fb1d973f | ||
|   | cd20e88ed4 | ||
|   | 00a6c8af1d | ||
|   | 605b1ae994 | ||
|   | 24d2268890 | ||
|   | be24413bbb | ||
|   | 068831f6cb | ||
|   | d369702e89 | ||
|   | 6ae271077f | ||
|   | c383ec4bfb | ||
|   | c3168d70ef | ||
|   | a25de8a414 | ||
|   | f6a1277806 | ||
|   | 5b2aff6b7e | ||
|   | 0407798ba0 | ||
|   | 059419da08 | ||
|   | 9b427a8e35 | ||
|   | cae5232130 | ||
|   | b8634c9f28 | ||
|   | 1c36f08da2 | ||
|   | 1640f9f022 | ||
|   | 331992ca50 | ||
|   | 94eddba213 | ||
|   | 6f92c15bd0 | ||
|   | d04ef6c256 | ||
|   | 8d5995f50b | ||
|   | d19969cb0e | ||
|   | 6ec34e930c | ||
|   | a7d2d0d592 | ||
|   | 8abd4fb0c1 | ||
|   | 3d522f39aa | ||
|   | 6139b57f53 | ||
|   | bd061e865e | ||
|   | 806ccf94d4 | ||
|   | 1f17d690a6 | ||
|   | ba13d899fe | ||
|   | b10b3c99c8 | ||
|   | a44b50bf2a | ||
|   | c70e6a961a | ||
|   | a95e93c845 | 
| @@ -17,5 +17,6 @@ module.exports = { | ||||
|     'no-unused-vars': 'off', | ||||
|     'no-useless-escape': 'off', | ||||
|     'no-control-regex': 'off', | ||||
|     'no-extra-semi': 'off', | ||||
|   } | ||||
| } | ||||
|   | ||||
							
								
								
									
										604
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										604
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -8,12 +8,13 @@ | ||||
|       "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", | ||||
|         "file-saver": "^2.0.5", | ||||
|         "font-awesome": "^4.6.3", | ||||
|         "ionicons": "^2.0.1", | ||||
|         "jquery": "^2.2.0", | ||||
| @@ -21,12 +22,17 @@ | ||||
|         "knockout": "^3.5.1", | ||||
|         "less": "^4.2.0", | ||||
|         "less-loader": "^11.1.3", | ||||
|         "moment-timezone": "^0.5.45", | ||||
|         "node-sass": "^9.0.0", | ||||
|         "popper.js": "^1.16.1", | ||||
|         "sass": "^1.67.0", | ||||
|         "sass-loader": "^13.3.2", | ||||
|         "svgaplayerweb": "^2.3.2", | ||||
|         "unplugin-element-plus": "^0.8.0", | ||||
|         "vue-clipboard2": "^0.3.3", | ||||
|         "vue-router": "^4.0.3", | ||||
|         "vuex": "^4.0.0" | ||||
|         "vuex": "^4.0.0", | ||||
|         "xlsx": "^0.18.5" | ||||
|       }, | ||||
|       "devDependencies": { | ||||
|         "@babel/core": "^7.12.16", | ||||
| @@ -36,9 +42,11 @@ | ||||
|         "@vue/cli-plugin-router": "~5.0.0", | ||||
|         "@vue/cli-plugin-vuex": "~5.0.0", | ||||
|         "@vue/cli-service": "~5.0.0", | ||||
|         "compression-webpack-plugin": "^10.0.0", | ||||
|         "eslint": "^7.32.0", | ||||
|         "eslint-plugin-vue": "^8.0.3", | ||||
|         "script-loader": "^0.7.2", | ||||
|         "unplugin-auto-import": "^0.16.7", | ||||
|         "unplugin-vue-components": "^0.25.2", | ||||
|         "vue": "^3.2.13", | ||||
|         "webpack-cli": "^5.1.4" | ||||
|       } | ||||
| @@ -79,6 +87,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", | ||||
| @@ -2181,6 +2195,27 @@ | ||||
|       "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==", | ||||
|       "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", | ||||
| @@ -3687,6 +3722,14 @@ | ||||
|         "node": ">= 10.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/adler-32": { | ||||
|       "version": "1.3.1", | ||||
|       "resolved": "https://registry.npmmirror.com/adler-32/-/adler-32-1.3.1.tgz", | ||||
|       "integrity": "sha512-ynZ4w/nUUv5rrsR8UUGoe1VC9hZj6V5hU9Qw1HlMDJGEJw5S7TfTErWTjMys6M7vr0YWcPqs3qAr4ss0nDfP+A==", | ||||
|       "engines": { | ||||
|         "node": ">=0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/admin-lte": { | ||||
|       "version": "2.3.2", | ||||
|       "resolved": "https://registry.npmmirror.com/admin-lte/-/admin-lte-2.3.2.tgz", | ||||
| @@ -4172,11 +4215,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", | ||||
| @@ -4402,9 +4440,23 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/caniuse-lite": { | ||||
|       "version": "1.0.30001546", | ||||
|       "resolved": "https://registry.npmmirror.com/caniuse-lite/-/caniuse-lite-1.0.30001546.tgz", | ||||
|       "integrity": "sha512-zvtSJwuQFpewSyRrI3AsftF6rM0X80mZkChIt1spBGEvRglCrjTniXvinc8JKRoqTwXAgvqTImaN9igfSMtUBw==" | ||||
|       "version": "1.0.30001651", | ||||
|       "resolved": "https://registry.npmmirror.com/caniuse-lite/-/caniuse-lite-1.0.30001651.tgz", | ||||
|       "integrity": "sha512-9Cf+Xv1jJNe1xPZLGuUXLNkE1BoDkqRqYyFJ9TDYSqhduqA4hu4oR9HluGoWYQC/aj8WHjsGVV+bwkh0+tegRg==", | ||||
|       "funding": [ | ||||
|         { | ||||
|           "type": "opencollective", | ||||
|           "url": "https://opencollective.com/browserslist" | ||||
|         }, | ||||
|         { | ||||
|           "type": "tidelift", | ||||
|           "url": "https://tidelift.com/funding/github/npm/caniuse-lite" | ||||
|         }, | ||||
|         { | ||||
|           "type": "github", | ||||
|           "url": "https://github.com/sponsors/ai" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     "node_modules/case-sensitive-paths-webpack-plugin": { | ||||
|       "version": "2.4.0", | ||||
| @@ -4415,6 +4467,18 @@ | ||||
|         "node": ">=4" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/cfb": { | ||||
|       "version": "1.2.2", | ||||
|       "resolved": "https://registry.npmmirror.com/cfb/-/cfb-1.2.2.tgz", | ||||
|       "integrity": "sha512-KfdUZsSOw19/ObEWasvBP/Ac4reZvAGauZhs6S/gqNhXhI7cKwvlH7ulj+dOEYnca4bm4SGo8C1bTAQvnTjgQA==", | ||||
|       "dependencies": { | ||||
|         "adler-32": "~1.3.0", | ||||
|         "crc-32": "~1.2.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/chalk": { | ||||
|       "version": "2.4.2", | ||||
|       "resolved": "https://registry.npmmirror.com/chalk/-/chalk-2.4.2.tgz", | ||||
| @@ -4607,6 +4671,16 @@ | ||||
|         "node": ">=6" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/clipboard": { | ||||
|       "version": "2.0.11", | ||||
|       "resolved": "https://registry.npmmirror.com/clipboard/-/clipboard-2.0.11.tgz", | ||||
|       "integrity": "sha512-C+0bbOqkezLIsmWSvlsXS0Q0bmkugu7jcfMIACB+RDEntIzQIkdr148we28AfSloQLRdZlYL/QYyrq05j/3Faw==", | ||||
|       "dependencies": { | ||||
|         "good-listener": "^1.2.2", | ||||
|         "select": "^1.1.2", | ||||
|         "tiny-emitter": "^2.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/clipboardy": { | ||||
|       "version": "2.3.0", | ||||
|       "resolved": "https://registry.npmmirror.com/clipboardy/-/clipboardy-2.3.0.tgz", | ||||
| @@ -4667,6 +4741,14 @@ | ||||
|         "node": ">=0.10.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/codepage": { | ||||
|       "version": "1.15.0", | ||||
|       "resolved": "https://registry.npmmirror.com/codepage/-/codepage-1.15.0.tgz", | ||||
|       "integrity": "sha512-3g6NUTPd/YtuuGrhMnOMRjFc+LJw/bnMp3+0r/Wcz3IXUuCosKRJvMphm5+Q+bvTVGcJJuRvVLuYba+WojaFaA==", | ||||
|       "engines": { | ||||
|         "node": ">=0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/color-convert": { | ||||
|       "version": "1.9.3", | ||||
|       "resolved": "https://registry.npmmirror.com/color-convert/-/color-convert-1.9.3.tgz", | ||||
| @@ -4752,67 +4834,6 @@ | ||||
|         "node": ">= 0.8.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/compression-webpack-plugin": { | ||||
|       "version": "10.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/compression-webpack-plugin/-/compression-webpack-plugin-10.0.0.tgz", | ||||
|       "integrity": "sha512-wLXLIBwpul/ALcm7Aj+69X0pYT3BYt6DdPn3qrgBIh9YejV9Bju9ShhlAsjujLyWMo6SAweFIWaUoFmXZNuNrg==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "schema-utils": "^4.0.0", | ||||
|         "serialize-javascript": "^6.0.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">= 14.15.0" | ||||
|       }, | ||||
|       "peerDependencies": { | ||||
|         "webpack": "^5.1.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/compression-webpack-plugin/node_modules/ajv": { | ||||
|       "version": "8.12.0", | ||||
|       "resolved": "https://registry.npmmirror.com/ajv/-/ajv-8.12.0.tgz", | ||||
|       "integrity": "sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "fast-deep-equal": "^3.1.1", | ||||
|         "json-schema-traverse": "^1.0.0", | ||||
|         "require-from-string": "^2.0.2", | ||||
|         "uri-js": "^4.2.2" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/compression-webpack-plugin/node_modules/ajv-keywords": { | ||||
|       "version": "5.1.0", | ||||
|       "resolved": "https://registry.npmmirror.com/ajv-keywords/-/ajv-keywords-5.1.0.tgz", | ||||
|       "integrity": "sha512-YCS/JNFAUyr5vAuhk1DWm1CBxRHW9LbJ2ozWeemrIqpbsqKjHVxYPyi5GC0rjZIT5JxJ3virVTS8wk4i/Z+krw==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "fast-deep-equal": "^3.1.3" | ||||
|       }, | ||||
|       "peerDependencies": { | ||||
|         "ajv": "^8.8.2" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/compression-webpack-plugin/node_modules/json-schema-traverse": { | ||||
|       "version": "1.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", | ||||
|       "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/compression-webpack-plugin/node_modules/schema-utils": { | ||||
|       "version": "4.2.0", | ||||
|       "resolved": "https://registry.npmmirror.com/schema-utils/-/schema-utils-4.2.0.tgz", | ||||
|       "integrity": "sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "@types/json-schema": "^7.0.9", | ||||
|         "ajv": "^8.9.0", | ||||
|         "ajv-formats": "^2.1.1", | ||||
|         "ajv-keywords": "^5.1.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">= 12.13.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/compression/node_modules/debug": { | ||||
|       "version": "2.6.9", | ||||
|       "resolved": "https://registry.npmmirror.com/debug/-/debug-2.6.9.tgz", | ||||
| @@ -4998,6 +5019,17 @@ | ||||
|         "node": ">=10" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/crc-32": { | ||||
|       "version": "1.2.2", | ||||
|       "resolved": "https://registry.npmmirror.com/crc-32/-/crc-32-1.2.2.tgz", | ||||
|       "integrity": "sha512-ROmzCKrTnOwybPcJApAA6WBWij23HVfGVNKqqrZpuyZOHqK2CwHSvpGuyt/UNNvaIjEd8X5IFGp4Mh+Ie1IHJQ==", | ||||
|       "bin": { | ||||
|         "crc32": "bin/crc32.njs" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/cross-spawn": { | ||||
|       "version": "6.0.5", | ||||
|       "resolved": "https://registry.npmmirror.com/cross-spawn/-/cross-spawn-6.0.5.tgz", | ||||
| @@ -5544,6 +5576,11 @@ | ||||
|         "node": ">=0.4.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/delegate": { | ||||
|       "version": "3.2.0", | ||||
|       "resolved": "https://registry.npmmirror.com/delegate/-/delegate-3.2.0.tgz", | ||||
|       "integrity": "sha512-IofjkYBZaZivn0V8nnsMJGBr4jVLxHDheKSW88PyxS5QC4Vo9ZbZVvhzlSxY87fVq3STR6r+4cGepyHkcWOQSw==" | ||||
|     }, | ||||
|     "node_modules/delegates": { | ||||
|       "version": "1.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/delegates/-/delegates-1.0.0.tgz", | ||||
| @@ -6682,6 +6719,11 @@ | ||||
|         "node": "^10.12.0 || >=12.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/file-saver": { | ||||
|       "version": "2.0.5", | ||||
|       "resolved": "https://registry.npmmirror.com/file-saver/-/file-saver-2.0.5.tgz", | ||||
|       "integrity": "sha512-P9bmyZ3h/PRG+Nzga+rbdI4OEpNDzAVyy74uVO9ATgzLK6VtAsYybF/+TOCvrc0MO793d6+42lLyZTw7/ArVzA==" | ||||
|     }, | ||||
|     "node_modules/fill-range": { | ||||
|       "version": "7.0.1", | ||||
|       "resolved": "https://registry.npmmirror.com/fill-range/-/fill-range-7.0.1.tgz", | ||||
| @@ -6815,6 +6857,14 @@ | ||||
|         "node": ">= 0.6" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/frac": { | ||||
|       "version": "1.1.2", | ||||
|       "resolved": "https://registry.npmmirror.com/frac/-/frac-1.1.2.tgz", | ||||
|       "integrity": "sha512-w/XBfkibaTl3YDqASwfDUqkna4Z2p9cFSr1aHDt0WoMTECnRfBOv2WArlZILlqgWlmdIlALXGpM2AOhEk5W3IA==", | ||||
|       "engines": { | ||||
|         "node": ">=0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/fraction.js": { | ||||
|       "version": "4.3.6", | ||||
|       "resolved": "https://registry.npmmirror.com/fraction.js/-/fraction.js-4.3.6.tgz", | ||||
| @@ -7071,6 +7121,14 @@ | ||||
|         "node": "*" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/good-listener": { | ||||
|       "version": "1.2.2", | ||||
|       "resolved": "https://registry.npmmirror.com/good-listener/-/good-listener-1.2.2.tgz", | ||||
|       "integrity": "sha512-goW1b+d9q/HIwbVYZzZ6SsTr4IgE+WA44A0GmPIQstuOrgsFcT7VEJ48nmr9GaRtNu0XTKacFLGnBPAM6Afouw==", | ||||
|       "dependencies": { | ||||
|         "delegate": "^3.1.2" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/gopd": { | ||||
|       "version": "1.0.1", | ||||
|       "resolved": "https://registry.npmmirror.com/gopd/-/gopd-1.0.1.tgz", | ||||
| @@ -7893,6 +7951,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", | ||||
| @@ -8063,6 +8127,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", | ||||
| @@ -8881,12 +8958,43 @@ | ||||
|         "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", | ||||
|       "integrity": "sha512-23g5BFj4zdQL/b6tor7Ji+QY4pEfNH784BMslY9Qb0UnJWRAt+lQGLYmRaM0KDBwIG23ffEBELhZDP2rhi9f/Q==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/moment": { | ||||
|       "version": "2.30.1", | ||||
|       "resolved": "https://registry.npmmirror.com/moment/-/moment-2.30.1.tgz", | ||||
|       "integrity": "sha512-uEmtNhbDOrWPFS+hdjFCBfy9f2YoyzRpwcl+DqpC6taX21FzsTLQVbMV/W7PzNSX6x/bhC1zA3c2UQ5NzH6how==", | ||||
|       "engines": { | ||||
|         "node": "*" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/moment-timezone": { | ||||
|       "version": "0.5.45", | ||||
|       "resolved": "https://registry.npmmirror.com/moment-timezone/-/moment-timezone-0.5.45.tgz", | ||||
|       "integrity": "sha512-HIWmqA86KcmCAhnMAN0wuDOARV/525R2+lOLotuGFzn4HO+FH+/645z2wx0Dt3iDv6/p61SIvKnDstISainhLQ==", | ||||
|       "dependencies": { | ||||
|         "moment": "^2.29.4" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": "*" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/mrmime": { | ||||
|       "version": "1.0.1", | ||||
|       "resolved": "https://registry.npmmirror.com/mrmime/-/mrmime-1.0.1.tgz", | ||||
| @@ -9909,6 +10017,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", | ||||
| @@ -9943,6 +10057,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", | ||||
| @@ -10731,6 +10856,12 @@ | ||||
|         "node": ">= 0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/raw-loader": { | ||||
|       "version": "0.5.1", | ||||
|       "resolved": "https://registry.npmmirror.com/raw-loader/-/raw-loader-0.5.1.tgz", | ||||
|       "integrity": "sha512-sf7oGoLuaYAScB4VGr0tzetsYlS8EJH6qnTCfQ/WVEa89hALQ4RQfCKt5xCyPQKPDUbVUAIP1QsxAwfAjlDp7Q==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/read-pkg": { | ||||
|       "version": "5.2.0", | ||||
|       "resolved": "https://registry.npmmirror.com/read-pkg/-/read-pkg-5.2.0.tgz", | ||||
| @@ -11179,6 +11310,15 @@ | ||||
|         "node": ">= 8.9.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/script-loader": { | ||||
|       "version": "0.7.2", | ||||
|       "resolved": "https://registry.npmmirror.com/script-loader/-/script-loader-0.7.2.tgz", | ||||
|       "integrity": "sha512-UMNLEvgOAQuzK8ji8qIscM3GIrRCWN6MmMXGD4SD5l6cSycgGsCo0tX5xRnfQcoghqct0tjHjcykgI1PyBE2aA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "raw-loader": "~0.5.1" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/scss-tokenizer": { | ||||
|       "version": "0.4.3", | ||||
|       "resolved": "https://registry.npmmirror.com/scss-tokenizer/-/scss-tokenizer-0.4.3.tgz", | ||||
| @@ -11196,6 +11336,17 @@ | ||||
|         "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": { | ||||
|       "version": "1.1.2", | ||||
|       "resolved": "https://registry.npmmirror.com/select/-/select-1.1.2.tgz", | ||||
|       "integrity": "sha512-OwpTSOfy6xSs1+pwcNrv0RBMOzI39Lp3qQKUTPVVPRjCdNa5JH/oPRiqsesIskK8TVgmRiHwO4KXlV2Li9dANA==" | ||||
|     }, | ||||
|     "node_modules/select-hose": { | ||||
|       "version": "2.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/select-hose/-/select-hose-2.0.0.tgz", | ||||
| @@ -11643,6 +11794,17 @@ | ||||
|       "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/ssf": { | ||||
|       "version": "0.11.2", | ||||
|       "resolved": "https://registry.npmmirror.com/ssf/-/ssf-0.11.2.tgz", | ||||
|       "integrity": "sha512-+idbmIXoYET47hH+d7dfm2epdOMUDjqcB4648sTZ+t2JwoyBFL/insLfB/racrDmsKB3diwsDA696pZMieAC5g==", | ||||
|       "dependencies": { | ||||
|         "frac": "~1.1.2" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/ssri": { | ||||
|       "version": "8.0.1", | ||||
|       "resolved": "https://registry.npmmirror.com/ssri/-/ssri-8.0.1.tgz", | ||||
| @@ -11779,6 +11941,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", | ||||
| @@ -11820,6 +11991,11 @@ | ||||
|       "integrity": "sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/svgaplayerweb": { | ||||
|       "version": "2.3.2", | ||||
|       "resolved": "https://registry.npmmirror.com/svgaplayerweb/-/svgaplayerweb-2.3.2.tgz", | ||||
|       "integrity": "sha512-QuTvNIgy3W6Mi4h74SczEHUtAwb8m3ax7Ai7xRLUuN6hjJh49RGtWOWq1IuF2I7ECcl0HAYn8FcTn99UDz9UiQ==" | ||||
|     }, | ||||
|     "node_modules/svgo": { | ||||
|       "version": "2.8.0", | ||||
|       "resolved": "https://registry.npmmirror.com/svgo/-/svgo-2.8.0.tgz", | ||||
| @@ -12057,6 +12233,11 @@ | ||||
|       "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/tiny-emitter": { | ||||
|       "version": "2.1.0", | ||||
|       "resolved": "https://registry.npmmirror.com/tiny-emitter/-/tiny-emitter-2.1.0.tgz", | ||||
|       "integrity": "sha512-NB6Dk1A9xgQPMoGqC5CVXn123gWyte215ONT5Pp5a0yt4nlEoO1ZWeCwpncaekPHXO60i47ihFnZPiRPjRMq4Q==" | ||||
|     }, | ||||
|     "node_modules/to-fast-properties": { | ||||
|       "version": "2.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz", | ||||
| @@ -12152,6 +12333,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", | ||||
| @@ -12192,6 +12379,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", | ||||
| @@ -12232,6 +12468,184 @@ | ||||
|         "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==", | ||||
|       "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-element-plus": { | ||||
|       "version": "0.8.0", | ||||
|       "resolved": "https://registry.npmmirror.com/unplugin-element-plus/-/unplugin-element-plus-0.8.0.tgz", | ||||
|       "integrity": "sha512-jByUGY3FG2B8RJKFryqxx4eNtSTj+Hjlo8edcOdJymewndDQjThZ1pRUQHRjQsbKhTV2jEctJV7t7RJ405UL4g==", | ||||
|       "dependencies": { | ||||
|         "@rollup/pluginutils": "^5.0.2", | ||||
|         "es-module-lexer": "^1.3.0", | ||||
|         "magic-string": "^0.30.1", | ||||
|         "unplugin": "^1.3.2" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=14.19.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/unplugin-element-plus/node_modules/magic-string": { | ||||
|       "version": "0.30.10", | ||||
|       "resolved": "https://registry.npmmirror.com/magic-string/-/magic-string-0.30.10.tgz", | ||||
|       "integrity": "sha512-iIRwTIf0QKV3UAnYK4PU8uiEc4SRh5jX0mwpIwETPpHdhVM4f53RSwS/vXvN1JhGX+Cs7B8qIq3d6AH49O5fAQ==", | ||||
|       "dependencies": { | ||||
|         "@jridgewell/sourcemap-codec": "^1.4.15" | ||||
|       } | ||||
|     }, | ||||
|     "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==" | ||||
|     }, | ||||
|     "node_modules/update-browserslist-db": { | ||||
|       "version": "1.0.13", | ||||
|       "resolved": "https://registry.npmmirror.com/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", | ||||
| @@ -12320,6 +12734,14 @@ | ||||
|         "@vue/shared": "3.2.13" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/vue-clipboard2": { | ||||
|       "version": "0.3.3", | ||||
|       "resolved": "https://registry.npmmirror.com/vue-clipboard2/-/vue-clipboard2-0.3.3.tgz", | ||||
|       "integrity": "sha512-aNWXIL2DKgJyY/1OOeITwAQz1fHaCIGvUFHf9h8UcoQBG5a74MkdhS/xqoYe7DNZdQmZRL+TAdIbtUs9OyVjbw==", | ||||
|       "dependencies": { | ||||
|         "clipboard": "^2.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/vue-eslint-parser": { | ||||
|       "version": "8.3.0", | ||||
|       "resolved": "https://registry.npmmirror.com/vue-eslint-parser/-/vue-eslint-parser-8.3.0.tgz", | ||||
| @@ -12575,7 +12997,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": { | ||||
| @@ -13034,6 +13456,22 @@ | ||||
|       "integrity": "sha512-CC1bOL87PIWSBhDcTrdeLo6eGT7mCFtrg0uIJtqJUFyK+eJnzl8A1niH56uu7KMa5XFrtiV+AQuHO3n7DsHnLQ==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/wmf": { | ||||
|       "version": "1.0.2", | ||||
|       "resolved": "https://registry.npmmirror.com/wmf/-/wmf-1.0.2.tgz", | ||||
|       "integrity": "sha512-/p9K7bEh0Dj6WbXg4JG0xvLQmIadrner1bi45VMJTfnbVHsc7yIajZyoSoK60/dtVBs12Fm6WkUI5/3WAVsNMw==", | ||||
|       "engines": { | ||||
|         "node": ">=0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/word": { | ||||
|       "version": "0.3.0", | ||||
|       "resolved": "https://registry.npmmirror.com/word/-/word-0.3.0.tgz", | ||||
|       "integrity": "sha512-OELeY0Q61OXpdUfTp+oweA/vtLVg5VDOXh+3he3PNzLGG/y0oylSOC1xRVj0+l4vQ3tj/bB1HVHv1ocXkQceFA==", | ||||
|       "engines": { | ||||
|         "node": ">=0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/wrap-ansi": { | ||||
|       "version": "7.0.0", | ||||
|       "resolved": "https://registry.npmmirror.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz", | ||||
| @@ -13100,6 +13538,26 @@ | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/xlsx": { | ||||
|       "version": "0.18.5", | ||||
|       "resolved": "https://registry.npmmirror.com/xlsx/-/xlsx-0.18.5.tgz", | ||||
|       "integrity": "sha512-dmg3LCjBPHZnQp5/F/+nnTa+miPJxUXB6vtk42YjBBKayDNagxGEeIdWApkYPOf3Z3pm3k62Knjzp7lMeTEtFQ==", | ||||
|       "dependencies": { | ||||
|         "adler-32": "~1.3.0", | ||||
|         "cfb": "~1.2.1", | ||||
|         "codepage": "~1.15.0", | ||||
|         "crc-32": "~1.2.1", | ||||
|         "ssf": "~0.11.2", | ||||
|         "wmf": "~1.0.1", | ||||
|         "word": "~0.3.0" | ||||
|       }, | ||||
|       "bin": { | ||||
|         "xlsx": "bin/xlsx.njs" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=0.8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/y18n": { | ||||
|       "version": "5.0.8", | ||||
|       "resolved": "https://registry.npmmirror.com/y18n/-/y18n-5.0.8.tgz", | ||||
|   | ||||
							
								
								
									
										16
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								package.json
									
									
									
									
									
								
							| @@ -3,17 +3,18 @@ | ||||
|   "version": "0.1.0", | ||||
|   "private": true, | ||||
|   "scripts": { | ||||
|     "serve": "vue-cli-service serve --mode development", | ||||
|     "dev": "vue-cli-service serve --mode development", | ||||
|     "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", | ||||
|     "file-saver": "^2.0.5", | ||||
|     "font-awesome": "^4.6.3", | ||||
|     "ionicons": "^2.0.1", | ||||
|     "jquery": "^2.2.0", | ||||
| @@ -21,12 +22,17 @@ | ||||
|     "knockout": "^3.5.1", | ||||
|     "less": "^4.2.0", | ||||
|     "less-loader": "^11.1.3", | ||||
|     "moment-timezone": "^0.5.45", | ||||
|     "node-sass": "^9.0.0", | ||||
|     "popper.js": "^1.16.1", | ||||
|     "sass": "^1.67.0", | ||||
|     "sass-loader": "^13.3.2", | ||||
|     "svgaplayerweb": "^2.3.2", | ||||
|     "unplugin-element-plus": "^0.8.0", | ||||
|     "vue-clipboard2": "^0.3.3", | ||||
|     "vue-router": "^4.0.3", | ||||
|     "vuex": "^4.0.0" | ||||
|     "vuex": "^4.0.0", | ||||
|     "xlsx": "^0.18.5" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@babel/core": "^7.12.16", | ||||
| @@ -36,9 +42,11 @@ | ||||
|     "@vue/cli-plugin-router": "~5.0.0", | ||||
|     "@vue/cli-plugin-vuex": "~5.0.0", | ||||
|     "@vue/cli-service": "~5.0.0", | ||||
|     "compression-webpack-plugin": "^10.0.0", | ||||
|     "eslint": "^7.32.0", | ||||
|     "eslint-plugin-vue": "^8.0.3", | ||||
|     "script-loader": "^0.7.2", | ||||
|     "unplugin-auto-import": "^0.16.7", | ||||
|     "unplugin-vue-components": "^0.25.2", | ||||
|     "vue": "^3.2.13", | ||||
|     "webpack-cli": "^5.1.4" | ||||
|   } | ||||
|   | ||||
							
								
								
									
										65
									
								
								src/api/AccessRestriction.vue/AccessRestriction.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								src/api/AccessRestriction.vue/AccessRestriction.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // ==================================地区限制==================================== | ||||
|  | ||||
| // 地区列表 | ||||
| export const recordPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ip/region/limit/record/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 加入白名单 | ||||
| export const addWhite = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ip/region/limit/record/addWhite', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 解除限制 | ||||
| export const relieve = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ip/region/limit/record/relieve', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 添加地区访问限制 | ||||
| export const recordSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ip/region/limit/record/save', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // ==================================访问白名单==================================== | ||||
|  | ||||
| // 白名单列表 | ||||
| export const whitePage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ip/region/white/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 移除白名单 | ||||
| export const whiteDel = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ip/region/white/del', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 添加白名单 | ||||
| export const whiteSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ip/region/white/save', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										19
									
								
								src/api/GiftPanelManagement/GiftPanelManagement.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								src/api/GiftPanelManagement/GiftPanelManagement.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| // 列表 | ||||
| export const list = query => { | ||||
|     return request({ | ||||
|         url: '/giftPanelTab/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 保存 | ||||
| export const update = query => { | ||||
|     return request({ | ||||
|         url: '/giftPanelTab/update', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										42
									
								
								src/api/SsGuild/SsGuild.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								src/api/SsGuild/SsGuild.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 周期选项下拉框 | ||||
| export const cycleDateList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ssGuild/cycleDateList', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // SS公会列表 | ||||
| export const list = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ssGuild/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 发送金币&批量发送 | ||||
| export const sendGold = query => { | ||||
|     return request({ | ||||
|         url: '/admin/ssGuild/sendGold', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 导出 | ||||
| // export const ssGuildExport = query => { | ||||
| //     return request({ | ||||
| //         url: `/admin/ssGuild/export`, | ||||
| //         method: 'post', | ||||
| //         params: query, | ||||
| //         responseType: 'blob' | ||||
| //     }); | ||||
| // }; | ||||
| // 导出-公会信息 | ||||
| export const ssGuildExport = query => { | ||||
|     window.location.href = `/admin/ssGuild/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
							
								
								
									
										34
									
								
								src/api/VipGive/VipGive.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								src/api/VipGive/VipGive.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| // 查询用户接口 | ||||
| export const getByErbanNo = query => { | ||||
|     return request({ | ||||
|         url: '/admin/user/getByErbanNo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 获取VIP列表接口 | ||||
| export const listAll = query => { | ||||
|     return request({ | ||||
|         url: '/admin/vip/listAll', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 获取列表接口 | ||||
| export const pageRecord = query => { | ||||
|     return request({ | ||||
|         url: '/vipSend/pageRecord', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 赠送VIP接口 | ||||
| export const vipSendSend = query => { | ||||
|     return request({ | ||||
|         url: '/vipSend/send', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										9
									
								
								src/api/chat/publicChatTopRecord.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								src/api/chat/publicChatTopRecord.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| import request from '@/utils/request'; | ||||
|  | ||||
| export const getPublicChatTopRecordPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/publicChatTopRecord/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										9
									
								
								src/api/common/gift.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								src/api/common/gift.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| import request from '@/utils/request'; | ||||
|  | ||||
| export const getGiftList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/gift/getAll', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										72
									
								
								src/api/common/upload.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								src/api/common/upload.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,72 @@ | ||||
| import request from "@/utils/request"; | ||||
| import '@/utils/ajaxfileupload'; | ||||
|  | ||||
| export const uploadFile = id => { | ||||
|     return new Promise((resolve, reject) => { | ||||
|         $.ajaxFileUpload({ | ||||
|             fileElementId: id, | ||||
|             url: '/admin/upload/img', | ||||
|             type: 'post', | ||||
|             dataType: 'json', | ||||
|             secureuri: false, | ||||
|             async: true, | ||||
|             submitType: 'ajax', | ||||
|             success: function (res) { | ||||
|                 resolve(res); | ||||
|             }, | ||||
|             error: function (res, status, e) { | ||||
|                 console.error(res); | ||||
|                 console.error(status); | ||||
|                 reject(e); | ||||
|             } | ||||
|         }); | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const uploadQiNiuFile = (file) => { | ||||
|     console.log(file); | ||||
|     let formData = new FormData(); | ||||
|     formData.append('file', file); | ||||
|     return new Promise((resolve, reject) => { | ||||
|         request.post('/admin/qiniu/upload/file', formData).then(res => { | ||||
|             resolve(res); | ||||
|         }).catch(e => { | ||||
|             reject(e); | ||||
|         }); | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const uploadTencentFile = id => { | ||||
|     return new Promise((resolve, reject) => { | ||||
|         $.ajaxFileUpload({ | ||||
|             fileElementId: id, | ||||
|             url: '/admin/upload/tencent/file', | ||||
|             type: 'post', | ||||
|             dataType: 'json', | ||||
|             secureuri: false, | ||||
|             async: true, | ||||
|             submitType: 'ajax', | ||||
|             success: function (res) { | ||||
|                 resolve(res); | ||||
|             }, | ||||
|             error: function (res, status, e) { | ||||
|                 console.error(res); | ||||
|                 console.error(status); | ||||
|                 reject(e); | ||||
|             } | ||||
|         }); | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const uploadGift = (file) => { | ||||
|     let formData = new FormData(); | ||||
|     console.log(file); | ||||
|     formData.append('file', file); | ||||
|     return new Promise((resolve, reject) => { | ||||
|         request.post('/admin/gift/upload', formData).then(res => { | ||||
|             resolve(res); | ||||
|         }).catch(e => { | ||||
|             reject(e); | ||||
|         }); | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										21
									
								
								src/api/feedBack/feedBack.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								src/api/feedBack/feedBack.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| // ==================================每日数据==================================== | ||||
| // 反馈类型 | ||||
| export const listType = query => { | ||||
|     return request({ | ||||
|         url: '/admin/feedback/listType', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 反馈列表 | ||||
| export const pageRecord = query => { | ||||
|     return request({ | ||||
|         url: '/admin/feedback/pageRecord', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										20
									
								
								src/api/gameAdmin/gameAdmin.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								src/api/gameAdmin/gameAdmin.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| // 获取游戏列表 | ||||
| export const mgList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/miniGame/statis/mgList', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 游戏编辑 | ||||
| export const save = query => { | ||||
|     return request({ | ||||
|         url: '/admin/miniGame/save', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										29
									
								
								src/api/gameInfo/gameInfo.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								src/api/gameInfo/gameInfo.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| // ==================================每日数据==================================== | ||||
| // 列表 | ||||
| export const page = query => { | ||||
|     return request({ | ||||
|         url: '/admin/gamePartner/info/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 编辑修改 | ||||
| export const save = query => { | ||||
|     return request({ | ||||
|         url: '/admin/gamePartner/info/save', | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // 删除 | ||||
| export const delGame = query => { | ||||
|     return request({ | ||||
|         url: '/admin/gamePartner/info/delGame', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										44
									
								
								src/api/invitationFission/invitationFission.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								src/api/invitationFission/invitationFission.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| // ==================================每日数据==================================== | ||||
| // 表单 | ||||
| export const userInviteFissionRecordGetDailyPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/userInviteFissionRecord/getDailyPage', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 详情表单 | ||||
| export const userInviteFissionRecordGetDailyDetailList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/userInviteFissionRecord/getDailyDetailList', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 导出 | ||||
| export const userInviteFissionRecordExport = query => { | ||||
|     window.location.href = `/admin/userInviteFissionRecord/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // ==================================邀请排名==================================== | ||||
| // 设置白名单 | ||||
| export const userInviteFissionRecordSetBlack = query => { | ||||
|     return request({ | ||||
|         url: '/admin/userInviteFissionRecord/setBlack', | ||||
|         headers: { "Content-Type": 'application/x-www-form-urlencoded' }, | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // 邀请排名列表 | ||||
| export const userInviteFissionRecordGetInviteRank = query => { | ||||
|     return request({ | ||||
|         url: '/admin/userInviteFissionRecord/getInviteRank', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										38
									
								
								src/api/lingSmallGames/lingSmallGames.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								src/api/lingSmallGames/lingSmallGames.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 获取游戏列表 | ||||
| export const sysConfKey = query => { | ||||
|     return request({ | ||||
|         url: '/admin/sysConf/key', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 获取列表 | ||||
| export const statisPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/miniGame/leadercc/statis/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 获取详情列表 | ||||
| export const detailPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/miniGame/leadercc/statis/detailPage', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 导出 | ||||
| export const exportForMiniGame = query => { | ||||
|     window.location.href = `/admin/miniGame/leadercc/statis/exportForMiniGame?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 导出弹窗 | ||||
| export const statisExport = query => { | ||||
|     window.location.href = `/admin/miniGame/leadercc/statis/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
							
								
								
									
										70
									
								
								src/api/luckGift/luckGift.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								src/api/luckGift/luckGift.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 奖池拉框 | ||||
| export const listType = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/pool/listType', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 池子列表 | ||||
| export const list = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/pool/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 基础配置 | ||||
| export const getConfig = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/config/getConfig', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 基础配置-修改 | ||||
| export const updateSet = query => { | ||||
|     return request({ | ||||
|         headers: { "Content-Type": 'application/json;charset=UTF-8' }, | ||||
|         url: '/admin/lucky24/config/update', | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // 个人数据 | ||||
| export const personal = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/record/personal', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 汇总 | ||||
| export const platform = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/record/platform', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 保存池子 | ||||
| export const save = query => { | ||||
|     return request({ | ||||
|         headers: { "Content-Type": 'application/json;charset=UTF-8' }, | ||||
|         url: '/admin/lucky24/pool/save', | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // 赠送用户 | ||||
| export const updateUserMulti = query => { | ||||
|     return request({ | ||||
|         url: '/admin/lucky24/config/updateUserMulti', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										80
									
								
								src/api/lucky/luckyGiftRangeConfig.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								src/api/lucky/luckyGiftRangeConfig.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,80 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| export const getLuckyGiftRangeConfigList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyGiftRangeConfig/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const saveLuckyGiftRangeConfig = data => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyGiftRangeConfig/save', | ||||
|         method: 'post', | ||||
|         data: data | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 获取礼物 | ||||
| export const getAll = query => { | ||||
|     return request({ | ||||
|         url: '/admin/gift/getAll', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 获取礼物区间 | ||||
| export const luckyGiftRangeConfigList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyGiftRangeConfig/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 幸运礼物配置列表 | ||||
| export const luckyGiftRewardList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyGiftReward/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 幸运礼物配置删除 | ||||
| export const luckyGiftRewardDelete = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyGiftReward/delete', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 幸运礼保存列表 | ||||
| export const luckyGiftRewardSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyGiftReward/save', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 幸运礼物明细 | ||||
| export const getGiftSendPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyGiftRewardRecord/getGiftSendPage', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 幸运礼物详情 | ||||
| export const getRewardList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyGiftRewardRecord/getRewardList', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 幸运礼物详情导出  | ||||
| export const luckyGiftRewardRecordExport = query => { | ||||
|     window.location.href = `/admin/luckyGiftRewardRecord/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
							
								
								
									
										173
									
								
								src/api/luckyTycoon/luckyTycoon.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										173
									
								
								src/api/luckyTycoon/luckyTycoon.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,173 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| // 地区接口 | ||||
| export const listPartitionInfo = query => { | ||||
|     return request({ | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 福袋列表请求 | ||||
| export const listLuckyBagLinearGift = query => { | ||||
|     return request({ | ||||
|         url: '/admin/gift/getGiftByTypes', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 福袋礼物列表请求 | ||||
| export const getPrizeGroupsInfo = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyBag/getGroupInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 所有礼物列表请求 | ||||
| export const getAll = query => { | ||||
|     return request({ | ||||
|         url: '/admin/gift/getAll', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 所有座驾列表请求 | ||||
| export const carAll = query => { | ||||
|     return request({ | ||||
|         url: '/admin/car/goods/total/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 所有头饰列表请求 | ||||
| export const headwearAll = query => { | ||||
|     return request({ | ||||
|         url: '/admin/headwear/total/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 所有铭牌列表请求 | ||||
| export const nameplateAll = query => { | ||||
|     return request({ | ||||
|         url: '/admin/nameplate/total/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 所有气泡列表请求 | ||||
| export const chatbubbleAll = query => { | ||||
|     return request({ | ||||
|         url: '/admin/chatbubble/total/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 所有资料卡列表请求 | ||||
| export const infocard = query => { | ||||
|     return request({ | ||||
|         url: '/admin/infocard/total/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 榜单统计-列表接口 | ||||
| export const luckyBagWeekRankList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyBagWeekRank/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 榜单统计-详情列表接口 | ||||
| export const luckyBagWeekRankListRank = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyBagWeekRank/pageRank', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 榜单统计-总导出 | ||||
| export const exportList = query => { | ||||
|     window.location.href = `/admin/luckyBagWeekRank/exportList?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 榜单统计-详情导出 | ||||
| export const exportRank = query => { | ||||
|     window.location.href = `/admin/luckyBagWeekRank/exportRank?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 用户中奖记录-列表 | ||||
| export const getRecordPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyBagFortunate/getRecordPage', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 用户中奖记录-导出 | ||||
| export const exportForReward = query => { | ||||
|     window.location.href = `/admin/luckyBagFortunate/exportForReward?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 欧气1+1-导出 | ||||
| export const luckyBagFortunateExport = query => { | ||||
|     window.location.href = `/admin/luckyBagFortunate/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 欧气1+1-列表 | ||||
| export const luckyBagFortunatePage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyBagFortunate/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 欧气1+1-保存 | ||||
| export const luckyBagFortunateSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyBagFortunate/save', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 欧气1+1-上下线 | ||||
| export const luckyBagFortunateUpdateEnabled = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyBagFortunate/updateEnabled', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 收藏-列表 | ||||
| export const luckyBagCollectPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyBagCollect/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 收藏-上下线 | ||||
| export const updateEnabled = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyBagCollect/updateEnabled', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 收藏-保存 | ||||
| export const luckyBagCollectSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/luckyBagCollect/save', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // 收藏-导出 | ||||
| export const luckyBagCollectExport = query => { | ||||
|     window.location.href = `/admin/luckyBagCollect/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
							
								
								
									
										58
									
								
								src/api/medal/medal.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								src/api/medal/medal.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| // 地区接口 | ||||
| export const listPartitionInfo = query => { | ||||
|     return request({ | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章信息-列表 | ||||
| export const medalPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medal/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章信息-新增&保存 | ||||
| export const medalSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medal/save', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章信息-发放 | ||||
| export const medalSend = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medal/send', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章记录-撤销 | ||||
| export const rollback = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medalRecord/rollback', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章记录-列表 | ||||
| export const medalRecordPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medalRecord/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 勋章记录-勋章列表 | ||||
| export const listAll = query => { | ||||
|     return request({ | ||||
|         url: '/admin/medal/listAll', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										28
									
								
								src/api/miniGame/miniGameForBaiShun.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								src/api/miniGame/miniGameForBaiShun.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| export const miniGameForBaiShunPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/miniGame/baiShun/statis/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const miniGameForBaiShunDetailPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/miniGame/baiShun/statis/detailPage', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const miniGameForBaiShunExport = query => { | ||||
|     window.location.href = `/admin/miniGame/baiShun/statis/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
|  | ||||
| export const miniGameForBaiShunExportAll = query => { | ||||
|     window.location.href = `/admin/miniGame/baiShun/statis/exportForMiniGame?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
							
								
								
									
										9
									
								
								src/api/miniGame/miniGameForNav.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								src/api/miniGame/miniGameForNav.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| import request from '@/utils/request'; | ||||
|  | ||||
| export const miniGameForNavPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/miniGame/nav/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										263
									
								
								src/api/nobleman/nobleman.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										263
									
								
								src/api/nobleman/nobleman.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,263 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| // 分区接口 | ||||
| export const listPartitionInfo = query => { | ||||
|     return request({ | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 邀请移除记录 | ||||
| export const pageOperateRecord = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/pageOperateRecord', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 查询公会信息 | ||||
| export const pageFamily = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/pageFamily', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 公会成员信息 | ||||
| export const pageFamilyMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/pageFamilyMember', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 创建公会信息 | ||||
| export const create = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/create', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 删除公会信息 | ||||
| export const dismiss = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/dismiss', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 幸运礼物详情导出  | ||||
| export const luckyGiftRewardRecordExport = query => { | ||||
|     window.location.href = `/admin/luckyGiftRewardRecord/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 公会信息编辑接口 | ||||
| export const update = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/update', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 违规类型列表接口 | ||||
| export const pageFun = query => { | ||||
|     return request({ | ||||
|         url: '/admin/familyMember/violation/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 违规类型列表接口 | ||||
| export const listFun = query => { | ||||
|     return request({ | ||||
|         url: '/admin/familyMember/violation/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 违规类型添加接口 | ||||
| export const addFun = query => { | ||||
|     return request({ | ||||
|         url: '/admin/familyMember/violation/add', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 编辑 | ||||
| export const updateFun = query => { | ||||
|     return request({ | ||||
|         url: '/admin/familyMember/violation/update', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 删除 | ||||
| export const delFun = query => { | ||||
|     return request({ | ||||
|         url: '/admin/familyMember/violation/del', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 添加违规记录 | ||||
| export const addRecord = query => { | ||||
|     return request({ | ||||
|         url: '/admin/familyMember/violation/addRecord', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 保存收款账户 | ||||
| export const savePayAccount = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/savePayAccount', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 违规类查询 | ||||
| export const listRecord = query => { | ||||
|     return request({ | ||||
|         url: '/admin/familyMember/violation/listRecord', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 导出 | ||||
| export const exportFamilyMember = query => { | ||||
|     window.location.href = `/admin/family/manage/exportFamilyMember?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 导出-公会信息 | ||||
| export const exportInfo = query => { | ||||
|     window.location.href = `/admin/family/manage/exportFamily?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
|  | ||||
|  | ||||
| // 工资梯度-列表 | ||||
| export const manageList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工资梯度-新增 | ||||
| export const manageAdd = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/add', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工资梯度-删除 | ||||
| export const manageDelete = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/delete', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工会统计-列表 | ||||
| export const statPageFamily = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/wage/stat/pageFamily', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工会统计-单个工会详情 | ||||
| export const listFamilyMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/wage/stat/listFamilyMember', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工会统计-单个工会导出 | ||||
| export const statExportFamilyMember = query => { | ||||
|     window.location.href = `/admin/family/wage/stat/exportFamilyMember?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 工会统计-每日工会详情 | ||||
| export const listFamilyMemberDaily = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/wage/stat/listFamilyMemberDaily', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 工会统计-单每日会导出 | ||||
| export const exportFamilyMemberDaily = query => { | ||||
|     window.location.href = `/admin/family/wage/stat/exportFamilyMemberDaily?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 工会统计-导出公会工资统计 | ||||
| export const statExportFamily = query => { | ||||
|     window.location.href = `/admin/family/wage/stat/exportFamily?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 工会统计-导出家族流水 | ||||
| export const incomeExportFamilys = query => { | ||||
|     window.location.href = `/admin/family/income/exportFamily?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 金币流水-列表 | ||||
| export const incomePageFamily = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/income/pageFamily', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 金币流水-详情 | ||||
| export const incomeListFamilyMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/income/listFamilyMember', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 金币流水-导出成员流水信息 | ||||
| export const incomeExportFamily = query => { | ||||
|     window.location.href = `/admin/family/income/exportFamilyMember?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 成员信息-弹窗详情 | ||||
| export const manageListFamilyMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/listFamilyMember', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 成员信息-新增成员 | ||||
| export const addMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/addMember', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 成员信息-设置管理员 | ||||
| export const setManager = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/setManager', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 成员信息-删除管理员 | ||||
| export const removeMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/removeMember', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										103
									
								
								src/api/noblemanNew/noblemanNew.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								src/api/noblemanNew/noblemanNew.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,103 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| // 分区接口 | ||||
| export const listPartitionInfo = query => { | ||||
|     return request({ | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 邀请移除记录 | ||||
| export const pageOperateRecord = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/pageOperateRecord', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 查询公会信息 | ||||
| export const pageFamily = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/pageGuild', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 公会成员信息 | ||||
| export const pageFamilyMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/family/manage/pageFamilyMember', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 创建公会信息 | ||||
| export const create = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/create', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 删除公会信息 | ||||
| export const dismiss = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/dismiss', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 幸运礼物详情导出  | ||||
| export const luckyGiftRewardRecordExport = query => { | ||||
|     window.location.href = `/admin/luckyGiftRewardRecord/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 公会信息编辑接口 | ||||
| export const update = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/update', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 导出-公会信息 | ||||
| export const exportInfo = query => { | ||||
|     window.location.href = `/admin/guild/manage/exportGuild?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 成员信息-弹窗详情 | ||||
| export const manageListFamilyMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/listGuildMember', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 成员信息-新增成员 | ||||
| export const addMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/addMember', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 成员信息-设置管理员 | ||||
| export const setManager = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/setManager', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 成员信息-删除管理员 | ||||
| export const removeMember = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/manage/removeMember', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										18
									
								
								src/api/official/officialConfig.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								src/api/official/officialConfig.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| import request from '@/utils/request'; | ||||
|  | ||||
| export const getOfficialConfigList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/official/config/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const saveOfficialConfig = data => { | ||||
|     return request({ | ||||
|         url: '/admin/official/config/save', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: data | ||||
|     }); | ||||
| } | ||||
							
								
								
									
										9
									
								
								src/api/official/officialRecord.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								src/api/official/officialRecord.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| import request from '@/utils/request'; | ||||
|  | ||||
| export const browseFor30Days = query => { | ||||
|     return request({ | ||||
|         url: '/admin/official/browse/record/browseFor30Days', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										9
									
								
								src/api/partition/partitionInfo.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								src/api/partition/partitionInfo.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| import request from '@/utils/request'; | ||||
|  | ||||
| export const getPartitionInfoList = query => { | ||||
|     return request({ | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| @@ -0,0 +1,52 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 地区接口 | ||||
| export const listPartitionInfo = query => { | ||||
|     return request({ | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 个人主页资源管理列表 | ||||
| export const pesonalBackgroundListByPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/pesonalBackground/listByPage', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 个人主页资源管理赠送 | ||||
| export const pesonalBackgroundListSend = query => { | ||||
|     return request({ | ||||
|         url: '/admin/pesonalBackground/send', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 个人主页资源管理保存 | ||||
| export const pesonalBackgroundSaveOrUpdate = query => { | ||||
|     return request({ | ||||
|         url: '/admin/pesonalBackground/saveOrUpdate', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 个人主页记录管理&个人赠送记录 | ||||
| export const pesonalBackgroundListRecordByPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/pesonalBackground/listRecordByPage', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 个人赠送记录撤回 | ||||
| export const pesonalBackgroundListRecordRecoveryPersonalBackground = query => { | ||||
|     return request({ | ||||
|         url: '/admin/pesonalBackground/recoveryPersonalBackground', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										34
									
								
								src/api/refund/refund.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								src/api/refund/refund.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| // 活动配置 相关接口(一级菜单:活动配置) | ||||
|  | ||||
| // 分区接口 | ||||
| export const listPartitionInfo = query => { | ||||
|     return request({ | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 国家 | ||||
| export const regionInfoList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/regionInfo/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 列表 | ||||
| export const refundList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/chargeRecord/refundList', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 导出 | ||||
| export const refundExport = query => { | ||||
|     window.location.href = `/admin/chargeRecord/refundExport?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
							
								
								
									
										185
									
								
								src/api/relAgency/relAgency.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										185
									
								
								src/api/relAgency/relAgency.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,185 @@ | ||||
|  | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| // 活动配置 相关接口(一级菜单:活动配置) | ||||
|  | ||||
| // 分区接口 | ||||
| export const listPartitionInfo = query => { | ||||
|     return request({ | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 获取 周期列表 | ||||
| export const getDateCycleList = query => {  | ||||
|     return request({ | ||||
|         url: '/anchorSalaryBill/dateCycle/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 获取 公会钻石薪资流水统计 列表 | ||||
| export const getAgencyDiamondFlow = query => { | ||||
|     return request({ | ||||
|         url: '/agency/diamond/flow/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 公会钻石薪资流水统计 导出 | ||||
| // export const agencyDiamondFlowExport = query => { | ||||
| //     return request({ | ||||
| //         url: `/agency/diamond/flow/export`, | ||||
| //         method: 'post', | ||||
| //         params: query, | ||||
| //         responseType: 'blob' | ||||
| //     }); | ||||
| // }; | ||||
| export const agencyDiamondFlowExport = query => { | ||||
|     window.location.href = `/agency/diamond/flow/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
| // 主播薪资操作(不用分区) | ||||
| export const getAnchorSalaryBill = query => { | ||||
|     return request({ | ||||
|         url: '/anchorSalaryBill/anchorSummary/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // salaryType 1钻石兑换薪资明细 2 薪资转赠充值代理 明细 3薪资转增公会长明细 4官方提现 6 薪资兑换金币明细 | ||||
| export const anchorSalaryBillDetail = query => { | ||||
|     return request({ | ||||
|         url: '/anchorSalaryBill/detail/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 充值代理转增薪资  | ||||
| export const chargeAgentList = query => { | ||||
|     return request({ | ||||
|         url: '/anchorSalaryBill/chargeAgent/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 充值代理转增薪资 总值 | ||||
| export const chargeAgentSum = query => { | ||||
|     return request({ | ||||
|         url: '/anchorSalaryBill/chargeAgent/sum', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 官方提现记录 列表 | ||||
| export const agencyWithdrawList = query => { | ||||
|     return request({ | ||||
|         url: '/agencyWithdrawExamine/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 官方提现记录 导出 | ||||
| export const agencyWithdrawExamineExport = query => { | ||||
|     return request({ | ||||
|         url: `/agencyWithdrawExamine/export`, | ||||
|         method: 'post', | ||||
|         params: query, | ||||
|         responseType: 'blob' | ||||
|     }); | ||||
| }; | ||||
| // 官方提现记录 结算 | ||||
| // export const agencyWithdrawSet = query => { | ||||
| //     return request({ | ||||
| //         url: '/agencyWithdrawExamine/settle', | ||||
| //         method: 'post', | ||||
| //         params: query | ||||
| //     }); | ||||
| // }; | ||||
| export const agencyWithdrawSet = query => { | ||||
|     return request({ | ||||
|         url: '/agencyWithdrawExamine/batchSettle', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 官方提现记录 批量结算 | ||||
| export const agencyWithdrawBatchSet = query => { | ||||
|     return request({ | ||||
|         url: '/agencyWithdrawExamine/batchSettle', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 官方提现记录 批量驳回 | ||||
| export const batchReject = query => { | ||||
|     return request({ | ||||
|         url: '/agencyWithdrawExamine/batchReject', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 公会开业数据统计 | ||||
| export const agencyOpenList = query => { | ||||
|     return request({ | ||||
|         url: '/agency/open/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 公会开业数据 详情 | ||||
| export const agencyOpenDetail = query => { | ||||
|     return request({ | ||||
|         url: '/agency/open/detail/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 公会优秀主播数据统计 | ||||
| export const excellentAnchorList = query => { | ||||
|     return request({ | ||||
|         url: '/agency/open/excellentAnchor/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 公会优秀主播数据统计 | ||||
| export const excellentAnchorDetail = query => { | ||||
|     return request({ | ||||
|         url: '/agency/open/excellentAnchor/detail/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 官方提现-国家 | ||||
| export const adminCountry = query => { | ||||
|     return request({ | ||||
|         url: '/admin/country/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // =====================================钻石充值流水======================================= | ||||
| // 查询 | ||||
| export const diamondStatistics = query => { | ||||
|     return request({ | ||||
|         url: '/admin/guild/diamondStatistics', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| //  导出 | ||||
| export const diamondStatisticsExport = query => { | ||||
|     window.location.href = `/admin/guild/diamondStatistics/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
							
								
								
									
										43
									
								
								src/api/relPrivilegeManage/relPrivilegeManage.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								src/api/relPrivilegeManage/relPrivilegeManage.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
| // 靓号申请管理 列表 | ||||
| export const getPrettyNumberExamineList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/prettyNumber/examine/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 靓号申请管理 通过 | ||||
| export const prettyNumberExaminePass = query => { | ||||
|     return request({ | ||||
|         url: '/admin/prettyNumber/examine/pass', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     });  | ||||
| }; | ||||
| // 靓号申请管理 删除 | ||||
| export const prettyNumberExamineDelete = query => { | ||||
|     return request({ | ||||
|         url: '/admin/prettyNumber/examine/delete', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 靓号申请管理 拒绝 | ||||
| export const prettyNumberExamineReject = query => { | ||||
|     return request({ | ||||
|         url: '/admin/prettyNumber/examine/reject', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 靓号导入 | ||||
| export const erbanUpload = query => { | ||||
|     return request({ | ||||
|         url: '/admin/prettyNumber/upload', | ||||
|         method: 'post', | ||||
|         headers: { 'Content-Type': 'multipart/form-data' }, | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										104
									
								
								src/api/relUserBelongings/relUserBelongings.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								src/api/relUserBelongings/relUserBelongings.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,104 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 用户财产 相关接口(一级菜单:用户财产管理) | ||||
|  | ||||
| // 获取 金币转赠历史列表 | ||||
| export const getGoldCoinTransferList = query => { | ||||
|     return request({ | ||||
|         url: '/gold/give/history', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 获取 金币转赠历史 金币汇总 | ||||
| export const getGoldCoinSumGold = query => { | ||||
|     return request({ | ||||
|         url: '/gold/give/history/sumGold', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
|  | ||||
| // 用户资产排行 列表 | ||||
| export const getUserAssetsList = query => { | ||||
|     return request({ | ||||
|         url: '/userAssets/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 用户资产排行 导出 | ||||
| export const userAssetsExport = query => { | ||||
|     return request({ | ||||
|         url: '/userAssets/export', | ||||
|         method: 'get', | ||||
|         params: query, | ||||
|         responseType: 'blob' | ||||
|     }); | ||||
| }; | ||||
| // 金币钻石操作记录 列表 | ||||
| export const officalGoldSearch = query => { | ||||
|     return request({ | ||||
|         url: '/offical/gold/search', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 金币钻石操作记录 导出 | ||||
| export const officalGoldExport = query => { | ||||
|     return request({ | ||||
|         url: '/offical/gold/export', | ||||
|         method: 'get', | ||||
|         params: query, | ||||
|         responseType: 'blob' | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 操作货币增加/减少 列表  | ||||
| export const officalGoldGive= query => { | ||||
|     return request({ | ||||
|         url: '/offical/gold/give', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|         // data: qs.stringify(query) | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 操作货币增加/减少 查看用户 | ||||
| export const getofficalGoldUserInfo = query => { | ||||
|     return request({ | ||||
|         url: '/offical/gold/userInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // 冻结用户资产管理 列表 | ||||
| export const getFrozenRecordList = query => { | ||||
|     return request({ | ||||
|         url: '/frozenRecord/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 冻结用户资产管理 冻结 | ||||
| export const userRecordFrozen= query => { | ||||
|     return request({ | ||||
|         url: '/frozenRecord/frozen', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 冻结用户资产管理 解冻 | ||||
| export const frozenRecordFree= query => { | ||||
|     return request({ | ||||
|         url: '/frozenRecord/free', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										34
									
								
								src/api/resource/resource.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								src/api/resource/resource.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| import request from '@/utils/request'; | ||||
|  | ||||
| export const getResourcePage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/resource/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const delResource = query => { | ||||
|     return request({ | ||||
|         url: '/admin/resource/del', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const effective = query => { | ||||
|     return request({ | ||||
|         url: '/admin/resource/effective', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const saveResource = data => { | ||||
|     return request({ | ||||
|         url: '/admin/resource/save', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: data | ||||
|     }); | ||||
| } | ||||
							
								
								
									
										9
									
								
								src/api/resource/resourceRule.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								src/api/resource/resourceRule.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| import request from '@/utils/request'; | ||||
|  | ||||
| export const getResourceRuleList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/resource/rule/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										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 | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										76
									
								
								src/api/roomAlbumPower/roomAlbumPower.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								src/api/roomAlbumPower/roomAlbumPower.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,76 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 获取房间权限列表 | ||||
| export const albumPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/album/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 房间相册管理权限分页列表 | ||||
| export const userPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/album/userPage', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 删除权限 | ||||
| export const delUserRoomAlbum = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/album/delUserRoomAlbum', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 删除房间权限 | ||||
| export const delRoomAlbum = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/album/delRoomAlbum', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 清空该房间相册 | ||||
| export const clearRoomAlbum = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/album/clearRoomAlbum', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 增加房间权限接口 | ||||
| export const albumSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/album/save', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 保存房间相册管理权限 | ||||
| export const saveManager = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/album/saveManager', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // =========图片管理============ | ||||
| // 分页列表 | ||||
| export const photoPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/photo/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 删除照片 | ||||
| export const photoDel = query => { | ||||
|     return request({ | ||||
|         url: '/admin/room/photo/del', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										87
									
								
								src/api/roomBackground/roomBackground.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								src/api/roomBackground/roomBackground.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 地区接口 | ||||
| export const listPartitionInfo = query => { | ||||
|     return request({ | ||||
|         url: '/partition/listPartitionInfo', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // ==============================================首页ui配置============================================== | ||||
| // 配置 | ||||
| export const appUiSetting = query => { | ||||
|     return request({ | ||||
|         url: '/appUiSetting', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 保存 | ||||
| export const appUiSettingSave = query => { | ||||
|     return request({ | ||||
|         url: '/appUiSetting/save', | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // ==============================================自定义背景============================================== | ||||
| // 列表 | ||||
| export const page = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 新增 | ||||
| export const roomBackgroundAdd = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/add', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 编辑 | ||||
| export const roomBackgroundUpdate = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/update', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // ==============================================自定义背景============================================== | ||||
| // 列表 | ||||
| export const customPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/custom/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 通过 | ||||
| export const customPass = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/custom/pass', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 拒绝 | ||||
| export const customReject = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/custom/reject', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 删除 | ||||
| export const customDel = query => { | ||||
|     return request({ | ||||
|         url: '/admin/roomBackground/custom/del', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										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 | ||||
|     }); | ||||
| }; | ||||
							
								
								
									
										17
									
								
								src/api/system/i18nMessage.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								src/api/system/i18nMessage.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| import request from "@/utils/request"; | ||||
|  | ||||
| export function getI18nMessageList() { | ||||
|     return request({ | ||||
|         url: '/admin/i18nMessage/list', | ||||
|         method: 'get' | ||||
|     }); | ||||
| } | ||||
|  | ||||
| export function saveI18nMessage(data) { | ||||
|     return request({ | ||||
|         url: '/admin/i18nMessage/save', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: data | ||||
|     }); | ||||
| } | ||||
| @@ -5,4 +5,12 @@ export function getSysConfList() { | ||||
|         url: '/admin/sysConf/getList', | ||||
|         method: 'get' | ||||
|     }); | ||||
| } | ||||
|  | ||||
| export const getConfigValueByKey = query => { | ||||
|     return request({ | ||||
|         url: '/admin/sysConf/key', | ||||
|         method: 'get', | ||||
|         params: query, | ||||
|     }); | ||||
| } | ||||
							
								
								
									
										27
									
								
								src/api/transferIdentitySet/transferIdentitySet.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								src/api/transferIdentitySet/transferIdentitySet.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
|  | ||||
| // 获取列表 | ||||
| export const userPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/give/user/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 新增 | ||||
| export const userSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/give/user/save', | ||||
|         method: 'post', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 删除 | ||||
| export const batchDel = query => { | ||||
|     return request({ | ||||
|         url: '/admin/give/user/batchDel', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| @@ -8,3 +8,30 @@ export const savePoolItem = query => { | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| //发布 | ||||
| export const deployPoolItem = query => { | ||||
|     return request({ | ||||
|         url: '/admin/seize-treasure/pool/item/deploy', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| //已发布奖池 | ||||
| export const deployedPoolItem = query => { | ||||
|     return request({ | ||||
|         url: '/admin/seize-treasure/pool/item/deployed', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| //统计 | ||||
| export const showPoolItemCount = query => { | ||||
|     return request({ | ||||
|         url: '/admin/seize-treasure/pool/item/count', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| } | ||||
							
								
								
									
										76
									
								
								src/api/wishingStar/wishingStar.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								src/api/wishingStar/wishingStar.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,76 @@ | ||||
| import request from '@/utils/request'; | ||||
| import qs from 'qs'; | ||||
| import { genQueryParam } from '@/utils/maintainer'; | ||||
|  | ||||
| // ==================================许愿礼物配置==================================== | ||||
| // 表单 | ||||
| export const promiseStarConfigList = query => { | ||||
|     return request({ | ||||
|         url: '/admin/promiseStarConfig/list', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 新增弹窗列表数据 | ||||
| export const giftGetAll = query => { | ||||
|     return request({ | ||||
|         url: '/admin/gift/getAll', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| // 新增 | ||||
| export const promiseStarConfigSave = query => { | ||||
|     return request({ | ||||
|         url: '/admin/promiseStarConfig/save', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
| // 下线 | ||||
| export const promiseStarConfigUpdateEnable = query => { | ||||
|     return request({ | ||||
|         url: '/admin/promiseStarConfig/updateEnable', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const promiseStarRoundPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/promiseStarRound/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| export const promiseStarUserRecordGetPromiseUsers = query => { | ||||
|     return request({ | ||||
|         url: '/admin/promiseStarUserRecord/getPromiseUsers', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     });  | ||||
| }; | ||||
|  | ||||
| export const promiseStarUserRecordSetUserWhite = query => { | ||||
|     return request({ | ||||
|         url: '/admin/promiseStarUserRecord/setUserWhite', | ||||
|         headers:{"Content-Type": 'application/x-www-form-urlencoded'}, | ||||
|         method: 'post', | ||||
|         data: query | ||||
|     });  | ||||
| }; | ||||
|  | ||||
| export const promiseStarUserRecordPage = query => { | ||||
|     return request({ | ||||
|         url: '/admin/promiseStarUserRecord/page', | ||||
|         method: 'get', | ||||
|         params: query | ||||
|     }); | ||||
| }; | ||||
| export const promiseStarUserRecordExport = query => { | ||||
|     window.location.href = `/admin/promiseStarUserRecord/export?${genQueryParam(query)}`; | ||||
|     return; | ||||
| }; | ||||
							
								
								
									
										
											BIN
										
									
								
								src/assets/images/zs.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/assets/images/zs.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 2.6 KiB | 
| @@ -29,26 +29,34 @@ export default { | ||||
|         } | ||||
|     }, | ||||
|     // 构建下拉组合框 | ||||
|     build: function (url, idstr, defval) { | ||||
|     build: function (val, idstr, defval) { | ||||
|         var _this = this; | ||||
|         if (url) { | ||||
|             $.ajax({ | ||||
|                 type: 'post', | ||||
|                 url: url, | ||||
|                 dataType: 'json', | ||||
|                 success: function (json) { | ||||
|                     $(idstr).empty(); | ||||
|                     $.each(json, function (n, value) { | ||||
|                         $(idstr).append("<option value='" + value.oval + "' data-value='" + value.oval + "'>" + value.otxt + "</option>"); | ||||
|                     }); | ||||
|                     $(idstr).btComboBox(); | ||||
|                     _this.setDef(idstr, defval); | ||||
|                 } | ||||
|             }); | ||||
|         if (val) { | ||||
|             if (Object.prototype.toString.call(val) === '[object Array]') { | ||||
|                 $(idstr).empty(); | ||||
|                 $.each(val, function (n, obj) { | ||||
|                     $(idstr).append("<option value='" + obj.value + "' data-value='" + obj.value + "'>" + obj.text + "</option>"); | ||||
|                 }); | ||||
|                 $(idstr).btComboBox(); | ||||
|                 _this.setDef(idstr, defval); | ||||
|             } else { | ||||
|                 $.ajax({ | ||||
|                     type: 'post', | ||||
|                     url: val, | ||||
|                     dataType: 'json', | ||||
|                     success: function (json) { | ||||
|                         $(idstr).empty(); | ||||
|                         $.each(json, function (n, value) { | ||||
|                             $(idstr).append("<option value='" + value.oval + "' data-value='" + value.oval + "'>" + value.otxt + "</option>"); | ||||
|                         }); | ||||
|                         $(idstr).btComboBox(); | ||||
|                         _this.setDef(idstr, defval); | ||||
|                     } | ||||
|                 }); | ||||
|             } | ||||
|         } else { | ||||
|             $(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; | ||||
| } | ||||
							
								
								
									
										2842
									
								
								src/assets/plugins/bootstrap-table/js/bootstrap-table.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2842
									
								
								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); | ||||
| })); | ||||
|  | ||||
							
								
								
									
										98
									
								
								src/components/common/TablePagination.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								src/components/common/TablePagination.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,98 @@ | ||||
| <template> | ||||
|     <div class="pagination"> | ||||
|         <el-pagination | ||||
|             background | ||||
|             :layout="paginationLayout" | ||||
|             :current-page="pageParams.pageNo" | ||||
|             :page-size="pageParams.pageSize" | ||||
|             :page-sizes="pageSizes" | ||||
|             :total="pageTotal" | ||||
|             :pager-count="pagerCount" | ||||
|             @size-change="handleSizeChange" | ||||
|             @current-change="handlePageChange" | ||||
|         ></el-pagination> | ||||
|     </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     props: { | ||||
|         pageParams: { | ||||
|             type: Object, | ||||
|             default: () => {} | ||||
|         }, | ||||
|         pageSizes: { | ||||
|             type: Array, | ||||
|             default: function () { | ||||
|                 return [5, 10, 20, 30, 40, 50, 100]; | ||||
|             } | ||||
|         }, | ||||
|         // pagerCount: { | ||||
|         //     type: Number, | ||||
|         //     default: 5 | ||||
|         // }, | ||||
|         pageTotal: { | ||||
|             type: Number, | ||||
|             default: 0 | ||||
|         }, | ||||
|         ifShowTotal: { | ||||
|             type: Boolean, | ||||
|             default: true | ||||
|         }, | ||||
|         ifShowSizes: { | ||||
|             type: Boolean, | ||||
|             default: true | ||||
|         }, | ||||
|         ifShowPrev: { | ||||
|             type: Boolean, | ||||
|             default: true | ||||
|         }, | ||||
|         ifShowPager: { | ||||
|             type: Boolean, | ||||
|             default: true | ||||
|         }, | ||||
|         ifShowNext: { | ||||
|             type: Boolean, | ||||
|             default: true | ||||
|         }, | ||||
|         ifShowJumper: { | ||||
|             type: Boolean, | ||||
|             default: false | ||||
|         } | ||||
|     }, | ||||
|     data() { | ||||
|         return { | ||||
|             pagerCount: 5 | ||||
|         }; | ||||
|     }, | ||||
|     methods: { | ||||
|         handleSizeChange(val) { | ||||
|             this.$emit('handleSizeChange', val); | ||||
|         }, | ||||
|         handlePageChange(val) { | ||||
|             this.$emit('handlePageChange', val); | ||||
|         }, | ||||
|         handleResize() { | ||||
|             if (window.innerWidth > 768) { | ||||
|                 this.pagerCount = 5; | ||||
|             } else { | ||||
|                 this.pagerCount = 2; | ||||
|             } | ||||
|         } | ||||
|     }, | ||||
|     mounted() { | ||||
|         this.handleResize(); // 初始化宽度 | ||||
|     }, | ||||
|     computed: { | ||||
|         paginationLayout() { | ||||
|             const layoutStr = ['total', 'sizes', 'prev', 'pager', 'next', 'jumper']; | ||||
|             const { ifShowTotal, ifShowSizes, ifShowPrev, ifShowPager, ifShowNext, ifShowJumper } = this; | ||||
|             let layoutWantedToBeShowed = []; | ||||
|             [ifShowTotal, ifShowSizes, ifShowPrev, ifShowPager, ifShowNext, ifShowJumper].forEach((item, index) => { | ||||
|                 if (item) layoutWantedToBeShowed.push(index); | ||||
|             }); | ||||
|             return layoutWantedToBeShowed.map((item) => layoutStr[item]).join(','); | ||||
|         } | ||||
|     } | ||||
| }; | ||||
| </script> | ||||
| @@ -3,7 +3,7 @@ | ||||
|         <div class="pull-right hidden-xs"> | ||||
|             <b>Version</b> 2.0.0 | ||||
|         </div> | ||||
|         <strong>Copyright © 2023 <a href="">触海网络</a>.</strong> All rights | ||||
|         <strong>Copyright © 2024 <a href="">触海网络</a>.</strong> All rights | ||||
|         reserved. | ||||
|     </footer> | ||||
| </template> | ||||
| @@ -16,5 +16,4 @@ export default { | ||||
| } | ||||
| </script> | ||||
|    | ||||
| <style scoped> | ||||
| </style> | ||||
| <style scoped></style> | ||||
| @@ -4,9 +4,9 @@ | ||||
|         <!-- Logo --> | ||||
|         <a class="logo"> | ||||
|             <!-- mini logo for sidebar mini 50x50 pixels --> | ||||
|             <span class="logo-mini"><b>P</b>K</span> | ||||
|             <span class="logo-mini"><b>M</b>S</span> | ||||
|             <!-- logo for regular state and mobile devices --> | ||||
|             <span class="logo-lg"><b>piko</b>管理系统</span> | ||||
|             <span class="logo-lg"><b>molistar</b>管理系统</span> | ||||
|         </a> | ||||
|         <!-- Header Navbar: style can be found in header.less --> | ||||
|         <nav class="navbar navbar-static-top" role="navigation"> | ||||
|   | ||||
| @@ -1,176 +1,253 @@ | ||||
| <template> | ||||
|     <!-- Left side column. contains the logo and sidebar --> | ||||
|     <aside class="main-sidebar" style="height: 100%; overflow: hidden; overflow: scroll;"> | ||||
|         <!-- sidebar: style can be found in sidebar.less --> | ||||
|         <section class="sidebar"> | ||||
|             <!-- Sidebar user panel (optional) --> | ||||
|             <div class="user-panel"> | ||||
|                 <div class="pull-left image"> | ||||
|                     <img :src="avatar" class="img-circle" :alt="username"> | ||||
|                 </div> | ||||
|                 <div class="pull-left info"> | ||||
|                     <p>{{ username }}</p> | ||||
|                     <!-- Status --> | ||||
|                     <a href="#"><i class="fa fa-circle text-success"></i> Online</a> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <!-- search form (Optional) --> | ||||
|             <form method="get" class="sidebar-form" onsubmit="return false;"> | ||||
|                 <div class="input-group"> | ||||
|                     <input type="text" name="q" class="form-control" placeholder="Search..." @input="search"> | ||||
|                     <span class="input-group-btn"> | ||||
|                         <button name="search" id="search-btn" class="btn btn-flat" @click="search"> | ||||
|                             <i class="fa fa-search"></i> | ||||
|                         </button> | ||||
|                     </span> | ||||
|                 </div> | ||||
|             </form> | ||||
|             <!-- /.search form --> | ||||
|             <!-- Sidebar Menu --> | ||||
|             <ul class="sidebar-menu"> | ||||
|                 <li class="header">主导航</li> | ||||
|                 <!-- Optionally, you can add icons to the links --> | ||||
|                 <li v-for="(parent, parentIndex) in parentMenus" :key="parent" :data-index="parentIndex" class="treeview"> | ||||
|                     <a> | ||||
|                         <i :class="[parent.icon ? parent.icon : 'fa fa-link']"></i> | ||||
|                         <span>{{ parent.name }}</span> | ||||
|                         <span class="label pull-right bg-yellow" :id="['ic' + parent.id]"> | ||||
|                             {{ getChildLength(parent.id) }} | ||||
|                         </span> | ||||
|                     </a> | ||||
|                     <ul class="treeview-menu" :id="['menu' + parent.id]"> | ||||
|                         <li v-for="(child, childIndex) in getChilds(parent.id)" :key="child" :data-index="childIndex"> | ||||
|                             <a :data-url="child.path" @click="handleClick(child)"> | ||||
|                                 <i | ||||
|                                     :class="[child.icon && child.icon != '' ? child.icon : 'fa fa-circle-o text-yellow']"></i> | ||||
|                                 <span>{{ child.name }}</span> | ||||
|                             </a> | ||||
|                         </li> | ||||
|                     </ul> | ||||
|                 </li> | ||||
|             </ul> | ||||
|             <!-- /.sidebar-menu --> | ||||
|         </section> | ||||
|         <!-- /.sidebar --> | ||||
|     </aside> | ||||
|     <!-- Content Wrapper. Contains page content --> | ||||
|     <div class="content-wrapper" style="height: 100%;"> | ||||
|         <!-- Content Header (Page header) --> | ||||
|         <section class="content-header" | ||||
|             :style="[childMenu.name && childMenu.name != '' ? 'display:block;' : 'display:none;']"> | ||||
|             <h1> | ||||
|                 {{ childMenu.name }} | ||||
|                 <small>{{ childMenu.description }}</small> | ||||
|             </h1> | ||||
|             <ol class="breadcrumb"> | ||||
|                 <li><a href="#"><i class="fa fa-dashboard"></i> {{ childMenu.parentName }}</a></li> | ||||
|                 <li class="active">{{ childMenu.name }}</li> | ||||
|             </ol> | ||||
|         </section> | ||||
|         <!-- Main content --> | ||||
|         <section class="content" style="height: 100%; overflow: hidden; overflow: scroll;"> | ||||
|             <!-- Your Page Content Here --> | ||||
|             <component :is="componentName"></component> | ||||
|         </section> | ||||
|         <!-- /.content --> | ||||
|     </div> | ||||
|     <!-- /.content-wrapper --> | ||||
|     <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> | ||||
|   <!-- Left side column. contains the logo and sidebar --> | ||||
|   <aside | ||||
|     class="main-sidebar" | ||||
|     style="height: 100%; overflow: hidden; overflow: scroll" | ||||
|   > | ||||
|     <!-- sidebar: style can be found in sidebar.less --> | ||||
|     <section class="sidebar"> | ||||
|       <!-- Sidebar user panel (optional) --> | ||||
|       <div class="user-panel"> | ||||
|         <div class="pull-left image"> | ||||
|           <img :src="avatar" class="img-circle" :alt="username" /> | ||||
|         </div> | ||||
|     </div> | ||||
|     <div class="modal fade" id="confirmModal" tabindex="-1" role="dialog" aria-labelledby="modalLabel" | ||||
|          data-backdrop="static"> | ||||
|         <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="confirmMsg"></div> | ||||
|             </div> | ||||
|         <div class="pull-left info"> | ||||
|           <p>{{ username }}</p> | ||||
|           <!-- Status --> | ||||
|           <a href="#"><i class="fa fa-circle text-success"></i> Online</a> | ||||
|         </div> | ||||
|       </div> | ||||
|       <!-- search form (Optional) --> | ||||
|       <form method="get" class="sidebar-form" onsubmit="return false;"> | ||||
|         <div class="input-group"> | ||||
|           <input | ||||
|             type="text" | ||||
|             name="q" | ||||
|             class="form-control" | ||||
|             placeholder="Search..." | ||||
|             @input="search" | ||||
|           /> | ||||
|           <span class="input-group-btn"> | ||||
|             <button | ||||
|               name="search" | ||||
|               id="search-btn" | ||||
|               class="btn btn-flat" | ||||
|               @click="search" | ||||
|             > | ||||
|               <i class="fa fa-search"></i> | ||||
|             </button> | ||||
|           </span> | ||||
|         </div> | ||||
|       </form> | ||||
|       <!-- /.search form --> | ||||
|       <!-- Sidebar Menu --> | ||||
|       <ul class="sidebar-menu"> | ||||
|         <li class="header">主导航</li> | ||||
|         <!-- Optionally, you can add icons to the links --> | ||||
|         <li | ||||
|           v-for="(parent, parentIndex) in parentMenus" | ||||
|           :key="parent" | ||||
|           :data-index="parentIndex" | ||||
|           class="treeview" | ||||
|         > | ||||
|           <a> | ||||
|             <i :class="[parent.icon ? parent.icon : 'fa fa-link']"></i> | ||||
|             <span>{{ parent.name }}</span> | ||||
|             <span class="label pull-right bg-yellow" :id="['ic' + parent.id]"> | ||||
|               {{ getChildLength(parent.id) }} | ||||
|             </span> | ||||
|           </a> | ||||
|           <ul class="treeview-menu" :id="['menu' + parent.id]"> | ||||
|             <li | ||||
|               v-for="(child, childIndex) in getChilds(parent.id)" | ||||
|               :key="child" | ||||
|               :data-index="childIndex" | ||||
|             > | ||||
|               <a :data-url="child.path" @click="handleClick(child)"> | ||||
|                 <i | ||||
|                   :class="[ | ||||
|                     child.icon && child.icon != '' | ||||
|                       ? child.icon | ||||
|                       : 'fa fa-circle-o text-yellow', | ||||
|                   ]" | ||||
|                 ></i> | ||||
|                 <span>{{ child.name }}</span> | ||||
|               </a> | ||||
|             </li> | ||||
|           </ul> | ||||
|         </li> | ||||
|       </ul> | ||||
|       <!-- /.sidebar-menu --> | ||||
|     </section> | ||||
|     <!-- /.sidebar --> | ||||
|   </aside> | ||||
|   <!-- Content Wrapper. Contains page content --> | ||||
|   <div class="content-wrapper" style="height: 100%"> | ||||
|     <!-- Content Header (Page header) --> | ||||
|     <section | ||||
|       class="content-header" | ||||
|       :style="[ | ||||
|         childMenu.name && childMenu.name != '' | ||||
|           ? 'display:block;' | ||||
|           : 'display:none;', | ||||
|       ]" | ||||
|     > | ||||
|       <h1> | ||||
|         {{ childMenu.name }} | ||||
|         <small>{{ childMenu.description }}</small> | ||||
|       </h1> | ||||
|       <ol class="breadcrumb"> | ||||
|         <li> | ||||
|           <a href="#" | ||||
|             ><i class="fa fa-dashboard"></i> {{ childMenu.parentName }}</a | ||||
|           > | ||||
|         </li> | ||||
|         <li class="active">{{ childMenu.name }}</li> | ||||
|       </ol> | ||||
|     </section> | ||||
|     <!-- Main content --> | ||||
|     <section class="content"> | ||||
|       <!-- <section class="content" style="height: 100%; overflow: hidden; overflow: scroll;"> --> | ||||
|       <!-- Your Page Content Here --> | ||||
|       <component :is="componentName"></component> | ||||
|     </section> | ||||
|     <!-- /.content --> | ||||
|   </div> | ||||
|   <!-- /.content-wrapper --> | ||||
|   <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> | ||||
|     </div> | ||||
|     <div class="modal fade loading" style="background: #00000040;" tabindex="-1" role="dialog" | ||||
|          aria-labelledby="loadingModalLabel" aria-hidden="true" data-backdrop="static" data-keyboard="false"> | ||||
|         <div class="loadingGif" style="position: fixed;"><img :src="loading"></div> | ||||
|   </div> | ||||
|   <div | ||||
|     class="modal fade" | ||||
|     id="confirmModal" | ||||
|     tabindex="-1" | ||||
|     role="dialog" | ||||
|     aria-labelledby="modalLabel" | ||||
|     data-backdrop="static" | ||||
|   > | ||||
|     <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="confirmMsg"></div> | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
|   <div | ||||
|     class="modal fade loading" | ||||
|     style="background: #00000040" | ||||
|     tabindex="-1" | ||||
|     role="dialog" | ||||
|     aria-labelledby="loadingModalLabel" | ||||
|     aria-hidden="true" | ||||
|     data-backdrop="static" | ||||
|     data-keyboard="false" | ||||
|   > | ||||
|     <div class="loadingGif" style="position: fixed; left: 50%; top: 50%"> | ||||
|       <img | ||||
|         src="https://img.zcool.cn/community/0111345d94b0b8a801211d53cbd04d.gif" | ||||
|         style="width: 10%" | ||||
|       /> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|    | ||||
| <script> | ||||
| import store from '@/store'; | ||||
| import loading from '@/assets/images/loading.gif'; | ||||
| import store from "@/store"; | ||||
| import Vue from "vue"; | ||||
| import { getStore } from "@/utils/store"; | ||||
|  | ||||
| export default { | ||||
|     name: 'MaintainerView', | ||||
|     data() { | ||||
|         return { | ||||
|             componentName: "", | ||||
|             username: "", | ||||
|             avatar: "", | ||||
|             parentMenus: [], | ||||
|             childMenus: [], | ||||
|             childMenu: { | ||||
|                 name: "", | ||||
|                 parentName: "", | ||||
|                 description: "", | ||||
|             } | ||||
|         }; | ||||
|   name: "MaintainerView", | ||||
|   data() { | ||||
|     return { | ||||
|       componentName: "", | ||||
|       username: "", | ||||
|       avatar: "", | ||||
|       parentMenus: [], | ||||
|       childMenus: [], | ||||
|       childMenu: { | ||||
|         name: "", | ||||
|         parentName: "", | ||||
|         description: "", | ||||
|       }, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getMenu(); | ||||
|     this.username = store.getters.username; | ||||
|     this.avatar = store.getters.avatar; | ||||
|   }, | ||||
|   methods: { | ||||
|     getMenu() { | ||||
|       this.parentMenus = getStore({ name: "parent_menus" }); | ||||
|       this.childMenus = getStore({ name: "child_menus" }); | ||||
|       store.dispatch("getMenu").then((res) => { | ||||
|         this.parentMenus = res.parents; | ||||
|         this.childMenus = res.childs; | ||||
|       }); | ||||
|     }, | ||||
|     created() { | ||||
|         this.getMenu(); | ||||
|         this.username = store.getters.username; | ||||
|         this.avatar = store.getters.avatar; | ||||
|     getChilds(parentId) { | ||||
|       return this.childMenus.filter((v) => v.parentid == parentId); | ||||
|     }, | ||||
|     methods: { | ||||
|         getMenu() { | ||||
|             store.dispatch('getMenu').then(res => { | ||||
|                 this.parentMenus = res.parents; | ||||
|                 this.childMenus = res.childs; | ||||
|             }); | ||||
|         }, | ||||
|         getChilds(parentId) { | ||||
|             return this.childMenus.filter(v => v.parentid == parentId); | ||||
|         }, | ||||
|         getChildLength(parentId) { | ||||
|             return this.childMenus.filter(v => v.parentid == parentId).length; | ||||
|         }, | ||||
|         handleClick(menu) { | ||||
|             this.childMenu.name = menu.name; | ||||
|             this.childMenu.parentName = menu.parentstr; | ||||
|             this.childMenu.description = menu.description; | ||||
|             store.dispatch('getViewComponent', menu.path).then(componentName => { | ||||
|                 console.log(componentName); | ||||
|                 this.componentName = componentName; | ||||
|             }); | ||||
|         }, | ||||
|         search() { | ||||
|             let text = $("input[type='text']").val(); | ||||
|             this.childMenus = store.getters.childMenus.filter(v => v.name.indexOf(text) >= 0); | ||||
|             if (!this.childMenus.length || this.childMenus.length == 0) { | ||||
|                 this.parentMenus = store.getters.parentMenus.filter(v => v.name.indexOf(text) >= 0); | ||||
|             } else { | ||||
|                 let parentIds = this.childMenus.map(v => v.parentid); | ||||
|                 let parentMenus = store.getters.parentMenus.filter(v => v.name.indexOf(text) >= 0); | ||||
|                 if (parentMenus && parentMenus.length > 0) { | ||||
|                     parentMenus.forEach(v => { | ||||
|                         parentIds.push(v.id); | ||||
|                     }); | ||||
|                 } | ||||
|                 console.log(parentIds); | ||||
|                 this.parentMenus = store.getters.parentMenus.filter(v1 => parentIds.filter(v2 => v1.id == v2).length > 0); | ||||
|                 this.childMenus = store.getters.childMenus.filter(v1 => parentIds.filter(v2 => v1.parentid == v2).length > 0); | ||||
|             } | ||||
|     getChildLength(parentId) { | ||||
|       return this.childMenus.filter((v) => v.parentid == parentId).length; | ||||
|     }, | ||||
|     handleClick(menu) { | ||||
|       this.childMenu.name = menu.name; | ||||
|       this.childMenu.parentName = menu.parentstr; | ||||
|       this.childMenu.description = menu.description; | ||||
|       store.dispatch("getViewComponent", menu.path).then((componentName) => { | ||||
|         this.componentName = componentName; | ||||
|         const files = require.context("@/views", true, /\.vue$/); | ||||
|         let components = {}; | ||||
|         files.keys().forEach((key) => { | ||||
|           components[key.replace(/(\.\/|\.vue)/g, "")] = files(key).default; | ||||
|         }); | ||||
|       }); | ||||
|     }, | ||||
|     search() { | ||||
|       let text = $("input[type='text']").val(); | ||||
|       this.childMenus = store.getters.childMenus.filter( | ||||
|         (v) => v.name.indexOf(text) >= 0 | ||||
|       ); | ||||
|       if (!this.childMenus.length || this.childMenus.length == 0) { | ||||
|         this.parentMenus = store.getters.parentMenus.filter( | ||||
|           (v) => v.name.indexOf(text) >= 0 | ||||
|         ); | ||||
|       } else { | ||||
|         let parentIds = this.childMenus.map((v) => v.parentid); | ||||
|         let parentMenus = store.getters.parentMenus.filter( | ||||
|           (v) => v.name.indexOf(text) >= 0 | ||||
|         ); | ||||
|         if (parentMenus && parentMenus.length > 0) { | ||||
|           parentMenus.forEach((v) => { | ||||
|             parentIds.push(v.id); | ||||
|           }); | ||||
|         } | ||||
|         this.parentMenus = store.getters.parentMenus.filter( | ||||
|           (v1) => parentIds.filter((v2) => v1.id == v2).length > 0 | ||||
|         ); | ||||
|       } | ||||
|     }, | ||||
| } | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
|    | ||||
| <style scoped> | ||||
| @import '@/css/main.css'; | ||||
| @import "@/css/main.css"; | ||||
| </style> | ||||
| @@ -1,8 +1,8 @@ | ||||
| export default { | ||||
|     KEY: "piko", | ||||
|     EXCLUDES: [ | ||||
|         "/login/login.action", | ||||
|         "/login/sendSmsCode.action", | ||||
|         "/login/login", | ||||
|         "/login/sendSmsCode", | ||||
|     ], | ||||
|     NEED_LOGOUT: "needLogout", | ||||
| }; | ||||
							
								
								
									
										70
									
								
								src/css/public.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								src/css/public.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| /* 主要的按钮样式处理 */ | ||||
| /*鼠标点击后移开,恢复本身样式*/ | ||||
| .primary, | ||||
| .primary:focus:not(.primary:hover) { | ||||
|     color: white; | ||||
|     background: #409eff; | ||||
| } | ||||
|  | ||||
| /*鼠标悬浮,没有按下;鼠标按下后抬起,没有移开*/ | ||||
| /* 更改背景和字體顏色 */ | ||||
| .primary:focus, | ||||
| .primary:hover { | ||||
|     color: white; | ||||
|     background: #409eff; | ||||
| } | ||||
|  | ||||
| /*鼠标按下,没有抬起*/ | ||||
| /* 更改邊框顏色 */ | ||||
| .primary:active { | ||||
|     color: white; | ||||
|     background: #337ecc; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*鼠标点击后移开,恢复本身样式*/ | ||||
| .danger, | ||||
| .danger:focus:not(.danger:hover) { | ||||
|     color: white; | ||||
|     background: #f56c6c; | ||||
| } | ||||
|  | ||||
| /* 危险的按钮样式 */ | ||||
| /*鼠标悬浮,没有按下;鼠标按下后抬起,没有移开*/ | ||||
| /* 更改背景和字體顏色 */ | ||||
| .danger:focus, | ||||
| .danger:hover { | ||||
|     color: white; | ||||
|     background: #f56c6c; | ||||
| } | ||||
|  | ||||
| /*鼠标按下,没有抬起*/ | ||||
| /* 更改邊框顏色 */ | ||||
| .danger:active { | ||||
|     color: white; | ||||
|     background: #c45656; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*鼠标点击后移开,恢复本身样式*/ | ||||
| .success, | ||||
| .success:focus:not(.success:hover) { | ||||
|     color: white; | ||||
|     background: #67c23a; | ||||
| } | ||||
|  | ||||
| /* 危险的按钮样式 */ | ||||
| /*鼠标悬浮,没有按下;鼠标按下后抬起,没有移开*/ | ||||
| /* 更改背景和字體顏色 */ | ||||
| .success:focus, | ||||
| .success:hover { | ||||
|     color: white; | ||||
|     background: #b3e19d; | ||||
| } | ||||
|  | ||||
| /*鼠标按下,没有抬起*/ | ||||
| /* 更改邊框顏色 */ | ||||
| .danger:active { | ||||
|     color: white; | ||||
|     background: #529b2e; | ||||
| } | ||||
							
								
								
									
										42
									
								
								src/main.js
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								src/main.js
									
									
									
									
									
								
							| @@ -1,10 +1,11 @@ | ||||
| import { createApp } from 'vue' | ||||
| // @ts-ignore | ||||
| import App from './App.vue' | ||||
| import router from './router' | ||||
| import store from './store' | ||||
|  | ||||
| import 'jquery' | ||||
| import 'jquery.md5' | ||||
|  | ||||
| import 'bootstrap/dist/css/bootstrap.min.css' | ||||
| import 'bootstrap/dist/js/bootstrap.min.js' | ||||
|  | ||||
| @@ -15,10 +16,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' | ||||
|  | ||||
| @@ -46,9 +47,30 @@ import '@/assets/plugins/jQuery-Validation-Engine/js/languages/jquery.validation | ||||
| import '@/assets/plugins/bootstrap-treeview/css/bootstrap-treeview.min.css' | ||||
| import '@/assets/plugins/bootstrap-treeview/js/bootstrap-treeview.min.js' | ||||
|  | ||||
| // @ts-ignore | ||||
| import components from '@/utils/components.js' | ||||
|  | ||||
| import ElementPlus from 'element-plus' | ||||
| import 'element-plus/dist/index.css' | ||||
|  | ||||
| createApp(App).use(store).use(router).use(components).use(ElementPlus).mount('#app') | ||||
| import Vue from 'vue'; | ||||
| // import ElementPlus from 'element-plus' | ||||
| // import 'element-plus/dist/index.css' | ||||
| import '@/css/public.css' | ||||
| import VueClipboard from 'vue-clipboard2' | ||||
| // import 'vue-clipboard2/dist/vue-clipboard.min.css' | ||||
| import { copy } from './utils/copy.js'; | ||||
| const app = createApp(App) | ||||
| app.config.globalProperties.$copy = function (text) { | ||||
|     copy(text, this); | ||||
| }; | ||||
| // 全局错误处理 | ||||
| window.onerror = function (message, source, lineno, colno, error) { | ||||
|     console.log(error) | ||||
|     // 判断是否是 'insertBefore' 错误 | ||||
|     if (error instanceof TypeError && message.includes('insertBefore')) { | ||||
|         console.error('捕获到 TypeError 错误:', error); | ||||
|         window.location.reload(); | ||||
|         // 你可以在这里处理错误,比如记录日志或执行其他操作 | ||||
|         return true;  // 阻止浏览器默认的错误处理 | ||||
|     } | ||||
|     return false;  // 默认处理其他类型的错误 | ||||
| }; | ||||
| app.config.warnHandler = () => null; | ||||
| app.use(store).use(router).use(components).use(VueClipboard).mount('#app') | ||||
|   | ||||
							
								
								
									
										81
									
								
								src/mixin/mixRegion.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								src/mixin/mixRegion.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,81 @@ | ||||
|  | ||||
| // 公共混入 用户区服处理  | ||||
| /** | ||||
|  * 注意: 使用混入,在选择区服切换的时候会添加搜索的区服, | ||||
|  *       所以页面data如果没有searchForm: { region: null }, 需要加上,否则查询searchForm为空 | ||||
|  */ | ||||
| export default { | ||||
|     data() { | ||||
|         return { | ||||
|             userRegion: JSON.parse(localStorage.getItem('user_region')), | ||||
|             regionEnum: [ | ||||
|                 { value: 1, name: 'A区' }, | ||||
|                 { value: 2, name: 'B区' }, | ||||
|                 { value: 3, name: 'C区' }, | ||||
|                 { value: 4, name: 'D区' }, | ||||
|                 { value: 5, name: 'E区' }, | ||||
|                 { value: 6, name: 'F区' } | ||||
|             ], | ||||
|             userAreaRegion: [], //拥有权限的区域列表 | ||||
|             region: null, //展示的区域 | ||||
|         } | ||||
|     }, | ||||
|     created() { | ||||
|         this.handleUserRegion() | ||||
|     }, | ||||
|     methods: { | ||||
|         handleUserRegion() { | ||||
|             if (this.userRegion.length == 0) { | ||||
|                 this.$message.error({ | ||||
|                     message: '请先联系管理员设置你的区服权限!', | ||||
|                     duration: 5000 | ||||
|                 }); | ||||
|                 return | ||||
|             } | ||||
|             this.userAreaRegion = this.regionEnum.filter(item => this.userRegion.includes(item.value)); | ||||
|             this.region = this.userAreaRegion[0].value; | ||||
|             this.searchForm.region = this.region; | ||||
|             console.log('当前查看区服:', this.region); | ||||
|         }, | ||||
|         handSearchRegion() { | ||||
|             if (this.$refs['searchForm']) { // 检查 this.$refs['searchForm'] 是否存在 | ||||
|                 this.$refs['searchForm'].validate((valid) => { | ||||
|                     if (valid) { | ||||
|                         this.pageParams.pageNo = 1; | ||||
|                         this.getData(); | ||||
|                     } | ||||
|                 }); | ||||
|             } else { | ||||
|                 this.pageParams.pageNo = 1; | ||||
|                 this.getData(); | ||||
|             } | ||||
|         }, | ||||
|     }, | ||||
|     computed: { | ||||
|         regionType() { | ||||
|             const { regionEnum } = this; | ||||
|             return function (value) { | ||||
|                 for (let item of regionEnum) { | ||||
|                     if (item.value === value) { | ||||
|                         return item.name; | ||||
|                     } | ||||
|                 } | ||||
|                 return ''; | ||||
|             }; | ||||
|         } | ||||
|     }, | ||||
|     watch: { | ||||
|         region: { | ||||
|             handler(newVal, oldVal) { | ||||
|                 this.searchForm.region = newVal; | ||||
|                 // 防止初始化重复调用查询表单接口 | ||||
|                 if (oldVal != null) { | ||||
|                     this.handSearchRegion() | ||||
|                 } | ||||
|             }, | ||||
|             // immediate: true,  //立即监听 | ||||
|         }, | ||||
|  | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -1,6 +1,7 @@ | ||||
| import { createRouter, createWebHashHistory } from 'vue-router' | ||||
| import HomeView from '../views/home/index.vue' | ||||
| import LoginView from '../views/login/index.vue' | ||||
| import BlankView from '../views/BlankView.vue' | ||||
|  | ||||
| const routes = [ | ||||
|   { | ||||
| @@ -12,6 +13,11 @@ const routes = [ | ||||
|     path: '/home', | ||||
|     name: 'home', | ||||
|     component: HomeView | ||||
|   }, | ||||
|   { | ||||
|     path: '/blank', | ||||
|     name: 'blank', | ||||
|     component: BlankView | ||||
|   } | ||||
| ] | ||||
|  | ||||
|   | ||||
| @@ -51,6 +51,7 @@ export default { | ||||
|         }, | ||||
|         getViewComponent(context, path) { | ||||
|             let component = path; | ||||
|             console.log(component) | ||||
|             if (path && path.endsWith('.html')) { | ||||
|                 const pathArray = path.split('/'); | ||||
|                 const routeName = toCamelCase(pathArray[pathArray.length - 1].replace('.html', '')); | ||||
|   | ||||
| @@ -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({ | ||||
|   | ||||
| @@ -4,7 +4,6 @@ jQuery.extend({ | ||||
|         if (s.error) { | ||||
|             s.error.call(s.context || s, xhr, status, e); | ||||
|         } | ||||
|  | ||||
|         // Fire the global callback | ||||
|         if (s.global) { | ||||
|             (s.context ? jQuery(s.context) : jQuery.event).trigger("ajaxError", [xhr, s, e]); | ||||
| @@ -13,17 +12,14 @@ jQuery.extend({ | ||||
|     createUploadIframe: function (id, uri) { | ||||
|         //create frame | ||||
|         var frameId = 'jUploadFrame' + id; | ||||
|  | ||||
|         if (window.ActiveXObject) { | ||||
|             var io = document.createElement('<iframe id="' + frameId + '" name="' + frameId + '" />'); | ||||
|             if (typeof uri == 'boolean') { | ||||
|                 io.src = 'javascript:false'; | ||||
|             } | ||||
|             else if (typeof uri == 'string') { | ||||
|             } else if (typeof uri == 'string') { | ||||
|                 io.src = uri; | ||||
|             } | ||||
|         } | ||||
|         else { | ||||
|         } else { | ||||
|             io = document.createElement('iframe'); | ||||
|             io.id = frameId; | ||||
|             io.name = frameId; | ||||
| @@ -31,18 +27,21 @@ jQuery.extend({ | ||||
|         io.style.position = 'absolute'; | ||||
|         io.style.top = '-1000px'; | ||||
|         io.style.left = '-1000px'; | ||||
|  | ||||
|         document.body.appendChild(io); | ||||
|  | ||||
|         return io | ||||
|         return io; | ||||
|     }, | ||||
|     createUploadForm: function (id, fileElementId) { | ||||
|         //create form	 | ||||
|         var formId = 'jUploadForm' + id; | ||||
|         var fileId = 'jUploadFile' + id; | ||||
|         var form = $('<form  action="" method="POST" name="' + formId + '" id="' + formId + '" enctype="multipart/form-data"></form>'); | ||||
|         var form = $('#' + formId); | ||||
|         if (form && form.length > 0) { | ||||
|             form.remove(); | ||||
|         } | ||||
|         form = $('<form  action="" method="POST" name="' + formId + '" id="' + formId + '" enctype="multipart/form-data"></form>'); | ||||
|         var oldElement = $('#' + fileElementId); | ||||
|         var newElement = $(oldElement).clone(); | ||||
|         var newElement = $(oldElement).clone(true).val(""); | ||||
|         //须要复制元素的全部事件处理。   | ||||
|         $(oldElement).attr('id', fileId); | ||||
|         $(oldElement).before(newElement); | ||||
|         $(oldElement).appendTo(form); | ||||
| @@ -53,7 +52,6 @@ jQuery.extend({ | ||||
|         $(form).appendTo('body'); | ||||
|         return form; | ||||
|     }, | ||||
|  | ||||
|     ajaxFileUpload: function (s) { | ||||
|         // TODO introduce global settings, allowing the client to modify them for all requests, not only timeout		 | ||||
|         s = jQuery.extend({}, jQuery.ajaxSettings, s); | ||||
| @@ -68,7 +66,7 @@ jQuery.extend({ | ||||
|         } | ||||
|         var requestDone = false; | ||||
|         // Create the request object | ||||
|         var xml = {} | ||||
|         var xml = {}; | ||||
|         if (s.global) | ||||
|             jQuery.event.trigger("ajaxSend", [xml, s]); | ||||
|         // Wait for a response to come back | ||||
| @@ -98,7 +96,6 @@ jQuery.extend({ | ||||
|                         // If a local callback was specified, fire it and pass it the data | ||||
|                         if (s.success) | ||||
|                             s.success(data, status); | ||||
|  | ||||
|                         // Fire the global callback | ||||
|                         if (s.global) | ||||
|                             jQuery.event.trigger("ajaxSuccess", [xml, s]); | ||||
| @@ -112,30 +109,22 @@ jQuery.extend({ | ||||
|                 // The request was completed | ||||
|                 if (s.global) | ||||
|                     jQuery.event.trigger("ajaxComplete", [xml, s]); | ||||
|  | ||||
|                 // Handle the global AJAX counter | ||||
|                 if (s.global && ! --jQuery.active) | ||||
|                     jQuery.event.trigger("ajaxStop"); | ||||
|  | ||||
|                 // Process result | ||||
|                 if (s.complete) | ||||
|                     s.complete(xml, status); | ||||
|  | ||||
|                 jQuery(io).unbind() | ||||
|  | ||||
|                 jQuery(io).unbind(); | ||||
|                 setTimeout(function () { | ||||
|                     try { | ||||
|                         $(io).remove(); | ||||
|                         $(form).remove(); | ||||
|  | ||||
|                     } catch (e) { | ||||
|                         jQuery.handleError(s, xml, null, e); | ||||
|                     } | ||||
|  | ||||
|                 }, 100) | ||||
|  | ||||
|                 xml = null | ||||
|  | ||||
|                 }, 100); | ||||
|                 xml = null; | ||||
|             } | ||||
|         } | ||||
|         // Timeout checker | ||||
| @@ -153,12 +142,23 @@ jQuery.extend({ | ||||
|             $(form).attr('target', frameId); | ||||
|             if (form.encoding) { | ||||
|                 form.encoding = 'multipart/form-data'; | ||||
|             } | ||||
|             else { | ||||
|             } else { | ||||
|                 form.enctype = 'multipart/form-data'; | ||||
|             } | ||||
|             $(form).submit(); | ||||
|  | ||||
|             let submitType = s.submitType; | ||||
|             let $form = $(form); | ||||
|             if (!submitType || submitType == 'form') { | ||||
|                 $form.submit(); | ||||
|             } else if (submitType == 'ajax') { | ||||
|                 $form.ajaxSubmit({ | ||||
|                     success: function (data, status) { | ||||
|                         s.success(data, status); | ||||
|                     }, | ||||
|                     error: function (err) { | ||||
|                         jQuery.handleError(s, xml, null, err); | ||||
|                     } | ||||
|                 }); | ||||
|             } | ||||
|         } catch (e) { | ||||
|             jQuery.handleError(s, xml, null, e); | ||||
|         } | ||||
| @@ -169,9 +169,7 @@ jQuery.extend({ | ||||
|             document.getElementById(frameId).addEventListener('load', uploadCallback, false); | ||||
|         } | ||||
|         return { abort: function () { } }; | ||||
|  | ||||
|     }, | ||||
|  | ||||
|     uploadHttpData: function (r, type) { | ||||
|         var data = !type; | ||||
|         data = type == "xml" || data ? r.responseXML : r.responseText; | ||||
|   | ||||
							
								
								
									
										46
									
								
								src/utils/bootstrap-table-helper.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										46
									
								
								src/utils/bootstrap-table-helper.js
									
									
									
									
										vendored
									
									
								
							| @@ -1,42 +1,50 @@ | ||||
| export default { | ||||
|     idstr: null, | ||||
|     // 是否有且只选择了一项 | ||||
|     isSelectOne: function (idstr) { | ||||
|         if ($(idstr).bootstrapTable('getSelections').length == 1) { | ||||
|     isSelectOne: function (id) { | ||||
|         if ($(id).bootstrapTable('getSelections').length == 1) { | ||||
|             return true; | ||||
|         } | ||||
|         return false; | ||||
|     }, | ||||
|     //是否选择了至少一项 | ||||
|     hasSelectAny: function (idstr) { | ||||
|         if ($(idstr).bootstrapTable('getSelections').length > 0) { | ||||
|     hasSelectAny: function (id) { | ||||
|         if ($(id).bootstrapTable('getSelections').length > 0) { | ||||
|             return true; | ||||
|         } | ||||
|         return false; | ||||
|     }, | ||||
|     // 获取选择的一项 | ||||
|     getOneSelectItem: function (idstr) { | ||||
|         return $(idstr).bootstrapTable('getSelections')[0]; | ||||
|     getOneSelectItem: function (id) { | ||||
|         return $(id).bootstrapTable('getSelections')[0]; | ||||
|     }, | ||||
|     // 已经选择的记录 | ||||
|     getAllSelectItems: function (idstr) { | ||||
|         return $(idstr).bootstrapTable('getSelections'); | ||||
|     getAllSelectItems: function (id) { | ||||
|         return $(id).bootstrapTable('getSelections'); | ||||
|     }, | ||||
|     getRowByUniqueId: function (idstr, id) { | ||||
|         return $(idstr).bootstrapTable('getRowByUniqueId', id); | ||||
|     getRowByUniqueId: function (id, recordId) { | ||||
|         return $(id).bootstrapTable('getRowByUniqueId', recordId); | ||||
|     }, | ||||
|     // 已选择的项数量 | ||||
|     selectLength: function (idstr) { | ||||
|         return $(idstr).bootstrapTable('getSelections').length; | ||||
|     selectLength: function (id) { | ||||
|         return $(id).bootstrapTable('getSelections').length; | ||||
|     }, | ||||
|     // 刷新 | ||||
|     doRefresh: function (idstr) { | ||||
|         $(idstr).bootstrapTable('refresh'); | ||||
|     doRefresh: function (id) { | ||||
|         $(id).bootstrapTable('refresh'); | ||||
|     }, | ||||
|     unCheckAll: function (idstr) { | ||||
|         $(idstr).bootstrapTable('uncheckAll'); | ||||
|     unCheckAll: function (id) { | ||||
|         $(id).bootstrapTable('uncheckAll'); | ||||
|     }, | ||||
|     doRefreshAndToPage1: function (idstr) { | ||||
|         $(idstr).bootstrapTable('selectPage', 1); | ||||
|     doRefreshAndToPage1: function (id) { | ||||
|         $(id).bootstrapTable('selectPage', 1); | ||||
|     }, | ||||
|     getData: function(id) { | ||||
|         return $(id).bootstrapTable('getData'); | ||||
|     }, | ||||
|     destroy: function(id) { | ||||
|         $(id).bootstrapTable('destroy'); | ||||
|     }, | ||||
|     load: function(id, data) { | ||||
|         $(id).bootstrapTable('load', data); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										11
									
								
								src/utils/copy.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								src/utils/copy.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
|  | ||||
| // copy.js | ||||
| export function copy(text, vueInstance) { | ||||
|   vueInstance.$copyText(text) | ||||
|     .then(() => { | ||||
|       vueInstance.$message.success('已复制'); | ||||
|     }) | ||||
|     .catch(() => { | ||||
|       vueInstance.$message.warning('复制失败'); | ||||
|     }); | ||||
| } | ||||
							
								
								
									
										684
									
								
								src/utils/excel/Blob.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										684
									
								
								src/utils/excel/Blob.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,684 @@ | ||||
| // /* Blob.js | ||||
| //  * A Blob, File, FileReader & URL implementation. | ||||
| //  * 2019-04-19 | ||||
| //  * | ||||
| //  * By Eli Grey, http://eligrey.com | ||||
| //  * By Jimmy Wärting, https://github.com/jimmywarting | ||||
| //  * License: MIT | ||||
| //  *   See https://github.com/eligrey/Blob.js/blob/master/LICENSE.md | ||||
| //  */ | ||||
|  | ||||
| // ; (function () { | ||||
| //     var global = typeof window === 'object' | ||||
| //         ? window : typeof self === 'object' | ||||
| //             ? self : this | ||||
|  | ||||
| //     var BlobBuilder = global.BlobBuilder | ||||
| //         || global.WebKitBlobBuilder | ||||
| //         || global.MSBlobBuilder | ||||
| //         || global.MozBlobBuilder | ||||
|  | ||||
| //     global.URL = global.URL || global.webkitURL || function (href, a) { | ||||
| //         a = document.createElement('a') | ||||
| //         a.href = href | ||||
| //         return a | ||||
| //     } | ||||
|  | ||||
| //     var origBlob = global.Blob | ||||
| //     var createObjectURL = URL.createObjectURL | ||||
| //     var revokeObjectURL = URL.revokeObjectURL | ||||
| //     var strTag = global.Symbol && global.Symbol.toStringTag | ||||
| //     var blobSupported = false | ||||
| //     var blobSupportsArrayBufferView = false | ||||
| //     var arrayBufferSupported = !!global.ArrayBuffer | ||||
| //     var blobBuilderSupported = BlobBuilder | ||||
| //         && BlobBuilder.prototype.append | ||||
| //         && BlobBuilder.prototype.getBlob | ||||
|  | ||||
| //     try { | ||||
| //         // Check if Blob constructor is supported | ||||
| //         blobSupported = new Blob(['ä']).size === 2 | ||||
|  | ||||
| //         // Check if Blob constructor supports ArrayBufferViews | ||||
| //         // Fails in Safari 6, so we need to map to ArrayBuffers there. | ||||
| //         blobSupportsArrayBufferView = new Blob([new Uint8Array([1, 2])]).size === 2 | ||||
| //     } catch (e) { } | ||||
|  | ||||
| //     /** | ||||
| //      * Helper function that maps ArrayBufferViews to ArrayBuffers | ||||
| //      * Used by BlobBuilder constructor and old browsers that didn't | ||||
| //      * support it in the Blob constructor. | ||||
| //      */ | ||||
| //     function mapArrayBufferViews(ary) { | ||||
| //         return ary.map(function (chunk) { | ||||
| //             if (chunk.buffer instanceof ArrayBuffer) { | ||||
| //                 var buf = chunk.buffer | ||||
|  | ||||
| //                 // if this is a subarray, make a copy so we only | ||||
| //                 // include the subarray region from the underlying buffer | ||||
| //                 if (chunk.byteLength !== buf.byteLength) { | ||||
| //                     var copy = new Uint8Array(chunk.byteLength) | ||||
| //                     copy.set(new Uint8Array(buf, chunk.byteOffset, chunk.byteLength)) | ||||
| //                     buf = copy.buffer | ||||
| //                 } | ||||
|  | ||||
| //                 return buf | ||||
| //             } | ||||
|  | ||||
| //             return chunk | ||||
| //         }) | ||||
| //     } | ||||
|  | ||||
| //     function BlobBuilderConstructor(ary, options) { | ||||
| //         options = options || {} | ||||
|  | ||||
| //         var bb = new BlobBuilder() | ||||
| //         mapArrayBufferViews(ary).forEach(function (part) { | ||||
| //             bb.append(part) | ||||
| //         }) | ||||
|  | ||||
| //         return options.type ? bb.getBlob(options.type) : bb.getBlob() | ||||
| //     } | ||||
|  | ||||
| //     function BlobConstructor(ary, options) { | ||||
| //         return new origBlob(mapArrayBufferViews(ary), options || {}) | ||||
| //     } | ||||
|  | ||||
| //     if (global.Blob) { | ||||
| //         BlobBuilderConstructor.prototype = Blob.prototype | ||||
| //         BlobConstructor.prototype = Blob.prototype | ||||
| //     } | ||||
|  | ||||
|  | ||||
|  | ||||
| //     /********************************************************/ | ||||
| //     /*               String Encoder fallback                */ | ||||
| //     /********************************************************/ | ||||
| //     function stringEncode(string) { | ||||
| //         var pos = 0 | ||||
| //         var len = string.length | ||||
| //         var Arr = global.Uint8Array || Array // Use byte array when possible | ||||
|  | ||||
| //         var at = 0  // output position | ||||
| //         var tlen = Math.max(32, len + (len >> 1) + 7)  // 1.5x size | ||||
| //         var target = new Arr((tlen >> 3) << 3)  // ... but at 8 byte offset | ||||
|  | ||||
| //         while (pos < len) { | ||||
| //             var value = string.charCodeAt(pos++) | ||||
| //             if (value >= 0xd800 && value <= 0xdbff) { | ||||
| //                 // high surrogate | ||||
| //                 if (pos < len) { | ||||
| //                     var extra = string.charCodeAt(pos) | ||||
| //                     if ((extra & 0xfc00) === 0xdc00) { | ||||
| //                         ++pos | ||||
| //                         value = ((value & 0x3ff) << 10) + (extra & 0x3ff) + 0x10000 | ||||
| //                     } | ||||
| //                 } | ||||
| //                 if (value >= 0xd800 && value <= 0xdbff) { | ||||
| //                     continue  // drop lone surrogate | ||||
| //                 } | ||||
| //             } | ||||
|  | ||||
| //             // expand the buffer if we couldn't write 4 bytes | ||||
| //             if (at + 4 > target.length) { | ||||
| //                 tlen += 8  // minimum extra | ||||
| //                 tlen *= (1.0 + (pos / string.length) * 2)  // take 2x the remaining | ||||
| //                 tlen = (tlen >> 3) << 3  // 8 byte offset | ||||
|  | ||||
| //                 var update = new Uint8Array(tlen) | ||||
| //                 update.set(target) | ||||
| //                 target = update | ||||
| //             } | ||||
|  | ||||
| //             if ((value & 0xffffff80) === 0) {  // 1-byte | ||||
| //                 target[at++] = value  // ASCII | ||||
| //                 continue | ||||
| //             } else if ((value & 0xfffff800) === 0) {  // 2-byte | ||||
| //                 target[at++] = ((value >> 6) & 0x1f) | 0xc0 | ||||
| //             } else if ((value & 0xffff0000) === 0) {  // 3-byte | ||||
| //                 target[at++] = ((value >> 12) & 0x0f) | 0xe0 | ||||
| //                 target[at++] = ((value >> 6) & 0x3f) | 0x80 | ||||
| //             } else if ((value & 0xffe00000) === 0) {  // 4-byte | ||||
| //                 target[at++] = ((value >> 18) & 0x07) | 0xf0 | ||||
| //                 target[at++] = ((value >> 12) & 0x3f) | 0x80 | ||||
| //                 target[at++] = ((value >> 6) & 0x3f) | 0x80 | ||||
| //             } else { | ||||
| //                 // FIXME: do we care | ||||
| //                 continue | ||||
| //             } | ||||
|  | ||||
| //             target[at++] = (value & 0x3f) | 0x80 | ||||
| //         } | ||||
|  | ||||
| //         return target.slice(0, at) | ||||
| //     } | ||||
|  | ||||
| //     /********************************************************/ | ||||
| //     /*               String Decoder fallback                */ | ||||
| //     /********************************************************/ | ||||
| //     function stringDecode(buf) { | ||||
| //         var end = buf.length | ||||
| //         var res = [] | ||||
|  | ||||
| //         var i = 0 | ||||
| //         while (i < end) { | ||||
| //             var firstByte = buf[i] | ||||
| //             var codePoint = null | ||||
| //             var bytesPerSequence = (firstByte > 0xEF) ? 4 | ||||
| //                 : (firstByte > 0xDF) ? 3 | ||||
| //                     : (firstByte > 0xBF) ? 2 | ||||
| //                         : 1 | ||||
|  | ||||
| //             if (i + bytesPerSequence <= end) { | ||||
| //                 var secondByte, thirdByte, fourthByte, tempCodePoint | ||||
|  | ||||
| //                 switch (bytesPerSequence) { | ||||
| //                     case 1: | ||||
| //                         if (firstByte < 0x80) { | ||||
| //                             codePoint = firstByte | ||||
| //                         } | ||||
| //                         break | ||||
| //                     case 2: | ||||
| //                         secondByte = buf[i + 1] | ||||
| //                         if ((secondByte & 0xC0) === 0x80) { | ||||
| //                             tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F) | ||||
| //                             if (tempCodePoint > 0x7F) { | ||||
| //                                 codePoint = tempCodePoint | ||||
| //                             } | ||||
| //                         } | ||||
| //                         break | ||||
| //                     case 3: | ||||
| //                         secondByte = buf[i + 1] | ||||
| //                         thirdByte = buf[i + 2] | ||||
| //                         if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) { | ||||
| //                             tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F) | ||||
| //                             if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) { | ||||
| //                                 codePoint = tempCodePoint | ||||
| //                             } | ||||
| //                         } | ||||
| //                         break | ||||
| //                     case 4: | ||||
| //                         secondByte = buf[i + 1] | ||||
| //                         thirdByte = buf[i + 2] | ||||
| //                         fourthByte = buf[i + 3] | ||||
| //                         if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) { | ||||
| //                             tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F) | ||||
| //                             if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) { | ||||
| //                                 codePoint = tempCodePoint | ||||
| //                             } | ||||
| //                         } | ||||
| //                 } | ||||
| //             } | ||||
|  | ||||
| //             if (codePoint === null) { | ||||
| //                 // we did not generate a valid codePoint so insert a | ||||
| //                 // replacement char (U+FFFD) and advance only 1 byte | ||||
| //                 codePoint = 0xFFFD | ||||
| //                 bytesPerSequence = 1 | ||||
| //             } else if (codePoint > 0xFFFF) { | ||||
| //                 // encode to utf16 (surrogate pair dance) | ||||
| //                 codePoint -= 0x10000 | ||||
| //                 res.push(codePoint >>> 10 & 0x3FF | 0xD800) | ||||
| //                 codePoint = 0xDC00 | codePoint & 0x3FF | ||||
| //             } | ||||
|  | ||||
| //             res.push(codePoint) | ||||
| //             i += bytesPerSequence | ||||
| //         } | ||||
|  | ||||
| //         var len = res.length | ||||
| //         var str = '' | ||||
| //         var i = 0 | ||||
|  | ||||
| //         while (i < len) { | ||||
| //             str += String.fromCharCode.apply(String, res.slice(i, i += 0x1000)) | ||||
| //         } | ||||
|  | ||||
| //         return str | ||||
| //     } | ||||
|  | ||||
| //     // string -> buffer | ||||
| //     var textEncode = typeof TextEncoder === 'function' | ||||
| //         ? TextEncoder.prototype.encode.bind(new TextEncoder()) | ||||
| //         : stringEncode | ||||
|  | ||||
| //     // buffer -> string | ||||
| //     var textDecode = typeof TextDecoder === 'function' | ||||
| //         ? TextDecoder.prototype.decode.bind(new TextDecoder()) | ||||
| //         : stringDecode | ||||
|  | ||||
| //     function FakeBlobBuilder() { | ||||
| //         function isDataView(obj) { | ||||
| //             return obj && DataView.prototype.isPrototypeOf(obj) | ||||
| //         } | ||||
| //         function bufferClone(buf) { | ||||
| //             var view = new Array(buf.byteLength) | ||||
| //             var array = new Uint8Array(buf) | ||||
| //             var i = view.length | ||||
| //             while (i--) { | ||||
| //                 view[i] = array[i] | ||||
| //             } | ||||
| //             return view | ||||
| //         } | ||||
| //         function array2base64(input) { | ||||
| //             var byteToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=' | ||||
|  | ||||
| //             var output = [] | ||||
|  | ||||
| //             for (var i = 0; i < input.length; i += 3) { | ||||
| //                 var byte1 = input[i] | ||||
| //                 var haveByte2 = i + 1 < input.length | ||||
| //                 var byte2 = haveByte2 ? input[i + 1] : 0 | ||||
| //                 var haveByte3 = i + 2 < input.length | ||||
| //                 var byte3 = haveByte3 ? input[i + 2] : 0 | ||||
|  | ||||
| //                 var outByte1 = byte1 >> 2 | ||||
| //                 var outByte2 = ((byte1 & 0x03) << 4) | (byte2 >> 4) | ||||
| //                 var outByte3 = ((byte2 & 0x0F) << 2) | (byte3 >> 6) | ||||
| //                 var outByte4 = byte3 & 0x3F | ||||
|  | ||||
| //                 if (!haveByte3) { | ||||
| //                     outByte4 = 64 | ||||
|  | ||||
| //                     if (!haveByte2) { | ||||
| //                         outByte3 = 64 | ||||
| //                     } | ||||
| //                 } | ||||
|  | ||||
| //                 output.push( | ||||
| //                     byteToCharMap[outByte1], byteToCharMap[outByte2], | ||||
| //                     byteToCharMap[outByte3], byteToCharMap[outByte4] | ||||
| //                 ) | ||||
| //             } | ||||
|  | ||||
| //             return output.join('') | ||||
| //         } | ||||
|  | ||||
| //         var create = Object.create || function (a) { | ||||
| //             function c() { } | ||||
| //             c.prototype = a | ||||
| //             return new c() | ||||
| //         } | ||||
|  | ||||
| //         if (arrayBufferSupported) { | ||||
| //             var viewClasses = [ | ||||
| //                 '[object Int8Array]', | ||||
| //                 '[object Uint8Array]', | ||||
| //                 '[object Uint8ClampedArray]', | ||||
| //                 '[object Int16Array]', | ||||
| //                 '[object Uint16Array]', | ||||
| //                 '[object Int32Array]', | ||||
| //                 '[object Uint32Array]', | ||||
| //                 '[object Float32Array]', | ||||
| //                 '[object Float64Array]' | ||||
| //             ] | ||||
|  | ||||
| //             var isArrayBufferView = ArrayBuffer.isView || function (obj) { | ||||
| //                 return obj && viewClasses.indexOf(Object.prototype.toString.call(obj)) > -1 | ||||
| //             } | ||||
| //         } | ||||
|  | ||||
| //         function concatTypedarrays(chunks) { | ||||
| //             var size = 0 | ||||
| //             var i = chunks.length | ||||
| //             while (i--) { size += chunks[i].length } | ||||
| //             var b = new Uint8Array(size) | ||||
| //             var offset = 0 | ||||
| //             for (i = 0, l = chunks.length; i < l; i++) { | ||||
| //                 var chunk = chunks[i] | ||||
| //                 b.set(chunk, offset) | ||||
| //                 offset += chunk.byteLength || chunk.length | ||||
| //             } | ||||
|  | ||||
| //             return b | ||||
| //         } | ||||
|  | ||||
| //         /********************************************************/ | ||||
| //         /*                   Blob constructor                   */ | ||||
| //         /********************************************************/ | ||||
| //         function Blob(chunks, opts) { | ||||
| //             chunks = chunks || [] | ||||
| //             opts = opts == null ? {} : opts | ||||
| //             for (var i = 0, len = chunks.length; i < len; i++) { | ||||
| //                 var chunk = chunks[i] | ||||
| //                 if (chunk instanceof Blob) { | ||||
| //                     chunks[i] = chunk._buffer | ||||
| //                 } else if (typeof chunk === 'string') { | ||||
| //                     chunks[i] = textEncode(chunk) | ||||
| //                 } else if (arrayBufferSupported && (ArrayBuffer.prototype.isPrototypeOf(chunk) || isArrayBufferView(chunk))) { | ||||
| //                     chunks[i] = bufferClone(chunk) | ||||
| //                 } else if (arrayBufferSupported && isDataView(chunk)) { | ||||
| //                     chunks[i] = bufferClone(chunk.buffer) | ||||
| //                 } else { | ||||
| //                     chunks[i] = textEncode(String(chunk)) | ||||
| //                 } | ||||
| //             } | ||||
|  | ||||
| //             this._buffer = global.Uint8Array | ||||
| //                 ? concatTypedarrays(chunks) | ||||
| //                 : [].concat.apply([], chunks) | ||||
| //             this.size = this._buffer.length | ||||
|  | ||||
| //             this.type = opts.type || '' | ||||
| //             if (/[^\u0020-\u007E]/.test(this.type)) { | ||||
| //                 this.type = '' | ||||
| //             } else { | ||||
| //                 this.type = this.type.toLowerCase() | ||||
| //             } | ||||
| //         } | ||||
|  | ||||
| //         Blob.prototype.arrayBuffer = function () { | ||||
| //             return Promise.resolve(this._buffer) | ||||
| //         } | ||||
|  | ||||
| //         Blob.prototype.text = function () { | ||||
| //             return Promise.resolve(textDecode(this._buffer)) | ||||
| //         } | ||||
|  | ||||
| //         Blob.prototype.slice = function (start, end, type) { | ||||
| //             var slice = this._buffer.slice(start || 0, end || this._buffer.length) | ||||
| //             return new Blob([slice], { type: type }) | ||||
| //         } | ||||
|  | ||||
| //         Blob.prototype.toString = function () { | ||||
| //             return '[object Blob]' | ||||
| //         } | ||||
|  | ||||
| //         /********************************************************/ | ||||
| //         /*                   File constructor                   */ | ||||
| //         /********************************************************/ | ||||
| //         function File(chunks, name, opts) { | ||||
| //             opts = opts || {} | ||||
| //             var a = Blob.call(this, chunks, opts) || this | ||||
| //             a.name = name.replace(/\//g, ':') | ||||
| //             a.lastModifiedDate = opts.lastModified ? new Date(opts.lastModified) : new Date() | ||||
| //             a.lastModified = +a.lastModifiedDate | ||||
|  | ||||
| //             return a | ||||
| //         } | ||||
|  | ||||
| //         File.prototype = create(Blob.prototype) | ||||
| //         File.prototype.constructor = File | ||||
|  | ||||
| //         if (Object.setPrototypeOf) { | ||||
| //             Object.setPrototypeOf(File, Blob) | ||||
| //         } else { | ||||
| //             try { File.__proto__ = Blob } catch (e) { } | ||||
| //         } | ||||
|  | ||||
| //         File.prototype.toString = function () { | ||||
| //             return '[object File]' | ||||
| //         } | ||||
|  | ||||
| //         /********************************************************/ | ||||
| //         /*                FileReader constructor                */ | ||||
| //         /********************************************************/ | ||||
| //         function FileReader() { | ||||
| //             if (!(this instanceof FileReader)) { | ||||
| //                 throw new TypeError("Failed to construct 'FileReader': Please use the 'new' operator, this DOM object constructor cannot be called as a function.") | ||||
| //             } | ||||
|  | ||||
| //             var delegate = document.createDocumentFragment() | ||||
| //             this.addEventListener = delegate.addEventListener | ||||
| //             this.dispatchEvent = function (evt) { | ||||
| //                 var local = this['on' + evt.type] | ||||
| //                 if (typeof local === 'function') local(evt) | ||||
| //                 delegate.dispatchEvent(evt) | ||||
| //             } | ||||
| //             this.removeEventListener = delegate.removeEventListener | ||||
| //         } | ||||
|  | ||||
| //         function _read(fr, blob, kind) { | ||||
| //             if (!(blob instanceof Blob)) { | ||||
| //                 throw new TypeError("Failed to execute '" + kind + "' on 'FileReader': parameter 1 is not of type 'Blob'.") | ||||
| //             } | ||||
|  | ||||
| //             fr.result = '' | ||||
|  | ||||
| //             setTimeout(function () { | ||||
| //                 this.readyState = FileReader.LOADING | ||||
| //                 fr.dispatchEvent(new Event('load')) | ||||
| //                 fr.dispatchEvent(new Event('loadend')) | ||||
| //             }) | ||||
| //         } | ||||
|  | ||||
| //         FileReader.EMPTY = 0 | ||||
| //         FileReader.LOADING = 1 | ||||
| //         FileReader.DONE = 2 | ||||
| //         FileReader.prototype.error = null | ||||
| //         FileReader.prototype.onabort = null | ||||
| //         FileReader.prototype.onerror = null | ||||
| //         FileReader.prototype.onload = null | ||||
| //         FileReader.prototype.onloadend = null | ||||
| //         FileReader.prototype.onloadstart = null | ||||
| //         FileReader.prototype.onprogress = null | ||||
|  | ||||
| //         FileReader.prototype.readAsDataURL = function (blob) { | ||||
| //             _read(this, blob, 'readAsDataURL') | ||||
| //             this.result = 'data:' + blob.type + ';base64,' + array2base64(blob._buffer) | ||||
| //         } | ||||
|  | ||||
| //         FileReader.prototype.readAsText = function (blob) { | ||||
| //             _read(this, blob, 'readAsText') | ||||
| //             this.result = textDecode(blob._buffer) | ||||
| //         } | ||||
|  | ||||
| //         FileReader.prototype.readAsArrayBuffer = function (blob) { | ||||
| //             _read(this, blob, 'readAsText') | ||||
| //             // return ArrayBuffer when possible | ||||
| //             this.result = (blob._buffer.buffer || blob._buffer).slice() | ||||
| //         } | ||||
|  | ||||
| //         FileReader.prototype.abort = function () { } | ||||
|  | ||||
| //         /********************************************************/ | ||||
| //         /*                         URL                          */ | ||||
| //         /********************************************************/ | ||||
| //         URL.createObjectURL = function (blob) { | ||||
| //             return blob instanceof Blob | ||||
| //                 ? 'data:' + blob.type + ';base64,' + array2base64(blob._buffer) | ||||
| //                 : createObjectURL.call(URL, blob) | ||||
| //         } | ||||
|  | ||||
| //         URL.revokeObjectURL = function (url) { | ||||
| //             revokeObjectURL && revokeObjectURL.call(URL, url) | ||||
| //         } | ||||
|  | ||||
| //         /********************************************************/ | ||||
| //         /*                         XHR                          */ | ||||
| //         /********************************************************/ | ||||
| //         var _send = global.XMLHttpRequest && global.XMLHttpRequest.prototype.send | ||||
| //         if (_send) { | ||||
| //             XMLHttpRequest.prototype.send = function (data) { | ||||
| //                 if (data instanceof Blob) { | ||||
| //                     this.setRequestHeader('Content-Type', data.type) | ||||
| //                     _send.call(this, textDecode(data._buffer)) | ||||
| //                 } else { | ||||
| //                     _send.call(this, data) | ||||
| //                 } | ||||
| //             } | ||||
| //         } | ||||
|  | ||||
| //         global.FileReader = FileReader | ||||
| //         global.File = File | ||||
| //         global.Blob = Blob | ||||
| //     } | ||||
|  | ||||
| //     function fixFileAndXHR() { | ||||
| //         var isIE = !!global.ActiveXObject || ( | ||||
| //             '-ms-scroll-limit' in document.documentElement.style && | ||||
| //             '-ms-ime-align' in document.documentElement.style | ||||
| //         ) | ||||
|  | ||||
| //         // Monkey patched | ||||
| //         // IE don't set Content-Type header on XHR whose body is a typed Blob | ||||
| //         // https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/6047383 | ||||
| //         var _send = global.XMLHttpRequest && global.XMLHttpRequest.prototype.send | ||||
| //         if (isIE && _send) { | ||||
| //             XMLHttpRequest.prototype.send = function (data) { | ||||
| //                 if (data instanceof Blob) { | ||||
| //                     this.setRequestHeader('Content-Type', data.type) | ||||
| //                     _send.call(this, data) | ||||
| //                 } else { | ||||
| //                     _send.call(this, data) | ||||
| //                 } | ||||
| //             } | ||||
| //         } | ||||
|  | ||||
| //         try { | ||||
| //             new File([], '') | ||||
| //         } catch (e) { | ||||
| //             try { | ||||
| //                 var klass = new Function('class File extends Blob {' + | ||||
| //                     'constructor(chunks, name, opts) {' + | ||||
| //                     'opts = opts || {};' + | ||||
| //                     'super(chunks, opts || {});' + | ||||
| //                     'this.name = name.replace(/\//g, ":");' + | ||||
| //                     'this.lastModifiedDate = opts.lastModified ? new Date(opts.lastModified) : new Date();' + | ||||
| //                     'this.lastModified = +this.lastModifiedDate;' + | ||||
| //                     '}};' + | ||||
| //                     'return new File([], ""), File' | ||||
| //                 )() | ||||
| //                 global.File = klass | ||||
| //             } catch (e) { | ||||
| //                 var klass = function (b, d, c) { | ||||
| //                     var blob = new Blob(b, c) | ||||
| //                     var t = c && void 0 !== c.lastModified ? new Date(c.lastModified) : new Date() | ||||
|  | ||||
| //                     blob.name = d.replace(/\//g, ':') | ||||
| //                     blob.lastModifiedDate = t | ||||
| //                     blob.lastModified = +t | ||||
| //                     blob.toString = function () { | ||||
| //                         return '[object File]' | ||||
| //                     } | ||||
|  | ||||
| //                     if (strTag) { | ||||
| //                         blob[strTag] = 'File' | ||||
| //                     } | ||||
|  | ||||
| //                     return blob | ||||
| //                 } | ||||
| //                 global.File = klass | ||||
| //             } | ||||
| //         } | ||||
| //     } | ||||
|  | ||||
| //     if (blobSupported) { | ||||
| //         fixFileAndXHR() | ||||
| //         global.Blob = blobSupportsArrayBufferView ? global.Blob : BlobConstructor | ||||
| //     } else if (blobBuilderSupported) { | ||||
| //         fixFileAndXHR() | ||||
| //         global.Blob = BlobBuilderConstructor | ||||
| //     } else { | ||||
| //         FakeBlobBuilder() | ||||
| //     } | ||||
|  | ||||
| //     if (strTag) { | ||||
| //         File.prototype[strTag] = 'File' | ||||
| //         Blob.prototype[strTag] = 'Blob' | ||||
| //         FileReader.prototype[strTag] = 'FileReader' | ||||
| //     } | ||||
|  | ||||
| //     var blob = global.Blob.prototype | ||||
| //     var stream | ||||
|  | ||||
| //     function promisify(obj) { | ||||
| //         return new Promise(function (resolve, reject) { | ||||
| //             obj.onload = | ||||
| //                 obj.onerror = function (evt) { | ||||
| //                     obj.onload = | ||||
| //                         obj.onerror = null | ||||
|  | ||||
| //                     evt.type === 'load' | ||||
| //                         ? resolve(obj.result || obj) | ||||
| //                         : reject(new Error('Failed to read the blob/file')) | ||||
| //                 } | ||||
| //         }) | ||||
| //     } | ||||
|  | ||||
|  | ||||
| //     try { | ||||
| //         new ReadableStream({ type: 'bytes' }) | ||||
| //         stream = function stream() { | ||||
| //             var position = 0 | ||||
| //             var blob = this | ||||
|  | ||||
| //             return new ReadableStream({ | ||||
| //                 type: 'bytes', | ||||
| //                 autoAllocateChunkSize: 524288, | ||||
|  | ||||
| //                 pull: function (controller) { | ||||
| //                     var v = controller.byobRequest.view | ||||
| //                     var chunk = blob.slice(position, position + v.byteLength) | ||||
| //                     return chunk.arrayBuffer() | ||||
| //                         .then(function (buffer) { | ||||
| //                             var uint8array = new Uint8Array(buffer) | ||||
| //                             var bytesRead = uint8array.byteLength | ||||
|  | ||||
| //                             position += bytesRead | ||||
| //                             v.set(uint8array) | ||||
| //                             controller.byobRequest.respond(bytesRead) | ||||
|  | ||||
| //                             if (position >= blob.size) | ||||
| //                                 controller.close() | ||||
| //                         }) | ||||
| //                 } | ||||
| //             }) | ||||
| //         } | ||||
| //     } catch (e) { | ||||
| //         try { | ||||
| //             new ReadableStream({}) | ||||
| //             stream = function stream(blob) { | ||||
| //                 var position = 0 | ||||
| //                 var blob = this | ||||
|  | ||||
| //                 return new ReadableStream({ | ||||
| //                     pull: function (controller) { | ||||
| //                         var chunk = blob.slice(position, position + 524288) | ||||
|  | ||||
| //                         return chunk.arrayBuffer().then(function (buffer) { | ||||
| //                             position += buffer.byteLength | ||||
| //                             var uint8array = new Uint8Array(buffer) | ||||
| //                             controller.enqueue(uint8array) | ||||
|  | ||||
| //                             if (position == blob.size) | ||||
| //                                 controller.close() | ||||
| //                         }) | ||||
| //                     } | ||||
| //                 }) | ||||
| //             } | ||||
| //         } catch (e) { | ||||
| //             try { | ||||
| //                 new Response('').body.getReader().read() | ||||
| //                 stream = function stream() { | ||||
| //                     return (new Response(this)).body | ||||
| //                 } | ||||
| //             } catch (e) { | ||||
| //                 stream = function stream() { | ||||
| //                     throw new Error('Include https://github.com/MattiasBuelens/web-streams-polyfill') | ||||
| //                 } | ||||
| //             } | ||||
| //         } | ||||
| //     } | ||||
|  | ||||
|  | ||||
| //     if (!blob.arrayBuffer) { | ||||
| //         blob.arrayBuffer = function arrayBuffer() { | ||||
| //             var fr = new FileReader() | ||||
| //             fr.readAsArrayBuffer(this) | ||||
| //             return promisify(fr) | ||||
| //         } | ||||
| //     } | ||||
|  | ||||
| //     if (!blob.text) { | ||||
| //         blob.text = function text() { | ||||
| //             var fr = new FileReader() | ||||
| //             fr.readAsText(this) | ||||
| //             return promisify(fr) | ||||
| //         } | ||||
| //     } | ||||
|  | ||||
| //     if (!blob.stream) { | ||||
| //         blob.stream = stream | ||||
| //     } | ||||
| // })() | ||||
							
								
								
									
										141
									
								
								src/utils/excel/Export2Excel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								src/utils/excel/Export2Excel.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,141 @@ | ||||
| /* eslint-disable */ | ||||
| require('script-loader!file-saver'); | ||||
| // require('script-loader!./Blob.js'); | ||||
| require('script-loader!xlsx/dist/xlsx.core.min'); | ||||
| function generateArray(table) { | ||||
|     var out = []; | ||||
|     var rows = table.querySelectorAll('tr'); | ||||
|     var ranges = []; | ||||
|     for (var R = 0; R < rows.length; ++R) { | ||||
|         var outRow = []; | ||||
|         var row = rows[R]; | ||||
|         var columns = row.querySelectorAll('td'); | ||||
|         for (var C = 0; C < columns.length; ++C) { | ||||
|             var cell = columns[C]; | ||||
|             var colspan = cell.getAttribute('colspan'); | ||||
|             var rowspan = cell.getAttribute('rowspan'); | ||||
|             var cellValue = cell.innerText; | ||||
|             if (cellValue !== "" && cellValue == +cellValue) cellValue = +cellValue; | ||||
|  | ||||
|             //Skip ranges | ||||
|             ranges.forEach(function (range) { | ||||
|                 if (R >= range.s.r && R <= range.e.r && outRow.length >= range.s.c && outRow.length <= range.e.c) { | ||||
|                     for (var i = 0; i <= range.e.c - range.s.c; ++i) outRow.push(null); | ||||
|                 } | ||||
|             }); | ||||
|  | ||||
|             //Handle Row Span | ||||
|             if (rowspan || colspan) { | ||||
|                 rowspan = rowspan || 1; | ||||
|                 colspan = colspan || 1; | ||||
|                 ranges.push({s: {r: R, c: outRow.length}, e: {r: R + rowspan - 1, c: outRow.length + colspan - 1}}); | ||||
|             } | ||||
|             ; | ||||
|  | ||||
|             //Handle Value | ||||
|             outRow.push(cellValue !== "" ? cellValue : null); | ||||
|  | ||||
|             //Handle Colspan | ||||
|             if (colspan) for (var k = 0; k < colspan - 1; ++k) outRow.push(null); | ||||
|         } | ||||
|         out.push(outRow); | ||||
|     } | ||||
|     return [out, ranges]; | ||||
| }; | ||||
|  | ||||
| function datenum(v, date1904) { | ||||
|     if (date1904) v += 1462; | ||||
|     var epoch = Date.parse(v); | ||||
|     return (epoch - new Date(Date.UTC(1899, 11, 30))) / (24 * 60 * 60 * 1000); | ||||
| } | ||||
|  | ||||
| function sheet_from_array_of_arrays(data, opts) { | ||||
|     var ws = {}; | ||||
|     var range = {s: {c: 10000000, r: 10000000}, e: {c: 0, r: 0}}; | ||||
|     for (var R = 0; R != data.length; ++R) { | ||||
|         for (var C = 0; C != data[R].length; ++C) { | ||||
|             if (range.s.r > R) range.s.r = R; | ||||
|             if (range.s.c > C) range.s.c = C; | ||||
|             if (range.e.r < R) range.e.r = R; | ||||
|             if (range.e.c < C) range.e.c = C; | ||||
|             var cell = {v: data[R][C]}; | ||||
|             if (cell.v == null) continue; | ||||
|             var cell_ref = XLSX.utils.encode_cell({c: C, r: R}); | ||||
|  | ||||
|             if (typeof cell.v === 'number') cell.t = 'n'; | ||||
|             else if (typeof cell.v === 'boolean') cell.t = 'b'; | ||||
|             else if (cell.v instanceof Date) { | ||||
|                 cell.t = 'n'; | ||||
|                 cell.z = XLSX.SSF._table[14]; | ||||
|                 cell.v = datenum(cell.v); | ||||
|             } | ||||
|             else cell.t = 's'; | ||||
|  | ||||
|             ws[cell_ref] = cell; | ||||
|         } | ||||
|     } | ||||
|     if (range.s.c < 10000000) ws['!ref'] = XLSX.utils.encode_range(range); | ||||
|     return ws; | ||||
| } | ||||
|  | ||||
| function Workbook() { | ||||
|     if (!(this instanceof Workbook)) return new Workbook(); | ||||
|     this.SheetNames = []; | ||||
|     this.Sheets = {}; | ||||
| } | ||||
|  | ||||
| function s2ab(s) { | ||||
|     var buf = new ArrayBuffer(s.length); | ||||
|     var view = new Uint8Array(buf); | ||||
|     for (var i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF; | ||||
|     return buf; | ||||
| } | ||||
|  | ||||
| export function export_table_to_excel(id) { | ||||
|     var theTable = document.getElementById(id); | ||||
|     console.log('a') | ||||
|     var oo = generateArray(theTable); | ||||
|     var ranges = oo[1]; | ||||
|  | ||||
|     /* original data */ | ||||
|     var data = oo[0]; | ||||
|     var ws_name = "SheetJS"; | ||||
|     console.log(data); | ||||
|  | ||||
|     var wb = new Workbook(), ws = sheet_from_array_of_arrays(data); | ||||
|  | ||||
|     /* add ranges to worksheet */ | ||||
|     // ws['!cols'] = ['apple', 'banan']; | ||||
|     ws['!merges'] = ranges; | ||||
|  | ||||
|     /* add worksheet to workbook */ | ||||
|     wb.SheetNames.push(ws_name); | ||||
|     wb.Sheets[ws_name] = ws; | ||||
|  | ||||
|     var wbout = XLSX.write(wb, {bookType: 'xlsx', bookSST: false, type: 'binary'}); | ||||
|  | ||||
|     saveAs(new Blob([s2ab(wbout)], {type: "application/octet-stream"}), "test.xlsx") | ||||
| } | ||||
|  | ||||
| function formatJson(jsonData) { | ||||
|     console.log(jsonData) | ||||
| } | ||||
| export function export_json_to_excel(th, jsonData, defaultTitle) { | ||||
|  | ||||
|     /* original data */ | ||||
|  | ||||
|     var data = jsonData; | ||||
|     data.unshift(th); | ||||
|     var ws_name = "SheetJS"; | ||||
|  | ||||
|     var wb = new Workbook(), ws = sheet_from_array_of_arrays(data); | ||||
|  | ||||
|  | ||||
|     /* add worksheet to workbook */ | ||||
|     wb.SheetNames.push(ws_name); | ||||
|     wb.Sheets[ws_name] = ws; | ||||
|  | ||||
|     var wbout = XLSX.write(wb, {bookType: 'xlsx', bookSST: false, type: 'binary'}); | ||||
|     var title = defaultTitle || '列表' | ||||
|     saveAs(new Blob([s2ab(wbout)], {type: "application/octet-stream"}), title + ".xlsx") | ||||
| } | ||||
							
								
								
									
										26
									
								
								src/utils/excelUtils.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								src/utils/excelUtils.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| import * as XLSX from 'xlsx'; | ||||
| const exportToExcel = (row, fileName, list, sheetNames) => {//调用方式 exportToExcel(接口返回的表格列表, "文件名", 定义的表头和字段[{ piko号: "erbanNo" }{ piko号: "erbanNo" }],, ["Sheet1"]); | ||||
|     var data = []; | ||||
|     var headerTitle = []; | ||||
|     row.forEach((res, i) => { | ||||
|         var arr = []; | ||||
|         for (let index = 0; index < list.length; index++) { | ||||
|             for (let key in list[index]) { | ||||
|                 headerTitle[index] = key; | ||||
|                 arr[index] = res[list[index][key]]; | ||||
|             } | ||||
|         } | ||||
|         data[i] = arr; | ||||
|     }); | ||||
|     let smallArr = Array.from(data); | ||||
|     let bigArr = []; | ||||
|     smallArr = smallArr.map((item) => { | ||||
|         bigArr.push(Object.values(item)); | ||||
|     }); | ||||
|     const ws = XLSX.utils.aoa_to_sheet([...[headerTitle], ...bigArr]); // tableName为表头,tableData为数据 | ||||
|     const wb = XLSX.utils.book_new(); | ||||
|     // 将工作表放入工作簿中 | ||||
|     XLSX.utils.book_append_sheet(wb, ws, sheetNames); | ||||
|     XLSX.writeFile(wb, fileName + ".xlsx"); | ||||
| } | ||||
| export default exportToExcel | ||||
							
								
								
									
										11
									
								
								src/utils/exportExcel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								src/utils/exportExcel.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| function formatJson(filterVal, jsonData) { | ||||
| 	return jsonData.map(v => filterVal.map(j => v[j])); | ||||
| } | ||||
|  | ||||
| export const exportExcel = (tHeader, filterVal, data, excelName) => { | ||||
| 	require.ensure([], () => { | ||||
| 		const { export_json_to_excel } = require('./excel/Export2Excel.js'); | ||||
| 		const combineData = formatJson(filterVal, data); | ||||
| 		export_json_to_excel(tHeader, combineData, excelName); | ||||
| 	}); | ||||
| } | ||||
| @@ -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); | ||||
| @@ -73,4 +47,13 @@ export function apiResult(json) { | ||||
|     $("#tipMsg").text("请求失败,错误信息:" + json.message); | ||||
|     $("#tipModal").modal('show'); | ||||
|     return false; | ||||
| } | ||||
|  | ||||
| export function genQueryParam(json) { | ||||
|     if (!json) return '' | ||||
|     return cleanArray(Object.keys(json).map(key => { | ||||
|         if (json[key] === undefined) return '' | ||||
|         return encodeURIComponent(key) + '=' + | ||||
|             encodeURIComponent(json[key]) | ||||
|     })).join('&'); | ||||
| } | ||||
| @@ -3,7 +3,7 @@ export const notifyNotice = () => { | ||||
|     console.log(window.Notification.permission); | ||||
|     if (window.Notification) { | ||||
|         $.ajax({ | ||||
|             url: "/admin/dynamic/verify/notifySwitch.action", | ||||
|             url: "/admin/dynamic/verify/notifySwitch", | ||||
|             success: function (json) { | ||||
|                 if (json == 'true') { | ||||
|                     notifyInterval = setInterval(notify, 50000); | ||||
| @@ -17,7 +17,7 @@ export const notifyNotice = () => { | ||||
|  | ||||
|     function notify() { | ||||
|         $.ajax({ | ||||
|             url: "/admin/dynamic/verify/notify.action", | ||||
|             url: "/admin/dynamic/verify/notify", | ||||
|             success: function (json) { | ||||
|                 if (json != null && json != "" && json != undefined && json != 'undefined') { | ||||
|                     var dynamicCount = json.dynamic; | ||||
|   | ||||
							
								
								
									
										20
									
								
								src/utils/partitionDesc.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								src/utils/partitionDesc.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| const partitionInfoMap = { | ||||
|     1: '英语区', | ||||
|     2: '阿拉伯语区', | ||||
|     4: '华语区', | ||||
|     8: '土耳其区', | ||||
| } | ||||
|  | ||||
| export const partitionDesc = (val) => { | ||||
|     return Object.keys(partitionInfoMap).filter(k=>{ | ||||
|         return(Number(val) & Number(k)) != 0  | ||||
|     }).map(k=>partitionInfoMap[k]).join(","); | ||||
| } | ||||
|  | ||||
| export const partitionIdArr = (val) => { | ||||
|     var arr =[]; | ||||
|      Object.keys(partitionInfoMap).filter(k=>{ | ||||
|         return(Number(val) & Number(k)) != 0  | ||||
|     }).map(k=>arr.push(Number(k))); | ||||
|     return arr | ||||
| } | ||||
							
								
								
									
										107
									
								
								src/utils/relDate.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								src/utils/relDate.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| export const formatDate = (value) => { | ||||
|     let timezone = 3; //目标时区时间,东3区(东时区正数 西时区负数) | ||||
|     let offset_GMT = new Date(value).getTimezoneOffset(); // 本地时间和格林威治的时间差,单位为分钟 | ||||
|     let nowDate = new Date(value).getTime(); // 本地时间距 1970 年 1 月 1 日午夜(GMT 时间)之间的毫秒数 | ||||
|     let date = new Date(nowDate + offset_GMT * 60 * 1000 + timezone * 60 * 60 * 1000); | ||||
|  | ||||
|     // 提取年、月、日、小时、分钟和秒 | ||||
|     let y = date.getFullYear(); | ||||
|     let MM = date.getMonth() + 1; | ||||
|     MM = MM < 10 ? ('0' + MM) : MM; | ||||
|     let d = date.getDate(); | ||||
|     d = d < 10 ? ('0' + d) : d; | ||||
|     let h = date.getHours(); | ||||
|     h = h < 10 ? ('0' + h) : h; | ||||
|     let m = date.getMinutes(); | ||||
|     m = m < 10 ? ('0' + m) : m; | ||||
|     let s = date.getSeconds(); | ||||
|     s = s < 10 ? ('0' + s) : s; | ||||
|     return `${y}-${MM}-${d} ${h}:${m}:${s}`; | ||||
| } | ||||
|  | ||||
| export const formatDate2 = (value) => { | ||||
|     let timezone = 3; //目标时区时间,东3区(东时区正数 西时区负数) | ||||
|     let offset_GMT = new Date(value).getTimezoneOffset(); // 本地时间和格林威治的时间差,单位为分钟 | ||||
|     let nowDate = new Date(value).getTime(); // 本地时间距 1970 年 1 月 1 日午夜(GMT 时间)之间的毫秒数 | ||||
|     let date = new Date(nowDate + offset_GMT * 60 * 1000 + timezone * 60 * 60 * 1000); | ||||
|  | ||||
|     let y = date.getFullYear(); | ||||
|     let MM = date.getMonth() + 1; | ||||
|     MM = MM < 10 ? ('0' + MM) : MM; | ||||
|     let d = date.getDate(); | ||||
|     d = d < 10 ? ('0' + d) : d; | ||||
|     let h = date.getHours(); | ||||
|     h = h < 10 ? ('0' + h) : h; | ||||
|     let m = date.getMinutes(); | ||||
|     m = m < 10 ? ('0' + m) : m; | ||||
|     let s = date.getSeconds(); | ||||
|     s = s < 10 ? ('0' + s) : s; | ||||
|     return `${y}/${MM}/${d} ${h}:${m}:${s}`; | ||||
| } | ||||
|  | ||||
| export const formatDateYMD = (value) => { | ||||
|     let timezone = 3; //目标时区时间,东3区(东时区正数 西时区负数) | ||||
|     let offset_GMT = new Date(value).getTimezoneOffset(); // 本地时间和格林威治的时间差,单位为分钟 | ||||
|     let nowDate = new Date(value).getTime(); // 本地时间距 1970 年 1 月 1 日午夜(GMT 时间)之间的毫秒数 | ||||
|     let date = new Date(nowDate + offset_GMT * 60 * 1000 + timezone * 60 * 60 * 1000); | ||||
|  | ||||
|     let y = date.getFullYear(); | ||||
|     let MM = date.getMonth() + 1; | ||||
|     MM = MM < 10 ? ('0' + MM) : MM; | ||||
|     let d = date.getDate(); | ||||
|     d = d < 10 ? ('0' + d) : d; | ||||
|     let h = date.getHours(); | ||||
|     h = h < 10 ? ('0' + h) : h; | ||||
|     let m = date.getMinutes(); | ||||
|     m = m < 10 ? ('0' + m) : m; | ||||
|     let s = date.getSeconds(); | ||||
|     s = s < 10 ? ('0' + s) : s; | ||||
|     return `${y}/${MM}/${d}`; | ||||
| } | ||||
|  | ||||
| export const formatDateYYYYMMDD = (value) => { | ||||
|     let date = new Date(value); | ||||
|     // 将时区设置为GMT+3 | ||||
|     let gmtOffset = 3; // GMT+3时区偏移量为3小时 | ||||
|     let localOffset = date.getTimezoneOffset() / 60; // 获取本地时区偏移量(以小时为单位) | ||||
|     let targetOffset = gmtOffset - localOffset; // 计算目标时区偏移量 | ||||
|     date.setHours(date.getHours() + targetOffset); // 根据偏移量调整小时 | ||||
|  | ||||
|     const y = date.getFullYear(); | ||||
|     let MM = date.getMonth() + 1; | ||||
|     MM = MM < 10 ? ('0' + MM) : MM; | ||||
|     let d = date.getDate(); | ||||
|     d = d < 10 ? ('0' + d) : d; | ||||
|     let h = date.getHours(); | ||||
|     h = h < 10 ? ('0' + h) : h; | ||||
|     let m = date.getMinutes(); | ||||
|     m = m < 10 ? ('0' + m) : m; | ||||
|     let s = date.getSeconds(); | ||||
|     s = s < 10 ? ('0' + s) : s; | ||||
|  | ||||
|     return `${y}-${MM}-${d}`; | ||||
| } | ||||
|  | ||||
|  | ||||
| export const formatDateYYYYMM = (value) => { | ||||
|     let date = new Date(value); | ||||
|     // 将时区设置为GMT+3 | ||||
|     let gmtOffset = 3; // GMT+3时区偏移量为3小时 | ||||
|     let localOffset = date.getTimezoneOffset() / 60; // 获取本地时区偏移量(以小时为单位) | ||||
|     let targetOffset = gmtOffset - localOffset; // 计算目标时区偏移量 | ||||
|     date.setHours(date.getHours() + targetOffset); // 根据偏移量调整小时 | ||||
|  | ||||
|     let y = date.getFullYear(); | ||||
|     let MM = date.getMonth() + 1; | ||||
|     MM = MM < 10 ? ('0' + MM) : MM; | ||||
|     let d = date.getDate(); | ||||
|     d = d < 10 ? ('0' + d) : d; | ||||
|     let h = date.getHours(); | ||||
|     h = h < 10 ? ('0' + h) : h; | ||||
|     let m = date.getMinutes(); | ||||
|     m = m < 10 ? ('0' + m) : m; | ||||
|     let s = date.getSeconds(); | ||||
|     s = s < 10 ? ('0' + s) : s; | ||||
|     console.log(y, MM, d, h, s); | ||||
|     return `${y}-${MM}`; | ||||
| } | ||||
| @@ -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; | ||||
|   | ||||
| @@ -19,4 +19,11 @@ export function upperFirst(str) { | ||||
|  */ | ||||
| export function lowerFirst(str) { | ||||
|     return str.charAt(0).toLowerCase() + str.slice(1); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * 是否为数字 | ||||
|  */ | ||||
| export function isNumber(str) { | ||||
|     return /^[0-9]+.?[0-9]*/.test(str); | ||||
| } | ||||
| @@ -1,6 +1,54 @@ | ||||
| //获取url中的参数 | ||||
| function getUrlParam(name) { | ||||
| export function getUrlParam(name) { | ||||
|     var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); //构造一个含有目标参数的正则表达式对象 | ||||
|     var r = window.location.search.substr(1).match(reg);  //匹配目标参数 | ||||
|     if (r != null) return unescape(r[2]); return null; //返回参数值 | ||||
| } | ||||
|  | ||||
| export function dateFormat (date, fmt) { | ||||
|     date = new Date(date); | ||||
|     var o = { | ||||
|         'M+': date.getMonth() + 1, | ||||
|         'd+': date.getDate(), | ||||
|         'h+': date.getHours(), | ||||
|         'm+': date.getMinutes(), | ||||
|         's+': date.getSeconds() | ||||
|     }; | ||||
|  | ||||
|     // 补全0 | ||||
|     let padLeftZero = (str) => { | ||||
|         return ('00' + str).substr(str.length); | ||||
|     } | ||||
|  | ||||
|     // 年份 | ||||
|     if (/(y+)/.test(fmt)) { | ||||
|         fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length)); | ||||
|     } | ||||
|  | ||||
|     // 月日时分秒 | ||||
|     for (var k in o) { | ||||
|         if (new RegExp('(' + k + ')').test(fmt)) { | ||||
|             var str = o[k] + ''; | ||||
|             fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? str : padLeftZero(str)); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     date = o = padLeftZero = null; | ||||
|     return fmt; | ||||
| } | ||||
|  | ||||
| export function buildSelectOption(id, defVal, array) { | ||||
|     let $select = $(id); | ||||
|     let children = $select.children();  | ||||
|     if (children && children.length > 0) { | ||||
|         $select.empty(); | ||||
|     } | ||||
|     for(let i in array) { | ||||
|         let obj = array[i]; | ||||
|         let selected = false; | ||||
|         if (obj.value == defVal) { | ||||
|             selected = true; | ||||
|         } | ||||
|         $select.append('<option value="' + obj.value + '"' + (selected ? 'selected' : '') + '>' + obj.text + '</option>'); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										24
									
								
								src/views/BlankView.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								src/views/BlankView.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
| <template> | ||||
|     <div></div> | ||||
| </template> | ||||
|    | ||||
| <script> | ||||
| import router from '@/router'; | ||||
|  | ||||
| export default { | ||||
|     name: 'BlankView', | ||||
|     created() { | ||||
|         console.log('blank...'); | ||||
|         console.log(window.performance.navigation.type); | ||||
|         //处理css样式污染问题 | ||||
|         if (window.performance.navigation.type == window.performance.navigation.TYPE_RELOAD) { | ||||
|             router.push('/home'); | ||||
|         } else { | ||||
|             console.log('router go ...'); | ||||
|             router.go(0); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| </script> | ||||
|    | ||||
| <style scoped></style> | ||||
							
								
								
									
										242
									
								
								src/views/GiftPanelManagement/GiftPanelManagement.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										242
									
								
								src/views/GiftPanelManagement/GiftPanelManagement.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,242 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 选择分区 --> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">选择分区</span> | ||||
|         <el-select | ||||
|           v-model="inquire.partitionId" | ||||
|           style="width: 75%" | ||||
|           placeholder="请选择" | ||||
|           @change="handleChange" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in inquire.inquireonInfos" | ||||
|             :key="item.id" | ||||
|             :label="item.desc" | ||||
|             :value="item.id" | ||||
|           ></el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="seq" align="center" label="排序" /> | ||||
|       <el-table-column prop="name" align="center" label="礼物面板类型" /> | ||||
|       <el-table-column prop="enable" align="center" label="是否生效"> | ||||
|         <template v-slot="scope">{{ scope.row.enable ? "是" : "否" }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="操作"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="ediClick(scope.row)" | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             size="default" | ||||
|             >编辑</el-button | ||||
|           > | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|     <!-- 编辑弹窗 --> | ||||
|     <el-dialog v-model="eidDialog" :title="eidDialogTitle" width="30%" center> | ||||
|       <!-- 礼物面板类型 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; white-space: nowrap; margin-right: 70px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >礼物面板类型</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="eidObj.type" | ||||
|           style="width: 60%" | ||||
|           class="input" | ||||
|           placeholder="请输入" | ||||
|           disabled | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <!-- 面板排序 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; white-space: nowrap; margin-right: 70px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >面板排序-{{ eidText }}</span | ||||
|         > | ||||
|         <el-input | ||||
|           v-model="eidObj.seq" | ||||
|           style="width: 60%" | ||||
|           class="input" | ||||
|           placeholder="请输入" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <!-- 是否生效 --> | ||||
|       <div style="margin-bottom: 25px; margin-top: 10px"> | ||||
|         <span | ||||
|           style="display: inline-block; white-space: nowrap; margin-right: 70px" | ||||
|           class="col-sm-2 control-label" | ||||
|           >是否生效</span | ||||
|         > | ||||
|         <el-select | ||||
|           v-model="eidObj.value" | ||||
|           style="width: 60%" | ||||
|           placeholder="请选择" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in eidObj.option" | ||||
|             :key="item.id" | ||||
|             :label="item.desc" | ||||
|             :value="item.id" | ||||
|           ></el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="eidDialog = false">取消</el-button> | ||||
|           <el-button type="primary" @click="eidDialogClick()"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { list, update } from "@/api/GiftPanelManagement/GiftPanelManagement"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "GiftPanelManagement", | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         partitionId: 4, | ||||
|         inquireonInfos: [ | ||||
|           { desc: "英语区", id: 1 }, | ||||
|           { desc: "阿拉伯区", id: 2 }, | ||||
|           { desc: "华语区", id: 4 }, | ||||
|           { desc: "土耳其区", id: 8 }, | ||||
|         ], | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 编辑 | ||||
|       eidDialog: false, | ||||
|       eidDialogTitle: "", | ||||
|       eidText: "", | ||||
|       eidObjNew: {}, | ||||
|       eidObj: { | ||||
|         type: "", | ||||
|         clientName: "", | ||||
|         seq: "", | ||||
|         value: "", | ||||
|         option: [ | ||||
|           { | ||||
|             desc: "是", | ||||
|             id: true, | ||||
|           }, | ||||
|           { | ||||
|             desc: "否", | ||||
|             id: false, | ||||
|           }, | ||||
|         ], | ||||
|       }, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.eidDialogTitle = `编辑礼物面板信息-华语区`; | ||||
|     this.eidText = `华语区`; | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       list({ | ||||
|         partitionId: this.inquire.partitionId, | ||||
|       }).then((res) => { | ||||
|         this.tableData = res.data; | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     ediClick(val) { | ||||
|       this.eidDialog = true; | ||||
|       this.eidObj.type = val.name; | ||||
|       this.eidObj.seq = val.seq; | ||||
|       this.eidObj.value = val.enable; | ||||
|       this.eidObjNew = val; | ||||
|     }, | ||||
|     eidDialogClick() { | ||||
|       update({ | ||||
|         enable: this.eidObj.value, | ||||
|         id: this.eidObjNew.id, | ||||
|         seq: this.eidObj.seq, | ||||
|         partitionId: this.inquire.partitionId, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: "编辑成功", | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.eidDialog = false; | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     handleChange(val) { | ||||
|       console.log(val); | ||||
|       if (val == 1) { | ||||
|         this.eidDialogTitle = `编辑礼物面板信息-英语区`; | ||||
|         this.eidText = `英语区`; | ||||
|       } else if (val == 2) { | ||||
|         this.eidDialogTitle = `编辑礼物面板信息-阿拉伯区`; | ||||
|         this.eidText = `阿拉伯区`; | ||||
|       } else if (val == 4) { | ||||
|         this.eidDialogTitle = `编辑礼物面板信息-华语区`; | ||||
|         this.eidText = `华语区`; | ||||
|       }else if (val == 8) { | ||||
|         this.eidDialogTitle = `编辑礼物面板信息-土耳其区`; | ||||
|         this.eidText = `土耳其区`; | ||||
|       } | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 70px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
| @@ -213,7 +213,7 @@ export default { | ||||
|                         return param; | ||||
|                     }, | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/sms/list.action', | ||||
|                     url: '/admin/sms/list', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
| @@ -256,7 +256,7 @@ export default { | ||||
|                     showLoading(); | ||||
|                     var option = ({ | ||||
|                         type: "POST", | ||||
|                         url: "/admin/sms/uploadExcel.action", | ||||
|                         url: "/admin/sms/uploadExcel", | ||||
|                         cache: false, | ||||
|                         contentType: false,    //不可缺 | ||||
|                         processData: false,    //不可缺 | ||||
| @@ -310,7 +310,7 @@ export default { | ||||
|                         createTime: createTime, | ||||
|                         sendTime: sendTime | ||||
|                     }; | ||||
|                     var url = "/admin/sms/query/send.action"; | ||||
|                     var url = "/admin/sms/query/send"; | ||||
|                     if (confirm("按查询条件发送最多一次可发送一万条短信!已发送过的用户不会重复发送,你确认批量发送吗?")) { | ||||
|                         sendSmsByData(data, url); | ||||
|                     } | ||||
| @@ -329,7 +329,7 @@ export default { | ||||
|                     var data = { | ||||
|                         ids: JSON.stringify(idArr) | ||||
|                     } | ||||
|                     var url = "/admin/sms/page/send.action"; | ||||
|                     var url = "/admin/sms/page/send"; | ||||
|                     if (confirm("你确认批量发送吗?")) { | ||||
|                         sendSmsByData(data, url); | ||||
|                     } | ||||
| @@ -338,7 +338,7 @@ export default { | ||||
|                 $("#table").on('click', '.opt-send', function () { | ||||
|                     var id = $(this).attr("data-id"); | ||||
|                     var data = { recordId: id }; | ||||
|                     var url = "/admin/sms/send.action"; | ||||
|                     var url = "/admin/sms/send"; | ||||
|                     if (confirm("已经发送过的短信将会重复发送,确定重复发送短信吗?")) { | ||||
|                         sendSmsByData(data, url); | ||||
|                     } | ||||
| @@ -349,7 +349,7 @@ export default { | ||||
|                     if (confirm("删除的数据将不能找回,确定删除吗?")) { | ||||
|                         $.ajax({ | ||||
|                             type: "post", | ||||
|                             url: "/admin/sms/del.action", | ||||
|                             url: "/admin/sms/del", | ||||
|                             data: { recordId: id }, | ||||
|                             dataType: "json", | ||||
|                             success: function (json) { | ||||
| @@ -389,6 +389,7 @@ export default { | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -62,7 +62,7 @@ export default { | ||||
|             } | ||||
|             $.ajax({ | ||||
|                 type: "POST", | ||||
|                 url: "/admin/qiniu/uploadPatch.action", | ||||
|                 url: "/admin/qiniu/uploadPatch", | ||||
|                 data: data, | ||||
|                 cache: false, | ||||
|                 contentType: false,    //不可缺 | ||||
|   | ||||
							
								
								
									
										195
									
								
								src/views/TencentUploadAdminView.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										195
									
								
								src/views/TencentUploadAdminView.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,195 @@ | ||||
| <template> | ||||
|     <section class="content"> | ||||
|         <div class="box box-primary"> | ||||
|             <div class="box-body"> | ||||
|                 <section class="content-header"> | ||||
|                     <h1 id="itemTitle"></h1> | ||||
|                 </section> | ||||
|                 <!-- .content --> | ||||
|                 <div id="table"></div> | ||||
|                 <div id="toolbar"> | ||||
|                     <br /> | ||||
|                     <br /> | ||||
|                           <button id="updateImgs" class="btn btn-sm btn-primary">上传文件</button> | ||||
|                     <h3 id="urlInfo"></h3> | ||||
|                     <br /> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|  | ||||
|     <div class=" modal fade" id="fileUpload" tabindex="-1" role="dialog" aria-labelledby="modalLabel1"> | ||||
|         <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="modalLabel1">上传文件</h4> | ||||
|                 </div> | ||||
|                 <div class="modal-footer" style="height: 20%"> | ||||
|                     <span>上传文件</span> | ||||
|                     <!--<input type="file" name="file" id="uploadFile">--> | ||||
|                     <input type="file" name="logoFile1" id="logoFile1" onchange="setFiles(this);" style="display:inline;" | ||||
|                         multiple> | ||||
|                     <!--<button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>--> | ||||
|                     <!--<button type="button" class="btn btn-primary" id="upload">上传七牛</button>--> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|     </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|  | ||||
| export default { | ||||
|     name: "TencentUploadAdminView", | ||||
|     setup() { | ||||
|  | ||||
|         function setFiles(obj) { | ||||
|             $("#confirmMsg").text("正在上传,请稍后"); | ||||
|             $("#confirmModal").modal('show'); | ||||
|             var f = $(obj).val(); | ||||
|             if (f == null || f == undefined || f == '') { | ||||
|                 return false; | ||||
|             } | ||||
|             var filePaths = $(obj)[0].files; | ||||
|             var num = filePaths.length; | ||||
|             var data = new FormData(); | ||||
|             for (var i = 0; i <= num - 1; i++) { | ||||
|                 var file = $(obj)[0].files[i]; | ||||
|                 data.append('file_' + i, file); | ||||
|             } | ||||
|             $.ajax({ | ||||
|                 type: "POST", | ||||
|                 url: "/admin/tencent/cos/uploadPatch", | ||||
|                 data: data, | ||||
|                 cache: false, | ||||
|                 contentType: false,    //不可缺 | ||||
|                 processData: false,    //不可缺 | ||||
|                 dataType: "json", | ||||
|                 success: function (res) { | ||||
|                     $("#logoFile1").val(""); | ||||
|                     $("#confirmModal").modal('hide'); | ||||
|                     $("#fileUpload").modal('hide'); | ||||
|                     console.log(res) | ||||
|                     if (res.code == 200) { | ||||
|                         $("#tipMsg").text("上传成功"); | ||||
|                         $("#tipModal").modal('show'); | ||||
|                         buildResult(res.data); | ||||
|                     } else { | ||||
|                         $("#tipMsg").text("上传失败."); | ||||
|                         $("#tipModal").modal('show'); | ||||
|                     } | ||||
|                 } | ||||
|             }); | ||||
|         } | ||||
|         window.setFiles = setFiles; | ||||
|         return { | ||||
|             setFiles | ||||
|         }; | ||||
|     }, | ||||
|     created() { | ||||
|         this.$nextTick(function () { | ||||
|             this.initData(); | ||||
|         }); | ||||
|     }, | ||||
|     methods: { | ||||
|         initData() { | ||||
|             $("#updateImgs").click(function () { | ||||
|                 $("#uploadFile").val(""); | ||||
|                 $("#fileUpload").modal('show'); | ||||
|             }); | ||||
|  | ||||
|             $("#upload").click(function () { | ||||
|                 $.ajaxFileUpload({ | ||||
|                     fileElementId: 'uploadFile',    //需要上传的文件域的ID,即<input type="file">的ID。 | ||||
|                     url: "/admin/tencent/cos/upload", //后台方法的路径 | ||||
|                     type: 'post',   //当要提交自定义参数时,这个参数要设置成post | ||||
|                     dataType: 'json',   //服务器返回的数据类型。可以为xml,script,json,html。如果不填写,jQuery会自动判断。 | ||||
|                     secureuri: false,   //是否启用安全提交,默认为false。 | ||||
|                     async: true,   //是否是异步 | ||||
|                     success: function (json) {   //提交成功后自动执行的处理函数,参数data就是服务器返回的数据。 | ||||
|                         console.log(json) | ||||
|                         if (json.flag) { | ||||
|                             $("#urlInfo").html(json.url); | ||||
|                             $("#tipMsg").text("上传成功"); | ||||
|                             $("#tipModal").modal('show'); | ||||
|                         } | ||||
|                         else { | ||||
|                             $("#tipMsg").text("上传失败."); | ||||
|                             $("#tipModal").modal('show'); | ||||
|                         } | ||||
|                         $("#faceJsonImgsUpload").modal('hide'); | ||||
|                     }, | ||||
|                     error: function (data, status, e) {  //提交失败自动执行的处理函数。 | ||||
|                         console.error(e); | ||||
|                         $("#tipMsg").text("上传失败"); | ||||
|                         $("#tipModal").modal('show'); | ||||
|                     } | ||||
|                 }); | ||||
|  | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
| }; | ||||
|  | ||||
| function buildResult(data) { | ||||
|     var $urlInfo = $('#urlInfo'); | ||||
|     for (var i = 0; i < data.length; i++) { | ||||
|         var $p = $('<p />'); | ||||
|         $p.html(data[i]); | ||||
|         $urlInfo.append($p); | ||||
|     } | ||||
| } | ||||
| </script> | ||||
|  | ||||
| <style scoped> | ||||
|  .bar1, .bar2 { | ||||
|         margin-bottom: 10px; | ||||
|     } | ||||
|  | ||||
|     label.col-sm-1 { | ||||
|         padding: 0; | ||||
|         line-height: 30px; | ||||
|         text-align: right; | ||||
|         /*padding-right: 4px;*/ | ||||
|     } | ||||
|  | ||||
|     label.col-sm-1 { | ||||
|         padding: 0; | ||||
|         line-height: 30px; | ||||
|         text-align: right; | ||||
|         /*padding-right: 4px;*/ | ||||
|     } | ||||
|  | ||||
|     input, select { | ||||
|         margin-left: 8px; | ||||
|         margin-right: 8px; | ||||
|     } | ||||
|  | ||||
|     .button-wrapper { | ||||
|         margin-top: 10px; | ||||
|     } | ||||
|  | ||||
|     .record { | ||||
|         margin-top: 10px; | ||||
|     } | ||||
|  | ||||
|     .record .title { | ||||
|         font-size: 16px; | ||||
|     } | ||||
|  | ||||
|     .toggle-group { | ||||
|         display: none; | ||||
|     } | ||||
|  | ||||
|     .tips { | ||||
|         font-size: 13px; | ||||
|         color: red; | ||||
|     } | ||||
|  | ||||
|     .opt-group .col-sm-7 { | ||||
|         text-align: left; | ||||
|     } | ||||
| </style> | ||||
							
								
								
									
										355
									
								
								src/views/accessRestriction/AccessRestriction.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										355
									
								
								src/views/accessRestriction/AccessRestriction.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,355 @@ | ||||
| <template> | ||||
|   <div class="outer"> | ||||
|     <div class="search"> | ||||
|       <div class="searchLeft"> | ||||
|         <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="add()" | ||||
|         >新增</el-button | ||||
|       > | ||||
|       <el-button class="primary" type="primary" size="default" @click="search()" | ||||
|         >查询</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <!-- 列表 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="erbanNo" align="center" label="用戶id" /> | ||||
|       <el-table-column prop="nick" align="center" label="用戶昵称" /> | ||||
|       <el-table-column prop="phone" align="center" label="手机号" /> | ||||
|       <el-table-column prop="signTime" align="center" label="注册时间" /> | ||||
|       <el-table-column prop="createTime" align="center" label="进入访问限制时间" /> | ||||
|       <el-table-column prop="inviteCode" align="center" label="邀请码" /> | ||||
|       <el-table-column prop="signDeviceId" align="center" label="注册设备" /> | ||||
|       <el-table-column prop="deviceIds" align="center" label="访问设备" /> | ||||
|       <el-table-column prop="lastCheckIpRegion" align="center" label="最近一次访问地点" /> | ||||
|       <el-table-column align="center" label="平台" | ||||
|         ><template v-slot="scope">{{ | ||||
|           scope.row.os == "android" ? "安卓" : "苹果" | ||||
|         }}</template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="sim卡信息" width="150" | ||||
|         ><template v-slot="scope"> | ||||
|           <div v-html="tableArrFormat(scope.row)"></div> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="系统语言" width="200"> | ||||
|         <template v-slot="scope"> | ||||
|           {{langFormat(scope.row.lang)}} | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="操作" width="300"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="unfreeze(scope.row)" | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             size="default" | ||||
|             >解除限制</el-button | ||||
|           > | ||||
|           <el-button | ||||
|             @click="addWhite(scope.row)" | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             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="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="sureClick(val, type)"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 添加弹窗 --> | ||||
|     <el-dialog v-model="addSure" title="提示" width="30%" center> | ||||
|       <div class="selectBox"> | ||||
|         <span class="left" style="margin-right: 20px">用户ID</span> | ||||
|         <el-input | ||||
|           v-model="selectUserId" | ||||
|           size="default" | ||||
|           placeholder="用户平台ID" | ||||
|           class="right" | ||||
|           style="width: 70%" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="addSure = false">取消</el-button> | ||||
|           <el-button type="primary" @click="addSureClick()"> 添加 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   recordPage, | ||||
|   addWhite, | ||||
|   relieve, | ||||
|   recordSave, | ||||
| } from "@/api/AccessRestriction.vue/AccessRestriction.js"; | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "AccessRestriction", | ||||
|   data() { | ||||
|     return { | ||||
|       userId: "", //用戶id | ||||
|       loading: false, //列表loading | ||||
|       tableData: [ | ||||
|         { | ||||
|           erbanNo: "123123123", | ||||
|         }, | ||||
|       ], //列表数据 | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|       delDialog: false, //控制公共弹窗展示 | ||||
|       delDialogText: "确定要解除限制吗?", //公共弹窗标题 | ||||
|       type: null, //1解除限制 2加入白名单 | ||||
|       obj: {}, //存放公共参数 | ||||
|       addSure: false, //控制确认添加弹窗展示 | ||||
|       selectUserId: "", //添加用户id | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 初始化 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       recordPage({ | ||||
|         page: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|         userErBanNo: this.userId, | ||||
|       }).then((res) => { | ||||
|         this.tableData = res.data.records; | ||||
|         this.loading = false; | ||||
|         this.total = res.data.total; | ||||
|       }); | ||||
|     }, | ||||
|     // 搜索 | ||||
|     search() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // 新增 | ||||
|     add() { | ||||
|       this.addSure = true; | ||||
|     }, | ||||
|     // 确认新增 | ||||
|     addSureClick() { | ||||
|       this.addSure = false; | ||||
|       this.delDialogText = "确定要添加地区限制访问吗?"; | ||||
|       this.delDialog = true; | ||||
|       this.type = 3; | ||||
|     }, | ||||
|     // 解除限制按钮 | ||||
|     unfreeze(row) { | ||||
|       console.log(row); | ||||
|       this.delDialogText = "确定要解除限制吗?"; | ||||
|       this.delDialog = true; | ||||
|       this.type = 1; | ||||
|       this.obj = row; | ||||
|     }, | ||||
|     // 加入白名单 | ||||
|     addWhite(row) { | ||||
|       console.log(row); | ||||
|       this.delDialogText = "确定要加入白名单吗?"; | ||||
|       this.delDialog = true; | ||||
|       this.type = 2; | ||||
|       this.obj = row; | ||||
|     }, | ||||
|     // 二次确认 | ||||
|     sureClick() { | ||||
|       if (this.type == 1) { | ||||
|         relieve({ uid: this.obj.uid }).then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "success", | ||||
|             }); | ||||
|             this.getData(); | ||||
|           } else { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "error", | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       } else if (this.type == 2) { | ||||
|         addWhite({ uid: this.obj.uid }).then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "success", | ||||
|             }); | ||||
|             this.getData(); | ||||
|           } else { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "error", | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|       if (this.type == 3) { | ||||
|         recordSave({ erBanNoStr: this.selectUserId }).then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             this.selectUserId = ""; | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "success", | ||||
|             }); | ||||
|             this.getData(); | ||||
|           } else { | ||||
|             ElMessage({ | ||||
|               showClose: true, | ||||
|               message: res.message, | ||||
|               type: "error", | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|       this.getData(); | ||||
|       this.delDialog = false; | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange(val) { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange(val) { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // sim格式化 | ||||
|     tableArrFormat(val) { | ||||
|       //   console.log("aaaaaaaaaaaaa", val.simCards); | ||||
|       var str = ""; | ||||
|       if (!val.simCards) { | ||||
|         return; | ||||
|       } | ||||
|       val.simCards.forEach((res, i) => { | ||||
|         str += ` | ||||
|                 sim卡${i + 1}: ${ | ||||
|           res == 452 | ||||
|             ? "越南" | ||||
|             : res == 454 | ||||
|             ? "香港" | ||||
|             : res == 460 | ||||
|             ? "中国" | ||||
|             : res == 466 | ||||
|             ? "台湾" | ||||
|             : res == 456 | ||||
|             ? "柬埔寨" | ||||
|             : res == 502 | ||||
|             ? "马来西亚" | ||||
|             : res == 525 | ||||
|             ? "新加坡" | ||||
|             : res == 510 | ||||
|             ? "印尼" | ||||
|             : res == 414 | ||||
|             ? "缅甸" | ||||
|             : res == 515 | ||||
|             ? "菲律宾" | ||||
|             : res == 520 | ||||
|             ? "泰国" | ||||
|             : res == 457 | ||||
|             ? "老挝" | ||||
|             : res | ||||
|         }<br> | ||||
|             `; | ||||
|       }); | ||||
|       return str; | ||||
|     }, | ||||
|     // sim格式化 | ||||
|     langFormat(val) { | ||||
|       var str = ""; | ||||
|       if (val == null) { | ||||
|         str = "空"; | ||||
|       }else if(val.match(/cn/gi)||val.match(/hans/gi)){ | ||||
|         str = `${val}【简体中文】`; | ||||
|       }else if(val.match(/tw/gi)||val.match(/hant/gi)||val.match(/hk/gi)||val.match(/mo/gi)){ | ||||
|         str = `${val}【繁体中文】`; | ||||
|       }else{ | ||||
|         str = val; | ||||
|       } | ||||
|       return str; | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </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> | ||||
							
								
								
									
										355
									
								
								src/views/accessRestriction/AccessWhitelist.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										355
									
								
								src/views/accessRestriction/AccessWhitelist.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,355 @@ | ||||
| <template> | ||||
|   <div class="outer"> | ||||
|     <!-- 搜索 --> | ||||
|     <div class="search"> | ||||
|       <div class="searchLeft"> | ||||
|         <span>用户平台ID</span> | ||||
|         <el-input | ||||
|           v-model="userId" | ||||
|           size="default" | ||||
|           placeholder="用户平台ID" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <div class="searchRight"> | ||||
|         <span>用户手机号</span> | ||||
|         <el-input | ||||
|           v-model="userPhone" | ||||
|           size="default" | ||||
|           placeholder="用户手机号" | ||||
|           class="input" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 按钮 --> | ||||
|     <div class="buttonBox"> | ||||
|       <el-button class="primary" type="primary" size="default" @click="add()" | ||||
|         >新增</el-button | ||||
|       > | ||||
|       <el-button class="primary" type="primary" size="default" @click="search()" | ||||
|         >查询</el-button | ||||
|       > | ||||
|     </div> | ||||
|     <!-- 列表 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="erbanNo" align="center" label="用戶id" /> | ||||
|       <el-table-column prop="phone" align="center" label="用戶手机号" /> | ||||
|       <el-table-column prop="nick" align="center" label="昵称" /> | ||||
|       <el-table-column prop="signTime" align="center" label="注册时间" /> | ||||
|       <el-table-column prop="roleName" align="center" label="身份" /> | ||||
|       <el-table-column prop="createTime" align="center" label="进入白名单时间" /> | ||||
|       <el-table-column prop="lastCheckTime" align="center" label="最近一次访问时间" /> | ||||
|       <el-table-column align="center" label="进入白名单来源"> | ||||
|         <template v-slot="scope"> | ||||
|           {{ | ||||
|             scope.row.source == 1 | ||||
|               ? "手动添加" | ||||
|               : scope.row.source == 2 | ||||
|               ? "手机号申请通过" | ||||
|               : scope.row.source == 3 | ||||
|               ? "限制访问记录添加" | ||||
|               : "未知来源" | ||||
|           }} | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="adminName" align="center" label="操作人" /> | ||||
|       <el-table-column align="center" label="操作" width="300"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button | ||||
|             @click="delWhite(scope.row)" | ||||
|             class="primary" | ||||
|             type="primary" | ||||
|             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="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="sureClick(val, type)"> 确认 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|     <!-- 添加弹窗 --> | ||||
|     <el-dialog v-model="addSure" title="提示" width="30%" center> | ||||
|       <div class="selectBox"> | ||||
|         <span class="left">添加号码类型</span> | ||||
|         <el-select | ||||
|           v-model="value" | ||||
|           fit-input-width="true" | ||||
|           placeholder="请选择" | ||||
|           class="right" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in options" | ||||
|             :key="item.value" | ||||
|             :label="item.label" | ||||
|             :value="item.value" | ||||
|           > | ||||
|           </el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|       <div class="selectBox" v-if="value == 1"> | ||||
|         <span class="left">用户ID</span> | ||||
|         <el-input | ||||
|           v-model="selectUserId" | ||||
|           size="default" | ||||
|           placeholder="用户平台ID" | ||||
|           class="right" | ||||
|         ></el-input> | ||||
|       </div> | ||||
|       <div class="selectBox" v-else> | ||||
|         <span class="left">手机号</span> | ||||
|         <el-input | ||||
|           v-model="selectUserPhone" | ||||
|           size="default" | ||||
|           placeholder="" | ||||
|           class="right" | ||||
|           style="width: 56%" | ||||
|         > | ||||
|         </el-input> | ||||
|         <b>+86</b> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <span class="dialog-footer"> | ||||
|           <el-button @click="addSure = false">取消</el-button> | ||||
|           <el-button type="primary" @click="addSureClick()"> 添加 </el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   whitePage, | ||||
|   whiteDel, | ||||
|   whiteSave, | ||||
| } from "@/api/AccessRestriction.vue/AccessRestriction.js"; | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "AccessWhitelist", | ||||
|   data() { | ||||
|     return { | ||||
|       userId: "", //用戶id | ||||
|       userPhone: "", //用戶手机号 | ||||
|       loading: false, //列表loading | ||||
|       tableData: [], //列表数据 | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|       delDialog: false, //控制公共弹窗展示 | ||||
|       delDialogText: "确定要移除白名单吗?", //公共弹窗标题 | ||||
|       addSure: false, //控制确认添加弹窗展示 | ||||
|       value: "1", //选择器 | ||||
|       options: [ | ||||
|         { | ||||
|           value: "1", | ||||
|           label: "用户id", | ||||
|         }, | ||||
|         { | ||||
|           value: "2", | ||||
|           label: "用户手机号", | ||||
|         }, | ||||
|       ], | ||||
|       selectUserId: "", //添加弹窗用户id | ||||
|       selectUserPhone: "", //添加弹窗用户手机号 | ||||
|       obj: {}, //存放公共参数 | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 初始化 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       whitePage({ | ||||
|         page: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|         userErBanNo: this.userId, | ||||
|         phone: this.userPhone, | ||||
|       }).then((res) => { | ||||
|         this.tableData = res.data.records; | ||||
|         this.loading = false; | ||||
|         this.total = res.data.total; | ||||
|       }); | ||||
|     }, | ||||
|     // 新增 | ||||
|     add() { | ||||
|       this.addSure = true; | ||||
|     }, | ||||
|     // 搜索 | ||||
|     search() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // 移除白名单 | ||||
|     delWhite(row) { | ||||
|       console.log(row); | ||||
|       this.obj = row; | ||||
|       this.delDialog = true; | ||||
|     }, | ||||
|     // 二次确认 | ||||
|     sureClick() { | ||||
|       whiteDel({ id: this.obj.id }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.delDialog = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 添加确认 | ||||
|     addSureClick() { | ||||
|       var objs = {}; | ||||
|       if (this.value == 1) { | ||||
|         objs = { | ||||
|           userErBanNoStr: this.selectUserId, | ||||
|         }; | ||||
|       } else { | ||||
|         let phone = this.selectUserPhone; | ||||
|         if (phone) { | ||||
|           phone = '86' + phone; | ||||
|         } | ||||
|         objs = { | ||||
|           phone: phone, | ||||
|         }; | ||||
|       } | ||||
|       whiteSave(objs).then((res) => { | ||||
|         this.selectUserId = ""; | ||||
|         this.selectUserPhone = ""; | ||||
|         if (res.code == 200) { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "success", | ||||
|           }); | ||||
|           this.getData(); | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.getData(); | ||||
|       }); | ||||
|       this.addSure = false; | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange(val) { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange(val) { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </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; | ||||
|   } | ||||
|   .selectBox { | ||||
|     margin-bottom: 10px; | ||||
|     display: flex; | ||||
|     justify-content: space-between; | ||||
|     width: 70%; | ||||
|     .left { | ||||
|       display: block; | ||||
|       margin-right: 25px; | ||||
|       white-space: nowrap; | ||||
|     } | ||||
|     .right { | ||||
|       width: 70%; | ||||
|       position: relative; | ||||
|     } | ||||
|  | ||||
|     b { | ||||
|       font-style: normal; | ||||
|       position: absolute; | ||||
|       left: 135px; | ||||
|       width: 54px; | ||||
|       height: 32px; | ||||
|       line-height: 32px; | ||||
|       text-align: center; | ||||
|       border-top-right-radius: 0; | ||||
|       border-bottom-right-radius: 0; | ||||
|       border-top-left-radius: 5px; | ||||
|       border-bottom-left-radius: 5px; | ||||
|       border-right: 1px solid #dcdfe6; | ||||
|       border-left: 1px solid #dcdfe6; | ||||
|       border-bottom: 1px solid #dcdfe6; | ||||
|       border-top: 1px solid #dcdfe6; | ||||
|       background: #fff; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| input[type="file"] { | ||||
|   display: none; | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										457
									
								
								src/views/accountApplyManage/accountApplyManage.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										457
									
								
								src/views/accountApplyManage/accountApplyManage.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,457 @@ | ||||
| <template> | ||||
|   <div class="account-apply-manage"> | ||||
|     <div class="container"> | ||||
|       <div class="region-box"> | ||||
|         <el-radio-group v-model="region"> | ||||
|           <el-radio v-for="(item, index) in userAreaRegion" | ||||
|                     :key="index" | ||||
|                     :label="item.value">{{ item.name }}</el-radio> | ||||
|         </el-radio-group> | ||||
|       </div> | ||||
|       <div class="handle-box"> | ||||
|         <el-form ref="searchForm" | ||||
|                  :model="searchForm" | ||||
|                  label-width="90px" | ||||
|                  :disabled="tableLoading"> | ||||
|           <div class="search-line"> | ||||
|             <el-form-item label="MoliStar ID" | ||||
|                           prop="erbanNo"> | ||||
|               <el-input v-model.trim="searchForm.erbanNo" | ||||
|                         placeholder="Please enter"></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="UID" | ||||
|                           prop="uid"> | ||||
|               <el-input v-model.trim="searchForm.uid" | ||||
|                         placeholder="Please enter"></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="SID" | ||||
|                           prop="sid"> | ||||
|               <el-input v-model.trim="searchForm.sid" | ||||
|                         placeholder="Please enter"></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="Region" | ||||
|                           prop="partitionId"> | ||||
|               <el-select v-model="searchForm.partitionId"> | ||||
|                 <el-option label="全部" | ||||
|                            value=""></el-option> | ||||
|                 <el-option v-for="item in partitionInfoList" | ||||
|                            :key="item.id" | ||||
|                            :label="item.desc" | ||||
|                            :value="item.id"></el-option> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|             <el-form-item label-width="40px"> | ||||
|               <el-button type="primary" | ||||
|                          @click="handSearch">Search</el-button> | ||||
|               <el-button plain | ||||
|                          @click="resetSearchForm">Reset Search</el-button> | ||||
|               <el-upload class="file-uploader" | ||||
|                          action="#" | ||||
|                          list-type="picture-card" | ||||
|                          :show-file-list="false" | ||||
|                          :on-change="handleExcel" | ||||
|                          accept=".xls, .xlsx" | ||||
|                          :auto-upload="false"> | ||||
|                 <el-button type="primary">Import</el-button> | ||||
|               </el-upload> | ||||
|             </el-form-item> | ||||
|           </div> | ||||
|         </el-form> | ||||
|         <!-- <el-upload | ||||
|           class="file-uploader" | ||||
|           action="#" | ||||
|           list-type="picture-card" | ||||
|           :show-file-list="false" | ||||
|           :on-change="handleExcel" | ||||
|           accept=".xls, .xlsx" | ||||
|           :auto-upload="false" | ||||
|         > | ||||
|           <el-button type="primary" class="el-icon-upload">Import</el-button> | ||||
|         </el-upload> --> | ||||
|       </div> | ||||
|       <div class="table"> | ||||
|         <el-table :data="tableData" | ||||
|                   border | ||||
|                   v-loading="tableLoading" | ||||
|                   @header-click="headerCopy" | ||||
|                   style="width: 100%"> | ||||
|           <el-table-column align="center" | ||||
|                            prop="id" | ||||
|                            label="No."> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="erbanNo" | ||||
|                            label="MoliStar ID"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="uid" | ||||
|                            label="UID"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="level" | ||||
|                            label="SID Level"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="nick" | ||||
|                            label="Nickname"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="partitionInfo" | ||||
|                            label="Region"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="createTime" | ||||
|                            label="Apply time"> | ||||
|             <template v-slot="scope">{{ | ||||
|               convertTimestamp(scope.row.createTime) | ||||
|             }}</template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="prettyNo" | ||||
|                            label="SID"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="status" | ||||
|                            label="State"> | ||||
|             <template v-slot="scope"> | ||||
|               <el-tag :type="applyStateTag(scope.row.status)">{{ | ||||
|                 applyStateText(scope.row.status) | ||||
|               }}</el-tag> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="updateTime" | ||||
|                            label="Review time"> | ||||
|             <template v-slot="scope">{{ | ||||
|               convertTimestamp(scope.row.updateTime) | ||||
|             }}</template> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            prop="operater" | ||||
|                            label="Operator"> | ||||
|           </el-table-column> | ||||
|           <el-table-column align="center" | ||||
|                            label="Operate"> | ||||
|             <template v-slot="scope"> | ||||
|               <el-button type="text" | ||||
|                          v-if="scope.row.status == 0" | ||||
|                          @click="handlePass(scope.$index, scope.row)"> | ||||
|                 Pass | ||||
|               </el-button> | ||||
|               <el-button type="text" | ||||
|                          v-if="scope.row.status == 0" | ||||
|                          @click="handleReject(scope.$index, scope.row)"> | ||||
|                 Reject | ||||
|               </el-button> | ||||
|               <el-button type="text" | ||||
|                          v-if="scope.row.status == 1" | ||||
|                          class="red" | ||||
|                          @click="handleDelete(scope.$index, scope.row)"> | ||||
|                 Delete | ||||
|               </el-button> | ||||
|             </template> | ||||
|           </el-table-column> | ||||
|         </el-table> | ||||
|         <table-pagination :pageParams="pageParams" | ||||
|                           :pageTotal="pageTotal" | ||||
|                           :ifShowSizes="true" | ||||
|                           @handleSizeChange="handleSizeChange" | ||||
|                           @handlePageChange="handlePageChange"></table-pagination> | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { | ||||
|   getPrettyNumberExamineList, | ||||
|   prettyNumberExaminePass, | ||||
|   prettyNumberExamineDelete, | ||||
|   prettyNumberExamineReject, | ||||
|   erbanUpload, | ||||
| } from "@/api/relPrivilegeManage/relPrivilegeManage.js"; | ||||
| import { getPartitionInfoList } from '@/api/partition/partitionInfo'; | ||||
| import TablePagination from "@/components/common/TablePagination"; | ||||
| import { formatDate } from "@/utils/relDate"; | ||||
| import { ElMessageBox, ElMessage } from "element-plus"; // 正确引入 ElM | ||||
| // 混入 | ||||
| // import Mixin from '../../mixin/mixRegion.js'; | ||||
|  | ||||
| export default { | ||||
|   name: "accountApplyManage", | ||||
|   // mixins: [Mixin], | ||||
|   components: { TablePagination }, | ||||
|   data () { | ||||
|     return { | ||||
|       partitionInfoList: [], | ||||
|       tableLoading: false, // 表格是否加载中 | ||||
|       tableData: [], // 接口返回的表格数据 | ||||
|       // 搜索表单相关 | ||||
|       searchForm: { | ||||
|         erbanNo: null, | ||||
|         uid: null, | ||||
|         sid: null, | ||||
|         partitionId: null, | ||||
|       }, | ||||
|       pageTotal: 0, // 接口返回的表格总条数 | ||||
|       pageParams: { | ||||
|         pageNo: 1, | ||||
|         pageSize: 10, | ||||
|       }, | ||||
|     }; | ||||
|   }, | ||||
|   created () { | ||||
|     this.initPartition(); | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     getData () { | ||||
|       this.tableLoading = true; | ||||
|  | ||||
|       let { pageParams, searchForm } = this; | ||||
|       searchForm = JSON.parse(JSON.stringify(searchForm)); | ||||
|       pageParams = JSON.parse(JSON.stringify(pageParams)); | ||||
|       Object.keys(searchForm).forEach((item) => { | ||||
|         if ( | ||||
|           !searchForm[item] || | ||||
|           (searchForm[item] !== undefined && searchForm[item] === "") | ||||
|         ) { | ||||
|           delete searchForm[item]; | ||||
|         } | ||||
|       }); | ||||
|       Object.assign(pageParams, searchForm); | ||||
|  | ||||
|       getPrettyNumberExamineList(pageParams).then((res) => { | ||||
|         this.tableLoading = false; | ||||
|         if (res.code == 200) { | ||||
|           let data = res.data; | ||||
|           console.log(data); | ||||
|           this.tableData = data.rows; | ||||
|           this.pageTotal = data.total; | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     //导入表格 | ||||
|     handleExcel (file) { | ||||
|       let formData = new FormData(); //声明一个FormDate对象 | ||||
|       formData.append("file", file.raw); //把文件信息放入对象中 | ||||
|       console.log(file.raw); | ||||
|       erbanUpload(formData) | ||||
|         .then((res) => { | ||||
|           if (res.code == 200) { | ||||
|             this.getData(); | ||||
|             this.$message.success("Operation successful"); | ||||
|           } | ||||
|         }) | ||||
|         .catch((err) => { | ||||
|           // that.$message({ | ||||
|           //     type: 'error', | ||||
|           //     message: 'Operation failed' | ||||
|           // }); | ||||
|         }); | ||||
|     }, | ||||
|     // 通过 | ||||
|     handlePass (index, row) { | ||||
|       ElMessageBox.confirm("Are you sure you want to pass?", "Prompt", { | ||||
|         type: "warning", | ||||
|         confirmButtonText: "Sure", | ||||
|         cancelButtonText: "Cancel", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           prettyNumberExaminePass({ id: row.id }).then((res) => { | ||||
|             if (res.code == 200) { | ||||
|               this.getData(); | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: "Operation successful", | ||||
|                 type: "success", | ||||
|               }); | ||||
|             } else { | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: res.message, | ||||
|                 type: "error", | ||||
|               }); | ||||
|             } | ||||
|           }); | ||||
|         }) | ||||
|         .catch(() => { }); | ||||
|     }, | ||||
|     // 拒绝 | ||||
|     handleReject (index, row) { | ||||
|       ElMessageBox.confirm("Are you sure you want to refuse?", "Prompt", { | ||||
|         type: "warning", | ||||
|         confirmButtonText: "Sure", | ||||
|         cancelButtonText: "Cancel", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           prettyNumberExamineReject({ id: row.id }).then((res) => { | ||||
|             if (res.code == 200) { | ||||
|               this.getData(); | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: "Operation successful", | ||||
|                 type: "success", | ||||
|               }); | ||||
|             } else { | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: res.message, | ||||
|                 type: "error", | ||||
|               }); | ||||
|             } | ||||
|           }); | ||||
|         }) | ||||
|         .catch(() => { }); | ||||
|     }, | ||||
|     // 删除操作 | ||||
|     handleDelete (index, row) { | ||||
|       // 二次确认删除 | ||||
|       ElMessageBox.confirm("Are you sure you want to delete?", "Prompt", { | ||||
|         type: "warning", | ||||
|         confirmButtonText: "Sure", | ||||
|         cancelButtonText: "Cancel", | ||||
|       }) | ||||
|         .then(() => { | ||||
|           prettyNumberExamineDelete({ id: row.id }).then((res) => { | ||||
|             if (res.code == 200) { | ||||
|               this.getData(); | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: "Operation successful", | ||||
|                 type: "success", | ||||
|               }); | ||||
|             } else { | ||||
|               ElMessage({ | ||||
|                 showClose: true, | ||||
|                 message: res.message, | ||||
|                 type: "error", | ||||
|               }); | ||||
|             } | ||||
|           }); | ||||
|         }) | ||||
|         .catch(() => { }); | ||||
|     }, | ||||
|     // 点击搜索 | ||||
|     handSearch () { | ||||
|       this.$refs["searchForm"].validate((valid) => { | ||||
|         if (valid) { | ||||
|           this.pageParams.pageNo = 1; | ||||
|           this.getData(); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|     // 重置搜索表单 | ||||
|     resetSearchForm () { | ||||
|       this.$refs["searchForm"].resetFields(); | ||||
|       this.pageParams.pageNo = 1; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange (val) { | ||||
|       this.pageParams.pageNo = val; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handlePageChange (val) { | ||||
|       this.pageParams.pageNo = val; | ||||
|       this.getData(); | ||||
|     }, | ||||
|     headerCopy (column, e) { | ||||
|       this.$copy(column.label); | ||||
|     }, | ||||
|     initPartition () { | ||||
|       getPartitionInfoList().then(res => { | ||||
|         let data = res.data; | ||||
|         this.partitionInfoList = data; | ||||
|       }); | ||||
|     }, | ||||
|   }, | ||||
|   computed: { | ||||
|     applyStateTag () { | ||||
|       return function (val) { | ||||
|         let text = ""; | ||||
|         switch (val) { | ||||
|           case 0: | ||||
|             text = "warning"; | ||||
|             break; | ||||
|           case 1: | ||||
|             text = "success"; | ||||
|             break; | ||||
|           case 2: | ||||
|             text = "info"; | ||||
|             break; | ||||
|           case 3: | ||||
|             text = "danger"; | ||||
|             break; | ||||
|         } | ||||
|         return text; | ||||
|       }; | ||||
|     }, | ||||
|     applyStateText () { | ||||
|       return function (val) { | ||||
|         let text = ""; | ||||
|         switch (val) { | ||||
|           case 0: | ||||
|             text = "In Review"; | ||||
|             break; | ||||
|           case 1: | ||||
|             text = "Passed"; | ||||
|             break; | ||||
|           case 2: | ||||
|             text = "Rejected"; | ||||
|             break; | ||||
|           case 3: | ||||
|             text = "Deleted"; | ||||
|             break; | ||||
|         } | ||||
|         return text; | ||||
|       }; | ||||
|     }, | ||||
|     convertTimestamp () { | ||||
|       return function (time) { | ||||
|         let date = new Date(time); | ||||
|         return formatDate(date); | ||||
|       }; | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style lang="scss"> | ||||
| .red { | ||||
|   color: rgb(241, 19, 19); | ||||
| } | ||||
|  | ||||
| // ::v-deep { | ||||
| //   .el-upload--picture-card { | ||||
| //     background-color: transparent; | ||||
| //     border: 0; | ||||
| //     border-radius: 0; | ||||
| //     box-sizing: border-box; | ||||
| //     width: 0; | ||||
| //     height: 45px; | ||||
| //     line-height: 0; | ||||
| //     vertical-align: top; | ||||
| //   } | ||||
| // } | ||||
| .file-uploader { | ||||
|   display: block; | ||||
|   margin-left: 51px; | ||||
|   input { | ||||
|     display: none; | ||||
|   } | ||||
|   .el-upload { | ||||
|     background-color: transparent; | ||||
|     border: 0; | ||||
|     border-radius: 0; | ||||
|     box-sizing: border-box; | ||||
|     width: 0; | ||||
|     height: 45px; | ||||
|     line-height: 0; | ||||
|     vertical-align: top; | ||||
|   } | ||||
|   span { | ||||
|     display: block; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -655,7 +655,7 @@ export default { | ||||
|                                 field: 'type', title: '奖品类型', align: 'center', width: '5%', valign: 'middle', formatter: function (val, row, index) { | ||||
|                                     switch (val) { | ||||
|                                         case 1: | ||||
|                                             return '金币'; | ||||
|                                             return '钻石'; | ||||
|  | ||||
|                                         case 2: | ||||
|                                             return '在线礼物'; | ||||
| @@ -757,6 +757,7 @@ export default { | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
|  | ||||
| </script> | ||||
|   | ||||
| @@ -597,7 +597,7 @@ export default { | ||||
|                     var id = $(this).data('id'); | ||||
|                     $.ajax({ | ||||
|                         type: "get", | ||||
|                         url: "/admin/charge/activity/getById.action", | ||||
|                         url: "/admin/charge/activity/getById", | ||||
|                         data: { id: id }, | ||||
|                         dataType: "json", | ||||
|                         success: function (json) { | ||||
| @@ -716,7 +716,7 @@ export default { | ||||
|                                 $('#modal_packName').append('<option value="">请选择...</option>'); | ||||
|                                 $.ajax({ | ||||
|                                     type: "get", | ||||
|                                     url: "/admin/activity/pack/list.action", | ||||
|                                     url: "/admin/activity/pack/list", | ||||
|                                     data: { | ||||
|                                         status: 1 | ||||
|                                     }, | ||||
| @@ -760,7 +760,7 @@ export default { | ||||
|                     if (confirm("你确认删除该记录吗? \r\n 删除后再也不能找回,请谨慎操作!")) { | ||||
|                         $.ajax({ | ||||
|                             type: 'post', | ||||
|                             url: "/admin/charge/activity/delete.action", | ||||
|                             url: "/admin/charge/activity/delete", | ||||
|                             data: { id: id }, | ||||
|                             dataType: "json", | ||||
|                             success: function (json) { | ||||
| @@ -791,7 +791,7 @@ export default { | ||||
|                     } | ||||
|                     $.ajax({ | ||||
|                         type: "get", | ||||
|                         url: "/admin/activity/pack/list.action", | ||||
|                         url: "/admin/activity/pack/list", | ||||
|                         data: { | ||||
|                             status: 1 | ||||
|                         }, | ||||
| @@ -1147,6 +1147,7 @@ export default { | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -617,6 +617,7 @@ export default { | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
|  | ||||
| </script> | ||||
|   | ||||
| @@ -218,7 +218,7 @@ export default { | ||||
|                     queryParamsType: "undefined", | ||||
|                     uniqueId: 'id', | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/luckySea/listItemGroup.action', | ||||
|                     url: '/admin/luckySea/listItemGroup', | ||||
|                     onLoadSuccess: function (data) {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
| @@ -410,7 +410,7 @@ export default { | ||||
|                 } | ||||
|  | ||||
|                 function getPageInfo() { | ||||
|                     $.get('/admin/luckySea/listItem.action', { | ||||
|                     $.get('/admin/luckySea/listItem', { | ||||
|                     }, function (res) { | ||||
|                         console.log(res); | ||||
|                         const data = res; | ||||
| @@ -654,6 +654,7 @@ export default { | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -154,7 +154,7 @@ export default { | ||||
|                         return param; | ||||
|                     }, | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/luckySea/listPlatformStat.action', | ||||
|                     url: '/admin/luckySea/listPlatformStat', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
| @@ -166,6 +166,7 @@ export default { | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -14,7 +14,7 @@ | ||||
|                         <i class="glyphicon glyphicon-search"></i>查询 | ||||
|                     </button> | ||||
|                     <div class="col-sm-12"> | ||||
|                         当前库存 <span name="stock" id="stock" />钻石 | ||||
|                         当前库存 <span name="stock" id="stock" />金币 | ||||
|                         <button id="editStock" class="btn btn-default">编辑库存</button> | ||||
|                     </div> | ||||
|                 </div> | ||||
| @@ -58,7 +58,7 @@ | ||||
|                     <h4 class="modal-title" id="editStockModalTitle">编辑库存</h4> | ||||
|                 </div> | ||||
|                 <div class="modal-body"> | ||||
|                     设置库存为 <input type="text" name="editedStock" id="editedStock" class="input-sm"> 钻石 | ||||
|                     设置库存为 <input type="text" name="editedStock" id="editedStock" class="input-sm"> 金币 | ||||
|                 </div> | ||||
|                 <div class="modal-footer"> | ||||
|                     <h4 id="editStockModalFooter"></h4> | ||||
| @@ -163,7 +163,7 @@ export default { | ||||
|                         return param; | ||||
|                     }, | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/luckySea/listActRecord.action', | ||||
|                     url: '/admin/luckySea/listActRecord', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
| @@ -228,7 +228,7 @@ export default { | ||||
|                             }; | ||||
|                             return param; | ||||
|                         }, | ||||
|                         url: '/admin/luckySea/listRoundDrawDetail.action', | ||||
|                         url: '/admin/luckySea/listRoundDrawDetail', | ||||
|                         onLoadSuccess: function () {  //加载成功时执行 | ||||
|                             $("#roundDetailModal").modal('show'); | ||||
|                         }, | ||||
| @@ -247,7 +247,7 @@ export default { | ||||
|                 function getStock() { | ||||
|                     $.ajax({ | ||||
|                         type: 'get', | ||||
|                         url: "/admin/luckySea/getStock.action", | ||||
|                         url: "/admin/luckySea/getStock", | ||||
|                         success: function (json) { | ||||
|                             if (json.success) { | ||||
|                                 console.log('data', json.data) | ||||
| @@ -268,7 +268,7 @@ export default { | ||||
|                 $('#editStockModelBtn').on('click', function () { | ||||
|                     $.ajax({ | ||||
|                         type: 'get', | ||||
|                         url: "/admin/luckySea/editStock.action", | ||||
|                         url: "/admin/luckySea/editStock", | ||||
|                         data: { | ||||
|                             stock: $("#editedStock").val(), | ||||
|                         }, | ||||
| @@ -289,6 +289,7 @@ export default { | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -83,7 +83,7 @@ export default { | ||||
|                         return param; | ||||
|                     }, | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/luckySea/listUserDrawRecordList.action', | ||||
|                     url: '/admin/luckySea/listUserDrawRecordList', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
| @@ -133,6 +133,7 @@ export default { | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -145,7 +145,7 @@ export default { | ||||
|                     }, | ||||
|                     uniqueId: 'id', | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/act/operational/list.action', | ||||
|                     url: '/admin/act/operational/list', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
| @@ -176,7 +176,7 @@ export default { | ||||
|                     if ($('#actForm').validationEngine('validate')) { | ||||
|                         $.ajax({ | ||||
|                             type: "post", | ||||
|                             url: "/admin/act/operational/save.action", | ||||
|                             url: "/admin/act/operational/save", | ||||
|                             data: $('#actForm').serialize(), | ||||
|                             dataType: 'json', | ||||
|                             success: function (json) { | ||||
| @@ -197,7 +197,7 @@ export default { | ||||
|                     var key = parseInt($(this).attr('data-id')); | ||||
|                     $.ajax({ | ||||
|                         type: 'post', | ||||
|                         url: '/admin/act/operational/del.action', | ||||
|                         url: '/admin/act/operational/del', | ||||
|                         data: { 'id': key }, | ||||
|                         dataType: 'json', | ||||
|                         success: function (res) { | ||||
| @@ -215,7 +215,7 @@ export default { | ||||
|                 $('#uploadBtn').on('click', function () { | ||||
|                     var options = { | ||||
|                         type: 'post', | ||||
|                         url: '/admin/upload/img.action', | ||||
|                         url: '/admin/upload/img', | ||||
|                         dataType: 'json', | ||||
|                         success: function (json) { | ||||
|                             if (json.path) { | ||||
| @@ -256,6 +256,7 @@ export default { | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -135,7 +135,7 @@ export default { | ||||
|                     }, | ||||
|                     uniqueId: 'id', | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/act/static/list.action', | ||||
|                     url: '/admin/act/static/list', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
| @@ -165,7 +165,7 @@ export default { | ||||
|                     if ($('#actForm').validationEngine('validate')) { | ||||
|                         $.ajax({ | ||||
|                             type: "post", | ||||
|                             url: "/admin/act/static/save.action", | ||||
|                             url: "/admin/act/static/save", | ||||
|                             data: $('#actForm').serialize(), | ||||
|                             dataType: 'json', | ||||
|                             success: function (json) { | ||||
| @@ -190,7 +190,7 @@ export default { | ||||
|                     var key = parseInt($(this).attr('data-id')); | ||||
|                     $.ajax({ | ||||
|                         type: 'post', | ||||
|                         url: '/admin/act/static/delete.action', | ||||
|                         url: '/admin/act/static/delete', | ||||
|                         data: { 'id': key }, | ||||
|                         dataType: 'json', | ||||
|                         success: function (res) { | ||||
| @@ -208,7 +208,7 @@ export default { | ||||
|                 $('#uploadBtn').on('click', function () { | ||||
|                     var options = { | ||||
|                         type: 'post', | ||||
|                         url: '/admin/upload/img.action', | ||||
|                         url: '/admin/upload/img', | ||||
|                         dataType: 'json', | ||||
|                         success: function (json) { | ||||
|                             if (json.path) { | ||||
| @@ -249,6 +249,7 @@ export default { | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -138,6 +138,7 @@ export default { | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -166,8 +166,14 @@ export default { | ||||
|                                 field: 'charmAward', title: '魅力榜奖励', align: 'center', valign: 'middle', formatter: function (val, row, index) { | ||||
|                                     var packArr = JSON.parse(val); | ||||
|                                     var str = ''; | ||||
|                                     for (var i = 0; i < packArr.length; i++) { | ||||
|                                         str += packObj[packArr[i]] + ','; | ||||
|                                     for (var i = 0, len = packArr.length; i < len; i++) { | ||||
|                                         let value = packObj[packArr[i]]; | ||||
|                                         if (value) { | ||||
|                                             str += value; | ||||
|                                         } | ||||
|                                         if (i != len - 1) { | ||||
|                                             str += ','; | ||||
|                                         } | ||||
|                                     } | ||||
|                                     return str.substr(0, str.length - 2); | ||||
|                                 } | ||||
| @@ -176,8 +182,14 @@ export default { | ||||
|                                 field: 'levelAward', title: '豪气榜奖励', align: 'center', valign: 'middle', formatter: function (val, row, index) { | ||||
|                                     var packArr = JSON.parse(val); | ||||
|                                     var str = ''; | ||||
|                                     for (var i = 0; i < packArr.length; i++) { | ||||
|                                         str += packObj[packArr[i]] + ','; | ||||
|                                     for (var i = 0, len = packArr.length; i < len; i++) { | ||||
|                                         let value = packObj[packArr[i]]; | ||||
|                                         if (value) { | ||||
|                                             str += value; | ||||
|                                         } | ||||
|                                         if (i != len - 1) { | ||||
|                                             str += ','; | ||||
|                                         } | ||||
|                                     } | ||||
|                                     return str.substr(0, str.length - 2); | ||||
|                                 } | ||||
| @@ -232,7 +244,7 @@ export default { | ||||
|                         }, | ||||
|                         uniqueId: 'id', | ||||
|                         toolbar: '#toolbar', | ||||
|                         url: '/admin/weekStarConfig/getWeekConfigList.action', | ||||
|                         url: '/admin/weekStarConfig/getWeekConfigList', | ||||
|                         onLoadSuccess: function () {  //加载成功时执行 | ||||
|                             console.log("load success"); | ||||
|                         }, | ||||
| @@ -341,10 +353,15 @@ export default { | ||||
|                         if (res.code == 200) { | ||||
|                             var str = ''; | ||||
|                             for (var i = 0; i < res.data.length; i++) { | ||||
|                                 let item = res.data[i]; | ||||
|                                 let giftName = item.giftName; | ||||
|                                 if (giftName.startsWith('{') && giftName.endsWith('}')) { | ||||
|                                     giftName = JSON.parse(giftName).zh; | ||||
|                                 }  | ||||
|                                 // 存入对象 | ||||
|                                 giftObj[res.data[i].giftId] = res.data[i].giftName; | ||||
|                                 giftObj[res.data[i].giftId] = giftName; | ||||
|                                 // 渲染select | ||||
|                                 str += '<option value="' + res.data[i].giftId + '">' + res.data[i].giftName + '</option>'; | ||||
|                                 str += '<option value="' + res.data[i].giftId + '">' + giftName + '</option>'; | ||||
|                             } | ||||
|                             console.log(JSON.stringify(giftObj)); | ||||
|                             // $('.giftSelect').html(str); | ||||
| @@ -362,10 +379,15 @@ export default { | ||||
|                         if (res.code == 200) { | ||||
|                             var str = ''; | ||||
|                             for (var i = 0; i < res.data.length; i++) { | ||||
|                                 let item = res.data[i]; | ||||
|                                 let giftName = item.giftName; | ||||
|                                 if (giftName.startsWith('{') && giftName.endsWith('}')) { | ||||
|                                     giftName = JSON.parse(giftName).zh; | ||||
|                                 } | ||||
|                                 // 存入对象 | ||||
|                                 giftObj[res.data[i].giftId] = res.data[i].giftName; | ||||
|                                 giftObj[res.data[i].giftId] = giftName; | ||||
|                                 // 渲染select | ||||
|                                 str += '<option value="' + res.data[i].giftId + '">' + res.data[i].giftName + '</option>'; | ||||
|                                 str += '<option value="' + res.data[i].giftId + '">' + giftName + '</option>'; | ||||
|                             } | ||||
|                             console.log(JSON.stringify(giftObj)); | ||||
|                             $('.giftSelect').html(str); | ||||
| @@ -409,6 +431,7 @@ export default { | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -150,7 +150,7 @@ export default { | ||||
|                         return param; | ||||
|                     }, | ||||
|                     toolbar: '#toolbar', | ||||
|                     url: '/admin/super/operate/record/list.action', | ||||
|                     url: '/admin/super/operate/record/list', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
| @@ -175,15 +175,16 @@ export default { | ||||
|                 }); | ||||
|                 picker1.on('changeDate', function () { | ||||
|                     var date = $('#beginDate').datetimepicker('getDate'); | ||||
|                     picker2.datepicker('setStartDate', date); | ||||
|                     picker2.datetimepicker('setStartDate', date); | ||||
|                 }); | ||||
|                 picker2.on('changeDate', function () { | ||||
|                     var date = $('#endDate').datetimepicker('getDate'); | ||||
|                     picker1.datepicker('setEndDate', date); | ||||
|                     picker1.datetimepicker('setEndDate', date); | ||||
|                 }); | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -83,7 +83,7 @@ export default { | ||||
|                         var params = "uids=" + id; | ||||
|                         $.ajax({ | ||||
|                             type: 'post', | ||||
|                             url: "/admin/super/del.action", | ||||
|                             url: "/admin/super/del", | ||||
|                             data: params, | ||||
|                             dataType: "json", | ||||
|                             success: function (json) { | ||||
| @@ -114,7 +114,7 @@ export default { | ||||
|                         showLoading() | ||||
|                         $.ajax({ | ||||
|                             type: "post", | ||||
|                             url: "/admin/super/save.action", | ||||
|                             url: "/admin/super/save", | ||||
|                             data: 'erbanNo=' + erbanNo, | ||||
|                             dataType: "json", | ||||
|                             success: function (json) { | ||||
| @@ -136,6 +136,7 @@ export default { | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
|  | ||||
|  | ||||
| @@ -179,7 +180,7 @@ function initTable() { | ||||
|             return param; | ||||
|         }, | ||||
|         toolbar: '#toolbar', | ||||
|         url: '/admin/super/list.action', | ||||
|         url: '/admin/super/list', | ||||
|         onLoadSuccess: function (data) {  //加载成功时执行 | ||||
|             setTimeout(function () { | ||||
|                 loadCreateTime(data); | ||||
| @@ -204,7 +205,7 @@ function loadCreateTime(data) { | ||||
|     if (param != '') { | ||||
|         $.ajax({ | ||||
|             type: "get", | ||||
|             url: "/admin/super/get/time.action", | ||||
|             url: "/admin/super/get/time", | ||||
|             data: param, | ||||
|             dataType: "json", | ||||
|             success: function (json) { | ||||
|   | ||||
| @@ -221,6 +221,7 @@ export default { | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -242,6 +242,7 @@ export default { | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -41,8 +41,8 @@ | ||||
|                             <div class="col-sm-9"> | ||||
|                                 <span> | ||||
|                                     <font color="#dd4b39">1.上传文件仅支持.xlsx格式的文件<br> | ||||
|                                         2.文件内容第一行为标题(例:平台号,金币,钻石)<br> | ||||
|                                         3.第一列为用户平台号,第二列为用户要添加的金币数量,第三列为用户要添加的钻石数量 | ||||
|                                         2.文件内容第一行为标题(例:平台号,钻石,金币)<br> | ||||
|                                         3.第一列为用户平台号,第二列为用户要添加的钻石数量,第三列为用户要添加的金币数量 | ||||
|                                     </font> | ||||
|                                 </span> | ||||
|                             </div> | ||||
| @@ -261,6 +261,7 @@ export default { | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -167,7 +167,7 @@ export default { | ||||
|                     }, | ||||
|                     toolbar: '#toolbar', | ||||
|                     uniqueId: 'id', | ||||
|                     url: '/admin/anchorFansTeamAudio/recordList.action', | ||||
|                     url: '/admin/anchorFansTeamAudio/recordList', | ||||
|                     onLoadSuccess: function () {  //加载成功时执行 | ||||
|                         console.log("load success"); | ||||
|                     }, | ||||
| @@ -195,7 +195,7 @@ export default { | ||||
|                     if (confirm("确定批量批量审核通过图片吗?")) { | ||||
|                         $.ajax({ | ||||
|                             type: 'post', | ||||
|                             url: '/admin/photo/batchPass.action', | ||||
|                             url: '/admin/photo/batchPass', | ||||
|                             data: { pid: JSON.stringify(pid) }, | ||||
|                             dataType: 'json', | ||||
|                             success: function (res) { | ||||
| @@ -221,7 +221,7 @@ export default { | ||||
|                         // console.log(data) | ||||
|                         $.ajax({ | ||||
|                             type: 'post', | ||||
|                             url: '/admin/anchorFansTeamAudio/pass.action', | ||||
|                             url: '/admin/anchorFansTeamAudio/pass', | ||||
|                             data: { pid: dataId, status: 2 }, | ||||
|                             dataType: 'json', | ||||
|                             success: function (res) { | ||||
| @@ -260,7 +260,7 @@ export default { | ||||
|                     if ($("#messageForm").validationEngine('validate')) { | ||||
|                         $.ajax({ | ||||
|                             type: 'post', | ||||
|                             url: '/admin/anchorFansTeamAudio/pass.action', | ||||
|                             url: '/admin/anchorFansTeamAudio/pass', | ||||
|                             data: { pid: dataId, message: message, status: 1 }, | ||||
|                             dataType: 'json', | ||||
|                             success: function (res) { | ||||
| @@ -279,6 +279,7 @@ export default { | ||||
|             }) | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| }; | ||||
| </script> | ||||
|  | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user