mirror of
https://github.com/Nereziel/cs2-WeaponPaints.git
synced 2026-02-17 18:39:07 +00:00
Compare commits
44 Commits
build-319
...
bfb2432f85
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
bfb2432f85 | ||
|
|
b5d7f12024 | ||
|
|
9ec64e346f | ||
|
|
b4dc20523c | ||
|
|
8891ce815e | ||
|
|
ea9963b920 | ||
|
|
4a5a08aca9 | ||
|
|
573604a9d9 | ||
|
|
3929a43e46 | ||
|
|
f7f18b7919 | ||
|
|
0d110d83c7 | ||
|
|
db20e2eef9 | ||
|
|
536cea96d6 | ||
|
|
84684f4a26 | ||
|
|
48b9679236 | ||
|
|
7493ee4c7f | ||
|
|
027a547052 | ||
|
|
686c225f4f | ||
|
|
a5397e3831 | ||
|
|
1b95ddb089 | ||
|
|
7d4078dc40 | ||
|
|
e3011c51ae | ||
|
|
b99f30deb2 | ||
|
|
44c59e6bac | ||
|
|
845a40c189 | ||
|
|
f93bed46f1 | ||
|
|
ccee3e52c9 | ||
|
|
7d33693930 | ||
|
|
7b868611e5 | ||
|
|
b7289dd1e8 | ||
|
|
5808255780 | ||
|
|
7724102d7c | ||
|
|
a6b9982367 | ||
|
|
bff8a726ce | ||
|
|
aca68aac1a | ||
|
|
7e5e47f1d1 | ||
|
|
59b63646c9 | ||
|
|
1f32b7922b | ||
|
|
eba4ba08d2 | ||
|
|
18051501f8 | ||
|
|
9d96b75ca4 | ||
|
|
6ea0336814 | ||
|
|
52e8525117 | ||
|
|
3621c1d3ad |
4
.github/workflows/build.yml
vendored
4
.github/workflows/build.yml
vendored
@@ -30,7 +30,7 @@ jobs:
|
|||||||
- name: Setup .NET
|
- name: Setup .NET
|
||||||
uses: actions/setup-dotnet@v3
|
uses: actions/setup-dotnet@v3
|
||||||
with:
|
with:
|
||||||
dotnet-version: 7.0.x
|
dotnet-version: 8.0.x
|
||||||
- name: Restore
|
- name: Restore
|
||||||
run: dotnet restore
|
run: dotnet restore
|
||||||
- name: Build
|
- name: Build
|
||||||
@@ -46,7 +46,7 @@ jobs:
|
|||||||
- name: Setup .NET
|
- name: Setup .NET
|
||||||
uses: actions/setup-dotnet@v3
|
uses: actions/setup-dotnet@v3
|
||||||
with:
|
with:
|
||||||
dotnet-version: 7.0.x
|
dotnet-version: 8.0.x
|
||||||
- name: Restore
|
- name: Restore
|
||||||
run: dotnet restore
|
run: dotnet restore
|
||||||
- name: Build
|
- name: Build
|
||||||
|
|||||||
240
Commands.cs
240
Commands.cs
@@ -1,7 +1,10 @@
|
|||||||
using CounterStrikeSharp.API.Core;
|
using System.Collections.Concurrent;
|
||||||
|
using CounterStrikeSharp.API;
|
||||||
|
using CounterStrikeSharp.API.Core;
|
||||||
using CounterStrikeSharp.API.Modules.Commands;
|
using CounterStrikeSharp.API.Modules.Commands;
|
||||||
using CounterStrikeSharp.API.Modules.Menu;
|
using CounterStrikeSharp.API.Modules.Menu;
|
||||||
using CounterStrikeSharp.API.Modules.Timers;
|
using CounterStrikeSharp.API.Modules.Timers;
|
||||||
|
using CounterStrikeSharp.API.Modules.Utils;
|
||||||
using Newtonsoft.Json.Linq;
|
using Newtonsoft.Json.Linq;
|
||||||
|
|
||||||
namespace WeaponPaints;
|
namespace WeaponPaints;
|
||||||
@@ -104,6 +107,16 @@ public partial class WeaponPaints
|
|||||||
|
|
||||||
private void RegisterCommands()
|
private void RegisterCommands()
|
||||||
{
|
{
|
||||||
|
_config.Additional.CommandStattrak.ForEach(c =>
|
||||||
|
{
|
||||||
|
AddCommand($"css_{c}", "Stattrak toggle", (player, info) =>
|
||||||
|
{
|
||||||
|
if (!Utility.IsPlayerValid(player)) return;
|
||||||
|
|
||||||
|
OnCommandStattrak(player, info);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
_config.Additional.CommandSkin.ForEach(c =>
|
_config.Additional.CommandSkin.ForEach(c =>
|
||||||
{
|
{
|
||||||
AddCommand($"css_{c}", "Skins info", (player, info) =>
|
AddCommand($"css_{c}", "Skins info", (player, info) =>
|
||||||
@@ -136,6 +149,30 @@ public partial class WeaponPaints
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void OnCommandStattrak(CCSPlayerController? player, CommandInfo commandInfo)
|
||||||
|
{
|
||||||
|
if (player == null || !player.IsValid) return;
|
||||||
|
|
||||||
|
if (!GPlayerWeaponsInfo.TryGetValue(player.Slot, out var teamInfo) ||
|
||||||
|
!teamInfo.TryGetValue(player.Team, out var teamWeapons) )
|
||||||
|
return;
|
||||||
|
|
||||||
|
var weapon = player.PlayerPawn.Value?.WeaponServices?.ActiveWeapon.Value;
|
||||||
|
|
||||||
|
if (weapon == null || !weapon.IsValid)
|
||||||
|
return;
|
||||||
|
if (!teamWeapons.TryGetValue(weapon.AttributeManager.Item.ItemDefinitionIndex, out var teamWeapon))
|
||||||
|
return;
|
||||||
|
|
||||||
|
teamWeapon.StatTrak = !teamWeapon.StatTrak;
|
||||||
|
RefreshWeapons(player);
|
||||||
|
|
||||||
|
if (!string.IsNullOrEmpty(Localizer["wp_stattrak_action"]))
|
||||||
|
{
|
||||||
|
player.Print(Localizer["wp_stattrak_action"]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void SetupKnifeMenu()
|
private void SetupKnifeMenu()
|
||||||
{
|
{
|
||||||
if (!Config.Additional.KnifeEnabled || !_gBCommandsAllowed) return;
|
if (!Config.Additional.KnifeEnabled || !_gBCommandsAllowed) return;
|
||||||
@@ -144,12 +181,17 @@ public partial class WeaponPaints
|
|||||||
.Where(pair => pair.Key.StartsWith("weapon_knife") || pair.Key.StartsWith("weapon_bayonet"))
|
.Where(pair => pair.Key.StartsWith("weapon_knife") || pair.Key.StartsWith("weapon_bayonet"))
|
||||||
.ToDictionary(pair => pair.Key, pair => pair.Value);
|
.ToDictionary(pair => pair.Key, pair => pair.Value);
|
||||||
|
|
||||||
var giveItemMenu = MenuApi?.NewMenu(Localizer["wp_knife_menu_title"]);
|
var giveItemMenu = Utility.CreateMenu(Localizer["wp_knife_menu_title"]);
|
||||||
|
|
||||||
var handleGive = (CCSPlayerController player, ChatMenuOption option) =>
|
var handleGive = (CCSPlayerController player, ChatMenuOption option) =>
|
||||||
{
|
{
|
||||||
if (!Utility.IsPlayerValid(player)) return;
|
if (!Utility.IsPlayerValid(player)) return;
|
||||||
|
|
||||||
|
var playerKnives = GPlayersKnife.GetOrAdd(player.Slot, new ConcurrentDictionary<CsTeam, string>());
|
||||||
|
var teamsToCheck = player.TeamNum < 2
|
||||||
|
? new[] { CsTeam.Terrorist, CsTeam.CounterTerrorist }
|
||||||
|
: [player.Team];
|
||||||
|
|
||||||
var knifeName = option.Text;
|
var knifeName = option.Text;
|
||||||
var knifeKey = knivesOnly.FirstOrDefault(x => x.Value == knifeName).Key;
|
var knifeKey = knivesOnly.FirstOrDefault(x => x.Value == knifeName).Key;
|
||||||
if (string.IsNullOrEmpty(knifeKey)) return;
|
if (string.IsNullOrEmpty(knifeKey)) return;
|
||||||
@@ -172,14 +214,18 @@ public partial class WeaponPaints
|
|||||||
Name = player.PlayerName,
|
Name = player.PlayerName,
|
||||||
IpAddress = player.IpAddress?.Split(":")[0]
|
IpAddress = player.IpAddress?.Split(":")[0]
|
||||||
};
|
};
|
||||||
|
|
||||||
GPlayersKnife[player.Slot] = knifeKey;
|
foreach (var team in teamsToCheck)
|
||||||
|
{
|
||||||
|
// Attempt to get the existing knives
|
||||||
|
playerKnives[team] = knifeKey;
|
||||||
|
}
|
||||||
|
|
||||||
if (_gBCommandsAllowed && (LifeState_t)player.LifeState == LifeState_t.LIFE_ALIVE)
|
if (_gBCommandsAllowed && (LifeState_t)player.LifeState == LifeState_t.LIFE_ALIVE)
|
||||||
RefreshWeapons(player);
|
RefreshWeapons(player);
|
||||||
|
|
||||||
if (WeaponSync != null)
|
if (WeaponSync != null)
|
||||||
_ = Task.Run(async () => await WeaponSync.SyncKnifeToDatabase(playerInfo, knifeKey));
|
_ = Task.Run(async () => await WeaponSync.SyncKnifeToDatabase(playerInfo, knifeKey, teamsToCheck));
|
||||||
};
|
};
|
||||||
foreach (var knifePair in knivesOnly)
|
foreach (var knifePair in knivesOnly)
|
||||||
{
|
{
|
||||||
@@ -219,7 +265,7 @@ public partial class WeaponPaints
|
|||||||
.Except([new KeyValuePair<string, string>("weapon_knife", "Default Knife")])
|
.Except([new KeyValuePair<string, string>("weapon_knife", "Default Knife")])
|
||||||
.ToDictionary(kvp => kvp.Value, kvp => kvp.Key);
|
.ToDictionary(kvp => kvp.Value, kvp => kvp.Key);
|
||||||
|
|
||||||
var weaponSelectionMenu = MenuApi?.NewMenu(Localizer["wp_skin_menu_weapon_title"]);
|
var weaponSelectionMenu = Utility.CreateMenu(Localizer["wp_skin_menu_weapon_title"]);
|
||||||
|
|
||||||
// Function to handle skin selection for a specific weapon
|
// Function to handle skin selection for a specific weapon
|
||||||
var handleWeaponSelection = (CCSPlayerController? player, ChatMenuOption option) =>
|
var handleWeaponSelection = (CCSPlayerController? player, ChatMenuOption option) =>
|
||||||
@@ -229,20 +275,19 @@ public partial class WeaponPaints
|
|||||||
var selectedWeapon = option.Text;
|
var selectedWeapon = option.Text;
|
||||||
|
|
||||||
if (!classNamesByWeapon.TryGetValue(selectedWeapon, out var selectedWeaponClassname)) return;
|
if (!classNamesByWeapon.TryGetValue(selectedWeapon, out var selectedWeaponClassname)) return;
|
||||||
var skinsForSelectedWeapon = SkinsList?.Where(skin =>
|
var skinsForSelectedWeapon = SkinsList.Where(skin =>
|
||||||
skin.TryGetValue("weapon_name", out var weaponName) &&
|
skin.TryGetValue("weapon_name", out var weaponName) &&
|
||||||
weaponName?.ToString() == selectedWeaponClassname
|
weaponName?.ToString() == selectedWeaponClassname
|
||||||
)?.ToList();
|
)?.ToList();
|
||||||
|
|
||||||
var skinSubMenu = MenuApi?.NewMenu(Localizer["wp_skin_menu_skin_title", selectedWeapon]);
|
var skinSubMenu = Utility.CreateMenu(Localizer["wp_skin_menu_skin_title", selectedWeapon]);
|
||||||
|
|
||||||
// Function to handle skin selection for the chosen weapon
|
// Function to handle skin selection for the chosen weapon
|
||||||
var handleSkinSelection = (CCSPlayerController p, ChatMenuOption opt) =>
|
var handleSkinSelection = (CCSPlayerController p, ChatMenuOption opt) =>
|
||||||
{
|
{
|
||||||
if (!Utility.IsPlayerValid(p)) return;
|
if (!Utility.IsPlayerValid(p)) return;
|
||||||
|
|
||||||
var steamId = p.SteamID.ToString();
|
var firstSkin = SkinsList.FirstOrDefault(skin =>
|
||||||
var firstSkin = SkinsList?.FirstOrDefault(skin =>
|
|
||||||
{
|
{
|
||||||
if (skin.TryGetValue("weapon_name", out var weaponName))
|
if (skin.TryGetValue("weapon_name", out var weaponName))
|
||||||
{
|
{
|
||||||
@@ -259,29 +304,38 @@ public partial class WeaponPaints
|
|||||||
!int.TryParse(weaponDefIndexObj.ToString(), out var weaponDefIndex) ||
|
!int.TryParse(weaponDefIndexObj.ToString(), out var weaponDefIndex) ||
|
||||||
!int.TryParse(selectedPaintId, out var paintId)) return;
|
!int.TryParse(selectedPaintId, out var paintId)) return;
|
||||||
{
|
{
|
||||||
if (Config.Additional.ShowSkinImage && SkinsList != null)
|
if (Config.Additional.ShowSkinImage)
|
||||||
{
|
{
|
||||||
var foundSkin = SkinsList.FirstOrDefault(skin =>
|
var foundSkin = SkinsList.FirstOrDefault(skin =>
|
||||||
((int?)skin?["weapon_defindex"] ?? 0) == weaponDefIndex &&
|
((int?)skin["weapon_defindex"] ?? 0) == weaponDefIndex &&
|
||||||
((int?)skin?["paint"] ?? 0) == paintId &&
|
((int?)skin["paint"] ?? 0) == paintId &&
|
||||||
skin?["image"] != null
|
skin["image"] != null
|
||||||
);
|
);
|
||||||
var image = foundSkin?["image"]?.ToString() ?? "";
|
var image = foundSkin?["image"]?.ToString() ?? "";
|
||||||
_playerWeaponImage[p.Slot] = image;
|
_playerWeaponImage[p.Slot] = image;
|
||||||
AddTimer(2.0f, () => _playerWeaponImage.Remove(p.Slot), CounterStrikeSharp.API.Modules.Timers.TimerFlags.STOP_ON_MAPCHANGE);
|
AddTimer(2.0f, () => _playerWeaponImage.Remove(p.Slot), TimerFlags.STOP_ON_MAPCHANGE);
|
||||||
}
|
}
|
||||||
|
|
||||||
p.Print(Localizer["wp_skin_menu_select", selectedSkin]);
|
p.Print(Localizer["wp_skin_menu_select", selectedSkin]);
|
||||||
|
var playerSkins = GPlayerWeaponsInfo.GetOrAdd(p.Slot, new ConcurrentDictionary<CsTeam, ConcurrentDictionary<int, WeaponInfo>>());
|
||||||
|
|
||||||
if (!GPlayerWeaponsInfo[p.Slot].TryGetValue(weaponDefIndex, out var value))
|
var teamsToCheck = p.TeamNum < 2
|
||||||
|
? new[] { CsTeam.Terrorist, CsTeam.CounterTerrorist }
|
||||||
|
: [p.Team];
|
||||||
|
|
||||||
|
foreach (var team in teamsToCheck)
|
||||||
{
|
{
|
||||||
value = new WeaponInfo();
|
// Ensure there's an entry for the team in playerSkins
|
||||||
GPlayerWeaponsInfo[p.Slot][weaponDefIndex] = value;
|
var teamWeapons = playerSkins.GetOrAdd(team, _ => new ConcurrentDictionary<int, WeaponInfo>());
|
||||||
}
|
|
||||||
|
|
||||||
value.Paint = paintId;
|
// Attempt to get or add the existing WeaponInfo
|
||||||
value.Wear = 0.01f;
|
var value = teamWeapons.GetOrAdd(weaponDefIndex, _ => new WeaponInfo());
|
||||||
value.Seed = 0;
|
|
||||||
|
// Update the properties of WeaponInfo
|
||||||
|
value.Paint = paintId;
|
||||||
|
value.Wear = 0.01f;
|
||||||
|
value.Seed = 0;
|
||||||
|
}
|
||||||
|
|
||||||
PlayerInfo playerInfo = new PlayerInfo
|
PlayerInfo playerInfo = new PlayerInfo
|
||||||
{
|
{
|
||||||
@@ -362,7 +416,7 @@ public partial class WeaponPaints
|
|||||||
|
|
||||||
private void SetupGlovesMenu()
|
private void SetupGlovesMenu()
|
||||||
{
|
{
|
||||||
var glovesSelectionMenu = MenuApi?.NewMenu(Localizer["wp_glove_menu_title"]);
|
var glovesSelectionMenu = Utility.CreateMenu(Localizer["wp_glove_menu_title"]);
|
||||||
if (glovesSelectionMenu == null) return;
|
if (glovesSelectionMenu == null) return;
|
||||||
glovesSelectionMenu.PostSelectAction = PostSelectAction.Close;
|
glovesSelectionMenu.PostSelectAction = PostSelectAction.Close;
|
||||||
|
|
||||||
@@ -371,6 +425,11 @@ public partial class WeaponPaints
|
|||||||
if (!Utility.IsPlayerValid(player) || player is null) return;
|
if (!Utility.IsPlayerValid(player) || player is null) return;
|
||||||
|
|
||||||
var selectedPaintName = option.Text;
|
var selectedPaintName = option.Text;
|
||||||
|
|
||||||
|
var playerGloves = GPlayersGlove.GetOrAdd(player.Slot, new ConcurrentDictionary<CsTeam, ushort>());
|
||||||
|
var teamsToCheck = player.TeamNum < 2
|
||||||
|
? new[] { CsTeam.Terrorist, CsTeam.CounterTerrorist }
|
||||||
|
: [player.Team];
|
||||||
|
|
||||||
var selectedGlove = GlovesList.FirstOrDefault(g => g.ContainsKey("paint_name") && g["paint_name"]?.ToString() == selectedPaintName);
|
var selectedGlove = GlovesList.FirstOrDefault(g => g.ContainsKey("paint_name") && g["paint_name"]?.ToString() == selectedPaintName);
|
||||||
var image = selectedGlove?["image"]?.ToString() ?? "";
|
var image = selectedGlove?["image"]?.ToString() ?? "";
|
||||||
@@ -397,15 +456,32 @@ public partial class WeaponPaints
|
|||||||
|
|
||||||
if (paint != 0)
|
if (paint != 0)
|
||||||
{
|
{
|
||||||
GPlayersGlove[player.Slot] = (ushort)weaponDefindex;
|
// Ensure that player weapons info exists for the player
|
||||||
|
if (!GPlayerWeaponsInfo.ContainsKey(player.Slot))
|
||||||
if (!GPlayerWeaponsInfo[player.Slot].ContainsKey(weaponDefindex))
|
|
||||||
{
|
{
|
||||||
WeaponInfo weaponInfo = new()
|
GPlayerWeaponsInfo[player.Slot] = new ConcurrentDictionary<CsTeam, ConcurrentDictionary<int, WeaponInfo>>();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Ensure teams are initialized
|
||||||
|
foreach (var team in teamsToCheck)
|
||||||
|
{
|
||||||
|
if (!GPlayerWeaponsInfo[player.Slot].ContainsKey(team))
|
||||||
{
|
{
|
||||||
Paint = paint
|
GPlayerWeaponsInfo[player.Slot][team] = new ConcurrentDictionary<int, WeaponInfo>();
|
||||||
};
|
}
|
||||||
GPlayerWeaponsInfo[player.Slot][weaponDefindex] = weaponInfo;
|
|
||||||
|
// Update the glove for the player in the specified team
|
||||||
|
playerGloves[team] = (ushort)weaponDefindex;
|
||||||
|
|
||||||
|
// Check if the glove information already exists for the player
|
||||||
|
if (!GPlayerWeaponsInfo[player.Slot][team].ContainsKey(weaponDefindex))
|
||||||
|
{
|
||||||
|
WeaponInfo weaponInfo = new()
|
||||||
|
{
|
||||||
|
Paint = paint
|
||||||
|
};
|
||||||
|
GPlayerWeaponsInfo[player.Slot][team][weaponDefindex] = weaponInfo;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -413,28 +489,30 @@ public partial class WeaponPaints
|
|||||||
GPlayersGlove.TryRemove(player.Slot, out _);
|
GPlayersGlove.TryRemove(player.Slot, out _);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(Localizer["wp_glove_menu_select"]))
|
|
||||||
{
|
|
||||||
player.Print(Localizer["wp_glove_menu_select", selectedPaintName]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (WeaponSync == null) return;
|
if (WeaponSync == null) return;
|
||||||
|
|
||||||
_ = Task.Run(async () =>
|
_ = Task.Run(async () =>
|
||||||
{
|
{
|
||||||
await WeaponSync.SyncGloveToDatabase(playerInfo, weaponDefindex);
|
// Sync glove to database for all teams
|
||||||
|
foreach (var team in teamsToCheck)
|
||||||
if (!GPlayerWeaponsInfo[playerInfo.Slot].TryGetValue(weaponDefindex, out var value))
|
|
||||||
{
|
{
|
||||||
value = new WeaponInfo();
|
await WeaponSync.SyncGloveToDatabase(playerInfo, (ushort)weaponDefindex, teamsToCheck);
|
||||||
GPlayerWeaponsInfo[playerInfo.Slot][weaponDefindex] = value;
|
|
||||||
|
// Check if the weapon info exists for the glove
|
||||||
|
if (!GPlayerWeaponsInfo[playerInfo.Slot][team].TryGetValue(weaponDefindex, out var value))
|
||||||
|
{
|
||||||
|
value = new WeaponInfo();
|
||||||
|
GPlayerWeaponsInfo[playerInfo.Slot][team][weaponDefindex] = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update weapon info
|
||||||
|
value.Paint = paint;
|
||||||
|
value.Wear = 0.00f;
|
||||||
|
value.Seed = 0;
|
||||||
|
|
||||||
|
// Sync weapon paints to database
|
||||||
|
await WeaponSync.SyncWeaponPaintsToDatabase(playerInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
value.Paint = paint;
|
|
||||||
value.Wear = 0.00f;
|
|
||||||
value.Seed = 0;
|
|
||||||
|
|
||||||
await WeaponSync.SyncWeaponPaintsToDatabase(playerInfo);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
AddTimer(0.1f, () => GivePlayerGloves(player));
|
AddTimer(0.1f, () => GivePlayerGloves(player));
|
||||||
@@ -547,7 +625,7 @@ public partial class WeaponPaints
|
|||||||
if (!CommandsCooldown.TryGetValue(player.Slot, out DateTime cooldownEndTime) ||
|
if (!CommandsCooldown.TryGetValue(player.Slot, out DateTime cooldownEndTime) ||
|
||||||
DateTime.UtcNow >= (CommandsCooldown.TryGetValue(player.Slot, out cooldownEndTime) ? cooldownEndTime : DateTime.UtcNow))
|
DateTime.UtcNow >= (CommandsCooldown.TryGetValue(player.Slot, out cooldownEndTime) ? cooldownEndTime : DateTime.UtcNow))
|
||||||
{
|
{
|
||||||
var agentsSelectionMenu = MenuApi?.NewMenu(Localizer["wp_agent_menu_title"]);
|
var agentsSelectionMenu = Utility.CreateMenu(Localizer["wp_agent_menu_title"]);
|
||||||
if (agentsSelectionMenu == null) return;
|
if (agentsSelectionMenu == null) return;
|
||||||
agentsSelectionMenu.PostSelectAction = PostSelectAction.Close;
|
agentsSelectionMenu.PostSelectAction = PostSelectAction.Close;
|
||||||
|
|
||||||
@@ -587,7 +665,7 @@ public partial class WeaponPaints
|
|||||||
|
|
||||||
private void SetupMusicMenu()
|
private void SetupMusicMenu()
|
||||||
{
|
{
|
||||||
var musicSelectionMenu = MenuApi?.NewMenu(Localizer["wp_music_menu_title"]);
|
var musicSelectionMenu = Utility.CreateMenu(Localizer["wp_music_menu_title"]);
|
||||||
if (musicSelectionMenu == null) return;
|
if (musicSelectionMenu == null) return;
|
||||||
musicSelectionMenu.PostSelectAction = PostSelectAction.Close;
|
musicSelectionMenu.PostSelectAction = PostSelectAction.Close;
|
||||||
|
|
||||||
@@ -596,6 +674,11 @@ public partial class WeaponPaints
|
|||||||
if (!Utility.IsPlayerValid(player) || player is null) return;
|
if (!Utility.IsPlayerValid(player) || player is null) return;
|
||||||
|
|
||||||
var selectedPaintName = option.Text;
|
var selectedPaintName = option.Text;
|
||||||
|
|
||||||
|
var playerMusic = GPlayersMusic.GetOrAdd(player.Slot, new ConcurrentDictionary<CsTeam, ushort>());
|
||||||
|
var teamsToCheck = player.TeamNum < 2
|
||||||
|
? new[] { CsTeam.Terrorist, CsTeam.CounterTerrorist }
|
||||||
|
: [player.Team]; // Corrected array initializer
|
||||||
|
|
||||||
var selectedMusic = MusicList.FirstOrDefault(g => g.ContainsKey("name") && g["name"]?.ToString() == selectedPaintName);
|
var selectedMusic = MusicList.FirstOrDefault(g => g.ContainsKey("name") && g["name"]?.ToString() == selectedPaintName);
|
||||||
if (selectedMusic != null)
|
if (selectedMusic != null)
|
||||||
@@ -607,7 +690,7 @@ public partial class WeaponPaints
|
|||||||
if (Config.Additional.ShowSkinImage)
|
if (Config.Additional.ShowSkinImage)
|
||||||
{
|
{
|
||||||
_playerWeaponImage[player.Slot] = image;
|
_playerWeaponImage[player.Slot] = image;
|
||||||
AddTimer(2.0f, () => _playerWeaponImage.Remove(player.Slot), CounterStrikeSharp.API.Modules.Timers.TimerFlags.STOP_ON_MAPCHANGE);
|
AddTimer(2.0f, () => _playerWeaponImage.Remove(player.Slot), TimerFlags.STOP_ON_MAPCHANGE);
|
||||||
}
|
}
|
||||||
|
|
||||||
PlayerInfo playerInfo = new PlayerInfo
|
PlayerInfo playerInfo = new PlayerInfo
|
||||||
@@ -619,15 +702,23 @@ public partial class WeaponPaints
|
|||||||
Name = player.PlayerName,
|
Name = player.PlayerName,
|
||||||
IpAddress = player.IpAddress?.Split(":")[0]
|
IpAddress = player.IpAddress?.Split(":")[0]
|
||||||
};
|
};
|
||||||
|
|
||||||
if (paint != 0)
|
if (paint != 0)
|
||||||
{
|
{
|
||||||
GPlayersMusic[player.Slot] = (ushort)paint;
|
foreach (var team in teamsToCheck)
|
||||||
|
{
|
||||||
|
playerMusic[team] = (ushort)paint;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
GPlayersMusic[player.Slot] = 0;
|
foreach (var team in teamsToCheck)
|
||||||
|
{
|
||||||
|
playerMusic[team] = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GivePlayerMusicKit(player);
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(Localizer["wp_music_menu_select"]))
|
if (!string.IsNullOrEmpty(Localizer["wp_music_menu_select"]))
|
||||||
{
|
{
|
||||||
@@ -638,11 +729,9 @@ public partial class WeaponPaints
|
|||||||
{
|
{
|
||||||
_ = Task.Run(async () =>
|
_ = Task.Run(async () =>
|
||||||
{
|
{
|
||||||
await WeaponSync.SyncMusicToDatabase(playerInfo, (ushort)paint);
|
await WeaponSync.SyncMusicToDatabase(playerInfo, (ushort)paint, teamsToCheck);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
//RefreshGloves(player);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -656,7 +745,12 @@ public partial class WeaponPaints
|
|||||||
IpAddress = player.IpAddress?.Split(":")[0]
|
IpAddress = player.IpAddress?.Split(":")[0]
|
||||||
};
|
};
|
||||||
|
|
||||||
GPlayersMusic[player.Slot] = 0;
|
foreach (var team in teamsToCheck)
|
||||||
|
{
|
||||||
|
playerMusic[team] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
GivePlayerMusicKit(player);
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(Localizer["wp_music_menu_select"]))
|
if (!string.IsNullOrEmpty(Localizer["wp_music_menu_select"]))
|
||||||
{
|
{
|
||||||
@@ -667,7 +761,7 @@ public partial class WeaponPaints
|
|||||||
{
|
{
|
||||||
_ = Task.Run(async () =>
|
_ = Task.Run(async () =>
|
||||||
{
|
{
|
||||||
await WeaponSync.SyncMusicToDatabase(playerInfo, 0);
|
await WeaponSync.SyncMusicToDatabase(playerInfo, 0, teamsToCheck);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -706,7 +800,7 @@ public partial class WeaponPaints
|
|||||||
|
|
||||||
private void SetupPinsMenu()
|
private void SetupPinsMenu()
|
||||||
{
|
{
|
||||||
var pinsSelectionMenu = MenuApi?.NewMenu(Localizer["wp_pins_menu_title"]);
|
var pinsSelectionMenu = Utility.CreateMenu(Localizer["wp_pins_menu_title"]);
|
||||||
if (pinsSelectionMenu == null) return;
|
if (pinsSelectionMenu == null) return;
|
||||||
pinsSelectionMenu.PostSelectAction = PostSelectAction.Close;
|
pinsSelectionMenu.PostSelectAction = PostSelectAction.Close;
|
||||||
|
|
||||||
@@ -716,6 +810,11 @@ public partial class WeaponPaints
|
|||||||
|
|
||||||
var selectedPaintName = option.Text;
|
var selectedPaintName = option.Text;
|
||||||
|
|
||||||
|
var playerPins = GPlayersPin.GetOrAdd(player.Slot, new ConcurrentDictionary<CsTeam, ushort>());
|
||||||
|
var teamsToCheck = player.TeamNum < 2
|
||||||
|
? new[] { CsTeam.Terrorist, CsTeam.CounterTerrorist }
|
||||||
|
: [player.Team];
|
||||||
|
|
||||||
var selectedPin = PinsList.FirstOrDefault(g => g.ContainsKey("name") && g["name"]?.ToString() == selectedPaintName);
|
var selectedPin = PinsList.FirstOrDefault(g => g.ContainsKey("name") && g["name"]?.ToString() == selectedPaintName);
|
||||||
if (selectedPin != null)
|
if (selectedPin != null)
|
||||||
{
|
{
|
||||||
@@ -738,14 +837,20 @@ public partial class WeaponPaints
|
|||||||
Name = player.PlayerName,
|
Name = player.PlayerName,
|
||||||
IpAddress = player.IpAddress?.Split(":")[0]
|
IpAddress = player.IpAddress?.Split(":")[0]
|
||||||
};
|
};
|
||||||
|
|
||||||
if (paint != 0)
|
if (paint != 0)
|
||||||
{
|
{
|
||||||
GPlayersPin[player.Slot] = (ushort)paint;
|
foreach (var team in teamsToCheck)
|
||||||
|
{
|
||||||
|
playerPins[team] = (ushort)paint; // Set pin for each team
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
GPlayersPin[player.Slot] = 0;
|
foreach (var team in teamsToCheck)
|
||||||
|
{
|
||||||
|
playerPins[team] = 0; // Set pin for each team
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(Localizer["wp_pins_menu_select"]))
|
if (!string.IsNullOrEmpty(Localizer["wp_pins_menu_select"]))
|
||||||
@@ -759,7 +864,7 @@ public partial class WeaponPaints
|
|||||||
{
|
{
|
||||||
_ = Task.Run(async () =>
|
_ = Task.Run(async () =>
|
||||||
{
|
{
|
||||||
await WeaponSync.SyncPinToDatabase(playerInfo, (ushort)paint);
|
await WeaponSync.SyncPinToDatabase(playerInfo, (ushort)paint, teamsToCheck);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -775,7 +880,10 @@ public partial class WeaponPaints
|
|||||||
IpAddress = player.IpAddress?.Split(":")[0]
|
IpAddress = player.IpAddress?.Split(":")[0]
|
||||||
};
|
};
|
||||||
|
|
||||||
GPlayersPin[player.Slot] = 0;
|
foreach (var team in teamsToCheck)
|
||||||
|
{
|
||||||
|
playerPins[team] = 0; // Set music for each team
|
||||||
|
}
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(Localizer["wp_pins_menu_select"]))
|
if (!string.IsNullOrEmpty(Localizer["wp_pins_menu_select"]))
|
||||||
{
|
{
|
||||||
@@ -788,7 +896,7 @@ public partial class WeaponPaints
|
|||||||
{
|
{
|
||||||
_ = Task.Run(async () =>
|
_ = Task.Run(async () =>
|
||||||
{
|
{
|
||||||
await WeaponSync.SyncPinToDatabase(playerInfo, 0);
|
await WeaponSync.SyncPinToDatabase(playerInfo, 0, teamsToCheck);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
10
Config.cs
10
Config.cs
@@ -43,6 +43,9 @@ namespace WeaponPaints
|
|||||||
|
|
||||||
[JsonPropertyName("CommandAgent")]
|
[JsonPropertyName("CommandAgent")]
|
||||||
public List<string> CommandAgent { get; set; } = ["agents"];
|
public List<string> CommandAgent { get; set; } = ["agents"];
|
||||||
|
|
||||||
|
[JsonPropertyName("CommandStattrak")]
|
||||||
|
public List<string> CommandStattrak { get; set; } = ["stattrak", "st"];
|
||||||
|
|
||||||
[JsonPropertyName("CommandSkin")]
|
[JsonPropertyName("CommandSkin")]
|
||||||
public List<string> CommandSkin { get; set; } = ["ws"];
|
public List<string> CommandSkin { get; set; } = ["ws"];
|
||||||
@@ -68,7 +71,7 @@ namespace WeaponPaints
|
|||||||
|
|
||||||
public class WeaponPaintsConfig : BasePluginConfig
|
public class WeaponPaintsConfig : BasePluginConfig
|
||||||
{
|
{
|
||||||
[JsonPropertyName("ConfigVersion")] public override int Version { get; set; } = 9;
|
[JsonPropertyName("ConfigVersion")] public override int Version { get; set; } = 10;
|
||||||
|
|
||||||
[JsonPropertyName("SkinsLanguage")]
|
[JsonPropertyName("SkinsLanguage")]
|
||||||
public string SkinsLanguage { get; set; } = "en";
|
public string SkinsLanguage { get; set; } = "en";
|
||||||
@@ -89,12 +92,15 @@ namespace WeaponPaints
|
|||||||
public string DatabaseName { get; set; } = "";
|
public string DatabaseName { get; set; } = "";
|
||||||
|
|
||||||
[JsonPropertyName("CmdRefreshCooldownSeconds")]
|
[JsonPropertyName("CmdRefreshCooldownSeconds")]
|
||||||
public int CmdRefreshCooldownSeconds { get; set; } = 10;
|
public int CmdRefreshCooldownSeconds { get; set; } = 3;
|
||||||
|
|
||||||
[JsonPropertyName("Website")]
|
[JsonPropertyName("Website")]
|
||||||
public string Website { get; set; } = "example.com/skins";
|
public string Website { get; set; } = "example.com/skins";
|
||||||
|
|
||||||
[JsonPropertyName("Additional")]
|
[JsonPropertyName("Additional")]
|
||||||
public Additional Additional { get; set; } = new();
|
public Additional Additional { get; set; } = new();
|
||||||
|
|
||||||
|
[JsonPropertyName("MenuType")]
|
||||||
|
public string MenuType { get; set; } = "selectable";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
99
Events.cs
99
Events.cs
@@ -2,6 +2,7 @@
|
|||||||
using CounterStrikeSharp.API.Core;
|
using CounterStrikeSharp.API.Core;
|
||||||
using CounterStrikeSharp.API.Core.Attributes.Registration;
|
using CounterStrikeSharp.API.Core.Attributes.Registration;
|
||||||
using CounterStrikeSharp.API.Modules.Entities;
|
using CounterStrikeSharp.API.Modules.Entities;
|
||||||
|
using CounterStrikeSharp.API.Modules.Entities.Constants;
|
||||||
using CounterStrikeSharp.API.Modules.Memory;
|
using CounterStrikeSharp.API.Modules.Memory;
|
||||||
using CounterStrikeSharp.API.Modules.Memory.DynamicFunctions;
|
using CounterStrikeSharp.API.Modules.Memory.DynamicFunctions;
|
||||||
|
|
||||||
@@ -9,6 +10,8 @@ namespace WeaponPaints
|
|||||||
{
|
{
|
||||||
public partial class WeaponPaints
|
public partial class WeaponPaints
|
||||||
{
|
{
|
||||||
|
private bool _mvpPlayed;
|
||||||
|
|
||||||
[GameEventHandler]
|
[GameEventHandler]
|
||||||
public HookResult OnClientFullConnect(EventPlayerConnectFull @event, GameEventInfo info)
|
public HookResult OnClientFullConnect(EventPlayerConnectFull @event, GameEventInfo info)
|
||||||
{
|
{
|
||||||
@@ -77,16 +80,17 @@ namespace WeaponPaints
|
|||||||
IpAddress = player.IpAddress?.Split(":")[0]
|
IpAddress = player.IpAddress?.Split(":")[0]
|
||||||
};
|
};
|
||||||
|
|
||||||
if (!GPlayerWeaponsInfo.TryGetValue(player.Slot, out var weaponInfos))
|
Task.Run(async () =>
|
||||||
return HookResult.Continue;
|
|
||||||
|
|
||||||
if (WeaponSync != null)
|
|
||||||
_ = Task.Run(async () => await WeaponSync.SyncStatTrakToDatabase(playerInfo, weaponInfos));
|
|
||||||
|
|
||||||
if (Config.Additional.SkinEnabled)
|
|
||||||
{
|
{
|
||||||
GPlayerWeaponsInfo.TryRemove(player.Slot, out _);
|
if (WeaponSync != null)
|
||||||
}
|
await WeaponSync.SyncStatTrakToDatabase(playerInfo);
|
||||||
|
|
||||||
|
if (Config.Additional.SkinEnabled)
|
||||||
|
{
|
||||||
|
GPlayerWeaponsInfo.TryRemove(player.Slot, out _);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
if (Config.Additional.KnifeEnabled)
|
if (Config.Additional.KnifeEnabled)
|
||||||
{
|
{
|
||||||
GPlayersKnife.TryRemove(player.Slot, out _);
|
GPlayersKnife.TryRemove(player.Slot, out _);
|
||||||
@@ -107,19 +111,22 @@ namespace WeaponPaints
|
|||||||
{
|
{
|
||||||
GPlayersPin.TryRemove(player.Slot, out _);
|
GPlayersPin.TryRemove(player.Slot, out _);
|
||||||
}
|
}
|
||||||
|
|
||||||
_temporaryPlayerWeaponWear.TryRemove(player.Slot, out _);
|
_temporaryPlayerWeaponWear.TryRemove(player.Slot, out _);
|
||||||
CommandsCooldown.Remove(player.Slot);
|
CommandsCooldown.Remove(player.Slot);
|
||||||
|
|
||||||
return HookResult.Continue;
|
return HookResult.Continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnMapStart(string mapName)
|
private void OnMapStart(string mapName)
|
||||||
{
|
{
|
||||||
if (Config.Additional is { KnifeEnabled: false, SkinEnabled: false, GloveEnabled: false }) return;
|
if (Config.Additional is { KnifeEnabled: false, SkinEnabled: false, GloveEnabled: false }) return;
|
||||||
|
|
||||||
if (Database != null)
|
if (Database != null)
|
||||||
WeaponSync = new WeaponSynchronization(Database, Config);
|
WeaponSync = new WeaponSynchronization(Database, Config);
|
||||||
|
|
||||||
|
_fadeSeed = 0;
|
||||||
|
_nextItemId = MinimumCustomItemId;
|
||||||
}
|
}
|
||||||
|
|
||||||
private HookResult OnPlayerSpawn(EventPlayerSpawn @event, GameEventInfo info)
|
private HookResult OnPlayerSpawn(EventPlayerSpawn @event, GameEventInfo info)
|
||||||
@@ -145,13 +152,45 @@ namespace WeaponPaints
|
|||||||
private HookResult OnRoundEnd(EventRoundEnd @event, GameEventInfo info)
|
private HookResult OnRoundEnd(EventRoundEnd @event, GameEventInfo info)
|
||||||
{
|
{
|
||||||
_gBCommandsAllowed = false;
|
_gBCommandsAllowed = false;
|
||||||
|
|
||||||
return HookResult.Continue;
|
return HookResult.Continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
private HookResult OnRoundStart(EventRoundStart @event, GameEventInfo info)
|
private HookResult OnRoundStart(EventRoundStart @event, GameEventInfo info)
|
||||||
{
|
{
|
||||||
_gBCommandsAllowed = true;
|
_gBCommandsAllowed = true;
|
||||||
|
_mvpPlayed = false;
|
||||||
|
return HookResult.Continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
private HookResult OnRoundMvp(EventRoundMvp @event, GameEventInfo info)
|
||||||
|
{
|
||||||
|
if (_mvpPlayed)
|
||||||
|
return HookResult.Continue;
|
||||||
|
|
||||||
|
var player = @event.Userid;
|
||||||
|
|
||||||
|
if (player == null || !player.IsValid || player.IsBot)
|
||||||
|
return HookResult.Continue;
|
||||||
|
|
||||||
|
if (!(GPlayersMusic.TryGetValue(player.Slot, out var musicInfo)
|
||||||
|
&& musicInfo.TryGetValue(player.Team, out var musicId)
|
||||||
|
&& musicId != 0))
|
||||||
|
return HookResult.Continue;
|
||||||
|
|
||||||
|
@event.Musickitid = musicId;
|
||||||
|
@event.Nomusic = 0;
|
||||||
|
info.DontBroadcast = true;
|
||||||
|
|
||||||
|
var newEvent = new EventRoundMvp(true)
|
||||||
|
{
|
||||||
|
Userid = player,
|
||||||
|
Musickitid = musicId,
|
||||||
|
Nomusic = 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
_mvpPlayed = true;
|
||||||
|
|
||||||
|
newEvent.FireEvent(false);
|
||||||
return HookResult.Continue;
|
return HookResult.Continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -166,7 +205,17 @@ namespace WeaponPaints
|
|||||||
|
|
||||||
var player = GetPlayerFromItemServices(itemServices);
|
var player = GetPlayerFromItemServices(itemServices);
|
||||||
if (player != null)
|
if (player != null)
|
||||||
|
{
|
||||||
|
var weaponServices = player.PlayerPawn.Value?.WeaponServices;
|
||||||
|
|
||||||
GivePlayerWeaponSkin(player, weapon);
|
GivePlayerWeaponSkin(player, weapon);
|
||||||
|
|
||||||
|
if (weaponServices is { MyWeapons.Count: 1 })
|
||||||
|
{
|
||||||
|
// player.GiveNamedItem(CsItem.Healthshot);
|
||||||
|
// newWeapon.AddEntityIOEvent("Kill", newWeapon, null, "", 0.1f);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch { }
|
catch { }
|
||||||
|
|
||||||
@@ -223,9 +272,8 @@ namespace WeaponPaints
|
|||||||
if (!Config.Additional.ShowSkinImage) return;
|
if (!Config.Additional.ShowSkinImage) return;
|
||||||
|
|
||||||
foreach (var player in Utilities.GetPlayers().Where(p =>
|
foreach (var player in Utilities.GetPlayers().Where(p =>
|
||||||
p is { IsValid: true, PlayerPawn.IsValid: true } &&
|
p is { IsValid: true, PlayerPawn.IsValid: true, IsBot: false } and
|
||||||
(LifeState_t)p.LifeState == LifeState_t.LIFE_ALIVE
|
{ Connected: PlayerConnectedState.PlayerConnected }
|
||||||
&& !p.IsBot && p is { Connected: PlayerConnectedState.PlayerConnected }
|
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
@@ -239,9 +287,10 @@ namespace WeaponPaints
|
|||||||
[GameEventHandler]
|
[GameEventHandler]
|
||||||
public HookResult OnItemPickup(EventItemPickup @event, GameEventInfo _)
|
public HookResult OnItemPickup(EventItemPickup @event, GameEventInfo _)
|
||||||
{
|
{
|
||||||
if (!IsWindows) return HookResult.Continue;
|
// if (!IsWindows) return HookResult.Continue;
|
||||||
|
|
||||||
var player = @event.Userid;
|
var player = @event.Userid;
|
||||||
|
if (!@event.Item.Contains("knife")) return HookResult.Continue;
|
||||||
|
|
||||||
if (player != null && player is { IsValid: true, Connected: PlayerConnectedState.PlayerConnected, PawnIsAlive: true, PlayerPawn.IsValid: true })
|
if (player != null && player is { IsValid: true, Connected: PlayerConnectedState.PlayerConnected, PawnIsAlive: true, PlayerPawn.IsValid: true })
|
||||||
{
|
{
|
||||||
GiveOnItemPickup(player);
|
GiveOnItemPickup(player);
|
||||||
@@ -253,11 +302,17 @@ namespace WeaponPaints
|
|||||||
private HookResult OnPlayerDeath(EventPlayerDeath @event, GameEventInfo info)
|
private HookResult OnPlayerDeath(EventPlayerDeath @event, GameEventInfo info)
|
||||||
{
|
{
|
||||||
CCSPlayerController? player = @event.Attacker;
|
CCSPlayerController? player = @event.Attacker;
|
||||||
|
CCSPlayerController? victim = @event.Userid;
|
||||||
|
|
||||||
if (player is null || !player.IsValid)
|
if (player is null || !player.IsValid)
|
||||||
return HookResult.Continue;
|
return HookResult.Continue;
|
||||||
|
|
||||||
|
if (victim == null || !victim.IsValid || victim == player)
|
||||||
|
return HookResult.Continue;
|
||||||
|
|
||||||
if (!GPlayerWeaponsInfo.TryGetValue(player.Slot, out _)) return HookResult.Continue;
|
if (!GPlayerWeaponsInfo.TryGetValue(player.Slot, out var teamInfo) ||
|
||||||
|
!teamInfo.TryGetValue(player.Team, out var teamWeapons) )
|
||||||
|
return HookResult.Continue;
|
||||||
|
|
||||||
CBasePlayerWeapon? weapon = player.PlayerPawn.Value?.WeaponServices?.ActiveWeapon.Value;
|
CBasePlayerWeapon? weapon = player.PlayerPawn.Value?.WeaponServices?.ActiveWeapon.Value;
|
||||||
|
|
||||||
@@ -265,7 +320,7 @@ namespace WeaponPaints
|
|||||||
|
|
||||||
int weaponDefIndex = weapon.AttributeManager.Item.ItemDefinitionIndex;
|
int weaponDefIndex = weapon.AttributeManager.Item.ItemDefinitionIndex;
|
||||||
|
|
||||||
if (!GPlayerWeaponsInfo[player.Slot].TryGetValue(weaponDefIndex, out var weaponInfo) || weaponInfo.Paint == 0)
|
if (!teamWeapons.TryGetValue(weaponDefIndex, out var weaponInfo) || weaponInfo.Paint == 0)
|
||||||
return HookResult.Continue;
|
return HookResult.Continue;
|
||||||
|
|
||||||
if (!weaponInfo.StatTrak) return HookResult.Continue;
|
if (!weaponInfo.StatTrak) return HookResult.Continue;
|
||||||
@@ -288,14 +343,14 @@ namespace WeaponPaints
|
|||||||
RegisterEventHandler<EventPlayerSpawn>(OnPlayerSpawn);
|
RegisterEventHandler<EventPlayerSpawn>(OnPlayerSpawn);
|
||||||
RegisterEventHandler<EventRoundStart>(OnRoundStart);
|
RegisterEventHandler<EventRoundStart>(OnRoundStart);
|
||||||
RegisterEventHandler<EventRoundEnd>(OnRoundEnd);
|
RegisterEventHandler<EventRoundEnd>(OnRoundEnd);
|
||||||
|
RegisterEventHandler<EventRoundMvp>(OnRoundMvp);
|
||||||
RegisterListener<Listeners.OnEntityCreated>(OnEntityCreated);
|
RegisterListener<Listeners.OnEntityCreated>(OnEntityCreated);
|
||||||
RegisterEventHandler<EventPlayerDeath>(OnPlayerDeath);
|
RegisterEventHandler<EventPlayerDeath>(OnPlayerDeath);
|
||||||
|
|
||||||
if (Config.Additional.ShowSkinImage)
|
if (Config.Additional.ShowSkinImage)
|
||||||
RegisterListener<Listeners.OnTick>(OnTick);
|
RegisterListener<Listeners.OnTick>(OnTick);
|
||||||
|
|
||||||
if (!IsWindows)
|
VirtualFunctions.GiveNamedItemFunc.Hook(OnGiveNamedItemPost, HookMode.Post);
|
||||||
VirtualFunctions.GiveNamedItemFunc.Hook(OnGiveNamedItemPost, HookMode.Post);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
141
Utility.cs
141
Utility.cs
@@ -1,6 +1,8 @@
|
|||||||
using CounterStrikeSharp.API.Core;
|
using CounterStrikeSharp.API.Core;
|
||||||
using CounterStrikeSharp.API.Core.Translations;
|
using CounterStrikeSharp.API.Core.Translations;
|
||||||
|
using CounterStrikeSharp.API.Modules.Menu;
|
||||||
using Dapper;
|
using Dapper;
|
||||||
|
using MenuManager;
|
||||||
using Microsoft.Extensions.Logging;
|
using Microsoft.Extensions.Logging;
|
||||||
using Newtonsoft.Json;
|
using Newtonsoft.Json;
|
||||||
using Newtonsoft.Json.Linq;
|
using Newtonsoft.Json.Linq;
|
||||||
@@ -24,58 +26,65 @@ namespace WeaponPaints
|
|||||||
{
|
{
|
||||||
string[] createTableQueries =
|
string[] createTableQueries =
|
||||||
[
|
[
|
||||||
"""
|
@"
|
||||||
CREATE TABLE IF NOT EXISTS `wp_player_skins` (
|
CREATE TABLE IF NOT EXISTS `wp_player_skins` (
|
||||||
`steamid` varchar(18) NOT NULL,
|
`steamid` varchar(18) NOT NULL,
|
||||||
`weapon_defindex` int(6) NOT NULL,
|
`weapon_team` int(1) NOT NULL,
|
||||||
`weapon_paint_id` int(6) NOT NULL,
|
`weapon_defindex` int(6) NOT NULL,
|
||||||
`weapon_wear` float NOT NULL DEFAULT 0.000001,
|
`weapon_paint_id` int(6) NOT NULL,
|
||||||
`weapon_seed` int(16) NOT NULL DEFAULT 0,
|
`weapon_wear` float NOT NULL DEFAULT 0.000001,
|
||||||
`weapon_nametag` VARCHAR(128) DEFAULT NULL,
|
`weapon_seed` int(16) NOT NULL DEFAULT 0,
|
||||||
`weapon_stattrak` tinyint(1) NOT NULL,
|
`weapon_nametag` VARCHAR(128) DEFAULT NULL,
|
||||||
`weapon_stattrak_count` int(10) NOT NULL,
|
`weapon_stattrak` tinyint(1) NOT NULL DEFAULT 0,
|
||||||
`weapon_sticker_0` VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0;0;0' COMMENT 'id;schema;x;y;wear;scale;rotation',
|
`weapon_stattrak_count` int(10) NOT NULL DEFAULT 0,
|
||||||
`weapon_sticker_1` VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0;0;0' COMMENT 'id;schema;x;y;wear;scale;rotation',
|
`weapon_sticker_0` VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0;0;0' COMMENT 'id;schema;x;y;wear;scale;rotation',
|
||||||
`weapon_sticker_2` VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0;0;0' COMMENT 'id;schema;x;y;wear;scale;rotation',
|
`weapon_sticker_1` VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0;0;0' COMMENT 'id;schema;x;y;wear;scale;rotation',
|
||||||
`weapon_sticker_3` VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0;0;0' COMMENT 'id;schema;x;y;wear;scale;rotation',
|
`weapon_sticker_2` VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0;0;0' COMMENT 'id;schema;x;y;wear;scale;rotation',
|
||||||
`weapon_sticker_4` VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0;0;0' COMMENT 'id;schema;x;y;wear;scale;rotation',
|
`weapon_sticker_3` VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0;0;0' COMMENT 'id;schema;x;y;wear;scale;rotation',
|
||||||
`weapon_keychain`VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0' COMMENT 'id;x;y;z;seed'
|
`weapon_sticker_4` VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0;0;0' COMMENT 'id;schema;x;y;wear;scale;rotation',
|
||||||
) ENGINE=InnoDB
|
`weapon_keychain` VARCHAR(128) NOT NULL DEFAULT '0;0;0;0;0' COMMENT 'id;x;y;z;seed',
|
||||||
""",
|
UNIQUE (`steamid`, `weapon_team`, `weapon_defindex`) -- Add unique constraint here
|
||||||
@"CREATE TABLE IF NOT EXISTS `wp_player_knife` (
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;",
|
||||||
`steamid` varchar(18) NOT NULL,
|
|
||||||
`knife` varchar(64) NOT NULL,
|
@"
|
||||||
UNIQUE (`steamid`)
|
CREATE TABLE IF NOT EXISTS `wp_player_knife` (
|
||||||
) ENGINE = InnoDB",
|
`steamid` varchar(18) NOT NULL,
|
||||||
"""
|
`weapon_team` int(1) NOT NULL,
|
||||||
CREATE TABLE IF NOT EXISTS `wp_player_gloves` (
|
`knife` varchar(64) NOT NULL,
|
||||||
`steamid` varchar(18) NOT NULL,
|
UNIQUE (`steamid`, `weapon_team`) -- Unique constraint
|
||||||
`weapon_defindex` int(11) NOT NULL,
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;",
|
||||||
UNIQUE (`steamid`)
|
|
||||||
) ENGINE=InnoDB
|
@"
|
||||||
""",
|
CREATE TABLE IF NOT EXISTS `wp_player_gloves` (
|
||||||
"""
|
`steamid` varchar(18) NOT NULL,
|
||||||
CREATE TABLE IF NOT EXISTS `wp_player_agents` (
|
`weapon_team` int(1) NOT NULL,
|
||||||
`steamid` varchar(18) NOT NULL,
|
`weapon_defindex` int(11) NOT NULL,
|
||||||
`agent_ct` varchar(64) DEFAULT NULL,
|
UNIQUE (`steamid`, `weapon_team`) -- Unique constraint
|
||||||
`agent_t` varchar(64) DEFAULT NULL,
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;",
|
||||||
UNIQUE (`steamid`)
|
|
||||||
) ENGINE=InnoDB
|
@"
|
||||||
""",
|
CREATE TABLE IF NOT EXISTS `wp_player_agents` (
|
||||||
"""
|
`steamid` varchar(18) NOT NULL,
|
||||||
CREATE TABLE IF NOT EXISTS `wp_player_music` (
|
`agent_ct` varchar(64) DEFAULT NULL,
|
||||||
`steamid` varchar(64) NOT NULL,
|
`agent_t` varchar(64) DEFAULT NULL,
|
||||||
`music_id` int(11) NOT NULL,
|
UNIQUE (`steamid`) -- Unique constraint
|
||||||
UNIQUE (`steamid`)
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;",
|
||||||
) ENGINE=InnoDB
|
|
||||||
""",
|
@"
|
||||||
"""
|
CREATE TABLE IF NOT EXISTS `wp_player_music` (
|
||||||
CREATE TABLE IF NOT EXISTS `wp_player_pins` (
|
`steamid` varchar(64) NOT NULL,
|
||||||
`steamid` varchar(64) NOT NULL,
|
`weapon_team` int(1) NOT NULL,
|
||||||
`id` int(11) NOT NULL,
|
`music_id` int(11) NOT NULL,
|
||||||
UNIQUE (`steamid`)
|
UNIQUE (`steamid`, `weapon_team`) -- Unique constraint
|
||||||
) ENGINE=InnoDB
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;",
|
||||||
""",
|
|
||||||
|
@"
|
||||||
|
CREATE TABLE IF NOT EXISTS `wp_player_pins` (
|
||||||
|
`steamid` varchar(64) NOT NULL,
|
||||||
|
`weapon_team` int(1) NOT NULL,
|
||||||
|
`id` int(11) NOT NULL,
|
||||||
|
UNIQUE (`steamid`, `weapon_team`) -- Unique constraint
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;"
|
||||||
];
|
];
|
||||||
|
|
||||||
foreach (var query in createTableQueries)
|
foreach (var query in createTableQueries)
|
||||||
@@ -181,10 +190,32 @@ namespace WeaponPaints
|
|||||||
Console.WriteLine("[WeaponPaints] " + message);
|
Console.WriteLine("[WeaponPaints] " + message);
|
||||||
Console.ResetColor();
|
Console.ResetColor();
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static string ReplaceTags(string message)
|
internal static IMenu? CreateMenu(string title)
|
||||||
{
|
{
|
||||||
return message.ReplaceColorTags();
|
var menuType = WeaponPaints.Instance.Config.MenuType.ToLower();
|
||||||
|
|
||||||
|
var menu = menuType switch
|
||||||
|
{
|
||||||
|
_ when menuType.Equals("selectable", StringComparison.CurrentCultureIgnoreCase) =>
|
||||||
|
WeaponPaints.MenuApi?.NewMenu(title),
|
||||||
|
|
||||||
|
_ when menuType.Equals("dynamic", StringComparison.CurrentCultureIgnoreCase) =>
|
||||||
|
WeaponPaints.MenuApi?.NewMenuForcetype(title, MenuType.ButtonMenu),
|
||||||
|
|
||||||
|
_ when menuType.Equals("center", StringComparison.CurrentCultureIgnoreCase) =>
|
||||||
|
WeaponPaints.MenuApi?.NewMenuForcetype(title, MenuType.CenterMenu),
|
||||||
|
|
||||||
|
_ when menuType.Equals("chat", StringComparison.CurrentCultureIgnoreCase) =>
|
||||||
|
WeaponPaints.MenuApi?.NewMenuForcetype(title, MenuType.ChatMenu),
|
||||||
|
|
||||||
|
_ when menuType.Equals("console", StringComparison.CurrentCultureIgnoreCase) =>
|
||||||
|
WeaponPaints.MenuApi?.NewMenuForcetype(title, MenuType.ConsoleMenu),
|
||||||
|
|
||||||
|
_ => WeaponPaints.MenuApi?.NewMenu(title)
|
||||||
|
};
|
||||||
|
|
||||||
|
return menu;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static async Task CheckVersion(string version, ILogger logger)
|
internal static async Task CheckVersion(string version, ILogger logger)
|
||||||
|
|||||||
18
Variables.cs
18
Variables.cs
@@ -3,6 +3,7 @@ using System.Runtime.InteropServices;
|
|||||||
using CounterStrikeSharp.API.Core;
|
using CounterStrikeSharp.API.Core;
|
||||||
using CounterStrikeSharp.API.Core.Capabilities;
|
using CounterStrikeSharp.API.Core.Capabilities;
|
||||||
using CounterStrikeSharp.API.Modules.Memory.DynamicFunctions;
|
using CounterStrikeSharp.API.Modules.Memory.DynamicFunctions;
|
||||||
|
using CounterStrikeSharp.API.Modules.Utils;
|
||||||
using MenuManager;
|
using MenuManager;
|
||||||
using Microsoft.Extensions.Localization;
|
using Microsoft.Extensions.Localization;
|
||||||
using Newtonsoft.Json.Linq;
|
using Newtonsoft.Json.Linq;
|
||||||
@@ -72,12 +73,13 @@ public partial class WeaponPaints
|
|||||||
};
|
};
|
||||||
|
|
||||||
public static IStringLocalizer? _localizer;
|
public static IStringLocalizer? _localizer;
|
||||||
internal static readonly ConcurrentDictionary<int, string> GPlayersKnife = new();
|
internal static readonly ConcurrentDictionary<int, ConcurrentDictionary<CsTeam, string>> GPlayersKnife = new();
|
||||||
internal static readonly ConcurrentDictionary<int, ushort> GPlayersGlove = new();
|
internal static readonly ConcurrentDictionary<int, ConcurrentDictionary<CsTeam, ushort>> GPlayersGlove = new();
|
||||||
internal static readonly ConcurrentDictionary<int, ushort> GPlayersMusic = new();
|
internal static readonly ConcurrentDictionary<int, ConcurrentDictionary<CsTeam, ushort>> GPlayersMusic = new();
|
||||||
internal static readonly ConcurrentDictionary<int, ushort> GPlayersPin = new();
|
internal static readonly ConcurrentDictionary<int, ConcurrentDictionary<CsTeam, ushort>> GPlayersPin = new();
|
||||||
public static readonly ConcurrentDictionary<int, (string? CT, string? T)> GPlayersAgent = new();
|
internal static readonly ConcurrentDictionary<int, (string? CT, string? T)> GPlayersAgent = new();
|
||||||
internal static readonly ConcurrentDictionary<int, ConcurrentDictionary<int, WeaponInfo>> GPlayerWeaponsInfo = new();
|
internal static readonly Dictionary<int, int> GPlayersKnivesPickup = [];
|
||||||
|
internal static readonly ConcurrentDictionary<int, ConcurrentDictionary<CsTeam, ConcurrentDictionary<int, WeaponInfo>>> GPlayerWeaponsInfo = new();
|
||||||
internal static List<JObject> SkinsList = [];
|
internal static List<JObject> SkinsList = [];
|
||||||
internal static List<JObject> PinsList = [];
|
internal static List<JObject> PinsList = [];
|
||||||
internal static List<JObject> GlovesList = [];
|
internal static List<JObject> GlovesList = [];
|
||||||
@@ -91,7 +93,7 @@ public partial class WeaponPaints
|
|||||||
internal static Database? Database;
|
internal static Database? Database;
|
||||||
|
|
||||||
private static readonly MemoryFunctionVoid<nint, string, float> CAttributeListSetOrAddAttributeValueByName = new(GameData.GetSignature("CAttributeList_SetOrAddAttributeValueByName"));
|
private static readonly MemoryFunctionVoid<nint, string, float> CAttributeListSetOrAddAttributeValueByName = new(GameData.GetSignature("CAttributeList_SetOrAddAttributeValueByName"));
|
||||||
|
|
||||||
private static readonly MemoryFunctionWithReturn<nint, string, int, int> SetBodygroupFunc = new(
|
private static readonly MemoryFunctionWithReturn<nint, string, int, int> SetBodygroupFunc = new(
|
||||||
GameData.GetSignature("CBaseModelEntity_SetBodygroup"));
|
GameData.GetSignature("CBaseModelEntity_SetBodygroup"));
|
||||||
|
|
||||||
@@ -164,4 +166,6 @@ public partial class WeaponPaints
|
|||||||
|
|
||||||
internal static IMenuApi? MenuApi;
|
internal static IMenuApi? MenuApi;
|
||||||
private static readonly PluginCapability<IMenuApi> MenuCapability = new("menu:nfcore");
|
private static readonly PluginCapability<IMenuApi> MenuCapability = new("menu:nfcore");
|
||||||
|
|
||||||
|
private int _fadeSeed;
|
||||||
}
|
}
|
||||||
134
WeaponAction.cs
134
WeaponAction.cs
@@ -20,11 +20,14 @@ namespace WeaponPaints
|
|||||||
|
|
||||||
bool isKnife = weapon.DesignerName.Contains("knife") || weapon.DesignerName.Contains("bayonet");
|
bool isKnife = weapon.DesignerName.Contains("knife") || weapon.DesignerName.Contains("bayonet");
|
||||||
|
|
||||||
if (isKnife && !GPlayersKnife.ContainsKey(player.Slot) || isKnife && GPlayersKnife[player.Slot] == "weapon_knife") return;
|
if (isKnife && (!GPlayersKnife.ContainsKey(player.Slot) ||
|
||||||
|
!GPlayersKnife[player.Slot].ContainsKey(player.Team) ||
|
||||||
|
GPlayersKnife[player.Slot][player.Team] == "weapon_knife"))
|
||||||
|
return;
|
||||||
|
|
||||||
if (isKnife)
|
if (isKnife)
|
||||||
{
|
{
|
||||||
var newDefIndex = WeaponDefindex.FirstOrDefault(x => x.Value == GPlayersKnife[player.Slot]);
|
var newDefIndex = WeaponDefindex.FirstOrDefault(x => x.Value == GPlayersKnife[player.Slot][player.Team]);
|
||||||
if (newDefIndex.Key == 0) return;
|
if (newDefIndex.Key == 0) return;
|
||||||
|
|
||||||
if (weapon.AttributeManager.Item.ItemDefinitionIndex != newDefIndex.Key)
|
if (weapon.AttributeManager.Item.ItemDefinitionIndex != newDefIndex.Key)
|
||||||
@@ -35,11 +38,15 @@ namespace WeaponPaints
|
|||||||
weapon.AttributeManager.Item.ItemDefinitionIndex = (ushort)newDefIndex.Key;
|
weapon.AttributeManager.Item.ItemDefinitionIndex = (ushort)newDefIndex.Key;
|
||||||
weapon.AttributeManager.Item.EntityQuality = 3;
|
weapon.AttributeManager.Item.EntityQuality = 3;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
weapon.AttributeManager.Item.EntityQuality = 0;
|
||||||
|
}
|
||||||
|
|
||||||
UpdatePlayerEconItemId(weapon.AttributeManager.Item);
|
UpdatePlayerEconItemId(weapon.AttributeManager.Item);
|
||||||
|
|
||||||
int weaponDefIndex = weapon.AttributeManager.Item.ItemDefinitionIndex;
|
int weaponDefIndex = weapon.AttributeManager.Item.ItemDefinitionIndex;
|
||||||
int fallbackPaintKit = 0;
|
int fallbackPaintKit;
|
||||||
|
|
||||||
weapon.AttributeManager.Item.AccountID = (uint)player.SteamID;
|
weapon.AttributeManager.Item.AccountID = (uint)player.SteamID;
|
||||||
|
|
||||||
@@ -47,7 +54,9 @@ namespace WeaponPaints
|
|||||||
bool isLegacyModel;
|
bool isLegacyModel;
|
||||||
|
|
||||||
if (_config.Additional.GiveRandomSkin &&
|
if (_config.Additional.GiveRandomSkin &&
|
||||||
!GPlayerWeaponsInfo[player.Slot].ContainsKey(weaponDefIndex))
|
GPlayerWeaponsInfo.ContainsKey(player.Slot) &&
|
||||||
|
(!GPlayerWeaponsInfo[player.Slot].ContainsKey(player.Team) ||
|
||||||
|
!GPlayerWeaponsInfo[player.Slot][player.Team].ContainsKey(weaponDefIndex)))
|
||||||
{
|
{
|
||||||
// Random skins
|
// Random skins
|
||||||
weapon.FallbackPaintKit = GetRandomPaint(weaponDefIndex);
|
weapon.FallbackPaintKit = GetRandomPaint(weaponDefIndex);
|
||||||
@@ -80,22 +89,33 @@ namespace WeaponPaints
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!GPlayerWeaponsInfo[player.Slot].TryGetValue(weaponDefIndex, out var value) || value.Paint == 0) return;
|
if (!GPlayerWeaponsInfo.TryGetValue(player.Slot, out var teamInfo) ||
|
||||||
|
!teamInfo.TryGetValue(player.Team, out var teamWeapons) )
|
||||||
|
return;
|
||||||
|
if (!teamWeapons.TryGetValue(weaponDefIndex, out var value))
|
||||||
|
return;
|
||||||
|
|
||||||
var weaponInfo = value;
|
var weaponInfo = value;
|
||||||
//Log($"Apply on {weapon.DesignerName}({weapon.AttributeManager.Item.ItemDefinitionIndex}) paint {gPlayerWeaponPaints[steamId.SteamId64][weapon.AttributeManager.Item.ItemDefinitionIndex]} seed {gPlayerWeaponSeed[steamId.SteamId64][weapon.AttributeManager.Item.ItemDefinitionIndex]} wear {gPlayerWeaponWear[steamId.SteamId64][weapon.AttributeManager.Item.ItemDefinitionIndex]}");
|
//Log($"Apply on {weapon.DesignerName}({weapon.AttributeManager.Item.ItemDefinitionIndex}) paint {gPlayerWeaponPaints[steamId.SteamId64][weapon.AttributeManager.Item.ItemDefinitionIndex]} seed {gPlayerWeaponSeed[steamId.SteamId64][weapon.AttributeManager.Item.ItemDefinitionIndex]} wear {gPlayerWeaponWear[steamId.SteamId64][weapon.AttributeManager.Item.ItemDefinitionIndex]}");
|
||||||
|
|
||||||
|
weapon.AttributeManager.Item.AttributeList.Attributes.RemoveAll();
|
||||||
|
weapon.AttributeManager.Item.NetworkedDynamicAttributes.Attributes.RemoveAll();
|
||||||
|
|
||||||
weapon.AttributeManager.Item.ItemID = 16384;
|
weapon.AttributeManager.Item.ItemID = 16384;
|
||||||
weapon.AttributeManager.Item.ItemIDLow = 16384 & 0xFFFFFFFF;
|
weapon.AttributeManager.Item.ItemIDLow = 16384 & 0xFFFFFFFF;
|
||||||
weapon.AttributeManager.Item.ItemIDHigh = weapon.AttributeManager.Item.ItemIDLow >> 32;
|
weapon.AttributeManager.Item.ItemIDHigh = weapon.AttributeManager.Item.ItemIDLow >> 32;
|
||||||
weapon.AttributeManager.Item.CustomName = weaponInfo.Nametag;
|
weapon.AttributeManager.Item.CustomName = weaponInfo.Nametag;
|
||||||
weapon.FallbackPaintKit = weaponInfo.Paint;
|
weapon.FallbackPaintKit = weaponInfo.Paint;
|
||||||
weapon.FallbackSeed = weaponInfo.Seed;
|
|
||||||
|
weapon.FallbackSeed = weaponInfo is { Paint: 38, Seed: 0 } ? _fadeSeed++ : weaponInfo.Seed;
|
||||||
|
|
||||||
weapon.FallbackWear = weaponInfo.Wear;
|
weapon.FallbackWear = weaponInfo.Wear;
|
||||||
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle, "set item texture prefab", weapon.FallbackPaintKit);
|
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle, "set item texture prefab", weapon.FallbackPaintKit);
|
||||||
|
|
||||||
if (weaponInfo.StatTrak)
|
if (weaponInfo.StatTrak)
|
||||||
{
|
{
|
||||||
|
weapon.AttributeManager.Item.EntityQuality = 9;
|
||||||
|
|
||||||
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle, "kill eater", ViewAsFloat((uint)weaponInfo.StatTrakCount));
|
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle, "kill eater", ViewAsFloat((uint)weaponInfo.StatTrakCount));
|
||||||
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle, "kill eater score type", 0);
|
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle, "kill eater score type", 0);
|
||||||
|
|
||||||
@@ -108,8 +128,6 @@ namespace WeaponPaints
|
|||||||
if (fallbackPaintKit == 0)
|
if (fallbackPaintKit == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (isKnife) return;
|
|
||||||
|
|
||||||
if (weaponInfo.KeyChain != null) SetKeychain(player, weapon);
|
if (weaponInfo.KeyChain != null) SetKeychain(player, weapon);
|
||||||
if (weaponInfo.Stickers.Count > 0) SetStickers(player, weapon);
|
if (weaponInfo.Stickers.Count > 0) SetStickers(player, weapon);
|
||||||
|
|
||||||
@@ -120,6 +138,7 @@ namespace WeaponPaints
|
|||||||
.ToList();
|
.ToList();
|
||||||
|
|
||||||
isLegacyModel = skinInfo.Count <= 0 || skinInfo[0].Value<bool>("legacy_model");
|
isLegacyModel = skinInfo.Count <= 0 || skinInfo[0].Value<bool>("legacy_model");
|
||||||
|
|
||||||
UpdatePlayerWeaponMeshGroupMask(player, weapon, isLegacyModel);
|
UpdatePlayerWeaponMeshGroupMask(player, weapon, isLegacyModel);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -128,7 +147,8 @@ namespace WeaponPaints
|
|||||||
{
|
{
|
||||||
int weaponDefIndex = weapon.AttributeManager.Item.ItemDefinitionIndex;
|
int weaponDefIndex = weapon.AttributeManager.Item.ItemDefinitionIndex;
|
||||||
if (!GPlayerWeaponsInfo.TryGetValue(player.Slot, out var playerWeapons) ||
|
if (!GPlayerWeaponsInfo.TryGetValue(player.Slot, out var playerWeapons) ||
|
||||||
!playerWeapons.TryGetValue(weaponDefIndex, out var weaponInfo) ||
|
!playerWeapons.TryGetValue(player.Team, out var weaponInfoDict) ||
|
||||||
|
!weaponInfoDict.TryGetValue(weaponDefIndex, out var weaponInfo) ||
|
||||||
weaponInfo.Stickers.Count <= 0) return;
|
weaponInfo.Stickers.Count <= 0) return;
|
||||||
|
|
||||||
float wearIncrement = 0.001f;
|
float wearIncrement = 0.001f;
|
||||||
@@ -152,7 +172,7 @@ namespace WeaponPaints
|
|||||||
int weaponDefIndex = weapon.AttributeManager.Item.ItemDefinitionIndex;
|
int weaponDefIndex = weapon.AttributeManager.Item.ItemDefinitionIndex;
|
||||||
|
|
||||||
if (!GPlayerWeaponsInfo.TryGetValue(player.Slot, out var playerWeapons) ||
|
if (!GPlayerWeaponsInfo.TryGetValue(player.Slot, out var playerWeapons) ||
|
||||||
!playerWeapons.TryGetValue(weaponDefIndex, out var weaponInfo))
|
!playerWeapons[player.Team].TryGetValue(weaponDefIndex, out var weaponInfo))
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -163,15 +183,13 @@ namespace WeaponPaints
|
|||||||
|
|
||||||
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
||||||
$"sticker slot {stickerSlot} id", ViewAsFloat(sticker.Id));
|
$"sticker slot {stickerSlot} id", ViewAsFloat(sticker.Id));
|
||||||
// CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
if (sticker.OffsetX != 0 || sticker.OffsetY != 0)
|
||||||
// $"sticker slot {stickerSlot} schema", stickerSlot);
|
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
||||||
// if (stickerSlot == 5)
|
$"sticker slot {stickerSlot} schema", 0);
|
||||||
// {
|
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
||||||
// // CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
$"sticker slot {stickerSlot} offset x", sticker.OffsetX);
|
||||||
// // $"sticker slot {stickerSlot} offset x", 0.05f);
|
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
||||||
// // CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
$"sticker slot {stickerSlot} offset y", sticker.OffsetY);
|
||||||
// // $"sticker slot {stickerSlot} offset y", 0.02f);
|
|
||||||
// }
|
|
||||||
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
||||||
$"sticker slot {stickerSlot} wear", sticker.Wear);
|
$"sticker slot {stickerSlot} wear", sticker.Wear);
|
||||||
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
||||||
@@ -194,8 +212,11 @@ namespace WeaponPaints
|
|||||||
int weaponDefIndex = weapon.AttributeManager.Item.ItemDefinitionIndex;
|
int weaponDefIndex = weapon.AttributeManager.Item.ItemDefinitionIndex;
|
||||||
|
|
||||||
if (!GPlayerWeaponsInfo.TryGetValue(player.Slot, out var playerWeaponsInfo) ||
|
if (!GPlayerWeaponsInfo.TryGetValue(player.Slot, out var playerWeaponsInfo) ||
|
||||||
!playerWeaponsInfo.TryGetValue(weaponDefIndex, out var value) ||
|
!playerWeaponsInfo.TryGetValue(player.Team, out var teamWeaponsInfo) ||
|
||||||
value.KeyChain == null) return;
|
!teamWeaponsInfo.TryGetValue(weaponDefIndex, out var value) ||
|
||||||
|
value.KeyChain == null)
|
||||||
|
return;
|
||||||
|
|
||||||
var keyChain = value.KeyChain;
|
var keyChain = value.KeyChain;
|
||||||
|
|
||||||
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
CAttributeListSetOrAddAttributeValueByName.Invoke(weapon.AttributeManager.Item.NetworkedDynamicAttributes.Handle,
|
||||||
@@ -218,6 +239,7 @@ namespace WeaponPaints
|
|||||||
|
|
||||||
//string knifeToGive = (CsTeam)player.TeamNum == CsTeam.Terrorist ? "weapon_knife_t" : "weapon_knife";
|
//string knifeToGive = (CsTeam)player.TeamNum == CsTeam.Terrorist ? "weapon_knife_t" : "weapon_knife";
|
||||||
player.GiveNamedItem(CsItem.Knife);
|
player.GiveNamedItem(CsItem.Knife);
|
||||||
|
Utilities.SetStateChanged(player, "CCSPlayerController", "m_pInventoryServices");
|
||||||
}
|
}
|
||||||
|
|
||||||
private static bool PlayerHasKnife(CCSPlayerController? player)
|
private static bool PlayerHasKnife(CCSPlayerController? player)
|
||||||
@@ -260,8 +282,8 @@ namespace WeaponPaints
|
|||||||
if (player.Team is CsTeam.None or CsTeam.Spectator)
|
if (player.Team is CsTeam.None or CsTeam.Spectator)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
int playerTeam = player.TeamNum;
|
var hasKnife = false;
|
||||||
|
|
||||||
Dictionary<string, List<(int, int)>> weaponsWithAmmo = [];
|
Dictionary<string, List<(int, int)>> weaponsWithAmmo = [];
|
||||||
|
|
||||||
foreach (var weapon in weapons)
|
foreach (var weapon in weapons)
|
||||||
@@ -269,7 +291,7 @@ namespace WeaponPaints
|
|||||||
if (!weapon.IsValid || weapon.Value == null ||
|
if (!weapon.IsValid || weapon.Value == null ||
|
||||||
!weapon.Value.IsValid || !weapon.Value.DesignerName.Contains("weapon_"))
|
!weapon.Value.IsValid || !weapon.Value.DesignerName.Contains("weapon_"))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
CCSWeaponBaseGun gun = weapon.Value.As<CCSWeaponBaseGun>();
|
CCSWeaponBaseGun gun = weapon.Value.As<CCSWeaponBaseGun>();
|
||||||
|
|
||||||
if (weapon.Value.Entity == null) continue;
|
if (weapon.Value.Entity == null) continue;
|
||||||
@@ -308,6 +330,7 @@ namespace WeaponPaints
|
|||||||
if (weaponData.GearSlot == gear_slot_t.GEAR_SLOT_KNIFE)
|
if (weaponData.GearSlot == gear_slot_t.GEAR_SLOT_KNIFE)
|
||||||
{
|
{
|
||||||
weapon.Value?.AddEntityIOEvent("Kill", weapon.Value, null, "", 0.1f);
|
weapon.Value?.AddEntityIOEvent("Kill", weapon.Value, null, "", 0.1f);
|
||||||
|
hasKnife = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
@@ -319,9 +342,16 @@ namespace WeaponPaints
|
|||||||
AddTimer(0.23f, () =>
|
AddTimer(0.23f, () =>
|
||||||
{
|
{
|
||||||
if (!_gBCommandsAllowed) return;
|
if (!_gBCommandsAllowed) return;
|
||||||
|
|
||||||
if (!PlayerHasKnife(player))
|
if (!PlayerHasKnife(player) && hasKnife)
|
||||||
GiveKnifeToPlayer(player);
|
{
|
||||||
|
var newKnife = new CBasePlayerWeapon(player.GiveNamedItem(CsItem.Knife));
|
||||||
|
newKnife.AddEntityIOEvent("Kill", newKnife, null, "", 0.01f);
|
||||||
|
var newWeapon = new CBasePlayerWeapon(player.GiveNamedItem(CsItem.USP));
|
||||||
|
player.GiveNamedItem(CsItem.Knife);
|
||||||
|
player.ExecuteClientCommand("slot3");
|
||||||
|
newWeapon.AddEntityIOEvent("Kill", newWeapon, null, "", 0.01f);
|
||||||
|
}
|
||||||
|
|
||||||
foreach (var entry in weaponsWithAmmo)
|
foreach (var entry in weaponsWithAmmo)
|
||||||
{
|
{
|
||||||
@@ -373,11 +403,15 @@ namespace WeaponPaints
|
|||||||
if (!player.PawnIsAlive)
|
if (!player.PawnIsAlive)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (!GPlayersGlove.TryGetValue(player.Slot, out var gloveInfo) || gloveInfo == 0) return;
|
if (!GPlayersGlove.TryGetValue(player.Slot, out var gloveInfo) ||
|
||||||
|
!gloveInfo.TryGetValue(player.Team, out var gloveId) ||
|
||||||
|
gloveId == 0 ||
|
||||||
|
!GPlayerWeaponsInfo.TryGetValue(player.Slot, out var playerWeaponsInfo) ||
|
||||||
|
!playerWeaponsInfo.TryGetValue(player.Team, out var teamWeaponsInfo) ||
|
||||||
|
!teamWeaponsInfo.TryGetValue(gloveId, out var weaponInfo))
|
||||||
|
return;
|
||||||
|
|
||||||
WeaponInfo weaponInfo = GPlayerWeaponsInfo[player.Slot][gloveInfo];
|
item.ItemDefinitionIndex = gloveId;
|
||||||
|
|
||||||
item.ItemDefinitionIndex = gloveInfo;
|
|
||||||
item.ItemIDLow = 16384 & 0xFFFFFFFF;
|
item.ItemIDLow = 16384 & 0xFFFFFFFF;
|
||||||
item.ItemIDHigh = 16384;
|
item.ItemIDHigh = 16384;
|
||||||
|
|
||||||
@@ -439,6 +473,7 @@ namespace WeaponPaints
|
|||||||
var viewModel = GetPlayerViewModel(player);
|
var viewModel = GetPlayerViewModel(player);
|
||||||
if (viewModel == null || viewModel.Weapon.Value == null ||
|
if (viewModel == null || viewModel.Weapon.Value == null ||
|
||||||
viewModel.Weapon.Value.Index != weapon.Index) return;
|
viewModel.Weapon.Value.Index != weapon.Index) return;
|
||||||
|
|
||||||
UpdateWeaponMeshGroupMask(viewModel, isLegacy);
|
UpdateWeaponMeshGroupMask(viewModel, isLegacy);
|
||||||
Utilities.SetStateChanged(viewModel, "CBaseEntity", "m_CBodyComponent");
|
Utilities.SetStateChanged(viewModel, "CBaseEntity", "m_CBodyComponent");
|
||||||
}
|
}
|
||||||
@@ -469,21 +504,29 @@ namespace WeaponPaints
|
|||||||
|
|
||||||
private static void GivePlayerMusicKit(CCSPlayerController player)
|
private static void GivePlayerMusicKit(CCSPlayerController player)
|
||||||
{
|
{
|
||||||
if (!GPlayersMusic.TryGetValue(player.Slot, out var value)) return;
|
if (player.IsBot) return;
|
||||||
if (player.InventoryServices == null) return;
|
if (!GPlayersMusic.TryGetValue(player.Slot, out var musicInfo) ||
|
||||||
|
!musicInfo.TryGetValue(player.Team, out var musicId) || musicId == 0) return;
|
||||||
|
|
||||||
player.InventoryServices.MusicID = value;
|
if (player.InventoryServices == null) return;
|
||||||
Utilities.SetStateChanged(player, "CCSPlayerController", "m_pInventoryServices");
|
|
||||||
player.MusicKitID = value;
|
player.MusicKitID = musicId;
|
||||||
|
// player.MvpNoMusic = false;
|
||||||
|
player.InventoryServices.MusicID = musicId;
|
||||||
Utilities.SetStateChanged(player, "CCSPlayerController", "m_iMusicKitID");
|
Utilities.SetStateChanged(player, "CCSPlayerController", "m_iMusicKitID");
|
||||||
|
// Utilities.SetStateChanged(player, "CCSPlayerController", "m_bMvpNoMusic");
|
||||||
|
Utilities.SetStateChanged(player, "CCSPlayerController", "m_pInventoryServices");
|
||||||
|
// player.MusicKitMVPs = musicId;
|
||||||
|
// Utilities.SetStateChanged(player, "CCSPlayerController", "m_iMusicKitMVPs");
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void GivePlayerPin(CCSPlayerController player)
|
private static void GivePlayerPin(CCSPlayerController player)
|
||||||
{
|
{
|
||||||
if (!GPlayersPin.TryGetValue(player.Slot, out var pin)) return;
|
if (!GPlayersPin.TryGetValue(player.Slot, out var pinInfo) ||
|
||||||
|
!pinInfo.TryGetValue(player.Team, out var pinId)) return;
|
||||||
if (player.InventoryServices == null) return;
|
if (player.InventoryServices == null) return;
|
||||||
|
|
||||||
player.InventoryServices.Rank[5] = pin > 0 ? (MedalRank_t)pin : MedalRank_t.MEDAL_RANK_NONE;
|
player.InventoryServices.Rank[5] = pinId > 0 ? (MedalRank_t)pinId : MedalRank_t.MEDAL_RANK_NONE;
|
||||||
Utilities.SetStateChanged(player, "CCSPlayerController", "m_pInventoryServices");
|
Utilities.SetStateChanged(player, "CCSPlayerController", "m_pInventoryServices");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -494,13 +537,22 @@ namespace WeaponPaints
|
|||||||
|
|
||||||
var myWeapons = pawn.WeaponServices?.MyWeapons;
|
var myWeapons = pawn.WeaponServices?.MyWeapons;
|
||||||
if (myWeapons == null) return;
|
if (myWeapons == null) return;
|
||||||
|
|
||||||
foreach (var handle in myWeapons)
|
foreach (var handle in myWeapons)
|
||||||
{
|
{
|
||||||
var weapon = handle.Value;
|
var weapon = handle.Value;
|
||||||
if (weapon != null && weapon.DesignerName.Contains("knife"))
|
|
||||||
|
if (weapon == null || !weapon.IsValid) continue;
|
||||||
|
if (myWeapons.Count == 1)
|
||||||
{
|
{
|
||||||
GivePlayerWeaponSkin(player, weapon);
|
var newWeapon = new CBasePlayerWeapon(player.GiveNamedItem(CsItem.USP));
|
||||||
|
weapon.AddEntityIOEvent("Kill", weapon, null, "", 0.01f);
|
||||||
|
player.GiveNamedItem(CsItem.Knife);
|
||||||
|
player.ExecuteClientCommand("slot3");
|
||||||
|
newWeapon.AddEntityIOEvent("Kill", newWeapon, null, "", 0.01f);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GivePlayerWeaponSkin(player, weapon);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
public int Seed { get; set; }
|
public int Seed { get; set; }
|
||||||
public float Wear { get; set; }
|
public float Wear { get; set; }
|
||||||
public string Nametag { get; set; } = "";
|
public string Nametag { get; set; } = "";
|
||||||
public bool StatTrak { get; set; } = false;
|
public bool StatTrak { get; set; }
|
||||||
public int StatTrakCount { get; set; }
|
public int StatTrakCount { get; set; }
|
||||||
public KeyChainInfo? KeyChain { get; set; }
|
public KeyChainInfo? KeyChain { get; set; }
|
||||||
public List<StickerInfo> Stickers { get; set; } = new();
|
public List<StickerInfo> Stickers { get; set; } = new();
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
using CounterStrikeSharp.API;
|
using CounterStrikeSharp.API;
|
||||||
using CounterStrikeSharp.API.Core;
|
using CounterStrikeSharp.API.Core;
|
||||||
using CounterStrikeSharp.API.Core.Attributes;
|
using CounterStrikeSharp.API.Core.Attributes;
|
||||||
|
using CounterStrikeSharp.API.Modules.Memory.DynamicFunctions;
|
||||||
using Microsoft.Extensions.Logging;
|
using Microsoft.Extensions.Logging;
|
||||||
using MySqlConnector;
|
using MySqlConnector;
|
||||||
|
|
||||||
@@ -16,7 +17,7 @@ public partial class WeaponPaints : BasePlugin, IPluginConfig<WeaponPaintsConfig
|
|||||||
public override string ModuleAuthor => "Nereziel & daffyy";
|
public override string ModuleAuthor => "Nereziel & daffyy";
|
||||||
public override string ModuleDescription => "Skin, gloves, agents and knife selector, standalone and web-based";
|
public override string ModuleDescription => "Skin, gloves, agents and knife selector, standalone and web-based";
|
||||||
public override string ModuleName => "WeaponPaints";
|
public override string ModuleName => "WeaponPaints";
|
||||||
public override string ModuleVersion => "2.8c";
|
public override string ModuleVersion => "3.1b";
|
||||||
|
|
||||||
public override void Load(bool hotReload)
|
public override void Load(bool hotReload)
|
||||||
{
|
{
|
||||||
@@ -25,19 +26,21 @@ public partial class WeaponPaints : BasePlugin, IPluginConfig<WeaponPaintsConfig
|
|||||||
if (hotReload)
|
if (hotReload)
|
||||||
{
|
{
|
||||||
OnMapStart(string.Empty);
|
OnMapStart(string.Empty);
|
||||||
|
|
||||||
|
GPlayerWeaponsInfo.Clear();
|
||||||
|
GPlayersKnife.Clear();
|
||||||
|
GPlayersGlove.Clear();
|
||||||
|
GPlayersAgent.Clear();
|
||||||
|
GPlayersPin.Clear();
|
||||||
|
GPlayersMusic.Clear();
|
||||||
|
|
||||||
foreach (var player in Enumerable
|
foreach (var player in Enumerable
|
||||||
.OfType<CCSPlayerController>(Utilities.GetPlayers().TakeWhile(player => WeaponSync != null))
|
.OfType<CCSPlayerController>(Utilities.GetPlayers().TakeWhile(_ => WeaponSync != null))
|
||||||
.Where(player => player.IsValid &&
|
.Where(player => player.IsValid &&
|
||||||
!string.IsNullOrEmpty(player.IpAddress) && player is
|
!string.IsNullOrEmpty(player.IpAddress) && player is
|
||||||
{ IsBot: false, Connected: PlayerConnectedState.PlayerConnected }))
|
{ IsBot: false, Connected: PlayerConnectedState.PlayerConnected }))
|
||||||
{
|
{
|
||||||
GPlayerWeaponsInfo.TryRemove(player.Slot, out _);
|
GPlayersKnivesPickup[player.Slot] = 0;
|
||||||
GPlayersKnife.TryRemove(player.Slot, out _);
|
|
||||||
GPlayersGlove.TryRemove(player.Slot, out _);
|
|
||||||
GPlayersAgent.TryRemove(player.Slot, out _);
|
|
||||||
GPlayersPin.TryRemove(player.Slot, out _);
|
|
||||||
|
|
||||||
var playerInfo = new PlayerInfo
|
var playerInfo = new PlayerInfo
|
||||||
{
|
{
|
||||||
UserId = player.UserId,
|
UserId = player.UserId,
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -24,5 +24,7 @@
|
|||||||
"wp_skin_menu_skin_title": "Select skin for {lime}{0}{default}",
|
"wp_skin_menu_skin_title": "Select skin for {lime}{0}{default}",
|
||||||
"wp_skin_menu_select": "You have chosen {lime}{0}{default} as your skin",
|
"wp_skin_menu_select": "You have chosen {lime}{0}{default} as your skin",
|
||||||
|
|
||||||
|
"wp_stattrak_action": "You have successfully changed the stattrak setting",
|
||||||
|
|
||||||
"None": "None"
|
"None": "None"
|
||||||
}
|
}
|
||||||
@@ -23,6 +23,8 @@
|
|||||||
"wp_skin_menu_weapon_title": "Ieroču Izvēlne",
|
"wp_skin_menu_weapon_title": "Ieroču Izvēlne",
|
||||||
"wp_skin_menu_skin_title": "Izvēlieties ādu priekš {lime}{0}{default}",
|
"wp_skin_menu_skin_title": "Izvēlieties ādu priekš {lime}{0}{default}",
|
||||||
"wp_skin_menu_select": "Jūs esat izvēlējies {lime}{0}{default} kā savu ādu",
|
"wp_skin_menu_select": "Jūs esat izvēlējies {lime}{0}{default} kā savu ādu",
|
||||||
|
|
||||||
|
"wp_stattrak_action": "Jūs veiksmīgi mainījāt stattrak iestatījumu",
|
||||||
|
|
||||||
"None": "Nav"
|
"None": "Nav"
|
||||||
}
|
}
|
||||||
@@ -24,5 +24,7 @@
|
|||||||
"wp_skin_menu_skin_title": "Wybierz skórkę dla {lime}{0}{default}",
|
"wp_skin_menu_skin_title": "Wybierz skórkę dla {lime}{0}{default}",
|
||||||
"wp_skin_menu_select": "Wybrałeś {lime}{0}{default} jako swoją skórkę",
|
"wp_skin_menu_select": "Wybrałeś {lime}{0}{default} jako swoją skórkę",
|
||||||
|
|
||||||
|
"wp_stattrak_action": "Pomyślnie zmieniłeś ustawienie stattraka",
|
||||||
|
|
||||||
"None": "Brak"
|
"None": "Brak"
|
||||||
}
|
}
|
||||||
@@ -24,5 +24,7 @@
|
|||||||
"wp_skin_menu_skin_title": "Selecione a skin para {lime}{0}{default}",
|
"wp_skin_menu_skin_title": "Selecione a skin para {lime}{0}{default}",
|
||||||
"wp_skin_menu_select": "Você escolheu {lime}{0}{default} como sua skin",
|
"wp_skin_menu_select": "Você escolheu {lime}{0}{default} como sua skin",
|
||||||
|
|
||||||
|
"wp_stattrak_action": "Você alterou a configuração de stattrak com sucesso",
|
||||||
|
|
||||||
"None": "Nenhum"
|
"None": "Nenhum"
|
||||||
}
|
}
|
||||||
@@ -24,5 +24,7 @@
|
|||||||
"wp_skin_menu_skin_title": "Selecione a skin para {lime}{0}{default}",
|
"wp_skin_menu_skin_title": "Selecione a skin para {lime}{0}{default}",
|
||||||
"wp_skin_menu_select": "Escolheu {lime}{0}{default} como a sua skin",
|
"wp_skin_menu_select": "Escolheu {lime}{0}{default} como a sua skin",
|
||||||
|
|
||||||
|
"wp_stattrak_action": "Alterou com sucesso a configuração do stattrak",
|
||||||
|
|
||||||
"None": "Nenhum"
|
"None": "Nenhum"
|
||||||
}
|
}
|
||||||
@@ -24,5 +24,7 @@
|
|||||||
"wp_skin_menu_skin_title": "Выберите скин для {lime}{0}{default}",
|
"wp_skin_menu_skin_title": "Выберите скин для {lime}{0}{default}",
|
||||||
"wp_skin_menu_select": "Вы выбрали {lime}{0}{default} в качестве вашего скина",
|
"wp_skin_menu_select": "Вы выбрали {lime}{0}{default} в качестве вашего скина",
|
||||||
|
|
||||||
|
"wp_stattrak_action": "Вы успешно изменили настройки статтрак",
|
||||||
|
|
||||||
"None": "Нет"
|
"None": "Нет"
|
||||||
}
|
}
|
||||||
@@ -24,5 +24,7 @@
|
|||||||
"wp_skin_menu_skin_title": "{lime}{0}{default} için cilt seçin",
|
"wp_skin_menu_skin_title": "{lime}{0}{default} için cilt seçin",
|
||||||
"wp_skin_menu_select": "{lime}{0}{default} olarak cildinizi seçtiniz",
|
"wp_skin_menu_select": "{lime}{0}{default} olarak cildinizi seçtiniz",
|
||||||
|
|
||||||
|
"wp_stattrak_action": "StatTrak ayarını başarıyla değiştirdiniz",
|
||||||
|
|
||||||
"None": "Hiçbiri"
|
"None": "Hiçbiri"
|
||||||
}
|
}
|
||||||
@@ -24,5 +24,7 @@
|
|||||||
"wp_skin_menu_skin_title": "Виберіть шкіру для {lime}{0}{default}",
|
"wp_skin_menu_skin_title": "Виберіть шкіру для {lime}{0}{default}",
|
||||||
"wp_skin_menu_select": "Ви обрали {lime}{0}{default} як свою шкіру",
|
"wp_skin_menu_select": "Ви обрали {lime}{0}{default} як свою шкіру",
|
||||||
|
|
||||||
|
"wp_stattrak_action": "Ви успішно змінили налаштування статтрака",
|
||||||
|
|
||||||
"None": "Немає"
|
"None": "Немає"
|
||||||
}
|
}
|
||||||
@@ -24,5 +24,7 @@
|
|||||||
"wp_skin_menu_skin_title": "选择 {lime}{0}{default} 的皮肤",
|
"wp_skin_menu_skin_title": "选择 {lime}{0}{default} 的皮肤",
|
||||||
"wp_skin_menu_select": "您选择了 {lime}{0}{default} 作为您的皮肤",
|
"wp_skin_menu_select": "您选择了 {lime}{0}{default} 作为您的皮肤",
|
||||||
|
|
||||||
|
"wp_stattrak_action": "您已成功更改 StatTrak 设置",
|
||||||
|
|
||||||
"None": "无"
|
"None": "无"
|
||||||
}
|
}
|
||||||
@@ -1,4 +1,6 @@
|
|||||||
<?php
|
<?php
|
||||||
|
define('SKIN_LANGUAGE', 'skins_en');
|
||||||
|
|
||||||
define('DB_HOST', 'localhost');
|
define('DB_HOST', 'localhost');
|
||||||
define('DB_PORT', '3306');
|
define('DB_PORT', '3306');
|
||||||
define('DB_NAME', '');
|
define('DB_NAME', '');
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ class UtilsClass
|
|||||||
public static function skinsFromJson(): array
|
public static function skinsFromJson(): array
|
||||||
{
|
{
|
||||||
$skins = [];
|
$skins = [];
|
||||||
$json = json_decode(file_get_contents(__DIR__ . "/../data/skins.json"), true);
|
$json = json_decode(file_get_contents(__DIR__ . "/../data/".SKIN_LANGUAGE.".json"), true);
|
||||||
|
|
||||||
foreach ($json as $skin) {
|
foreach ($json as $skin) {
|
||||||
$skins[(int) $skin['weapon_defindex']][(int) $skin['paint']] = [
|
$skins[(int) $skin['weapon_defindex']][(int) $skin['paint']] = [
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Berlin 2019 диамантена монета",
|
"name": "Berlin 2019 диамантена монета",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 звезда за операция „Разбита мрежа“",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 звезди за операция „Разбита мрежа“",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 звезди за операция „Разбита мрежа“",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Медал за служба 2020",
|
"name": "Медал за служба 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Диамантена монета от операция „Счупен зъб“",
|
"name": "Диамантена монета от операция „Счупен зъб“",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 звезда за операция „Счупен зъб“",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 звезди за операция „Счупен зъб“",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 звезди за операция „Счупен зъб“",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Медал за служба 2021",
|
"name": "Медал за служба 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Диамантена монета от операция „Коварно течение“",
|
"name": "Диамантена монета от операция „Коварно течение“",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 звезда за операция „Коварно течение“",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 звезди за операция „Коварно течение“",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 звезди за операция „Коварно течение“",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Stockholm 2021 монета",
|
"name": "Stockholm 2021 монета",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Diamantová mince šampionátu StarLadder Berlin 2019",
|
"name": "Diamantová mince šampionátu StarLadder Berlin 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 hvězda operace Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 hvězd operace Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 hvězd operace Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Medaile Za zásluhy (2020)",
|
"name": "Medaile Za zásluhy (2020)",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Diamantová mince za operaci Broken Fang",
|
"name": "Diamantová mince za operaci Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 hvězda operace Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 hvězd operace Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 hvězd operace Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Medaile Za zásluhy (2021)",
|
"name": "Medaile Za zásluhy (2021)",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Diamantová mince za operaci Riptide",
|
"name": "Diamantová mince za operaci Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 hvězda operace Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 hvězd operace Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 hvězd operace Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Mince šampionátu PGL Stockholm 2021",
|
"name": "Mince šampionátu PGL Stockholm 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Diamantmønt: Berlin 2019",
|
"name": "Diamantmønt: Berlin 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 stjerne til Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 stjerner til Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 stjerner til Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Tjenestemedalje 2020",
|
"name": "Tjenestemedalje 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Diamantmønt | Operation Broken Fang",
|
"name": "Diamantmønt | Operation Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 stjerne til Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 stjerner til Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 stjerner til Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Tjenestemedalje 2021",
|
"name": "Tjenestemedalje 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Diamantmønt | Operation Riptide",
|
"name": "Diamantmønt | Operation Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 stjerne til Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 stjerner til Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 stjerner til Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Mønt: Stockholm 2021",
|
"name": "Mønt: Stockholm 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Diamantmünze – Berlin 2019",
|
"name": "Diamantmünze – Berlin 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 Stern für Operation Zerfetztes Netz",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 Sterne für Operation Zerfetztes Netz",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 Sterne für Operation Zerfetztes Netz",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Verdienstmedaille 2020",
|
"name": "Verdienstmedaille 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Diamantmünze der Operation Zerbrochener Reißzahn",
|
"name": "Diamantmünze der Operation Zerbrochener Reißzahn",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 Stern für Operation Zerbrochener Reißzahn",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 Stern für Operation Zerbrochener Reißzahn",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 Stern für Operation Zerbrochener Reißzahn",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Verdienstmedaille 2021",
|
"name": "Verdienstmedaille 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Diamantmünze der Operation Springflut",
|
"name": "Diamantmünze der Operation Springflut",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 Stern für Operation Springflut",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 Sterne für Operation Springflut",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 Sterne für Operation Springflut",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Münze – Stockholm 2021",
|
"name": "Münze – Stockholm 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Διαμαντένιο νόμισμα Βερολίνο 2019",
|
"name": "Διαμαντένιο νόμισμα Βερολίνο 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 Αστέρι για Επιχείρηση Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 Αστέρια για Επιχείρηση Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 Αστέρια για την Επιχείρηση Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Μετάλλιο υπηρεσίας 2020",
|
"name": "Μετάλλιο υπηρεσίας 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Διαμαντένιο νόμισμα επιχείρησης Broken Fang",
|
"name": "Διαμαντένιο νόμισμα επιχείρησης Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 αστέρι για επιχείρηση Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 αστέρια για επιχείρηση Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 αστέρια για επιχείρηση Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Μετάλλιο Υπηρεσίας 2021",
|
"name": "Μετάλλιο Υπηρεσίας 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Διαμαντένιο νόμισμα Επιχείρησης Riptide",
|
"name": "Διαμαντένιο νόμισμα Επιχείρησης Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 Αστέρι για την Επιχείρηση Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 Αστέρια για την Επιχείρηση Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 Αστέρια για την Επιχείρηση Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Νόμισμα Στοκχόλμη 2021",
|
"name": "Νόμισμα Στοκχόλμη 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Berlin 2019 Diamond Coin",
|
"name": "Berlin 2019 Diamond Coin",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 Star for Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 Stars for Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 Stars for Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "2020 Service Medal",
|
"name": "2020 Service Medal",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Diamond Operation Broken Fang Coin",
|
"name": "Diamond Operation Broken Fang Coin",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 Star for Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 Stars for Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 Stars for Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "2021 Service Medal",
|
"name": "2021 Service Medal",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Diamond Operation Riptide Coin",
|
"name": "Diamond Operation Riptide Coin",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 Star for Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 Stars for Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 Stars for Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Stockholm 2021 Coin",
|
"name": "Stockholm 2021 Coin",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Moneda de diamante de Berlín 2019",
|
"name": "Moneda de diamante de Berlín 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 estrella de la Operación Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 estrellas de la Operación Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 estrellas de la Operación Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Medalla de Servicio de 2020",
|
"name": "Medalla de Servicio de 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Moneda de diamante de la Operación Broken Fang",
|
"name": "Moneda de diamante de la Operación Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 estrella de la Operación Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 estrellas de la Operación Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 estrellas de la Operación Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Medalla de Servicio de 2021",
|
"name": "Medalla de Servicio de 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Moneda de diamante de la Operación Riptide",
|
"name": "Moneda de diamante de la Operación Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 estrella de la Operación Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 estrellas de la Operación Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 estrellas de la Operación Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Moneda de Estocolmo 2021",
|
"name": "Moneda de Estocolmo 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Moneda de diamante de Berlín 2019",
|
"name": "Moneda de diamante de Berlín 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 estrella de la Operación Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 estrellas de la Operación Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 estrellas de la Operación Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Medalla de Servicio de 2020",
|
"name": "Medalla de Servicio de 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Moneda de diamante de la Operación Broken Fang",
|
"name": "Moneda de diamante de la Operación Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 estrella de la Operación Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 estrellas de la Operación Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 estrellas de la Operación Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Medalla de servicio del 2021",
|
"name": "Medalla de servicio del 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Moneda de diamante de la Operación Riptide",
|
"name": "Moneda de diamante de la Operación Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 estrella de la Operación Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 estrellas de la Operación Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 estrellas de la Operación Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Moneda de Estocolmo 2021",
|
"name": "Moneda de Estocolmo 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Berliini 2019 -timanttikolikko",
|
"name": "Berliini 2019 -timanttikolikko",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 tähti Operaatio Pirstaleiselle verkolle",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 tähteä Operaatio Pirstaleiselle verkolle",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 tähteä Operaatio Pirstaleiselle verkolle",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Palvelusmitali 2020",
|
"name": "Palvelusmitali 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Timanttinen Operaatio Katkennut torahammas -kolikko",
|
"name": "Timanttinen Operaatio Katkennut torahammas -kolikko",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 tähti – Operaatio Katkennut torahammas",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 tähteä – Operaatio Katkennut torahammas",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 tähteä – Operaatio Katkennut torahammas",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Palvelusmitali 2021",
|
"name": "Palvelusmitali 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Timanttinen Operaatio Ristiaallokko -kolikko",
|
"name": "Timanttinen Operaatio Ristiaallokko -kolikko",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 tähti – Operaatio Ristiaallokko",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 tähteä – Operaatio Ristiaallokko",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 tähteä – Operaatio Ristiaallokko",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Tukholma 2021 -kolikko",
|
"name": "Tukholma 2021 -kolikko",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Insigne en diamant de Berlin 2019",
|
"name": "Insigne en diamant de Berlin 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 étoile pour l'Opération Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 étoiles pour l'Opération Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 étoiles pour l'Opération Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Médaille de service 2020",
|
"name": "Médaille de service 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Insigne en diamant de l'Opération Broken Fang",
|
"name": "Insigne en diamant de l'Opération Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "Opération Broken Fang : 1 étoile",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "Opération Broken Fang : 10 étoiles",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "Opération Broken Fang : 100 étoiles",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Médaille de service 2021",
|
"name": "Médaille de service 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Insigne en diamant de l'Opération Riptide",
|
"name": "Insigne en diamant de l'Opération Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "Opération Riptide : 1 étoile",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "Opération Riptide : 10 étoiles",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "Opération Riptide : 100 étoiles",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Insigne de Stockholm 2021",
|
"name": "Insigne de Stockholm 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Berlin 2019 Gyémánt Érme",
|
"name": "Berlin 2019 Gyémánt Érme",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 csillag az Operation Shattered Webhez",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 csillag az Operation Shattered Webhez",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 csillag az Operation Shattered Webhez",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "2020-as Szolgálati Érdemérem",
|
"name": "2020-as Szolgálati Érdemérem",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Gyémánt Operation Broken Fang Érem",
|
"name": "Gyémánt Operation Broken Fang Érem",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 csillag az Operation Broken Fanghez",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 csillag az Operation Broken Fanghez",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 csillag az Operation Broken Fanghez",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "2021-es Szolgálati Érdemérem",
|
"name": "2021-es Szolgálati Érdemérem",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Gyémánt Operation Riptide Érem",
|
"name": "Gyémánt Operation Riptide Érem",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 csillag az Operation Riptide-hoz",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 csillag az Operation Riptide-hoz",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 csillag az Operation Riptide-hoz",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Stockholm 2021 Érme",
|
"name": "Stockholm 2021 Érme",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Gettone di diamante di Berlino 2019",
|
"name": "Gettone di diamante di Berlino 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 Stella per l'Operazione Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 Stelle per l'Operazione Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 Stelle per l'Operazione Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Medaglia al merito di servizio (2020)",
|
"name": "Medaglia al merito di servizio (2020)",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Gettone diamante dell'Operazione Broken Fang",
|
"name": "Gettone diamante dell'Operazione Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 Stella per l'Operazione Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 Stelle per l'Operazione Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 Stelle per l'Operazione Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Medaglia al merito di servizio (2021)",
|
"name": "Medaglia al merito di servizio (2021)",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Gettone diamante dell'Operazione Riptide",
|
"name": "Gettone diamante dell'Operazione Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 Stella per l'Operazione Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 Stelle per l'Operazione Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 Stelle per l'Operazione Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Gettone di Stoccolma 2021",
|
"name": "Gettone di Stoccolma 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Berlin 2019 ダイヤモンドコイン",
|
"name": "Berlin 2019 ダイヤモンドコイン",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "Operation Shattered Web スター x 1",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "Operation Shattered Web スター x 10",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "Operation Shattered Web スター x 100",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "2020 従軍メダル",
|
"name": "2020 従軍メダル",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Operation Broken Fang ダイヤモンドコイン",
|
"name": "Operation Broken Fang ダイヤモンドコイン",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "Operation Broken Fang スター x 1",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "Operation Broken Fang スター x 10",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "Operation Broken Fang スター x 100",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "2021 従軍メダル",
|
"name": "2021 従軍メダル",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Operation Riptide ダイヤモンドコイン",
|
"name": "Operation Riptide ダイヤモンドコイン",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "Operation Riptide スター x 1",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "Operation Riptide スター x 10",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "Operation Riptide スター x 100",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Stockholm 2021 コイン",
|
"name": "Stockholm 2021 コイン",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "베를린 2019 다이아몬드 주화",
|
"name": "베를린 2019 다이아몬드 주화",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "파괴 망 작전 별 1개",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "파괴 망 작전 별 10개",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "파괴 망 작전 별 100개",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "2020년 무공 훈장",
|
"name": "2020년 무공 훈장",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "브로큰 팽 작전 다이아몬드 주화",
|
"name": "브로큰 팽 작전 다이아몬드 주화",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "브로큰 팽 작전 별 1개",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "브로큰 팽 작전 별 10개",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "브로큰 팽 작전 별 100개",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "2021년 무공 훈장",
|
"name": "2021년 무공 훈장",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "립타이드 작전 다이아몬드 주화",
|
"name": "립타이드 작전 다이아몬드 주화",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "립타이드 작전 별 1개",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "립타이드 작전 별 10개",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "립타이드 작전 별 100개",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "스톡홀름 2021 주화",
|
"name": "스톡홀름 2021 주화",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Diamanten Berlin 2019-munt",
|
"name": "Diamanten Berlin 2019-munt",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 ster voor Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 sterren voor Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 sterren voor Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Dienstmedaille 2020",
|
"name": "Dienstmedaille 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Diamanten Operation Broken Fang-munt",
|
"name": "Diamanten Operation Broken Fang-munt",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 ster voor Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 sterren voor Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 sterren voor Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Dienstmedaille 2021",
|
"name": "Dienstmedaille 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Diamanten Operation Riptide-munt",
|
"name": "Diamanten Operation Riptide-munt",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 ster voor Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 sterren voor Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 sterren voor Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Stockholm 2021-munt",
|
"name": "Stockholm 2021-munt",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Diamantmynt for Berlin 2019",
|
"name": "Diamantmynt for Berlin 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 stjerne til Operasjon Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 stjerner til Operasjon Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 stjerner til Operasjon Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Tjenestemedalje 2020",
|
"name": "Tjenestemedalje 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Diamantmynt for Operasjon Broken Fang",
|
"name": "Diamantmynt for Operasjon Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 stjerne til Operasjon Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 stjerner til Operasjon Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 stjerner til Operasjon Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Tjenestemedalje 2021",
|
"name": "Tjenestemedalje 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Diamantmynt for Operasjon Riptide",
|
"name": "Diamantmynt for Operasjon Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 stjerne til Operasjon Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 stjerner til Operasjon Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 stjerner til Operasjon Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Mynt for Stockholm 2021",
|
"name": "Mynt for Stockholm 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Diamentowy żeton StarLadder Berlin 2019",
|
"name": "Diamentowy żeton StarLadder Berlin 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 gwiazda dla operacji Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 gwiazd dla operacji Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 gwiazd dla operacji Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Medal za Służbę w 2020",
|
"name": "Medal za Służbę w 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Diamentowy żeton operacji Broken Fang",
|
"name": "Diamentowy żeton operacji Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 gwiazda dla operacji Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 gwiazd dla operacji Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 gwiazd dla operacji Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Medal za Służbę w 2021",
|
"name": "Medal za Służbę w 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Diamentowy żeton operacji Riptide",
|
"name": "Diamentowy żeton operacji Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 gwiazda dla operacji Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 gwiazd dla operacji Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 gwiazd dla operacji Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Żeton PGL Stockholm 2021",
|
"name": "Żeton PGL Stockholm 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Moeda de Diamante do Berlim 2019",
|
"name": "Moeda de Diamante do Berlim 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 estrela da Operação Teia Fragmentada",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 estrelas da Operação Teia Fragmentada",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 estrelas da Operação Teia Fragmentada",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Medalha de Serviço de 2020",
|
"name": "Medalha de Serviço de 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Moeda de Diamante da Op. Presa Quebrada",
|
"name": "Moeda de Diamante da Op. Presa Quebrada",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 estrela da Operação Presa Quebrada",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 estrelas da Operação Presa Quebrada",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 estrelas da Operação Presa Quebrada",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Medalha de Serviço de 2021",
|
"name": "Medalha de Serviço de 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Moeda de Diamante da Op. Correnteza",
|
"name": "Moeda de Diamante da Op. Correnteza",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 estrela da Operação Correnteza",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 estrelas da Operação Correnteza",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 estrelas da Operação Correnteza",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Moeda do Estocolmo 2021",
|
"name": "Moeda do Estocolmo 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Moeda de Diamante de Berlim 2019",
|
"name": "Moeda de Diamante de Berlim 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 Estrela - Operação Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 Estrelas - Operação Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 Estrelas - Operação Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Medalha de Serviço de 2020",
|
"name": "Medalha de Serviço de 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Moeda de Diamante da Operação Broken Fang",
|
"name": "Moeda de Diamante da Operação Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 Estrela - Operação Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 Estrelas - Operação Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 Estrelas - Operação Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Medalha de Serviço de 2021",
|
"name": "Medalha de Serviço de 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Moeda de Diamante da Operação Riptide",
|
"name": "Moeda de Diamante da Operação Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 Estrela - Operação Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 Estrelas - Operação Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 Estrelas - Operação Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Moeda de Estocolmo 2021",
|
"name": "Moeda de Estocolmo 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Berlin 2019 - Monedă de diamant",
|
"name": "Berlin 2019 - Monedă de diamant",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 stea pentru operațiunea Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 stele pentru operațiunea Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 de stele pentru operațiunea Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Medalie de merit 2020",
|
"name": "Medalie de merit 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Monedă de diamant – Operațiunea Broken Fang",
|
"name": "Monedă de diamant – Operațiunea Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 stea pentru operațiunea Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 stele pentru operațiunea Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 de stele pentru operațiunea Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Medalie de merit 2021",
|
"name": "Medalie de merit 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Monedă de diamant – Operațiunea Riptide",
|
"name": "Monedă de diamant – Operațiunea Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 stea pentru operațiunea Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 stele pentru operațiunea Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 stele pentru operațiunea Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Moneda Stockholm 2021",
|
"name": "Moneda Stockholm 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Бриллиантовая монета StarLadder Berlin 2019",
|
"name": "Бриллиантовая монета StarLadder Berlin 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 звезда операции «Расколотая сеть»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 звёзд операции «Расколотая сеть»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 звёзд операции «Расколотая сеть»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Медаль за службу в 2020",
|
"name": "Медаль за службу в 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Бриллиантовая монета операции «Сломанный клык»",
|
"name": "Бриллиантовая монета операции «Сломанный клык»",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 звезда операции «Сломанный клык»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 звёзд операции «Сломанный клык»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 звёзд операции «Сломанный клык»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Медаль за службу в 2021",
|
"name": "Медаль за службу в 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Бриллиантовая монета операции «Хищные воды»",
|
"name": "Бриллиантовая монета операции «Хищные воды»",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 звезда операции «Хищные воды»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 звёзд операции «Хищные воды»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 звёзд операции «Хищные воды»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Монета PGL Major Stockholm 2021",
|
"name": "Монета PGL Major Stockholm 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Diamantmynt för Berlin 2019",
|
"name": "Diamantmynt för Berlin 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 stjärna för Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 stjärnor för Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 stjärnor för Operation Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "2020 års tjänstemedalj",
|
"name": "2020 års tjänstemedalj",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Diamantmynt för Operation Broken Fang",
|
"name": "Diamantmynt för Operation Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 stjärna för Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 stjärnor för Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 stjärnor för Operation Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "2021 års tjänstemedalj",
|
"name": "2021 års tjänstemedalj",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Diamantmynt för Operation Riptide",
|
"name": "Diamantmynt för Operation Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 stjärna för Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 stjärnor för Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 stjärnor för Operation Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Stockholm 2021-mynt",
|
"name": "Stockholm 2021-mynt",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "เหรียญเพชร Berlin 2019",
|
"name": "เหรียญเพชร Berlin 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 ดาวสำหรับปฏิบัติการ Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 ดาวสำหรับปฏิบัติการ Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 ดาวสำหรับปฏิบัติการ Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "เหรียญรางวัลบริการ 2020",
|
"name": "เหรียญรางวัลบริการ 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "เหรียญเพชรปฏิบัติการ Broken Fang",
|
"name": "เหรียญเพชรปฏิบัติการ Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 ดาวสำหรับปฏิบัติการ Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 ดาวสำหรับปฏิบัติการ Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 ดาวสำหรับปฏิบัติการ Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "เหรียญรางวัลบริการ 2021",
|
"name": "เหรียญรางวัลบริการ 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "เหรียญเพชรปฏิบัติการ Riptide",
|
"name": "เหรียญเพชรปฏิบัติการ Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 ดาวสำหรับปฏิบัติการ Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 ดาวสำหรับปฏิบัติการ Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 ดาวสำหรับปฏิบัติการ Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "เหรียญ Stockholm 2021",
|
"name": "เหรียญ Stockholm 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Berlin 2019 Pırlanta Jetonu",
|
"name": "Berlin 2019 Pırlanta Jetonu",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "Parçalanmış Ağ Operasyonu İçin 1 Yıldız",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "Parçalanmış Ağ Operasyonu İçin 10 Yıldız",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "Parçalanmış Ağ Operasyonu İçin 100 Yıldız",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "2020 Hizmet Madalyası",
|
"name": "2020 Hizmet Madalyası",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Elmas Kırık Diş Operasyonu Jetonu",
|
"name": "Elmas Kırık Diş Operasyonu Jetonu",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "Kırık Diş Operasyonu için 1 yıldız",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "Kırık Diş Operasyonu için 10 yıldız",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "Kırık Diş Operasyonu için 100 yıldız",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "2021 Hizmet Madalyası",
|
"name": "2021 Hizmet Madalyası",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Elmas Girdap Operasyonu Jetonu",
|
"name": "Elmas Girdap Operasyonu Jetonu",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "Girdap Operasyonu için 1 Yıldız",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "Girdap Operasyonu için 10 Yıldız",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "Girdap Operasyonu için 100 Yıldız",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Stockholm 2021 Jetonu",
|
"name": "Stockholm 2021 Jetonu",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Діамантова монета «Берлін 2019»",
|
"name": "Діамантова монета «Берлін 2019»",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 зірка для операції «Розірвана мережа»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 зірок для операції «Розірвана мережа»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 зірок для операції «Розірвана мережа»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Медаль за службу 2020",
|
"name": "Медаль за службу 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Діамантова монета учасника операції «Зламане ікло»",
|
"name": "Діамантова монета учасника операції «Зламане ікло»",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 зірка для операції «Зламане ікло»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 зірок для операції «Зламане ікло»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 зірок для операції «Зламане ікло»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Медаль за службу 2021",
|
"name": "Медаль за службу 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Діамантова монета учасника операції «Хижі води»",
|
"name": "Діамантова монета учасника операції «Хижі води»",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 зірка для операції «Хижі води»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 зірок для операції «Хижі води»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 зірок для операції «Хижі води»",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Монета «Стокгольм 2021»",
|
"name": "Монета «Стокгольм 2021»",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Huy chương kim cương Berlin 2019",
|
"name": "Huy chương kim cương Berlin 2019",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 sao cho chiến dịch Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 sao cho chiến dịch Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 sao cho chiến dịch Shattered Web",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "Huy chương phục vụ 2020",
|
"name": "Huy chương phục vụ 2020",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "Huy chương kim cương chiến dịch Broken Fang",
|
"name": "Huy chương kim cương chiến dịch Broken Fang",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 sao cho chiến dịch Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 sao cho chiến dịch Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 sao cho chiến dịch Broken Fang",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "Huy chương phục vụ 2021",
|
"name": "Huy chương phục vụ 2021",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "Huy chương kim cương chiến dịch Riptide",
|
"name": "Huy chương kim cương chiến dịch Riptide",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1 sao cho chiến dịch Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 sao cho chiến dịch Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 sao cho chiến dịch Riptide",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Huy chương Stockholm 2021",
|
"name": "Huy chương Stockholm 2021",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "柏林 2019 钻石硬币",
|
"name": "柏林 2019 钻石硬币",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1颗用于“裂网大行动”的大行动之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10颗用于“裂网大行动”的大行动之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100颗用于“裂网大行动”的大行动之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "2020 年服役勋章",
|
"name": "2020 年服役勋章",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "“狂牙大行动”钻石币",
|
"name": "“狂牙大行动”钻石币",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1颗用于“狂牙大行动”的大行动之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10颗用于“狂牙大行动”的大行动之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100颗用于“狂牙大行动”的大行动之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "2021 年服役勋章",
|
"name": "2021 年服役勋章",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "“激流大行动”钻石币",
|
"name": "“激流大行动”钻石币",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "1颗用于“激流大行动”的大行动之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10颗用于“激流大行动”的大行动之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100颗用于“激流大行动”的大行动之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "斯德哥尔摩 2021 硬币",
|
"name": "斯德哥尔摩 2021 硬币",
|
||||||
|
|||||||
@@ -1274,21 +1274,6 @@
|
|||||||
"name": "Berlin 2019 鑽石幣",
|
"name": "Berlin 2019 鑽石幣",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4626.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4671",
|
|
||||||
"name": "1 顆《裂網行動》之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4671.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4672",
|
|
||||||
"name": "10 顆《裂網行動》之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4672.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4673",
|
|
||||||
"name": "100 顆《裂網行動》之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4673.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4674",
|
"id": "4674",
|
||||||
"name": "2020 年服役勳章",
|
"name": "2020 年服役勳章",
|
||||||
@@ -1394,21 +1379,6 @@
|
|||||||
"name": "「狂牙行動」鑽石幣",
|
"name": "「狂牙行動」鑽石幣",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4703.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4704",
|
|
||||||
"name": "1 顆「狂牙行動」之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4704.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4705",
|
|
||||||
"name": "10 顆「狂牙行動」之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4705.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4706",
|
|
||||||
"name": "100 顆「狂牙行動」之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4706.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4737",
|
"id": "4737",
|
||||||
"name": "2021 年服役勳章",
|
"name": "2021 年服役勳章",
|
||||||
@@ -1459,21 +1429,6 @@
|
|||||||
"name": "《猛潮行動》鑽石幣",
|
"name": "《猛潮行動》鑽石幣",
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4762.png"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"id": "4763",
|
|
||||||
"name": "一顆《猛潮行動》的行動之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4763.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4764",
|
|
||||||
"name": "10 顆《猛潮行動》的行動之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4764.png"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": "4765",
|
|
||||||
"name": "100 顆《猛潮行動》的行動之星",
|
|
||||||
"image": "https://raw.githubusercontent.com/Nereziel/cs2-WeaponPaints/main/website/img/skins/collectible-4765.png"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"id": "4797",
|
"id": "4797",
|
||||||
"name": "Stockholm 2021 硬幣",
|
"name": "Stockholm 2021 硬幣",
|
||||||
|
|||||||
12539
website/data/skins.json
Normal file
12539
website/data/skins.json
Normal file
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user