// ==UserScript== // @name CSGO2.WIKI饰品捡漏大师 - 入档模板历史价格查询 // @namespace https://github.com/your-github-username/cs-assistant // @version 5.0.0.1 // @description CSGO2.WIKI 饰品捡漏大师脚本超实用!能依据排行榜查询多档次饰品数据,快速掌握历史价格。帮你精准定位性价比饰品,不错过任何捡漏时机,在 CSGO2 饰品交易里轻松抢占先机。 // @author Jack Mr // @match *://*.youpin898.com/* // @match *://buff.163.com/* // @icon  // @grant none // @license MIT // @run-at document-start // @grant GM_xmlhttpRequest // @downloadURL https://update.greasyfork.icu/scripts/524378/CSGO2WIKI%E9%A5%B0%E5%93%81%E6%8D%A1%E6%BC%8F%E5%A4%A7%E5%B8%88%20-%20%E5%85%A5%E6%A1%A3%E6%A8%A1%E6%9D%BF%E5%8E%86%E5%8F%B2%E4%BB%B7%E6%A0%BC%E6%9F%A5%E8%AF%A2.user.js // @updateURL https://update.greasyfork.icu/scripts/524378/CSGO2WIKI%E9%A5%B0%E5%93%81%E6%8D%A1%E6%BC%8F%E5%A4%A7%E5%B8%88%20-%20%E5%85%A5%E6%A1%A3%E6%A8%A1%E6%9D%BF%E5%8E%86%E5%8F%B2%E4%BB%B7%E6%A0%BC%E6%9F%A5%E8%AF%A2.meta.js // ==/UserScript== (function () { 'use strict'; let dataList = []; // 截取接口数据 let urlFlag = ''; // 获取当前页面的域名 const hostname = window.location.hostname; // 根据不同的域名设置不同的标志 if (hostname.includes('youpin898.com')) { urlFlag = 'yy'; } if (hostname === 'buff.163.com') { urlFlag = 'buff'; } const templatesCollectionT1 = { // 多普勒系列--匕首 '爪子刀(★) | 多普勒p1': [1, 3, 4, 5, 7, 8, 9, 13, 14, 16, 20, 24, 27, 28, 31, 32, 42, 44, 45, 48, 49, 54, 58, 59, 60, 62, 66, 68, 71, 72, 75, 77, 88, 90, 96, 98, 102, 108, 110, 112, 113, 116, 121, 125, 126, 129, 134, 138, 142, 143, 146, 148, 149, 151, 152, 156, 160, 162, 164, 165, 166, 170, 171, 174, 177, 178, 182, 183, 184, 185, 188, 189, 190, 193, 194, 195, 196, 202, 203, 204, 206, 209, 213, 216, 217, 218, 220, 222, 230, 232, 233, 234, 235, 238, 241, 243, 246, 250, 252, 253, 254, 258, 259, 262, 266, 269, 274, 280, 281, 284, 287, 292, 296, 303, 304, 307, 309, 310, 311, 315, 321, 325, 328, 329, 332, 333, 334, 335, 337, 340, 344, 349, 351, 353, 354, 355, 356, 359, 364, 368, 369, 370, 372, 373, 374, 378, 384, 385, 387, 388, 393, 394, 397, 398, 400, 402, 404, 405, 406, 408, 409, 410, 411, 412, 413, 415, 419, 425, 432, 434, 436, 438, 441, 443, 444, 445, 448, 450, 451, 452, 454, 457, 459, 461, 463, 464, 471, 473, 477, 479, 480, 483, 485, 489, 492, 493, 496, 498, 499, 504, 506, 507, 515, 516, 522, 526, 529, 530, 531, 532, 535, 537, 539, 540, 541, 545, 546, 547, 552, 553, 555, 559, 560, 561, 569, 570, 574, 578, 579, 580, 582, 589, 590, 591, 593, 594, 598, 602, 605, 606, 607, 610, 611, 614, 616, 621, 624, 626, 627, 628, 630, 631, 632, 637, 642, 647, 649, 652, 653, 655, 656, 660, 663, 667, 670, 672, 673, 674, 678, 680, 683, 684, 685, 688, 689, 691, 693, 696, 699, 701, 702, 705, 706, 709, 710, 715, 716, 717, 723, 725, 727, 728, 730, 731, 732, 733, 736, 743, 744, 746, 750, 753, 756, 761, 764, 766, 767, 770, 773, 776, 777, 780, 783, 785, 787, 791, 792, 794, 795, 803, 805, 809, 810, 812, 817, 818, 820, 822, 826, 832, 839, 843, 844, 845, 846, 852, 853, 854, 858, 861, 865, 867, 868, 869, 873, 874, 876, 894, 899, 907, 908, 909, 918, 919, 922, 923, 929, 930, 931, 939, 941, 948, 949, 951, 958, 959, 962, 966, 969, 971, 972, 976, 977, 980, 982, 988, 989, 992, 994, 997, 998, 1000], '爪子刀(★) | 多普勒p2': [1, 3, 4, 7, 9, 13, 20, 24, 27, 28, 31, 42, 44, 45, 49, 54, 59, 60, 62, 66, 71, 72, 75, 77, 88, 90, 96, 98, 102, 110, 113, 116, 121, 125, 134, 138, 142, 143, 148, 151, 156, 160, 162, 164, 166, 170, 174, 177, 183, 184, 185, 189, 190, 193, 194, 195, 196, 203, 206, 209, 216, 217, 218, 220, 222, 232, 234, 235, 238, 246, 250, 253, 254, 258, 259, 262, 266, 269, 280, 284, 296, 303, 304, 307, 309, 310, 311, 315, 321, 325, 328, 329, 333, 334, 335, 349, 351, 353, 354, 355, 364, 368, 369, 370, 372, 373, 374, 384, 385, 387, 388, 394, 397, 398, 400, 402, 404, 408, 409, 410, 411, 413, 415, 419, 425, 432, 434, 436, 438, 441, 443, 445, 448, 450, 451, 459, 463, 464, 473, 477, 479, 480, 483, 485, 489, 492, 496, 498, 499, 504, 506, 507, 515, 526, 529, 530, 531, 532, 535, 537, 540, 545, 546, 547, 552, 553, 555, 559, 560, 561, 569, 570, 574, 579, 580, 582, 589, 590, 591, 593, 594, 598, 605, 606, 610, 611, 616, 624, 626, 627, 628, 630, 632, 642, 647, 655, 663, 667, 670, 672, 674, 678, 680, 684, 689, 691, 693, 699, 706, 709, 710, 715, 716, 717, 723, 725, 727, 730, 731, 733, 744, 746, 750, 753, 756, 764, 766, 767, 776, 783, 785, 791, 794, 805, 809, 810, 812, 817, 818, 820, 822, 839, 843, 844, 845, 846, 852, 853, 854, 858, 861, 865, 868, 869, 894, 899, 907, 909, 919, 929, 930, 931, 939, 941, 948, 951, 958, 962, 969, 972, 976, 977, 980, 989, 992, 997, 998], '爪子刀(★) | 多普勒p3': [11, 29, 34, 41, 46, 80, 84, 87, 93, 105, 107, 136, 137, 147, 150, 181, 201, 205, 210, 224, 229, 256, 278, 324, 326, 341, 345, 348, 358, 375, 395, 396, 399, 401, 403, 422, 428, 447, 449, 468, 482, 488, 494, 517, 520, 521, 550, 568, 571, 575, 576, 577, 583, 599, 601, 636, 639, 648, 657, 664, 668, 712, 714, 745, 747, 751, 754, 763, 781, 789, 793, 800, 807, 813, 824, 825, 827, 834, 848, 849, 856, 872, 887, 891, 892, 897, 910, 911, 914, 915, 925, 936, 940, 943, 944, 956, 961, 968, 975, 981], '爪子刀(★) | 多普勒p4': [11, 29, 34, 41, 46, 80, 84, 87, 93, 105, 107, 136, 137, 147, 150, 181, 201, 205, 210, 224, 229, 256, 278, 324, 326, 341, 345, 348, 358, 375, 392, 395, 396, 399, 401, 403, 422, 428, 447, 449, 468, 482, 488, 494, 517, 520, 521, 525, 550, 568, 571, 575, 576, 577, 583, 599, 601, 636, 639, 648, 657, 664, 668, 712, 714, 745, 747, 751, 754, 763, 781, 789, 793, 800, 807, 813, 824, 825, 827, 834, 848, 849, 856, 872, 887, 891, 892, 897, 910, 911, 914, 915, 925, 936, 940, 943, 944, 956, 961, 968, 975, 981], // 伽玛多普勒系列--匕首 '爪子刀(★) | 伽玛多普勒p1': [4, 7, 13, 20, 24, 31, 44, 49, 59, 66, 72, 75, 77, 88, 96, 98, 102, 113, 116, 134, 138, 142, 143, 151, 160, 162, 164, 166, 174, 184, 185, 189, 190, 193, 194, 209, 217, 218, 220, 235, 246, 250, 253, 258, 259, 262, 269, 284, 296, 303, 310, 311, 325, 334, 349, 353, 354, 355, 369, 373, 374, 384, 387, 388, 394, 398, 408, 409, 410, 419, 425, 432, 434, 436, 443, 450, 451, 464, 477, 479, 480, 492, 498, 504, 507, 526, 529, 530, 531, 532, 540, 552, 560, 570, 574, 579, 580, 594, 598, 610, 616, 627, 642, 667, 670, 678, 680, 684, 689, 693, 699, 709, 715, 716, 723, 730, 731, 733, 744, 750, 767, 776, 783, 812, 820, 839, 843, 845, 852, 853, 861, 865, 899, 907, 919, 929, 939, 951, 969, 992, 998], '爪子刀(★) | 伽玛多普勒p2': [1, 3, 4, 7, 9, 13, 20, 24, 27, 28, 31, 42, 44, 45, 49, 54, 59, 60, 62, 66, 71, 72, 75, 77, 88, 90, 96, 98, 102, 110, 113, 116, 121, 125, 134, 138, 142, 143, 148, 151, 156, 160, 162, 164, 166, 170, 174, 177, 183, 184, 185, 189, 190, 193, 194, 195, 196, 203, 206, 209, 216, 217, 218, 220, 222, 232, 234, 235, 238, 246, 250, 253, 254, 258, 259, 262, 266, 269, 280, 284, 296, 303, 304, 307, 309, 310, 311, 315, 321, 325, 328, 329, 333, 334, 335, 349, 351, 353, 354, 355, 364, 368, 369, 370, 372, 373, 374, 384, 385, 387, 388, 394, 397, 398, 400, 402, 404, 408, 409, 410, 411, 413, 415, 419, 425, 432, 434, 436, 438, 441, 443, 445, 448, 450, 451, 459, 463, 464, 473, 477, 479, 480, 483, 485, 489, 492, 496, 498, 499, 504, 506, 507, 515, 526, 529, 530, 531, 532, 535, 537, 540, 545, 546, 547, 552, 553, 555, 559, 560, 561, 569, 570, 574, 579, 580, 582, 589, 590, 591, 593, 594, 598, 605, 606, 610, 611, 616, 624, 626, 627, 628, 630, 632, 642, 647, 655, 663, 667, 670, 672, 674, 678, 680, 684, 689, 691, 693, 699, 706, 709, 710, 715, 716, 717, 723, 725, 727, 730, 731, 733, 744, 746, 750, 753, 756, 764, 766, 767, 776, 783, 785, 791, 794, 805, 809, 810, 812, 817, 818, 820, 822, 839, 843, 844, 845, 846, 852, 853, 854, 858, 861, 865, 868, 869, 894, 899, 907, 909, 919, 929, 930, 931, 939, 941, 948, 951, 958, 962, 969, 972, 976, 977, 980, 989, 992, 997, 998], '爪子刀(★) | 伽玛多普勒p3': [11, 29, 34, 41, 46, 80, 84, 87, 93, 105, 107, 136, 137, 147, 150, 181, 201, 205, 210, 224, 229, 256, 278, 324, 326, 341, 345, 348, 358, 375, 395, 396, 399, 401, 403, 422, 428, 447, 449, 468, 482, 488, 494, 517, 520, 521, 550, 568, 571, 575, 576, 577, 583, 599, 601, 636, 639, 648, 657, 664, 668, 712, 714, 745, 747, 751, 754, 763, 781, 789, 793, 800, 807, 813, 824, 825, 827, 834, 848, 849, 856, 872, 887, 891, 892, 897, 910, 911, 914, 915, 925, 936, 943, 944, 956, 961, 968, 975, 981], '爪子刀(★) | 伽玛多普勒p4': [11, 29, 34, 41, 46, 80, 84, 87, 93, 105, 107, 136, 137, 147, 150, 181, 201, 205, 210, 224, 229, 256, 278, 324, 326, 341, 345, 348, 358, 375, 395, 396, 399, 401, 403, 422, 428, 447, 449, 468, 482, 488, 494, 517, 520, 521, 550, 568, 571, 575, 576, 577, 583, 599, 601, 636, 639, 648, 657, 664, 668, 712, 714, 745, 747, 751, 754, 763, 781, 789, 793, 800, 807, 813, 824, 825, 827, 834, 848, 849, 856, 872, 887, 891, 892, 897, 910, 911, 914, 915, 925, 936, 943, 944, 956, 961, 968, 975, 981], // 渐变大理石系列--匕首 '爪子刀(★) | 渐变大理石': [5, 8, 14, 16, 28, 32, 48, 58, 68, 108, 112, 121, 126, 129, 146, 149, 152, 156, 165, 171, 177, 178, 182, 188, 202, 204, 206, 213, 230, 233, 238, 241, 243, 252, 274, 281, 287, 292, 332, 337, 340, 344, 356, 359, 370, 372, 378, 393, 405, 406, 412, 444, 452, 454, 457, 461, 471, 493, 499, 516, 522, 539, 541, 545, 546, 553, 559, 578, 589, 591, 602, 607, 614, 621, 628, 631, 632, 637, 649, 652, 653, 655, 656, 660, 672, 673, 683, 685, 688, 696, 701, 702, 705, 706, 725, 728, 732, 736, 743, 761, 764, 766, 770, 773, 777, 780, 787, 791, 792, 795, 803, 817, 826, 832, 844, 854, 858, 867, 868, 873, 874, 876, 908, 918, 922, 923, 949, 959, 966, 971, 972, 977, 982, 988, 994, 997, 1000], '运动手套(★) | 大型猎物': [921, 203, 653, 817, 705], '沙漠之鹰 | 热处理': [843, 347, 66, 308, 772, 792, 461, 69, 259, 328, 704, 990], '廓尔喀刀(★) | 表面淬火': [398, 838, 652, 371, 182, 494], }; const templatesCollectionT2 = { // 多普勒系列--匕首 // '爪子刀(★) | 多普勒p1': [], '爪子刀(★) | 多普勒p2': [5, 8, 14, 15, 16, 17, 32, 35, 39, 48, 55, 58, 68, 70, 74, 83, 86, 92, 99, 100, 101, 106, 108, 112, 119, 120, 122, 123, 124, 126, 127, 128, 129, 131, 132, 133, 135, 140, 144, 146, 149, 152, 153, 158, 159, 165, 169, 171, 178, 180, 182, 186, 188, 197, 198, 199, 202, 204, 208, 213, 219, 221, 225, 226, 230, 231, 233, 237, 239, 241, 242, 243, 244, 245, 247, 248, 252, 261, 263, 264, 265, 268, 274, 275, 279, 281, 286, 287, 288, 290, 292, 305, 306, 316, 317, 320, 330, 331, 332, 337, 338, 339, 340, 344, 350, 352, 356, 359, 360, 362, 366, 371, 378, 383, 386, 391, 393, 405, 406, 407, 412, 417, 418, 420, 423, 426, 444, 452, 454, 456, 457, 460, 461, 467, 469, 471, 472, 474, 476, 478, 484, 490, 493, 495, 497, 500, 501, 502, 503, 505, 509, 510, 516, 519, 522, 523, 524, 534, 539, 541, 542, 544, 548, 551, 557, 558, 562, 563, 565, 578, 581, 585, 595, 600, 602, 603, 607, 609, 614, 615, 618, 620, 621, 622, 623, 625, 631, 634, 637, 638, 643, 646, 649, 650, 652, 653, 656, 659, 660, 669, 671, 673, 675, 679, 681, 682, 683, 685, 688, 692, 694, 696, 701, 702, 704, 705, 708, 711, 713, 720, 721, 728, 732, 736, 739, 743, 748, 755, 761, 768, 770, 771, 772, 773, 775, 777, 779, 780, 784, 787, 788, 792, 795, 796, 803, 816, 826, 832, 836, 855, 857, 859, 862, 867, 871, 873, 874, 876, 882, 883, 890, 893, 896, 908, 913, 918, 922, 923, 926, 927, 928, 935, 937, 938, 945, 949, 952, 954, 959, 965, 966, 971, 973, 982, 983, 985, 986, 987, 988, 994, 999, 1000], '爪子刀(★) | 多普勒p3': [6, 12, 18, 21, 22, 30, 33, 37, 43, 64, 73, 76, 79, 89, 94, 103, 104, 109, 111, 117, 130, 141, 145, 154, 155, 157, 161, 168, 172, 173, 176, 179, 187, 191, 211, 212, 223, 227, 236, 249, 260, 273, 276, 277, 282, 283, 285, 289, 293, 295, 299, 302, 308, 312, 313, 314, 323, 336, 357, 361, 376, 377, 380, 381, 382, 389, 392, 416, 421, 424, 429, 430, 433, 435, 440, 442, 446, 455, 458, 462, 465, 466, 481, 486, 487, 491, 508, 511, 512, 513, 514, 518, 525, 527, 528, 536, 538, 549, 556, 564, 566, 572, 573, 584, 586, 587, 588, 592, 596, 597, 604, 608, 612, 633, 640, 645, 651, 654, 658, 661, 665, 666, 686, 687, 690, 697, 698, 703, 719, 726, 737, 740, 742, 749, 752, 757, 758, 759, 760, 762, 769, 774, 782, 790, 798, 802, 804, 806, 808, 811, 815, 821, 835, 838, 840, 851, 860, 863, 864, 866, 875, 878, 881, 884, 886, 895, 898, 901, 902, 916, 917, 921, 933, 942, 953, 955, 960, 974, 978, 979, 984, 990, 991, 993, 995], '爪子刀(★) | 多普勒p4': [6, 12, 18, 21, 22, 30, 33, 37, 43, 64, 73, 76, 79, 89, 94, 103, 104, 109, 111, 117, 130, 141, 145, 154, 155, 157, 161, 168, 172, 173, 176, 179, 187, 191, 211, 212, 223, 227, 236, 249, 260, 273, 276, 277, 282, 283, 285, 289, 293, 295, 299, 302, 308, 312, 313, 314, 323, 336, 357, 361, 376, 377, 380, 381, 382, 389, 416, 421, 424, 429, 430, 433, 435, 440, 442, 446, 455, 458, 462, 465, 466, 481, 486, 487, 491, 508, 511, 512, 513, 514, 518, 525, 527, 528, 536, 538, 549, 556, 564, 566, 572, 573, 584, 586, 587, 588, 592, 596, 597, 604, 608, 612, 633, 640, 645, 651, 654, 658, 661, 665, 666, 686, 687, 690, 697, 698, 703, 719, 726, 737, 740, 742, 749, 752, 757, 758, 759, 760, 762, 769, 774, 782, 790, 798, 802, 804, 806, 808, 811, 815, 821, 835, 838, 840, 851, 860, 863, 864, 866, 875, 878, 881, 884, 886, 895, 898, 901, 902, 916, 917, 921, 933, 942, 953, 955, 960, 974, 978, 979, 984, 990, 991, 993, 995], '爪子刀(★) | 多普勒红宝石': [4, 7, 39, 60, 86, 106, 110, 116, 125, 132, 151, 185, 194, 196, 202, 218, 222, 226, 253, 325, 328, 354, 360, 374, 383, 384, 422, 436, 464, 478, 480, 487, 507, 540, 551, 555, 560, 560, 570, 598, 621, 646, 659, 667, 678, 681, 693, 694, 696, 711, 717, 750, 756, 770, 776, 777, 819, 843, 858, 859, 868, 871, 894, 896, 908, 922, 969, 983], '爪子刀(★) | 多普勒蓝宝石': [4, 7, 39, 60, 86, 106, 110, 116, 125, 132, 151, 185, 194, 196, 202, 218, 222, 226, 253, 325, 328, 354, 360, 374, 383, 384, 422, 436, 464, 478, 480, 487, 507, 540, 551, 555, 560, 560, 570, 598, 621, 646, 659, 667, 678, 681, 693, 694, 696, 711, 717, 750, 756, 770, 776, 777, 819, 843, 858, 859, 868, 871, 894, 896, 908, 922, 969, 983], // 伽玛多普勒系列--匕首 '爪子刀(★) | 伽玛多普勒p1': [1, 3, 5, 8, 9, 14, 16, 27, 28, 32, 42, 45, 48, 54, 58, 60, 62, 68, 71, 90, 108, 110, 112, 121, 125, 126, 129, 146, 148, 149, 152, 156, 165, 170, 171, 177, 178, 182, 183, 188, 195, 196, 202, 203, 204, 206, 213, 216, 222, 230, 232, 233, 234, 238, 241, 243, 252, 254, 266, 274, 280, 281, 287, 292, 304, 307, 309, 315, 321, 328, 329, 332, 333, 335, 337, 340, 344, 351, 356, 359, 364, 368, 370, 372, 378, 385, 393, 397, 400, 402, 404, 405, 406, 411, 412, 413, 415, 438, 441, 444, 445, 448, 452, 454, 457, 459, 461, 463, 471, 473, 483, 485, 489, 493, 496, 499, 506, 515, 516, 522, 535, 537, 539, 541, 545, 546, 547, 553, 555, 559, 561, 569, 578, 582, 589, 590, 591, 593, 602, 605, 606, 607, 611, 614, 621, 624, 626, 628, 630, 631, 632, 637, 647, 649, 652, 653, 655, 656, 660, 663, 672, 673, 674, 683, 685, 688, 691, 696, 701, 702, 705, 706, 710, 717, 725, 727, 728, 732, 736, 743, 746, 753, 756, 761, 764, 766, 770, 773, 777, 780, 785, 787, 791, 792, 794, 795, 803, 805, 809, 810, 817, 818, 822, 826, 832, 844, 846, 854, 858, 867, 868, 869, 873, 874, 876, 894, 908, 909, 918, 922, 923, 930, 931, 941, 948, 949, 958, 959, 962, 966, 971, 972, 976, 977, 980, 982, 988, 989, 994, 997, 1000], '爪子刀(★) | 伽玛多普勒p2': [5, 8, 14, 15, 16, 17, 32, 35, 39, 48, 55, 58, 68, 70, 74, 83, 86, 92, 99, 100, 101, 106, 108, 112, 119, 120, 122, 123, 124, 126, 127, 128, 129, 131, 132, 133, 135, 140, 144, 146, 149, 152, 153, 158, 159, 165, 169, 171, 178, 180, 182, 186, 188, 197, 198, 199, 202, 204, 208, 213, 219, 221, 225, 226, 230, 231, 233, 237, 239, 241, 242, 243, 244, 245, 247, 248, 252, 261, 263, 264, 265, 268, 274, 275, 279, 281, 286, 287, 288, 290, 292, 305, 306, 316, 317, 320, 330, 331, 332, 337, 338, 339, 340, 344, 350, 352, 356, 359, 360, 362, 366, 371, 378, 383, 386, 391, 393, 405, 406, 407, 412, 417, 418, 420, 423, 426, 444, 452, 454, 456, 457, 460, 461, 467, 469, 471, 472, 474, 476, 478, 484, 490, 493, 495, 497, 500, 501, 502, 503, 505, 509, 510, 516, 519, 522, 523, 524, 534, 539, 541, 542, 544, 548, 551, 557, 558, 562, 563, 565, 578, 581, 585, 595, 600, 602, 603, 607, 609, 614, 615, 618, 620, 621, 622, 623, 625, 631, 634, 637, 638, 643, 646, 649, 650, 652, 653, 656, 659, 660, 669, 671, 673, 675, 679, 681, 682, 683, 685, 688, 692, 694, 696, 701, 702, 704, 705, 708, 711, 713, 720, 721, 728, 732, 736, 739, 743, 748, 755, 761, 768, 770, 771, 772, 773, 775, 777, 779, 780, 784, 787, 788, 792, 795, 796, 803, 816, 826, 832, 836, 855, 857, 859, 862, 867, 871, 873, 874, 876, 882, 883, 890, 893, 896, 908, 913, 918, 922, 923, 926, 927, 928, 935, 937, 938, 945, 949, 952, 954, 959, 965, 966, 971, 973, 982, 983, 985, 986, 987, 988, 994, 999, 1000], '爪子刀(★) | 伽玛多普勒p3': [6, 12, 18, 21, 22, 30, 33, 37, 43, 64, 73, 76, 79, 89, 94, 103, 104, 109, 111, 117, 130, 141, 145, 154, 155, 157, 161, 168, 172, 173, 176, 179, 187, 191, 211, 212, 223, 227, 236, 249, 260, 273, 276, 277, 282, 283, 285, 289, 293, 295, 299, 302, 308, 312, 313, 314, 323, 336, 357, 361, 376, 377, 380, 381, 382, 389, 416, 421, 424, 429, 430, 433, 435, 440, 442, 446, 455, 458, 462, 465, 466, 481, 486, 487, 491, 508, 511, 512, 513, 514, 518, 525, 527, 528, 536, 538, 549, 556, 564, 566, 572, 573, 584, 586, 587, 588, 592, 596, 597, 604, 608, 612, 633, 640, 645, 651, 654, 658, 661, 665, 666, 686, 687, 690, 697, 698, 703, 719, 726, 737, 740, 742, 749, 752, 757, 758, 759, 760, 762, 769, 774, 782, 790, 798, 802, 804, 806, 808, 811, 815, 821, 835, 838, 840, 851, 860, 863, 864, 866, 875, 878, 881, 884, 886, 895, 898, 901, 902, 916, 917, 921, 933, 942, 953, 955, 960, 974, 978, 979, 984, 990, 991, 993, 995], '爪子刀(★) | 伽玛多普勒p4': [6, 12, 18, 21, 22, 30, 33, 37, 43, 64, 73, 76, 79, 89, 94, 103, 104, 109, 111, 117, 130, 141, 145, 154, 155, 157, 161, 168, 172, 173, 176, 179, 187, 191, 211, 212, 223, 227, 236, 249, 260, 273, 276, 277, 282, 283, 285, 289, 293, 295, 299, 302, 308, 312, 313, 314, 323, 336, 357, 361, 376, 377, 380, 381, 382, 389, 416, 421, 424, 429, 430, 433, 435, 440, 442, 446, 455, 458, 462, 465, 466, 481, 486, 487, 491, 508, 511, 512, 513, 514, 518, 525, 527, 528, 536, 538, 549, 556, 564, 566, 572, 573, 584, 586, 587, 588, 592, 596, 597, 604, 608, 612, 633, 640, 645, 651, 654, 658, 661, 665, 666, 686, 687, 690, 697, 698, 703, 719, 726, 737, 740, 742, 749, 752, 757, 758, 759, 760, 762, 769, 774, 782, 790, 798, 802, 804, 806, 808, 811, 815, 821, 835, 838, 840, 851, 860, 863, 864, 866, 875, 878, 881, 884, 886, 895, 898, 901, 902, 916, 917, 921, 933, 942, 953, 955, 960, 974, 978, 979, 984, 990, 991, 993, 995], // 渐变大理石系列--匕首 '爪子刀(★) | 渐变大理石': [1, 3, 4, 9, 27, 42, 45, 54, 60, 62, 71, 88, 90, 98, 102, 110, 125, 138, 148, 162, 170, 183, 185, 195, 196, 203, 216, 222, 232, 234, 253, 254, 266, 269, 280, 296, 304, 307, 309, 311, 315, 321, 328, 329, 333, 334, 335, 351, 354, 364, 368, 385, 387, 388, 397, 400, 402, 404, 411, 413, 415, 438, 441, 445, 448, 451, 459, 463, 473, 483, 485, 489, 506, 515, 535, 537, 547, 561, 569, 570, 582, 590, 593, 605, 606, 624, 626, 630, 647, 670, 674, 691, 710, 717, 723, 727, 746, 753, 756, 785, 805, 809, 810, 818, 822, 846, 869, 909, 930, 931, 941, 948, 958, 962, 976, 980, 989], '运动手套(★) | 大型猎物': [11, 16, 112, 201, 267, 301, 345, 486, 614, 896], '沙漠之鹰 | 热处理': [67, 96, 263, 297, 321, 341, 530, 695, 885, 885, 16, 16, 273, 273, 674, 674, 48, 48, 482, 482, 517, 517, 790, 790, 904, 904, 490, 948], '廓尔喀刀(★) | 表面淬火': [29, 130, 214, 283, 358, 407, 575, 702, 720, 749, 770, 839, 868, 881, 928], }; const templatesCollectionT3 = { // 多普勒系列--匕首 '爪子刀(★) | 多普勒p1': [15, 17, 35, 39, 55, 70, 74, 83, 86, 92, 99, 100, 101, 106, 119, 120, 122, 123, 124, 127, 128, 131, 132, 133, 135, 140, 144, 153, 158, 159, 169, 180, 186, 197, 198, 199, 208, 219, 221, 225, 226, 231, 237, 239, 242, 244, 245, 247, 248, 261, 263, 264, 265, 268, 275, 279, 286, 288, 290, 305, 306, 316, 317, 320, 330, 331, 338, 339, 350, 352, 360, 362, 366, 371, 383, 386, 391, 407, 417, 418, 420, 423, 426, 456, 460, 467, 469, 472, 474, 476, 478, 484, 490, 495, 497, 500, 501, 502, 503, 505, 509, 510, 519, 523, 524, 534, 542, 544, 548, 551, 557, 558, 562, 563, 565, 581, 585, 595, 600, 603, 609, 615, 618, 620, 622, 623, 625, 634, 638, 643, 646, 650, 659, 669, 671, 675, 679, 681, 682, 692, 694, 704, 708, 711, 713, 720, 721, 739, 748, 755, 768, 771, 772, 775, 779, 784, 788, 796, 816, 836, 855, 857, 859, 862, 871, 882, 883, 890, 893, 896, 913, 926, 927, 928, 935, 937, 938, 945, 952, 954, 965, 973, 983, 985, 986, 987, 999], // '爪子刀(★) | 多普勒p2': [], '爪子刀(★) | 多普勒p3': [2, 10, 19, 23, 25, 26, 36, 38, 40, 47, 50, 51, 52, 53, 56, 57, 61, 63, 65, 67, 69, 78, 81, 82, 85, 91, 95, 97, 114, 115, 118, 139, 163, 167, 192, 200, 207, 214, 215, 228, 240, 251, 255, 257, 267, 270, 271, 272, 291, 294, 297, 298, 300, 301, 318, 319, 322, 327, 342, 343, 346, 347, 363, 365, 367, 379, 390, 414, 427, 431, 437, 439, 470, 475, 453, 533, 543, 554, 567, 613, 617, 619, 629, 635, 644, 662, 676, 695, 700, 707, 718, 722, 724, 729, 734, 735, 738, 741, 765, 778, 786, 797, 799, 801, 814, 819, 823, 828, 829, 830, 831, 833, 837, 841, 842, 847, 850, 877, 879, 880, 885, 888, 889, 900, 903, 904, 905, 906, 912, 920, 924, 932, 934, 946, 947, 950, 957, 963, 964, 967, 970, 996], '爪子刀(★) | 多普勒p4': [2, 10, 19, 23, 25, 26, 36, 38, 40, 47, 50, 51, 52, 53, 56, 57, 61, 63, 65, 67, 69, 78, 81, 82, 85, 91, 95, 97, 114, 115, 118, 139, 163, 167, 207, 214, 215, 228, 240, 251, 255, 257, 267, 270, 271, 272, 291, 294, 297, 298, 300, 301, 318, 319, 322, 342, 343, 414, 431, 453, 533, 543, 554, 567, 613, 617, 619, 635, 662, 676, 695, 700, 718, 724, 729, 734, 735, 738, 741, 765, 778, 786, 797, 801, 823, 828, 829, 830, 831, 837, 841, 850, 879, 880, 885, 900, 903, 904, 905, 906, 912, 920, 924, 947, 950, 963, 964, 967, 970, 996], '爪子刀(★) | 多普勒红宝石': [20, 31, 45, 49, 58, 66, 77, 119, 132, 149, 153, 160, 162, 166, 174, 178, 184, 189, 192, 193, 203, 204, 217, 234, 246, 250, 262, 280, 286, 287, 292, 296, 303, 334, 369, 370, 373, 388, 394, 404, 409, 411, 412, 423, 443, 444, 450, 463, 464, 468, 469, 477, 489, 492, 498, 502, 504, 506, 510, 526, 530, 532, 574, 579, 580, 589, 593, 600, 616, 627, 637, 670, 699, 705, 706, 716, 723, 730, 733, 764, 766, 787, 795, 803, 817, 818, 844, 853, 857, 861, 874, 893, 913, 928, 935, 939, 949, 992, 998], '爪子刀(★) | 多普勒蓝宝石': [20, 31, 45, 49, 58, 66, 77, 119, 132, 149, 153, 160, 162, 166, 174, 178, 184, 189, 192, 193, 203, 204, 217, 234, 246, 250, 262, 280, 286, 287, 292, 296, 303, 334, 369, 370, 373, 388, 394, 404, 409, 411, 412, 423, 443, 444, 450, 463, 464, 468, 469, 477, 489, 492, 498, 502, 504, 506, 510, 526, 530, 532, 574, 579, 580, 589, 593, 600, 616, 627, 637, 670, 699, 705, 706, 716, 723, 730, 733, 764, 766, 787, 795, 803, 817, 818, 844, 853, 857, 861, 874, 893, 913, 928, 935, 939, 949, 992, 998], // 伽玛多普勒系列--匕首 // '爪子刀(★) | 伽玛多普勒p1': [], // '爪子刀(★) | 伽玛多普勒p2': [], '爪子刀(★) | 伽玛多普勒p3': [2, 10, 19, 23, 25, 26, 36, 38, 40, 47, 50, 51, 52, 53, 56, 57, 61, 63, 65, 67, 69, 78, 81, 82, 85, 91, 95, 97, 114, 115, 118, 139, 163, 167, 175, 207, 214, 215, 228, 240, 251, 255, 257, 267, 270, 271, 272, 291, 294, 297, 298, 300, 301, 318, 319, 322, 342, 343, 414, 431, 453, 533, 543, 554, 567, 613, 617, 619, 635, 641, 662, 676, 695, 700, 718, 724, 729, 734, 735, 738, 741, 765, 778, 786, 797, 801, 823, 828, 829, 830, 831, 837, 841, 850, 879, 880, 885, 900, 903, 904, 905, 906, 912, 920, 924, 947, 950, 963, 964, 967, 970, 996], '爪子刀(★) | 伽玛多普勒p4': [2, 10, 19, 23, 25, 26, 36, 38, 40, 47, 50, 51, 52, 53, 56, 57, 61, 63, 65, 67, 69, 78, 81, 82, 85, 91, 95, 97, 114, 115, 118, 139, 163, 167, 207, 214, 215, 228, 240, 251, 255, 257, 267, 270, 271, 272, 291, 294, 297, 298, 300, 301, 318, 319, 322, 342, 343, 414, 431, 453, 533, 543, 554, 567, 613, 617, 619, 635, 662, 676, 695, 700, 718, 724, 729, 734, 735, 738, 741, 765, 778, 786, 797, 801, 823, 828, 829, 830, 831, 837, 841, 850, 879, 880, 885, 900, 903, 904, 905, 906, 912, 920, 924, 947, 950, 963, 964, 967, 970, 996], // 渐变大理石系列--匕首 '爪子刀(★) | 渐变大理石': [7, 13, 20, 24, 31, 39, 44, 49, 59, 66, 72, 75, 77, 83, 96, 106, 113, 115, 116, 119, 132, 134, 142, 143, 151, 153, 160, 164, 166, 174, 184, 186, 189, 190, 193, 194, 209, 217, 218, 220, 221, 226, 231, 235, 237, 244, 246, 248, 250, 258, 259, 262, 265, 279, 284, 286, 290, 303, 310, 325, 349, 352, 353, 355, 360, 369, 371, 373, 374, 383, 384, 386, 394, 398, 408, 409, 410, 419, 423, 425, 432, 434, 436, 443, 450, 464, 469, 472, 474, 476, 477, 478, 479, 480, 484, 490, 492, 496, 498, 502, 504, 507, 510, 519, 523, 526, 529, 530, 531, 532, 534, 540, 544, 551, 552, 555, 558, 560, 562, 574, 579, 580, 585, 594, 595, 598, 600, 603, 610, 611, 616, 627, 634, 638, 642, 646, 650, 659, 663, 667, 669, 671, 675, 678, 679, 680, 681, 684, 689, 692, 693, 694, 699, 704, 708, 709, 711, 715, 716, 720, 721, 730, 731, 733, 739, 744, 748, 750, 755, 767, 771, 772, 776, 783, 784, 788, 794, 796, 812, 816, 820, 833, 839, 843, 845, 852, 853, 855, 857, 859, 861, 862, 865, 871, 883, 890, 893, 894, 896, 899, 907, 913, 919, 926, 927, 928, 929, 935, 937, 939, 951, 952, 954, 969, 973, 983, 986, 992, 998, 999], '运动手套(★) | 大型猎物': [18, 30, 34, 40, 59, 65, 69, 103, 93, 127, 139, 177, 197, 226, 230, 242, 254, 270, 355, 378, 382, 390, 459, 492, 507, 537, 541, 580, 609, 669, 738, 785, 798, 850, 872, 898, 902, 935], }; const templatesCollectionT4 = { }; console.log('脚本已初始化'); // 拦截 XMLHttpRequest 请求 const originalXhrOpen = XMLHttpRequest.prototype.open; // 重写 XMLHttpRequest 的 open 方法 XMLHttpRequest.prototype.open = function (method, url) { // queryOnSaleCommodityList 是uu获取在售列表的接口 if (url.includes('queryOnSaleCommodityList')) { const originalOnreadystatechange = this.onreadystatechange; console.log("===triger!!") // 监听请求完成后的回调 this.onreadystatechange = function () { if (this.readyState === 4 && this.status === 200) { // 获取接口返回的数据 const res = JSON.parse(this.responseText); // 存储接口数据,假设接口返回的数据结构适合存储 if (res && res.Data) { res.Data.forEach(item => { let obj = { wearValue: item.abrade.replace(/0+$/, '') || '', // 假设接口返回的数据有 wearValue 字段 paintseed: item.paintSeed || '', // 假设接口返回的数据有 wearValue 字段 template: item.dopplerName || '', // 假设接口返回的数据有 wearValue 字段 多普勒P级 targetName: item.commodityName || '', // 假设接口返回的数据有 wearValue 字段 物品全称 } dataList.push(obj) }); console.log("dataList =====> " + JSON.stringify(dataList)); } } // 调用原始的 onreadystatechange 回调 if (originalOnreadystatechange) { originalOnreadystatechange.apply(this, arguments); } }; } // 调用原始的 open 方法 originalXhrOpen.apply(this, arguments); }; // 按钮弹出窗口 function showPopup(dataList, goodsName, type) { // 创建背景遮罩 const overlay = document.createElement('div'); overlay.style.position = 'fixed'; overlay.style.top = '0'; overlay.style.left = '0'; overlay.style.width = '100%'; overlay.style.height = '100%'; overlay.style.backgroundColor = 'rgba(0, 0, 0, 0.5)'; overlay.style.zIndex = '9998'; overlay.style.transition = 'opacity 0.3s ease-in-out'; overlay.style.opacity = 0; setTimeout(() => overlay.style.opacity = 1, 10); // 为遮罩添加渐变出现效果 // 创建弹窗容器 const popup = document.createElement('div'); popup.style.position = 'fixed'; popup.style.left = '50%'; popup.style.top = '50%'; popup.style.transform = 'translate(-50%, -50%) scale(0.8)'; popup.style.padding = '30px'; popup.style.backgroundColor = '#ffffff'; popup.style.borderRadius = '15px'; popup.style.boxShadow = '0 15px 30px rgba(0, 0, 0, 0.2)'; popup.style.zIndex = '9999'; popup.style.maxWidth = '900px'; popup.style.width = '50%'; popup.style.fontFamily = 'Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif'; popup.style.border = 'none'; popup.style.transition = 'opacity 0.3s ease-in-out, transform 0.3s ease-in-out'; popup.style.opacity = 0; popup.className = 'aaaaapopup'; // 添加类名aaaaapopup setTimeout(() => { popup.style.opacity = 1; popup.style.transform = 'translate(-50%, -50%) scale(1)'; }, 10); // 为弹窗添加渐变出现和缩放效果 // 创建内容容器并设置最大高度与隐藏滚动条 const contentContainer = document.createElement('div'); contentContainer.style.maxHeight = '600px'; contentContainer.style.overflow = 'auto'; // 启用滚动 contentContainer.style.padding = '20px'; contentContainer.style.fontSize = '16px'; contentContainer.style.lineHeight = '1.2'; // 隐藏滚动条,但支持滚动 contentContainer.style.scrollbarWidth = 'none'; // Firefox contentContainer.style.msOverflowStyle = 'none'; // IE 10+ // 使用 Webkit 方式隐藏滚动条 contentContainer.style.webkitOverflowScrolling = 'touch'; // 平滑滚动效果 const style = document.createElement('style'); style.innerHTML = ` /* Webkit 浏览器 */ .hide-scrollbar::-webkit-scrollbar { display: none; } .hide-scrollbar { -ms-overflow-style: none; /* IE 10+ */ scrollbar-width: none; /* Firefox */ } `; document.head.appendChild(style); contentContainer.classList.add('hide-scrollbar'); // 添加样式类以隐藏滚动条 // 弹窗内容 let content = `

${type === '1' ? '磨损' : '模板'}价格查询

`; // 遍历数据列表并生成内容 dataList.forEach((data, index) => { const isLastItem = index === dataList.length - 1; content += `

名称: ${goodsName}

图案模板: ${data.paintSeed ? data.paintSeed : ''}

磨损: ${data.wearFlot}

印花: ${data.stickers.length > 0 ? data.stickers.map(sticker => ` ${sticker.name} `).join('') : '

'}

成交价格: ¥${data.tradePrice}

成交时在售底价: ¥${data.minSellPrice}

成交时间: ${new Date(data.tradeTime * 1000).toLocaleString()}

`; }); // 将内容添加到内容容器中 contentContainer.innerHTML = content; // 创建关闭文本 const closeText = document.createElement('span'); closeText.innerText = '关闭'; closeText.style.position = 'absolute'; closeText.style.top = '15px'; closeText.style.right = '15px'; closeText.style.color = '#273249'; closeText.style.fontSize = '18px'; closeText.style.cursor = 'pointer'; closeText.style.fontWeight = '400'; closeText.style.transition = 'color 0.3s'; closeText.addEventListener('mouseenter', () => { closeText.style.color = '#666'; }); closeText.addEventListener('mouseleave', () => { closeText.style.color = '#273249'; }); closeText.addEventListener('click', () => { popup.style.opacity = 0; popup.style.transform = 'translate(-50%, -50%) scale(0.8)'; overlay.style.opacity = 0; setTimeout(() => { document.body.removeChild(popup); document.body.removeChild(overlay); }, 300); }); // 将关闭文本和内容容器添加到弹窗 popup.appendChild(contentContainer); popup.appendChild(closeText); // 添加到页面 document.body.appendChild(overlay); document.body.appendChild(popup); } // 发送查询请求的函数 function sendRequest(wearValue, paintseed, template, type, targetName) { // 第一个接口的URL const firstApiUrl = 'https://sdt-api.ok-skins.com/user/skin/v2/skin-info?content=' + wearValue + '×tamp=' + new Date().getTime(); // 请求第一个接口 fetch(firstApiUrl, { method: 'GET', headers: { 'Content-Type': 'application/json', 'Accept': 'application/json', 'X-App-Version': '1.0.0', 'X-Currency': 'CNY', 'X-Device': '1', 'X-Device-Id': '6ff4f894-4c0a-49a4-935c-2303c4185ecb', 'Language': 'zh_CN', 'Origin': 'https://steamdt.com', 'Referer': 'https://steamdt.com/', } }) .then(response => response.json()) // 解析第一个接口的响应 .then(firstApiData => { // 遍历第一个接口返回的数组,寻找匹配的名称 const matchedItem = firstApiData?.data?.find(item => item.assetDetail?.classInfo?.name === targetName); if (matchedItem) { const itemId = matchedItem.assetDetail.classInfo.itemId; // 获取 itemId const goodsName = matchedItem.assetDetail.classInfo.name; // 获取 goodsName // 第二个接口的URL const secondApiUrl = 'https://sdt-api.ok-skins.com/item/trade/v1/list?timestamp=' + new Date().getTime(); const headers = { 'Content-Type': 'application/json', 'Accept': 'application/json', 'X-App-Version': '1.0.0', 'X-Currency': 'CNY', 'X-Device': '1', 'X-Device-Id': '6ff4f894-4c0a-49a4-935c-2303c4185ecb', 'Language': 'zh_CN', 'Origin': 'https://steamdt.com', 'Referer': 'https://steamdt.com/', }; const requestData = { paintSeed: paintseed ? [paintseed] : [], // 传入 paintseed 数据 specialStyles: template ? [template] : [], // 传入 template 数据 style: template ? [template] : [], // 传入 style 数据 wear: type === '1' ? wearValue : '', // 磨损字段 pageSize: 20, itemId: itemId, sortBy: "tradeTime", sortType: "desc", styles: "", paintIndex: [], // 根据需求调整 timestamp: new Date().getTime().toString(), // 使用当前时间戳 }; // 使用 fetch 发送 POST 请求 fetch(secondApiUrl, { method: 'POST', headers: headers, body: JSON.stringify(requestData), }) .then(response => response.json()) .then(data => { if (data && data.data.list.length > 0) { showPopup(data.data.list, goodsName, type); // 使用返回的数据更新弹窗 } }) .catch(error => { console.error('第二个接口请求失败:', error); }); } else { console.error('没有找到匹配的物品名:', targetName); } }) .catch(error => { console.error('第一个接口请求失败:', error); }); } document.addEventListener('DOMContentLoaded', function () { const defaultPaintseedList = new Set([]); const storedPaintseedList = localStorage.getItem('paintseedList'); let paintseedList = storedPaintseedList ? new Set(JSON.parse(storedPaintseedList)) : new Set(defaultPaintseedList); let refreshIntervalId = null; const panel = document.createElement('div'); panel.style.position = 'fixed'; panel.style.top = '20px'; panel.style.right = '20px'; panel.style.backgroundColor = 'rgba(38, 49, 71, 0.9)'; panel.style.backdropFilter = 'blur(5px)'; // 添加模糊效果 panel.style.borderRadius = '8px'; panel.style.color = '#fff'; panel.style.boxShadow = '0 4px 8px rgba(0, 0, 0, 0.2)'; panel.style.padding = '18px'; panel.style.zIndex = 10000; panel.style.maxHeight = '400px'; panel.style.overflowY = 'auto'; panel.style.fontFamily = 'Arial, sans-serif'; panel.innerHTML = ` 【特殊模板捡漏大师】自定义高亮面板

自定义模板历史记录:


自定义模板id:


自动操作:
`; document.body.appendChild(panel); let isPanelHidden = true; panel.style.transform = 'translateX(calc(100% + 5px))'; panel.style.transition = 'transform 0.3s ease'; panel.style.backgroundColor = 'rgba(247, 151, 49, 0.9)'; panel.addEventListener('click', (e) => { // 只有当点击的是面板背景而不是内部元素时才触发 if (e.target === panel) { if (!isPanelHidden) { // 移动到右边缘,只留下10px panel.style.transform = 'translateX(calc(100% + 5px))'; panel.style.transition = 'transform 0.3s ease'; panel.style.backgroundColor = 'rgba(247, 151, 49, 0.9)'; isPanelHidden = true; } else { // 恢复原位 panel.style.transform = 'translateX(0)'; panel.style.backgroundColor = 'rgba(38, 49, 71, 0.9)'; isPanelHidden = false; } } }); const paintseedDisplay = document.getElementById('paintseedList'); const clearButton = document.getElementById('clearPaintseeds'); const updateButton = document.getElementById('updatePaintseeds'); const paintseedInput = document.getElementById('paintseedInput'); const toggleRefreshButton = document.getElementById('toggleRefresh'); let highlightedPaintseeds = new Set(JSON.parse(localStorage.getItem('highlightedPaintseeds') || '[]')); updatePanel(); function processTRElements() { let found = false; if (urlFlag === 'yy') { if (dataList.length <= 0) return found; const rows = document.querySelectorAll('tr.ant-table-row'); rows.forEach((row) => { // 检查当前行是否包含磨损值 const wearValueDiv = row.querySelector('.wear-degree-num___AbgA1 span'); const wearText = wearValueDiv.textContent.trim(); const wearMatch = wearText.match(/磨损:\s*(\d+\.\d+)/); let wearValue = ''; // 磨损值 if (wearMatch) { wearValue = wearMatch[1]; } // dataList的磨损值匹配wearValue const matchedData = dataList.find(item => item.wearValue === wearValue); if (matchedData) { // 获取doppler名称 let template = matchedData.template || ''; let paintseed = matchedData.paintseed || ''; let targetName = matchedData.targetName || ''; let topTemplate = ''; template = targetName.includes('多普勒') ? template.toLowerCase() || '' : ''; topTemplate = targetName.replace(/\s*\(.*?\)/g, '').trim() + template; // 添加查看历史价格按钮 const historyButton = document.createElement('button'); historyButton.innerText = '查看历史价格'; historyButton.className = 'view-history-btn'; historyButton.style.display = 'block'; historyButton.style.cursor = 'pointer'; historyButton.style.marginBottom = '6px'; historyButton.style.padding = '8px 15px'; historyButton.style.backgroundColor = '#F7971D'; historyButton.style.border = 'none'; historyButton.style.color = '#fff'; historyButton.style.borderRadius = '4px'; historyButton.style.fontSize = '14px'; historyButton.style.transition = 'background-color 0.3s'; historyButton.style.width = '130px'; // 悬浮效果 historyButton.addEventListener('mouseenter', () => { historyButton.style.backgroundColor = '#D0801B'; }); historyButton.addEventListener('mouseleave', () => { historyButton.style.backgroundColor = '#F7971D'; }); // 添加查看历史价格按钮点击事件 historyButton.addEventListener('click', function () { const existingPopups = document.querySelectorAll('.aaaaapopup'); existingPopups.forEach(popup => popup.remove()); // 调用请求函数 sendRequest(wearValue, '', '', '1', targetName); // 传入磨损值和paintseed }); // 添加按模板查询价格按钮 const templateButton = document.createElement('button'); templateButton.innerText = '按模板查询价格'; templateButton.className = 'view-template-btn'; templateButton.style.cursor = 'pointer'; templateButton.style.padding = '8px 15px'; templateButton.style.backgroundColor = '#F7971D'; templateButton.style.border = 'none'; templateButton.style.color = '#fff'; templateButton.style.borderRadius = '4px'; templateButton.style.fontSize = '14px'; templateButton.style.transition = 'background-color 0.3s'; templateButton.style.width = '130px'; // 悬浮效果 templateButton.addEventListener('mouseenter', () => { templateButton.style.backgroundColor = '#D0801B'; }); templateButton.addEventListener('mouseleave', () => { templateButton.style.backgroundColor = '#F7971D'; }); templateButton.addEventListener('click', function () { const existingPopups = document.querySelectorAll('.aaaaapopup'); existingPopups.forEach(popup => popup.remove()); // 调用请求函数 sendRequest(wearValue, paintseed, template, '2', targetName); // 传入磨损值和paintseed }); // 创建显示T1/T2的div const templateLabel = document.createElement('div'); templateLabel.style.marginTop = '5px'; templateLabel.style.marginBottom = '5px'; templateLabel.style.fontSize = '16px'; templateLabel.style.fontWeight = '600'; templateLabel.style.backgroundColor = '#fff'; templateLabel.style.color = '#fff'; templateLabel.style.fontStyle = 'italic'; templateLabel.style.textAlign = 'center'; templateLabel.style.borderRadius = '4px'; templateLabel.style.cursor = 'pointer'; templateLabel.addEventListener('click', function () { // 使用 window.open 打开链接,并指定 '_blank' 表示新标签页 window.open('https://csgo2.wiki', '_blank'); }); // 根据模板和paintseed判断是否需要变更背景颜色 if (templatesCollectionT1[topTemplate] && templatesCollectionT1[topTemplate].includes(Number(paintseed))) { row.style.backgroundColor = '#E3BF90'; // 满足条件则背景变为黄色 templateLabel.style.backgroundColor = '#273249'; templateLabel.style.color = '#fff'; templateLabel.innerText = 'wiki榜单T1🥇'; // 显示T1 templateLabel.style.padding = '6px'; } else if (templatesCollectionT2[topTemplate] && templatesCollectionT2[topTemplate].includes(Number(paintseed))) { row.style.backgroundColor = '#FFF2E2'; // 满足条件则背景变为蓝色 templateLabel.style.backgroundColor = '#454B58'; templateLabel.style.color = '#fff'; templateLabel.innerText = 'wiki榜单T2'; // 显示T2 templateLabel.style.padding = '6px'; } else if (templatesCollectionT3[topTemplate] && templatesCollectionT3[topTemplate].includes(Number(paintseed))) { templateLabel.style.backgroundColor = '#B3B3B3'; templateLabel.innerText = 'wiki榜单T3'; // 显示T3 templateLabel.style.padding = '6px'; } else if (templatesCollectionT4[topTemplate] && templatesCollectionT4[topTemplate].includes(Number(paintseed))) { templateLabel.style.backgroundColor = '#DBDBDB'; templateLabel.innerText = 'wiki榜单T4'; // 显示T4 templateLabel.style.padding = '6px'; } else { row.style.backgroundColor = ''; // 不满足条件则恢复默认背景 } // 自定义模板 if (paintseed !== null && paintseedList.has(paintseed)) { row.style.backgroundColor = '#E3BF90'; // 满足条件则背景变为黄色 templateLabel.style.backgroundColor = '#273249'; templateLabel.style.color = '#fff'; let infix = templateLabel.innerText ? "|" : ""; templateLabel.innerText = "自定义模板🚩" + infix + templateLabel.innerText; // 自定义模板 templateLabel.style.padding = '6px'; highlightedPaintseeds.add(paintseed); found = true; } // 获取行内的一个 td 元素,假设是最后一个 td const lastTd = row.querySelector('td:last-child'); if (lastTd) { lastTd.appendChild(templateLabel); // 添加显示T1/T2的div lastTd.appendChild(historyButton); lastTd.appendChild(templateButton); } dataList = dataList.filter(item => item.wearValue !== wearValue); } }); } if (urlFlag === 'buff') { const rows = document.querySelectorAll('tr'); rows.forEach(row => { // 检查当前行是否包含磨损值 const wearValueDiv = row.querySelector('.wear-value'); if (wearValueDiv && !row.querySelector('.view-history-btn') && !row.querySelector('.view-template-btn')) { // 添加查看历史价格按钮 const historyButton = document.createElement('button'); historyButton.innerText = '饰品/历史价格'; historyButton.className = 'view-history-btn'; historyButton.style.display = 'block'; historyButton.style.margin = '5px 10px 5px'; historyButton.style.cursor = 'pointer'; historyButton.style.padding = '8px 15px'; historyButton.style.backgroundColor = '#F7971D'; historyButton.style.border = 'none'; historyButton.style.color = '#fff'; historyButton.style.borderRadius = '4px'; historyButton.style.fontSize = '14px'; historyButton.style.transition = 'background-color 0.3s'; // 悬浮效果 historyButton.addEventListener('mouseenter', () => { historyButton.style.backgroundColor = '#ECBB7E'; }); historyButton.addEventListener('mouseleave', () => { historyButton.style.backgroundColor = '#F7971D'; }); // 获取paintseed值 const assetInfo = JSON.parse(row.getAttribute('data-asset-info')); const goodsInfo = JSON.parse(row.getAttribute('data-goods-info')); let paintseed = ''; let template = ''; let targetName = ''; let wearValue = null; let topTemplate = ''; // 获取磨损值 const wearText = wearValueDiv.textContent.trim(); const wearMatch = wearText.match(/磨损:\s*(\d+\.\d+)/); if (wearMatch) { wearValue = wearMatch[1]; } if (goodsInfo) { targetName = goodsInfo.name || ''; } if (assetInfo) { paintseed = assetInfo?.info?.paintseed; template = targetName.includes('多普勒') ? assetInfo?.info?.metaphysic?.data?.name?.toLowerCase() || '' : ''; } topTemplate = targetName.replace(/\s*\(.*?\)/g, '').trim() + template; // 添加查看历史价格按钮点击事件 historyButton.addEventListener('click', function () { const existingPopups = document.querySelectorAll('.aaaaapopup'); existingPopups.forEach(popup => popup.remove()); // 调用请求函数 sendRequest(wearValue, '', '', '1', targetName); // 传入磨损值和paintseed }); // 添加按模板查询价格按钮 const templateButton = document.createElement('button'); templateButton.innerText = '模板/历史价格'; templateButton.className = 'view-template-btn'; templateButton.style.marginLeft = '10px'; templateButton.style.marginBottom = '10px'; templateButton.style.cursor = 'pointer'; templateButton.style.padding = '8px 15px'; templateButton.style.backgroundColor = '#F7971D'; templateButton.style.border = 'none'; templateButton.style.color = '#fff'; templateButton.style.borderRadius = '4px'; templateButton.style.fontSize = '14px'; templateButton.style.transition = 'background-color 0.3s'; // 悬浮效果 templateButton.addEventListener('mouseenter', () => { templateButton.style.backgroundColor = '#ECBB7E'; }); templateButton.addEventListener('mouseleave', () => { templateButton.style.backgroundColor = '#F7971D'; }); templateButton.addEventListener('click', function () { const existingPopups = document.querySelectorAll('.aaaaapopup'); existingPopups.forEach(popup => popup.remove()); // 调用请求函数 sendRequest(wearValue, paintseed, template, '2', targetName); // 传入磨损值和paintseed }); // 创建显示T1/T2的div const templateLabel = document.createElement('div'); templateLabel.style.padding = '5px'; templateLabel.style.marginTop = '5px'; templateLabel.style.marginLeft = '10px'; templateLabel.style.backgroundColor = '#fff'; templateLabel.style.borderRadius = '4px'; templateLabel.style.fontSize = '13px'; templateLabel.style.fontWeight = '600'; templateLabel.style.color = '#fff'; templateLabel.style.fontStyle = 'italic'; templateLabel.style.textAlign = 'center'; templateLabel.style.width = '110px'; templateLabel.style.cursor = 'pointer'; templateLabel.addEventListener('click', function () { // 使用 window.open 打开链接,并指定 '_blank' 表示新标签页 window.open('https://csgo2.wiki', '_blank'); }); // 根据模板和paintseed判断是否需要变更背景颜色 if (templatesCollectionT1[topTemplate] && templatesCollectionT1[topTemplate].includes(Number(paintseed))) { row.style.backgroundColor = '#E3BF90'; // 满足条件则背景变为黄色 templateLabel.style.backgroundColor = '#273249'; templateLabel.style.color = '#fff'; templateLabel.innerText = 'wiki榜单T1🥇'; // 显示T1 } else if (templatesCollectionT2[topTemplate] && templatesCollectionT2[topTemplate].includes(Number(paintseed))) { row.style.backgroundColor = '#FFF2E2'; // 满足条件则背景变为蓝色 templateLabel.style.backgroundColor = '#454B58'; templateLabel.innerText = 'wiki榜单T2'; // 显示T2 templateLabel.style.padding = '6px'; templateLabel.style.color = '#fff'; } else if (templatesCollectionT3[topTemplate] && templatesCollectionT3[topTemplate].includes(Number(paintseed))) { templateLabel.style.backgroundColor = '#B3B3B3'; // row.style.backgroundColor = 'lightgreen'; // 满足条件则背景变为绿色 templateLabel.innerText = 'wiki榜单T3'; // 显示T3 templateLabel.style.padding = '6px'; } else if (templatesCollectionT4[topTemplate] && templatesCollectionT4[topTemplate].includes(Number(paintseed))) { templateLabel.style.backgroundColor = '#DBDBDB'; templateLabel.innerText = 'wiki榜单T4'; // 显示T4 templateLabel.style.padding = '6px'; } else { row.style.backgroundColor = ''; // 不满足条件则恢复默认背景 } // 自定义模板 if (paintseed !== null && paintseedList.has(paintseed)) { row.style.backgroundColor = '#E3BF90'; // 满足条件则背景变为黄色 templateLabel.style.backgroundColor = '#273249'; templateLabel.style.color = '#fff'; let infix = templateLabel.innerText ? "|" : ""; templateLabel.innerText = "自定义模板" + infix + templateLabel.innerText; // 自定义模板 templateLabel.style.padding = '6px'; highlightedPaintseeds.add(paintseed); found = true; } // 将按钮添加到当前行 row.appendChild(templateLabel); // 添加显示T1/T2的div row.appendChild(historyButton); row.appendChild(templateButton); } }); } updatePanel(); if (found) { // playAudioNotification(); } return found; } function updatePanel() { paintseedDisplay.textContent = Array.from(highlightedPaintseeds).join(', '); paintseedInput.value = Array.from(paintseedList).join(', '); localStorage.setItem('highlightedPaintseeds', JSON.stringify(Array.from(highlightedPaintseeds))); } clearButton.addEventListener('click', () => { highlightedPaintseeds.clear(); updatePanel(); }); updateButton.addEventListener('click', () => { const inputValues = paintseedInput.value .replace(/,|、|\s+/g, ',') .split(',') .map(item => item.trim()) .filter(item => item !== '') .map(Number) .filter(n => !isNaN(n)); paintseedList = new Set(inputValues); highlightedPaintseeds.clear(); processTRElements(); updatePanel(); localStorage.setItem('paintseedList', JSON.stringify(Array.from(paintseedList))); }); toggleRefreshButton.addEventListener('click', () => { if (refreshIntervalId) { clearInterval(refreshIntervalId); refreshIntervalId = null; toggleRefreshButton.textContent = "刷新直到有漏"; localStorage.setItem('refreshActive', 'false'); } else { refreshIntervalId = setInterval(() => { if (!processTRElements()) { location.reload(); } else { clearInterval(refreshIntervalId); refreshIntervalId = null; toggleRefreshButton.textContent = "刷新直到有漏"; localStorage.setItem('refreshActive', 'false'); } }, 5000); toggleRefreshButton.textContent = "停止刷新"; localStorage.setItem('refreshActive', 'true'); } }); processTRElements(); const observer = new MutationObserver((mutations) => { mutations.forEach((mutation) => { if (mutation.type === 'childList') { processTRElements(); } }); }); observer.observe(document.body, { childList: true, subtree: true }); if (localStorage.getItem('refreshActive') === 'true') { toggleRefreshButton.click(); } function playAudioNotification() { const audioContext = new (window.AudioContext || window.webkitAudioContext)(); const oscillator = audioContext.createOscillator(); const gainNode = audioContext.createGain(); oscillator.type = 'sine'; oscillator.frequency.setValueAtTime(440, audioContext.currentTime); gainNode.gain.setValueAtTime(0.2, audioContext.currentTime); oscillator.connect(gainNode); gainNode.connect(audioContext.destination); oscillator.start(); oscillator.stop(audioContext.currentTime + 1); } }); })();