diff --git a/[core]/mercyv-garage/client/main.lua b/[core]/mercyv-garage/client/main.lua index e80a9d38..d0a6e814 100644 --- a/[core]/mercyv-garage/client/main.lua +++ b/[core]/mercyv-garage/client/main.lua @@ -385,6 +385,7 @@ RegisterNetEvent('mercyv-garage:receiveVehicles', function(vehicles, garageId) vehClass = v.vehClass or 0, carname = displayName, carimage = displayName, + modelname = v.modelname or '', }) end diff --git a/[core]/mercyv-garage/nui/images/cars/Gt500.png b/[core]/mercyv-garage/nui/images/cars/Gt500.png deleted file mode 100644 index 20891bbe..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Gt500.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Habanero.png b/[core]/mercyv-garage/nui/images/cars/Habanero.png deleted file mode 100644 index 64ffdbce..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Habanero.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Hakuchou.png b/[core]/mercyv-garage/nui/images/cars/Hakuchou.png deleted file mode 100644 index 9049a81f..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Hakuchou.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Hellion.png b/[core]/mercyv-garage/nui/images/cars/Hellion.png deleted file mode 100644 index e95224e3..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Hellion.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Hermes.png b/[core]/mercyv-garage/nui/images/cars/Hermes.png deleted file mode 100644 index 8183e519..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Hermes.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Hexer.png b/[core]/mercyv-garage/nui/images/cars/Hexer.png deleted file mode 100644 index 4f4924c6..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Hexer.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Hotknife.png b/[core]/mercyv-garage/nui/images/cars/Hotknife.png deleted file mode 100644 index 61e239eb..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Hotknife.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Hotring.png b/[core]/mercyv-garage/nui/images/cars/Hotring.png deleted file mode 100644 index 1b741a1a..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Hotring.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Huntley.png b/[core]/mercyv-garage/nui/images/cars/Huntley.png deleted file mode 100644 index 7aa85114..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Huntley.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Hustler.png b/[core]/mercyv-garage/nui/images/cars/Hustler.png deleted file mode 100644 index 9767eae2..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Hustler.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Imorgon.png b/[core]/mercyv-garage/nui/images/cars/Imorgon.png deleted file mode 100644 index 584816cb..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Imorgon.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Impaler.png b/[core]/mercyv-garage/nui/images/cars/Impaler.png deleted file mode 100644 index 19af636a..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Impaler.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Impaler2.png b/[core]/mercyv-garage/nui/images/cars/Impaler2.png deleted file mode 100644 index 13350e57..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Impaler2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Impaler3.png b/[core]/mercyv-garage/nui/images/cars/Impaler3.png deleted file mode 100644 index bfe898b8..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Impaler3.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Impaler4.png b/[core]/mercyv-garage/nui/images/cars/Impaler4.png deleted file mode 100644 index 66241944..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Impaler4.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Imperator.png b/[core]/mercyv-garage/nui/images/cars/Imperator.png deleted file mode 100644 index 75a7114c..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Imperator.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Imperator2.png b/[core]/mercyv-garage/nui/images/cars/Imperator2.png deleted file mode 100644 index 9d3dfd80..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Imperator2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Infernus.png b/[core]/mercyv-garage/nui/images/cars/Infernus.png deleted file mode 100644 index 93708078..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Infernus.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Infernus2.png b/[core]/mercyv-garage/nui/images/cars/Infernus2.png deleted file mode 100644 index 3de042c5..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Infernus2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Ingot.png b/[core]/mercyv-garage/nui/images/cars/Ingot.png deleted file mode 100644 index 7163d108..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Ingot.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Innovation.png b/[core]/mercyv-garage/nui/images/cars/Innovation.png deleted file mode 100644 index a8d14fca..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Innovation.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Intruder.png b/[core]/mercyv-garage/nui/images/cars/Intruder.png deleted file mode 100644 index f7d78344..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Intruder.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Issi2.png b/[core]/mercyv-garage/nui/images/cars/Issi2.png deleted file mode 100644 index 6f73d434..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Issi2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Issi3.png b/[core]/mercyv-garage/nui/images/cars/Issi3.png deleted file mode 100644 index 7804ca7a..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Issi3.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Issi4.png b/[core]/mercyv-garage/nui/images/cars/Issi4.png deleted file mode 100644 index 8acd4ceb..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Issi4.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Issi7.png b/[core]/mercyv-garage/nui/images/cars/Issi7.png deleted file mode 100644 index f4ae783c..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Issi7.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Italigtb.png b/[core]/mercyv-garage/nui/images/cars/Italigtb.png deleted file mode 100644 index 064b70e0..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Italigtb.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Italigtb2.png b/[core]/mercyv-garage/nui/images/cars/Italigtb2.png deleted file mode 100644 index 5e2226ce..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Italigtb2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Italigto.png b/[core]/mercyv-garage/nui/images/cars/Italigto.png deleted file mode 100644 index 58e17332..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Italigto.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Jackal.png b/[core]/mercyv-garage/nui/images/cars/Jackal.png deleted file mode 100644 index adcb6fed..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Jackal.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Jb700.png b/[core]/mercyv-garage/nui/images/cars/Jb700.png deleted file mode 100644 index 751bac3f..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Jb700.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Jb7002.png b/[core]/mercyv-garage/nui/images/cars/Jb7002.png deleted file mode 100644 index 4deca4eb..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Jb7002.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Jester.png b/[core]/mercyv-garage/nui/images/cars/Jester.png deleted file mode 100644 index 946298a4..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Jester.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Jester2.png b/[core]/mercyv-garage/nui/images/cars/Jester2.png deleted file mode 100644 index 87c10d06..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Jester2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Jugular.png b/[core]/mercyv-garage/nui/images/cars/Jugular.png deleted file mode 100644 index d15d8d85..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Jugular.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Kalahari.png b/[core]/mercyv-garage/nui/images/cars/Kalahari.png deleted file mode 100644 index 85d95be5..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Kalahari.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Kamacho.png b/[core]/mercyv-garage/nui/images/cars/Kamacho.png deleted file mode 100644 index bd97ea8f..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Kamacho.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Kanjo.png b/[core]/mercyv-garage/nui/images/cars/Kanjo.png deleted file mode 100644 index 9d8a8eea..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Kanjo.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Khamelion.png b/[core]/mercyv-garage/nui/images/cars/Khamelion.png deleted file mode 100644 index 7078435d..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Khamelion.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Komoda.png b/[core]/mercyv-garage/nui/images/cars/Komoda.png deleted file mode 100644 index 5fde3594..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Komoda.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Krieger.png b/[core]/mercyv-garage/nui/images/cars/Krieger.png deleted file mode 100644 index 51c136b7..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Krieger.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Kuruma.png b/[core]/mercyv-garage/nui/images/cars/Kuruma.png deleted file mode 100644 index 5dbb5276..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Kuruma.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Landstalker.png b/[core]/mercyv-garage/nui/images/cars/Landstalker.png deleted file mode 100644 index a0dcad73..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Landstalker.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Landstalker2.png b/[core]/mercyv-garage/nui/images/cars/Landstalker2.png deleted file mode 100644 index 129c9be5..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Landstalker2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Le7b.png b/[core]/mercyv-garage/nui/images/cars/Le7b.png deleted file mode 100644 index 61d6ad78..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Le7b.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Lectro.png b/[core]/mercyv-garage/nui/images/cars/Lectro.png deleted file mode 100644 index 5778f2d9..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Lectro.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Locust.png b/[core]/mercyv-garage/nui/images/cars/Locust.png deleted file mode 100644 index 66e57d5a..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Locust.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Lurcher.png b/[core]/mercyv-garage/nui/images/cars/Lurcher.png deleted file mode 100644 index ed2e59b3..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Lurcher.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Lynx.png b/[core]/mercyv-garage/nui/images/cars/Lynx.png deleted file mode 100644 index 5aaae99f..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Lynx.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Mamba.png b/[core]/mercyv-garage/nui/images/cars/Mamba.png deleted file mode 100644 index b2ac0fc2..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Mamba.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Manana.png b/[core]/mercyv-garage/nui/images/cars/Manana.png deleted file mode 100644 index 64007625..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Manana.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Manana2.png b/[core]/mercyv-garage/nui/images/cars/Manana2.png deleted file mode 100644 index e97295e3..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Manana2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Massacro.png b/[core]/mercyv-garage/nui/images/cars/Massacro.png deleted file mode 100644 index eaaf108b..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Massacro.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Massacro2.png b/[core]/mercyv-garage/nui/images/cars/Massacro2.png deleted file mode 100644 index c4e4e91c..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Massacro2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Michelli.png b/[core]/mercyv-garage/nui/images/cars/Michelli.png deleted file mode 100644 index d280c4b9..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Michelli.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Monroe.png b/[core]/mercyv-garage/nui/images/cars/Monroe.png deleted file mode 100644 index 9eec4839..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Monroe.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Moonbeam.png b/[core]/mercyv-garage/nui/images/cars/Moonbeam.png deleted file mode 100644 index 969ca280..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Moonbeam.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Nebula.png b/[core]/mercyv-garage/nui/images/cars/Nebula.png deleted file mode 100644 index 4a5b9ec0..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Nebula.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Nemesis.png b/[core]/mercyv-garage/nui/images/cars/Nemesis.png deleted file mode 100644 index c59fadb7..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Nemesis.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Neo.png b/[core]/mercyv-garage/nui/images/cars/Neo.png deleted file mode 100644 index 108f5988..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Neo.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Neon.png b/[core]/mercyv-garage/nui/images/cars/Neon.png deleted file mode 100644 index 0214c261..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Neon.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Nero.png b/[core]/mercyv-garage/nui/images/cars/Nero.png deleted file mode 100644 index 12eab663..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Nero.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Nero2.png b/[core]/mercyv-garage/nui/images/cars/Nero2.png deleted file mode 100644 index c9902036..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Nero2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Nightblade.png b/[core]/mercyv-garage/nui/images/cars/Nightblade.png deleted file mode 100644 index 67bfe7c4..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Nightblade.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Nightshade.png b/[core]/mercyv-garage/nui/images/cars/Nightshade.png deleted file mode 100644 index 0efcd6f4..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Nightshade.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Ninef.png b/[core]/mercyv-garage/nui/images/cars/Ninef.png deleted file mode 100644 index fa0cd5cf..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Ninef.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Ninef2.png b/[core]/mercyv-garage/nui/images/cars/Ninef2.png deleted file mode 100644 index 73d18d90..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Ninef2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Novak.png b/[core]/mercyv-garage/nui/images/cars/Novak.png deleted file mode 100644 index 0a62f0ee..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Novak.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Omnis.png b/[core]/mercyv-garage/nui/images/cars/Omnis.png deleted file mode 100644 index 23517f6d..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Omnis.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Oppressor.png b/[core]/mercyv-garage/nui/images/cars/Oppressor.png deleted file mode 100644 index a1c186ae..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Oppressor.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Oracle2.png b/[core]/mercyv-garage/nui/images/cars/Oracle2.png deleted file mode 100644 index f928314f..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Oracle2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Osiris.png b/[core]/mercyv-garage/nui/images/cars/Osiris.png deleted file mode 100644 index e2a11f27..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Osiris.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Outlaw.png b/[core]/mercyv-garage/nui/images/cars/Outlaw.png deleted file mode 100644 index 0b7591e1..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Outlaw.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Panto.png b/[core]/mercyv-garage/nui/images/cars/Panto.png deleted file mode 100644 index faa86236..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Panto.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Paragon.png b/[core]/mercyv-garage/nui/images/cars/Paragon.png deleted file mode 100644 index c4cc7446..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Paragon.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Paragon2.png b/[core]/mercyv-garage/nui/images/cars/Paragon2.png deleted file mode 100644 index a5f3a0d4..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Paragon2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Pariah.png b/[core]/mercyv-garage/nui/images/cars/Pariah.png deleted file mode 100644 index 51d9d34c..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Pariah.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Patriot.png b/[core]/mercyv-garage/nui/images/cars/Patriot.png deleted file mode 100644 index 992114fb..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Patriot.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Patriot2.png b/[core]/mercyv-garage/nui/images/cars/Patriot2.png deleted file mode 100644 index 753f2086..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Patriot2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Pcj.png b/[core]/mercyv-garage/nui/images/cars/Pcj.png deleted file mode 100644 index 59707c52..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Pcj.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Penetrator.png b/[core]/mercyv-garage/nui/images/cars/Penetrator.png deleted file mode 100644 index 638fcdd0..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Penetrator.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Penumbra.png b/[core]/mercyv-garage/nui/images/cars/Penumbra.png deleted file mode 100644 index 25d65ac4..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Penumbra.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Penumbra2.png b/[core]/mercyv-garage/nui/images/cars/Penumbra2.png deleted file mode 100644 index f3760406..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Penumbra2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Peyote.png b/[core]/mercyv-garage/nui/images/cars/Peyote.png deleted file mode 100644 index 94069903..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Peyote.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Peyote2.png b/[core]/mercyv-garage/nui/images/cars/Peyote2.png deleted file mode 100644 index 9e4ef149..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Peyote2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Pfister811.png b/[core]/mercyv-garage/nui/images/cars/Pfister811.png deleted file mode 100644 index 6036327c..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Pfister811.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Phoenix.png b/[core]/mercyv-garage/nui/images/cars/Phoenix.png deleted file mode 100644 index 93dee990..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Phoenix.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Pigalle.png b/[core]/mercyv-garage/nui/images/cars/Pigalle.png deleted file mode 100644 index 44301d3a..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Pigalle.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Prairie.png b/[core]/mercyv-garage/nui/images/cars/Prairie.png deleted file mode 100644 index 71616e27..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Prairie.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Premier.png b/[core]/mercyv-garage/nui/images/cars/Premier.png deleted file mode 100644 index 7bec001b..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Premier.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Primo.png b/[core]/mercyv-garage/nui/images/cars/Primo.png deleted file mode 100644 index 07267e39..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Primo.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Primo2.png b/[core]/mercyv-garage/nui/images/cars/Primo2.png deleted file mode 100644 index 0b63f5a9..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Primo2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Radi.png b/[core]/mercyv-garage/nui/images/cars/Radi.png deleted file mode 100644 index 3e4008cb..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Radi.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Raiden.png b/[core]/mercyv-garage/nui/images/cars/Raiden.png deleted file mode 100644 index 132ee3f0..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Raiden.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Rancherxl.png b/[core]/mercyv-garage/nui/images/cars/Rancherxl.png deleted file mode 100644 index 7546cd6a..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Rancherxl.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Rapidgt.png b/[core]/mercyv-garage/nui/images/cars/Rapidgt.png deleted file mode 100644 index 760daccd..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Rapidgt.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Rapidgt2.png b/[core]/mercyv-garage/nui/images/cars/Rapidgt2.png deleted file mode 100644 index 17c46142..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Rapidgt2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Rapidgt3.png b/[core]/mercyv-garage/nui/images/cars/Rapidgt3.png deleted file mode 100644 index aab51669..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Rapidgt3.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Raptor.png b/[core]/mercyv-garage/nui/images/cars/Raptor.png deleted file mode 100644 index 8cc1d6b7..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Raptor.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Ratbike.png b/[core]/mercyv-garage/nui/images/cars/Ratbike.png deleted file mode 100644 index 4b090fba..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Ratbike.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Reaper.png b/[core]/mercyv-garage/nui/images/cars/Reaper.png deleted file mode 100644 index 15790b3a..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Reaper.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Rebel2.png b/[core]/mercyv-garage/nui/images/cars/Rebel2.png deleted file mode 100644 index 727c96ce..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Rebel2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Rebla.png b/[core]/mercyv-garage/nui/images/cars/Rebla.png deleted file mode 100644 index 8ba4f682..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Rebla.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Regina.png b/[core]/mercyv-garage/nui/images/cars/Regina.png deleted file mode 100644 index 3ae28afe..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Regina.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Rentalbus.png b/[core]/mercyv-garage/nui/images/cars/Rentalbus.png deleted file mode 100644 index c6985785..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Rentalbus.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Retinue.png b/[core]/mercyv-garage/nui/images/cars/Retinue.png deleted file mode 100644 index 080dd33e..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Retinue.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Retinue2.png b/[core]/mercyv-garage/nui/images/cars/Retinue2.png deleted file mode 100644 index 4c10b52c..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Retinue2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Revolter.png b/[core]/mercyv-garage/nui/images/cars/Revolter.png deleted file mode 100644 index 84100e33..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Revolter.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Rhapsody.png b/[core]/mercyv-garage/nui/images/cars/Rhapsody.png deleted file mode 100644 index 3b878784..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Rhapsody.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Riata.png b/[core]/mercyv-garage/nui/images/cars/Riata.png deleted file mode 100644 index be8d93d5..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Riata.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Rocoto.png b/[core]/mercyv-garage/nui/images/cars/Rocoto.png deleted file mode 100644 index 6e6f6b98..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Rocoto.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Ruffian.png b/[core]/mercyv-garage/nui/images/cars/Ruffian.png deleted file mode 100644 index 3ffdf948..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Ruffian.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Ruiner2.png b/[core]/mercyv-garage/nui/images/cars/Ruiner2.png deleted file mode 100644 index 67899ec3..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Ruiner2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Ruston.png b/[core]/mercyv-garage/nui/images/cars/Ruston.png deleted file mode 100644 index 883d7b54..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Ruston.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/S80.png b/[core]/mercyv-garage/nui/images/cars/S80.png deleted file mode 100644 index 80cd6463..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/S80.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sabregt.png b/[core]/mercyv-garage/nui/images/cars/Sabregt.png deleted file mode 100644 index e5ec47ab..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sabregt.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sabregt2.png b/[core]/mercyv-garage/nui/images/cars/Sabregt2.png deleted file mode 100644 index d9c485cb..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sabregt2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sadler.png b/[core]/mercyv-garage/nui/images/cars/Sadler.png deleted file mode 100644 index 364738f2..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sadler.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sadler2.png b/[core]/mercyv-garage/nui/images/cars/Sadler2.png deleted file mode 100644 index 3e1152e5..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sadler2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sanchez.png b/[core]/mercyv-garage/nui/images/cars/Sanchez.png deleted file mode 100644 index b24e0fae..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sanchez.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sanctus.png b/[core]/mercyv-garage/nui/images/cars/Sanctus.png deleted file mode 100644 index c84ce1da..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sanctus.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sandking.png b/[core]/mercyv-garage/nui/images/cars/Sandking.png deleted file mode 100644 index 41adc2f2..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sandking.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Savestra.png b/[core]/mercyv-garage/nui/images/cars/Savestra.png deleted file mode 100644 index 7bfb5cc0..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Savestra.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sc1.png b/[core]/mercyv-garage/nui/images/cars/Sc1.png deleted file mode 100644 index f3276c95..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sc1.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Schafter2.png b/[core]/mercyv-garage/nui/images/cars/Schafter2.png deleted file mode 100644 index 2f013f07..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Schafter2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Schlagen.png b/[core]/mercyv-garage/nui/images/cars/Schlagen.png deleted file mode 100644 index dacc6269..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Schlagen.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Schwarzer.png b/[core]/mercyv-garage/nui/images/cars/Schwarzer.png deleted file mode 100644 index 1aae965a..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Schwarzer.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Seminole.png b/[core]/mercyv-garage/nui/images/cars/Seminole.png deleted file mode 100644 index a50218cb..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Seminole.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sentinel2.png b/[core]/mercyv-garage/nui/images/cars/Sentinel2.png deleted file mode 100644 index 6bffe369..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sentinel2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Serrano.png b/[core]/mercyv-garage/nui/images/cars/Serrano.png deleted file mode 100644 index 89648e0a..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Serrano.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Seven70.png b/[core]/mercyv-garage/nui/images/cars/Seven70.png deleted file mode 100644 index 4f3be04b..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Seven70.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Shotaro.png b/[core]/mercyv-garage/nui/images/cars/Shotaro.png deleted file mode 100644 index 4ceacec3..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Shotaro.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sovereign.png b/[core]/mercyv-garage/nui/images/cars/Sovereign.png deleted file mode 100644 index a3211237..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sovereign.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Specter.png b/[core]/mercyv-garage/nui/images/cars/Specter.png deleted file mode 100644 index b4ba1048..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Specter.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Specter2.png b/[core]/mercyv-garage/nui/images/cars/Specter2.png deleted file mode 100644 index 49c85ecd..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Specter2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Stafford.png b/[core]/mercyv-garage/nui/images/cars/Stafford.png deleted file mode 100644 index 91051d80..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Stafford.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Stalion.png b/[core]/mercyv-garage/nui/images/cars/Stalion.png deleted file mode 100644 index da6e13fd..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Stalion.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Stalion2.png b/[core]/mercyv-garage/nui/images/cars/Stalion2.png deleted file mode 100644 index c38f5397..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Stalion2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Stanier.png b/[core]/mercyv-garage/nui/images/cars/Stanier.png deleted file mode 100644 index 67a68a86..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Stanier.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Stinger.png b/[core]/mercyv-garage/nui/images/cars/Stinger.png deleted file mode 100644 index ab3159ba..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Stinger.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Stingergt.png b/[core]/mercyv-garage/nui/images/cars/Stingergt.png deleted file mode 100644 index 45fc718d..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Stingergt.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Streiter.png b/[core]/mercyv-garage/nui/images/cars/Streiter.png deleted file mode 100644 index db4b924f..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Streiter.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Stretch.png b/[core]/mercyv-garage/nui/images/cars/Stretch.png deleted file mode 100644 index 0b160adb..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Stretch.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Stromberg.png b/[core]/mercyv-garage/nui/images/cars/Stromberg.png deleted file mode 100644 index 61b2dcd2..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Stromberg.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sugoi.png b/[core]/mercyv-garage/nui/images/cars/Sugoi.png deleted file mode 100644 index 46ffa0a2..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sugoi.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sultan.png b/[core]/mercyv-garage/nui/images/cars/Sultan.png deleted file mode 100644 index 22769b68..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sultan.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sultan2.png b/[core]/mercyv-garage/nui/images/cars/Sultan2.png deleted file mode 100644 index 6fab0d49..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sultan2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Sultanrs.png b/[core]/mercyv-garage/nui/images/cars/Sultanrs.png deleted file mode 100644 index f68a5710..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Sultanrs.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Superd.png b/[core]/mercyv-garage/nui/images/cars/Superd.png deleted file mode 100644 index acf6779f..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Superd.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Surano.png b/[core]/mercyv-garage/nui/images/cars/Surano.png deleted file mode 100644 index 019962a6..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Surano.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Surge.png b/[core]/mercyv-garage/nui/images/cars/Surge.png deleted file mode 100644 index c77c4c93..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Surge.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Swinger.png b/[core]/mercyv-garage/nui/images/cars/Swinger.png deleted file mode 100644 index 16000e84..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Swinger.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/T20.png b/[core]/mercyv-garage/nui/images/cars/T20.png deleted file mode 100644 index e3c64270..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/T20.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Tailgater.png b/[core]/mercyv-garage/nui/images/cars/Tailgater.png deleted file mode 100644 index 1a793ff6..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Tailgater.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Taipan.png b/[core]/mercyv-garage/nui/images/cars/Taipan.png deleted file mode 100644 index add8810a..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Taipan.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Tampa.png b/[core]/mercyv-garage/nui/images/cars/Tampa.png deleted file mode 100644 index 48cc44ae..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Tampa.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Tempesta.png b/[core]/mercyv-garage/nui/images/cars/Tempesta.png deleted file mode 100644 index d5227cea..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Tempesta.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Tezeract.png b/[core]/mercyv-garage/nui/images/cars/Tezeract.png deleted file mode 100644 index f9581f4a..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Tezeract.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Thrax.png b/[core]/mercyv-garage/nui/images/cars/Thrax.png deleted file mode 100644 index cf4c57ad..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Thrax.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Thrust.png b/[core]/mercyv-garage/nui/images/cars/Thrust.png deleted file mode 100644 index 67c7b330..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Thrust.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Tigon.png b/[core]/mercyv-garage/nui/images/cars/Tigon.png deleted file mode 100644 index a6848de0..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Tigon.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Torero.png b/[core]/mercyv-garage/nui/images/cars/Torero.png deleted file mode 100644 index be94b4cd..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Torero.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Tornado.png b/[core]/mercyv-garage/nui/images/cars/Tornado.png deleted file mode 100644 index 889f2f29..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Tornado.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/Toros.png b/[core]/mercyv-garage/nui/images/cars/Toros.png deleted file mode 100644 index 0c67964e..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/Toros.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/noimage.png b/[core]/mercyv-garage/nui/images/cars/noimage.png deleted file mode 100644 index 46dfad72..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/noimage.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/cars/porschepanemara.png b/[core]/mercyv-garage/nui/images/cars/porschepanemara.png deleted file mode 100644 index 93e1c32d..00000000 Binary files a/[core]/mercyv-garage/nui/images/cars/porschepanemara.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/category.png b/[core]/mercyv-garage/nui/images/category.png deleted file mode 100644 index c202382e..00000000 Binary files a/[core]/mercyv-garage/nui/images/category.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/close.png b/[core]/mercyv-garage/nui/images/close.png deleted file mode 100644 index 71777bb5..00000000 Binary files a/[core]/mercyv-garage/nui/images/close.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/defaultimage.png b/[core]/mercyv-garage/nui/images/defaultimage.png deleted file mode 100644 index 3b794ce6..00000000 Binary files a/[core]/mercyv-garage/nui/images/defaultimage.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/#U00d6verfl#U00f6d.png b/[core]/mercyv-garage/nui/images/logo/#U00d6verfl#U00f6d.png deleted file mode 100644 index a6db9374..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/#U00d6verfl#U00f6d.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Albany.png b/[core]/mercyv-garage/nui/images/logo/Albany.png deleted file mode 100644 index 216ae4d1..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Albany.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Annis.png b/[core]/mercyv-garage/nui/images/logo/Annis.png deleted file mode 100644 index a23af75e..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Annis.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/B#U00fcrgerfahrzeug.png b/[core]/mercyv-garage/nui/images/logo/B#U00fcrgerfahrzeug.png deleted file mode 100644 index 3bc6475a..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/B#U00fcrgerfahrzeug.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/BF.png b/[core]/mercyv-garage/nui/images/logo/BF.png deleted file mode 100644 index 99d8f15d..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/BF.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Benefactor.png b/[core]/mercyv-garage/nui/images/logo/Benefactor.png deleted file mode 100644 index ce1efb72..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Benefactor.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Bollokan.png b/[core]/mercyv-garage/nui/images/logo/Bollokan.png deleted file mode 100644 index bfe0b419..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Bollokan.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Bravado.png b/[core]/mercyv-garage/nui/images/logo/Bravado.png deleted file mode 100644 index 6e38f237..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Bravado.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Brute.png b/[core]/mercyv-garage/nui/images/logo/Brute.png deleted file mode 100644 index 4af696b5..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Brute.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Buckingham.png b/[core]/mercyv-garage/nui/images/logo/Buckingham.png deleted file mode 100644 index 37029a2d..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Buckingham.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Canis.png b/[core]/mercyv-garage/nui/images/logo/Canis.png deleted file mode 100644 index b8715529..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Canis.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Chariot.png b/[core]/mercyv-garage/nui/images/logo/Chariot.png deleted file mode 100644 index 02cd51fa..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Chariot.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Cheval.png b/[core]/mercyv-garage/nui/images/logo/Cheval.png deleted file mode 100644 index b8b8b80d..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Cheval.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Classique.png b/[core]/mercyv-garage/nui/images/logo/Classique.png deleted file mode 100644 index 04057f1d..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Classique.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Coil.png b/[core]/mercyv-garage/nui/images/logo/Coil.png deleted file mode 100644 index 49ca240a..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Coil.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Custom.png b/[core]/mercyv-garage/nui/images/logo/Custom.png deleted file mode 100644 index b8715529..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Custom.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/DUDE-Logo.png b/[core]/mercyv-garage/nui/images/logo/DUDE-Logo.png deleted file mode 100644 index a94fcbc2..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/DUDE-Logo.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Declasse.png b/[core]/mercyv-garage/nui/images/logo/Declasse.png deleted file mode 100644 index 193bea53..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Declasse.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Dewbauchee.png b/[core]/mercyv-garage/nui/images/logo/Dewbauchee.png deleted file mode 100644 index 6156dd4c..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Dewbauchee.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Dinka.png b/[core]/mercyv-garage/nui/images/logo/Dinka.png deleted file mode 100644 index ae0de4d9..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Dinka.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Dundreary.png b/[core]/mercyv-garage/nui/images/logo/Dundreary.png deleted file mode 100644 index 1fac4ce3..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Dundreary.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Emperor.png b/[core]/mercyv-garage/nui/images/logo/Emperor.png deleted file mode 100644 index 30d7eea3..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Emperor.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Enus.png b/[core]/mercyv-garage/nui/images/logo/Enus.png deleted file mode 100644 index 8603f684..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Enus.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Fathom.png b/[core]/mercyv-garage/nui/images/logo/Fathom.png deleted file mode 100644 index 81e634ff..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Fathom.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Gallivanter.png b/[core]/mercyv-garage/nui/images/logo/Gallivanter.png deleted file mode 100644 index 6d058ae0..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Gallivanter.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Grotti.png b/[core]/mercyv-garage/nui/images/logo/Grotti.png deleted file mode 100644 index 803eddfc..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Grotti.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/HVY.png b/[core]/mercyv-garage/nui/images/logo/HVY.png deleted file mode 100644 index 625eb30f..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/HVY.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Hijak.png b/[core]/mercyv-garage/nui/images/logo/Hijak.png deleted file mode 100644 index b3c40670..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Hijak.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Imponte.png b/[core]/mercyv-garage/nui/images/logo/Imponte.png deleted file mode 100644 index 62d422f6..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Imponte.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Invetero.png b/[core]/mercyv-garage/nui/images/logo/Invetero.png deleted file mode 100644 index b885726a..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Invetero.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Jack Sheepe.png b/[core]/mercyv-garage/nui/images/logo/Jack Sheepe.png deleted file mode 100644 index 5185b8ff..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Jack Sheepe.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/JackSheepe.png b/[core]/mercyv-garage/nui/images/logo/JackSheepe.png deleted file mode 100644 index cac15dc5..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/JackSheepe.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Jobuilt.png b/[core]/mercyv-garage/nui/images/logo/Jobuilt.png deleted file mode 100644 index 7a1a0a92..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Jobuilt.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Karin.png b/[core]/mercyv-garage/nui/images/logo/Karin.png deleted file mode 100644 index e16212a4..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Karin.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/LCC.png b/[core]/mercyv-garage/nui/images/logo/LCC.png deleted file mode 100644 index c40c6c9a..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/LCC.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/LCS.png b/[core]/mercyv-garage/nui/images/logo/LCS.png deleted file mode 100644 index d0acde3c..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/LCS.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Lampadati.png b/[core]/mercyv-garage/nui/images/logo/Lampadati.png deleted file mode 100644 index 52fd417a..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Lampadati.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Liberty Chop Shop.png b/[core]/mercyv-garage/nui/images/logo/Liberty Chop Shop.png deleted file mode 100644 index 22e57644..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Liberty Chop Shop.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Liberty City Cycles.png b/[core]/mercyv-garage/nui/images/logo/Liberty City Cycles.png deleted file mode 100644 index c5c4f6d8..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Liberty City Cycles.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/MTL.png b/[core]/mercyv-garage/nui/images/logo/MTL.png deleted file mode 100644 index ccd1e48d..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/MTL.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Maibatsu Corporation.png b/[core]/mercyv-garage/nui/images/logo/Maibatsu Corporation.png deleted file mode 100644 index bff2249b..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Maibatsu Corporation.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Maibatsu.png b/[core]/mercyv-garage/nui/images/logo/Maibatsu.png deleted file mode 100644 index b928ded0..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Maibatsu.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Mammoth.png b/[core]/mercyv-garage/nui/images/logo/Mammoth.png deleted file mode 100644 index 0b6d022c..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Mammoth.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Maxwell.png b/[core]/mercyv-garage/nui/images/logo/Maxwell.png deleted file mode 100644 index 43a1f649..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Maxwell.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Nagasaki.png b/[core]/mercyv-garage/nui/images/logo/Nagasaki.png deleted file mode 100644 index 510fe0f2..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Nagasaki.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Obey.png b/[core]/mercyv-garage/nui/images/logo/Obey.png deleted file mode 100644 index b64c1bea..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Obey.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Ocelot.png b/[core]/mercyv-garage/nui/images/logo/Ocelot.png deleted file mode 100644 index 167d306b..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Ocelot.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Overflod.png b/[core]/mercyv-garage/nui/images/logo/Overflod.png deleted file mode 100644 index 0a0e5a35..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Overflod.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Pegassi.png b/[core]/mercyv-garage/nui/images/logo/Pegassi.png deleted file mode 100644 index 6a1d4c91..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Pegassi.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Pfister.png b/[core]/mercyv-garage/nui/images/logo/Pfister.png deleted file mode 100644 index ef66fb93..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Pfister.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Principe.png b/[core]/mercyv-garage/nui/images/logo/Principe.png deleted file mode 100644 index 2404d16e..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Principe.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/ProLaps.png b/[core]/mercyv-garage/nui/images/logo/ProLaps.png deleted file mode 100644 index 187fbd03..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/ProLaps.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Progen.png b/[core]/mercyv-garage/nui/images/logo/Progen.png deleted file mode 100644 index 6715be84..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Progen.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/RUNE.png b/[core]/mercyv-garage/nui/images/logo/RUNE.png deleted file mode 100644 index 54facf62..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/RUNE.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Schyster.png b/[core]/mercyv-garage/nui/images/logo/Schyster.png deleted file mode 100644 index 8aaa860c..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Schyster.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Shitzu.png b/[core]/mercyv-garage/nui/images/logo/Shitzu.png deleted file mode 100644 index 5b252c2a..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Shitzu.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Speedophile.png b/[core]/mercyv-garage/nui/images/logo/Speedophile.png deleted file mode 100644 index 3dd01785..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Speedophile.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Stanley.png b/[core]/mercyv-garage/nui/images/logo/Stanley.png deleted file mode 100644 index 26ab099d..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Stanley.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Steel Horse.png b/[core]/mercyv-garage/nui/images/logo/Steel Horse.png deleted file mode 100644 index 368b247f..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Steel Horse.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/SteelHorse.png b/[core]/mercyv-garage/nui/images/logo/SteelHorse.png deleted file mode 100644 index 40e63a9f..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/SteelHorse.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Truffade.png b/[core]/mercyv-garage/nui/images/logo/Truffade.png deleted file mode 100644 index c09bfe2f..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Truffade.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Vapid.png b/[core]/mercyv-garage/nui/images/logo/Vapid.png deleted file mode 100644 index ca53a240..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Vapid.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Vulcar.png b/[core]/mercyv-garage/nui/images/logo/Vulcar.png deleted file mode 100644 index b4b857a2..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Vulcar.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Vysser.png b/[core]/mercyv-garage/nui/images/logo/Vysser.png deleted file mode 100644 index 7cde65a5..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Vysser.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/WMC.png b/[core]/mercyv-garage/nui/images/logo/WMC.png deleted file mode 100644 index 3af5ed8a..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/WMC.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Weeny.png b/[core]/mercyv-garage/nui/images/logo/Weeny.png deleted file mode 100644 index 2a60d244..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Weeny.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Western Motorcycle Company.png b/[core]/mercyv-garage/nui/images/logo/Western Motorcycle Company.png deleted file mode 100644 index ab97689a..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Western Motorcycle Company.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Western.png b/[core]/mercyv-garage/nui/images/logo/Western.png deleted file mode 100644 index 39ea89cf..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Western.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/WesternCompany.png b/[core]/mercyv-garage/nui/images/logo/WesternCompany.png deleted file mode 100644 index 39ea89cf..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/WesternCompany.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Willard.png b/[core]/mercyv-garage/nui/images/logo/Willard.png deleted file mode 100644 index e0b9f604..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Willard.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/Zirconium.png b/[core]/mercyv-garage/nui/images/logo/Zirconium.png deleted file mode 100644 index 1c4a9be8..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/Zirconium.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/ambulance.png b/[core]/mercyv-garage/nui/images/logo/ambulance.png deleted file mode 100644 index 6a01298d..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/ambulance.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/bennys.png b/[core]/mercyv-garage/nui/images/logo/bennys.png deleted file mode 100644 index fedb1c0b..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/bennys.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/bmv.png b/[core]/mercyv-garage/nui/images/logo/bmv.png deleted file mode 100644 index f54326ec..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/bmv.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/ems.png b/[core]/mercyv-garage/nui/images/logo/ems.png deleted file mode 100644 index 6a01298d..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/ems.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/logo.png b/[core]/mercyv-garage/nui/images/logo/logo.png deleted file mode 100644 index ea282444..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/logo.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/lscustom.png b/[core]/mercyv-garage/nui/images/logo/lscustom.png deleted file mode 100644 index 17115eb1..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/lscustom.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/lscustoms.png b/[core]/mercyv-garage/nui/images/logo/lscustoms.png deleted file mode 100644 index 17115eb1..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/lscustoms.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/police.png b/[core]/mercyv-garage/nui/images/logo/police.png deleted file mode 100644 index b762c293..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/police.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/police2.png b/[core]/mercyv-garage/nui/images/logo/police2.png deleted file mode 100644 index b762c293..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/police2.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/ubermacht.png b/[core]/mercyv-garage/nui/images/logo/ubermacht.png deleted file mode 100644 index 2f55db2f..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/ubermacht.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/uebermacht.png b/[core]/mercyv-garage/nui/images/logo/uebermacht.png deleted file mode 100644 index 6c05cba5..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/uebermacht.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/logo/unmarked.png b/[core]/mercyv-garage/nui/images/logo/unmarked.png deleted file mode 100644 index 980a98cd..00000000 Binary files a/[core]/mercyv-garage/nui/images/logo/unmarked.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/images/rectangle.png b/[core]/mercyv-garage/nui/images/rectangle.png deleted file mode 100644 index 855956e0..00000000 Binary files a/[core]/mercyv-garage/nui/images/rectangle.png and /dev/null differ diff --git a/[core]/mercyv-garage/nui/index.html b/[core]/mercyv-garage/nui/index.html deleted file mode 100644 index 00d64de0..00000000 --- a/[core]/mercyv-garage/nui/index.html +++ /dev/null @@ -1,319 +0,0 @@ - - - - - - MercyV Garage - - - - - - - -
- - -
-
- - -
-
-
- MercyV -
-
- MercyV Garage - {{ garageId || 'Garage' }} -
-
-
-
{{ playerName }}
- -
-
- - -
- - -
-
- Alle -
-
- Autos -
-
- Moto -
-
- Bikes -
-
- Boote -
-
- Flug -
-
-
- Favoriten -
-
-
- Admin -
-
- - -
- - -
-
- - -
-
- Abholgebühr: {{ impoundPrice }}$ -
-
- - -
- - -
-
-
- {{ v.nearby ? 'In der Nähe' : v.stored===0 ? 'Draußen' : 'Eingelagert' }} -
- -
{{ v.carname }}
-
{{ v.plate }}
-
- -
-
-
- -

Keine Fahrzeuge

-
-
- - -
-
- -
-
{{ selectedVehicle.carname }}
-
{{ selectedVehicle.plate }}
-
{{ selectedVehicle.parking }}
-
- - {{ selectedVehicle.stored===0 ? 'Aktuell draußen' : 'Eingelagert' }} -
- - -
- Fahrzeug ist draußen -
-
- - {{ selectedVehicle.favorite===1 ? 'Favorit entfernen' : 'Zu Favoriten' }} -
-
- -
-
-
-
-
- - -
-
- -
-
-
- -
-
- Garage Editor - Admin Tool -
-
-
- - -
-
- -
- -
-
- Garagen ({{ adminGarages.length }}) -
-
-
-
- -
-
-
{{ g.label }}
-
{{ g.type }}
-
-
- - -
-
-
-
- -
-
-
- {{ editingGarage._isNew ? 'Neue Garage erstellen' : 'Bearbeiten: ' + editingGarage.label }} -
- -
-
-
-
Basis
-
-
- - -
-
- - -
-
- - -
-
- - -
-
- - -
-
- - -
-
-
-
-
- Positionen - Position aufsuchen → "Hier erfassen" → E drücken -
-
-
{{ pos.label }}
-
- - - - -
- -
-
- - -
-
- Job-Fahrzeuge - GTA-Modellname z.B. police3, ambulance -
-
-
- {{ v.model }} - -
-
- Noch keine Fahrzeuge eingetragen -
-
-
- - -
-
- -
-
- -
- -

Garage auswählen oder neue erstellen

-
- -
-
-
- - -
-
- -

Garage löschen?

-

{{ deleteConfirmId }} wird permanent entfernt.

-
- - -
-
-
- - -
-
- -

Position erfassen

-

{{ getFieldLabel(capturingField) }}

-

Geh zur Position → E drücken

-

ESC = Abbrechen

-
-
- -
- - - - diff --git a/[core]/mercyv-garage/nui/script.js b/[core]/mercyv-garage/nui/script.js deleted file mode 100644 index cd98b75b..00000000 --- a/[core]/mercyv-garage/nui/script.js +++ /dev/null @@ -1,230 +0,0 @@ -const app = new Vue({ - el: '#app', - data: { - show: false, showAdminPanel: false, isAdmin: false, - garageId: null, garageType: 'normal', - playerName: '', avatar: 'images/defaultimage.png', - vehicles: [], activeTab: 'all', showFavorites: false, - searchQuery: '', - selectedVehicle: null, selectedIndex: null, - impound: false, impoundPrice: 1500, - adminGarages: [], editingGarage: null, - deleteConfirmId: null, capturingField: null, - windowWidth: window.innerWidth, - posFields: [ - { field: 'npc', label: 'NPC Position', hasHeading: true }, - { field: 'spawn', label: 'Spawn Position (Fahrzeug erscheint)', hasHeading: true }, - { field: 'park', label: 'Einpark-Zone (Marker am Boden)', hasHeading: false }, - ], - jobVehicles: [], // Fahrzeuge für die aktuelle Jobgarage - newJobVehicle: '', // Eingabe: neues Modell - }, - - computed: { - filteredVehicles() { - return this.vehicles.filter(v => { - if (this.showFavorites && v.favorite != 1) return false; - if (this.searchQuery) { - const q = this.searchQuery.toLowerCase(); - if (!v.carname.toLowerCase().includes(q) && !v.plate.toLowerCase().includes(q)) return false; - } - const cls = v.vehClass || 0; - if (this.activeTab === 'cars') return ![8,13,14,15,16].includes(cls); - if (this.activeTab === 'motor') return cls === 8; - if (this.activeTab === 'bikes') return cls === 13; - if (this.activeTab === 'boat') return cls === 14; - if (this.activeTab === 'aircraft') return cls === 15 || cls === 16; - return true; - }); - } - }, - - methods: { - close() { - this.show = false; this.showAdminPanel = false; - this.selectedVehicle = null; - $.post(`https://${GetParentResourceName()}/close`, JSON.stringify({})); - }, - setTab(tab) { - this.activeTab = tab; this.showFavorites = false; - this.selectedVehicle = null; this.selectedIndex = null; - }, - toggleFavorites() { - this.showFavorites = !this.showFavorites; - this.selectedVehicle = null; this.selectedIndex = null; - }, - selectVehicle(v, index) { - this.selectedVehicle = v; this.selectedIndex = index; - $.post(`https://${GetParentResourceName()}/previewVehicle`, JSON.stringify({ modelname: v.modelname, props: v.props })); - }, - takeOut() { - if (!this.selectedVehicle) return; - $.post(`https://${GetParentResourceName()}/takeOut`, JSON.stringify({ - plate: this.selectedVehicle.plate, - vehClass: this.selectedVehicle.vehClass || 0, - })); - // close() aufrufen damit SetNuiFocus(false) auf Lua-Seite läuft - this.close(); - }, - - parkFromPanel() { - if (!this.selectedVehicle || !this.selectedVehicle.nearby) return; - $.post(`https://${GetParentResourceName()}/parkFromPanel`, JSON.stringify({ plate: this.selectedVehicle.plate })); - }, - - parkJobVehicle() { - if (!this.selectedVehicle || !this.selectedVehicle.nearby) return; - $.post(`https://${GetParentResourceName()}/parkJobVehicle`, JSON.stringify({ - plate: this.selectedVehicle.plate, - nearbyJobPlate: this.selectedVehicle.nearbyJobPlate || null, - })); - }, - - toggleFav(plate, current) { - const newVal = current == 1 ? 0 : 1; - $.post(`https://${GetParentResourceName()}/setFavorite`, JSON.stringify({ plate, value: newVal })); - const v = this.vehicles.find(x => x.plate === plate); - if (v) { v.favorite = newVal; if (this.selectedVehicle && this.selectedVehicle.plate === plate) this.selectedVehicle.favorite = newVal; } - }, - - // ADMIN - openAdmin() { - this.showAdminPanel = true; - this.isAdmin = true; - this.loadAdminGarages(); - }, - - openAdminFromGarage() { - // Via NUI Callback damit Lua die Kamera sauber aufräumt - $.post(`https://${GetParentResourceName()}/openAdminFromGarage`, JSON.stringify({})); - }, - closeAdmin() { - this.showAdminPanel = false; this.show = false; - $.post(`https://${GetParentResourceName()}/closeAdmin`, JSON.stringify({})); - }, - loadAdminGarages() { - $.post(`https://${GetParentResourceName()}/getAdminGarages`, JSON.stringify({}), (data) => { - try { - const d = typeof data === 'string' ? JSON.parse(data) : data; - if (Array.isArray(d) && d.length > 0) { - this.adminGarages = d.sort((a,b) => a.label.localeCompare(b.label)); - } - // Falls leer: Daten kommen via ADMIN_GARAGES message - } catch(e) {} - }); - }, - newGarage() { - this.editingGarage = { _isNew: true, id:'', label:'', type:'normal', access:'none', gang:'none', npc_model:'a_m_m_prolhost_01', blip_show:1, blip_show_bool:true, blip_type:357, blip_colour:3, npc_x:0,npc_y:0,npc_z:0,npc_heading:0, spawn_x:0,spawn_y:0,spawn_z:0,spawn_heading:0, park_x:0,park_y:0,park_z:0,park_heading:0 }; - this.jobVehicles = []; - }, - editGarage(g) { - this.editingGarage = Object.assign({ _isNew: false, blip_show_bool: g.blip_show == 1 }, g); - // Job-Fahrzeuge laden falls Jobgarage - if (g.type === 'jobgarage') { - this.jobVehicles = g.job_vehicles ? [...g.job_vehicles] : []; - } else { - this.jobVehicles = []; - } - }, - confirmDelete(id) { this.deleteConfirmId = id; }, - deleteGarage() { - if (!this.deleteConfirmId) return; - $.post(`https://${GetParentResourceName()}/adminDeleteGarage`, JSON.stringify({ id: this.deleteConfirmId })); - this.adminGarages = this.adminGarages.filter(g => g.id !== this.deleteConfirmId); - if (this.editingGarage && this.editingGarage.id === this.deleteConfirmId) this.editingGarage = null; - this.deleteConfirmId = null; - }, - // Job-Fahrzeug hinzufügen - addJobVehicle() { - const model = this.newJobVehicle.trim().toLowerCase(); - if (!model) return; - if (!this.jobVehicles.find(v => v.model === model)) { - this.jobVehicles.push({ model, label: model.toUpperCase() }); - } - this.newJobVehicle = ''; - }, - removeJobVehicle(index) { - this.jobVehicles.splice(index, 1); - }, - saveGarage() { - const g = this.editingGarage; - if (!g) return; - if (!g.id || !g.id.trim()) { return; } - if (!g.label || !g.label.trim()) { return; } - g.id = g.id.trim().replace(/\s+/g,'_'); - const payload = Object.assign({}, g); - delete payload._isNew; delete payload.blip_show_bool; - payload.blip_show = g.blip_show_bool ? 1 : 0; - if (g.type === 'jobgarage') { - payload.job_vehicles = this.jobVehicles; - } - $.post(`https://${GetParentResourceName()}/adminSaveGarage`, JSON.stringify(payload)); - const i = this.adminGarages.findIndex(x => x.id === payload.id); - if (i >= 0) this.adminGarages.splice(i, 1, payload); else this.adminGarages.push(payload); - this.adminGarages.sort((a,b) => a.label.localeCompare(b.label)); - this.editingGarage._isNew = false; - }, - teleportTo(g) { $.post(`https://${GetParentResourceName()}/teleportToGarage`, JSON.stringify({ x:g.npc_x, y:g.npc_y, z:g.npc_z, heading:g.npc_heading })); }, - capturePos(field) { - this.capturingField = field; - $.post(`https://${GetParentResourceName()}/startCapture`, JSON.stringify({ field })); - }, - getFieldLabel(field) { - const l = { npc:'NPC Position', spawn:'Spawn Position', park:'Einpark-Zone' }; - return l[field] || field; - }, - getTypeIcon(type) { - const m = { normal:'fas fa-car', aircraft:'fas fa-plane', boat:'fas fa-ship', jobgarage:'fas fa-briefcase', impound:'fas fa-lock', impoundboat:'fas fa-ship', impoundplane:'fas fa-plane' }; - return m[type] || 'fas fa-warehouse'; - }, - applyCapture(field, x, y, z, heading) { - if (!this.editingGarage) return; - this.editingGarage[field+'_x'] = x; - this.editingGarage[field+'_y'] = y; - this.editingGarage[field+'_z'] = z; - if (heading !== undefined) this.editingGarage[field+'_heading'] = heading; - }, - } -}); - -window.addEventListener('message', function(e) { - const msg = e.data; - if (!msg || !msg.action) return; - switch(msg.action) { - case 'OPEN': - app.show = true; app.showAdminPanel = false; - app.garageId = msg.garageId; app.garageType = msg.garageType || 'normal'; - app.vehicles = msg.vehicles || []; app.playerName = msg.playerName || ''; - app.impound = msg.impound || false; app.impoundPrice = msg.impoundPrice || 1500; - app.selectedVehicle = null; app.selectedIndex = null; - app.showFavorites = false; app.searchQuery = ''; - if (msg.garageType === 'aircraft' || msg.garageType === 'impoundplane') app.activeTab = 'aircraft'; - else if (msg.garageType === 'boat' || msg.garageType === 'impoundboat') app.activeTab = 'boat'; - else app.activeTab = 'all'; - break; - case 'CLOSE': app.show = false; app.showAdminPanel = false; break; - case 'OPEN_ADMIN': - app.show = true; app.showAdminPanel = true; app.isAdmin = true; - app.loadAdminGarages(); break; - case 'SET_PROFILE': app.playerName = msg.name || ''; app.avatar = msg.avatar || 'images/defaultimage.png'; break; - case 'SET_ADMIN': app.isAdmin = msg.isAdmin || false; break; - case 'POSITION_CAPTURED': - app.capturingField = null; - if (app.editingGarage) app.applyCapture(msg.field, msg.x, msg.y, msg.z, msg.heading); - break; - case 'CAPTURE_CANCELLED': app.capturingField = null; break; - case 'ADMIN_GARAGES': - if (msg.garages) { - app.adminGarages = msg.garages.sort((a,b) => a.label.localeCompare(b.label)); - } - break; - case 'SYNC_GARAGES_DONE': if (app.showAdminPanel) app.loadAdminGarages(); break; - } -}); - -$(document).keydown(function(e) { - if (e.keyCode === 27) { - if (app.showAdminPanel) app.closeAdmin(); - else app.close(); - } -}); diff --git a/[core]/mercyv-garage/nui/style.css b/[core]/mercyv-garage/nui/style.css deleted file mode 100644 index 91bb0273..00000000 --- a/[core]/mercyv-garage/nui/style.css +++ /dev/null @@ -1,539 +0,0 @@ -@font-face { - src: url('./fonts/Gilroy-ExtraBold.otf') format("OpenType"); - font-family: "GilroyBold"; -} -@font-face { - src: url('./fonts/Gilroy-Light.otf') format("OpenType"); - font-family: "GilroyLight"; -} - -:root { - --bg-base: #111213; - --bg-modal: #18191b; - --bg-sidebar: #111213; - --bg-card: #1e2022; - --bg-card-hover:#252729; - --bg-input: #1a1c1e; - --accent: #E8830A; - --accent-hover: #F5960F; - --accent-dim: rgba(232,131,10,0.12); - --accent-dim2: rgba(232,131,10,0.22); - --text-primary: #ffffff; - --text-secondary: rgba(255,255,255,0.55); - --text-muted: rgba(255,255,255,0.25); - --border: rgba(255,255,255,0.07); - --border-hover: rgba(255,255,255,0.13); - --green: #4CAF50; - --red: #EF5350; - --blue: #42A5F5; -} - -* { box-sizing: border-box; margin: 0; padding: 0; } - -html, body { - width: 100vw; height: 100vh; - overflow: hidden; - user-select: none; - -webkit-user-select: none; - font-family: "GilroyLight", "Segoe UI", sans-serif; -} - -body { background: transparent; } - -#app { width: 100vw; height: 100vh; display: flex; align-items: center; justify-content: center; } - -/* ──────────────────── BACKDROP / MODAL ──────────────────── */ - -.mv-backdrop { - position: fixed; inset: 0; - display: flex; align-items: center; justify-content: center; - background: rgba(0,0,0,0.55); - backdrop-filter: blur(2px); -} - -.mv-backdrop-transparent { - position: fixed; inset: 0; - display: flex; align-items: center; justify-content: center; - background: transparent; -} - -.mv-modal { - width: 1200px; - height: 760px; - background: var(--bg-modal); - border-radius: 14px; - overflow: hidden; - border: 1px solid rgba(255,255,255,0.12); - display: flex; - flex-direction: column; - box-shadow: 0 8px 40px rgba(0,0,0,0.7); -} - -.mv-modal-wide { width: 1300px; height: 800px; } - -/* ──────────────────── HEADER ──────────────────── */ - -.mv-header { - display: flex; align-items: center; justify-content: space-between; - padding: 12px 16px; - background: var(--bg-base); - border-bottom: 1px solid var(--border); - flex-shrink: 0; -} - -.mv-header-left { display: flex; align-items: center; gap: 10px; } - -.mv-header-icon { - width: 34px; height: 34px; border-radius: 8px; - background: var(--accent-dim2); - border: 1px solid rgba(232,131,10,0.3); - display: flex; align-items: center; justify-content: center; - overflow: hidden; -} - -.mv-logo-img { width: 28px; height: 28px; object-fit: contain; } -.mv-logo-fallback { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: var(--accent); font-size: 14px; } - -.mv-header-title { display: flex; flex-direction: column; gap: 1px; } -.mv-title-main { font-family: "GilroyBold", sans-serif; font-size: 16px; color: var(--text-primary); letter-spacing: 0.3px; } -.mv-title-sub { font-size: 11px; color: var(--text-muted); letter-spacing: 0.4px; text-transform: uppercase; } - -.mv-header-right { display: flex; align-items: center; gap: 10px; } -.mv-player-name { font-size: 12px; color: var(--text-secondary); } - -.mv-close-btn { - width: 28px; height: 28px; border-radius: 7px; - border: 1px solid var(--border-hover); - background: rgba(255,255,255,0.04); - color: var(--text-secondary); cursor: pointer; - display: flex; align-items: center; justify-content: center; - font-size: 11px; transition: all 0.15s; -} -.mv-close-btn:hover { background: rgba(255,255,255,0.1); color: white; } - -/* ──────────────────── BODY LAYOUT ──────────────────── */ - -.mv-body { display: flex; flex: 1; overflow: hidden; } - -/* ──────────────────── SIDEBAR ──────────────────── */ - -.mv-sidebar { - width: 175px; flex-shrink: 0; - background: var(--bg-sidebar); - border-right: 1px solid var(--border); - padding: 8px 0; - display: flex; flex-direction: column; -} - -.mv-sidebar-item { - display: flex; align-items: center; gap: 10px; - padding: 11px 16px; - cursor: pointer; - border-radius: 0; - color: var(--text-secondary); - font-size: 15px; - transition: all 0.15s; - margin: 1px 8px; - border-radius: 8px; - border-left: 2px solid transparent; -} -.mv-sidebar-item i { font-size: 16px; width: 20px; text-align: center; } -.mv-sidebar-item:hover { background: rgba(255,255,255,0.04); color: rgba(255,255,255,0.75); } - -.mv-sidebar-item.active { - background: var(--accent-dim); - border-left: 2px solid var(--accent); - color: var(--accent); - font-family: "GilroyBold", sans-serif; -} -.mv-sidebar-item.active i { color: var(--accent); } - -.mv-sidebar-item.active-fav { color: #FFD700; } -.mv-sidebar-item.active-fav i { color: #FFD700; } - -.mv-sidebar-divider { height: 1px; background: var(--border); margin: 6px 14px; } -.mv-sidebar-spacer { flex: 1; } - -.mv-admin-item { color: var(--text-muted); font-size: 11px; } -.mv-admin-item:hover { color: var(--accent); } - -/* ──────────────────── MAIN AREA ──────────────────── */ - -.mv-main { flex: 1; display: grid; grid-template-rows: auto 1fr; overflow: hidden; } -.mv-main-content { display: flex; overflow: hidden; flex: 1; } - -.mv-topbar { - display: flex; align-items: center; gap: 12px; - padding: 10px 14px; - flex-shrink: 0; -} - -.mv-search-wrap { - flex: 1; position: relative; -} -.mv-search-icon { - position: absolute; left: 10px; top: 50%; transform: translateY(-50%); - color: var(--text-muted); font-size: 11px; -} -.mv-search { - width: 100%; padding: 8px 10px 8px 28px; - background: var(--bg-input); - border: 1px solid var(--border); - border-radius: 8px; - color: var(--text-secondary); - font-size: 12px; font-family: inherit; - outline: none; transition: border 0.15s; -} -.mv-search:focus { border-color: rgba(232,131,10,0.35); } -.mv-search::placeholder { color: var(--text-muted); } - -.mv-impound-badge { - font-size: 11px; color: var(--accent); - background: var(--accent-dim); - border: 1px solid rgba(232,131,10,0.2); - padding: 5px 10px; border-radius: 6px; - white-space: nowrap; -} - -/* ──────────────────── VEHICLE GRID ──────────────────── */ - -.mv-content-row { - display: flex; flex: 1; overflow: hidden; -} - -.mv-grid { - flex: 1; overflow-y: auto; - padding: 14px; - display: grid; - grid-template-columns: repeat(4, 1fr); - gap: 12px; - align-content: start; -} -.mv-grid::-webkit-scrollbar { width: 0px; } - -.mv-card { - background: var(--bg-card); - border: 1px solid var(--border); - border-radius: 10px; - padding: 10px 8px 8px; - text-align: center; - cursor: pointer; - position: relative; - transition: all 0.15s; -} -.mv-card:hover { background: var(--bg-card-hover); border-color: var(--border-hover); transform: translateY(-1px); } -.mv-card-active { border-color: var(--accent) !important; background: var(--bg-card-hover); } - -.mv-card-status { - position: absolute; top: 6px; left: 6px; - font-size: 11px; padding: 3px 7px; border-radius: 3px; - font-family: "GilroyBold", sans-serif; letter-spacing: 0.05em; -} -.status-in { background: rgba(76,175,80,0.2); color: #81C784; border: 1px solid rgba(76,175,80,0.3); } -.status-out { background: rgba(232,131,10,0.2); color: var(--accent); border: 1px solid rgba(232,131,10,0.3); } - -.mv-card-img { width: 115px; height: 70px; object-fit: contain; margin: 8px auto 8px; display: block; } -.mv-card-name { - font-size: 14px; font-family: "GilroyBold", sans-serif; - color: var(--text-primary); margin-bottom: 2px; - white-space: nowrap; overflow: hidden; text-overflow: ellipsis; -} -.mv-card-plate { font-size: 13px; color: var(--text-muted); letter-spacing: 0.08em; } -.mv-card-fav { - position: absolute; bottom: 6px; right: 7px; - font-size: 10px; color: #FFD700; opacity: 0.7; cursor: pointer; transition: opacity 0.15s; -} -.mv-card-fav:hover { opacity: 1; } - -.mv-empty { - grid-column: 1/-1; display: flex; flex-direction: column; - align-items: center; justify-content: center; - color: var(--text-muted); gap: 8px; padding: 30px; -} -.mv-empty i { font-size: 2.5rem; } -.mv-empty p { font-size: 12px; } - -/* ──────────────────── DETAIL PANEL ──────────────────── */ - -.mv-detail { - width: 300px; flex-shrink: 0; - overflow-y: auto; padding: 16px; - display: flex; flex-direction: column; gap: 8px; - border-left: 1px solid var(--border); - background: rgba(0,0,0,0.15); -} -.mv-detail::-webkit-scrollbar { width: 0px; } - -.mv-back-btn { - align-self: flex-start; - padding: 6px 12px; - background: rgba(255,255,255,0.05); - border: 1px solid var(--border); - border-radius: 7px; - color: var(--text-secondary); - font-size: 11px; cursor: pointer; - font-family: inherit; transition: background 0.15s; -} -.mv-back-btn:hover { background: rgba(255,255,255,0.1); } - -.mv-detail-img-wrap { text-align: center; padding: 8px 0; } -.mv-detail-img { width: 160px; height: 90px; object-fit: contain; } - -.mv-detail-name { font-family: "GilroyBold", sans-serif; font-size: 22px; color: white; text-align: center; } -.mv-detail-plate { font-size: 14px; color: var(--text-secondary); text-align: center; } -.mv-detail-garage{ font-size: 13px; color: var(--text-muted); text-align: center; } - -.mv-detail-status { - text-align: center; font-size: 12px; padding: 6px 12px; - border-radius: 6px; display: inline-block; align-self: center; -} -.ds-in { background: rgba(76,175,80,0.15); color: #81C784; border: 1px solid rgba(76,175,80,0.2); } -.ds-out { background: var(--accent-dim); color: var(--accent); border: 1px solid rgba(232,131,10,0.2); } - -.mv-takeout-btn { - padding: 13px; border-radius: 8px; - background: var(--accent); border: none; - color: white; font-family: "GilroyBold", sans-serif; - font-size: 14px; cursor: pointer; letter-spacing: 0.04em; - transition: background 0.15s, transform 0.1s; -} -.mv-takeout-btn:hover { background: var(--accent-hover); } -.mv-takeout-btn:active { transform: scale(0.98); } - -.mv-already-out { - text-align: center; font-size: 11px; color: var(--text-muted); - padding: 8px; background: rgba(255,255,255,0.03); - border-radius: 6px; border: 1px solid var(--border); -} -.mv-detail-fav { - text-align: center; font-size: 11px; color: #FFD700; - cursor: pointer; opacity: 0.7; transition: opacity 0.15s; -} -.mv-detail-fav:hover { opacity: 1; } - -/* ──────────────────── ADMIN SIDEBAR ──────────────────── */ - -.mv-admin-sidebar { width: 220px; } - -.mv-admin-list { flex: 1; overflow-y: auto; } -.mv-admin-list::-webkit-scrollbar { width: 3px; } -.mv-admin-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; } - -.mv-admin-list-item { - display: flex; align-items: center; gap: 8px; - padding: 9px 12px; margin: 2px 6px; border-radius: 8px; - cursor: pointer; transition: background 0.12s; - border-left: 2px solid transparent; -} -.mv-admin-list-item:hover { background: rgba(255,255,255,0.04); } -.admin-item-active { background: var(--accent-dim) !important; border-left: 2px solid var(--accent); } - -.mv-admin-item-icon { - width: 28px; height: 28px; border-radius: 6px; - display: flex; align-items: center; justify-content: center; - font-size: 11px; flex-shrink: 0; - background: rgba(255,255,255,0.06); - color: var(--text-secondary); -} -.type-icon-normal { background: rgba(76,175,80,0.15); color: #81C784; } -.type-icon-aircraft { background: rgba(66,165,245,0.15); color: #64B5F6; } -.type-icon-boat { background: rgba(0,188,212,0.15); color: #4DD0E1; } -.type-icon-jobgarage { background: rgba(232,131,10,0.15); color: var(--accent); } -.type-icon-impound, .type-icon-impoundboat, .type-icon-impoundplane - { background: rgba(239,83,80,0.15); color: #EF9A9A; } - -.mv-admin-item-info { flex: 1; min-width: 0; } -.mv-admin-item-label { font-size: 12px; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } -.mv-admin-item-type { font-size: 10px; color: var(--text-muted); margin-top: 1px; text-transform: uppercase; letter-spacing: 0.05em; } - -.mv-admin-item-btns { display: flex; gap: 4px; opacity: 0; transition: opacity 0.12s; } -.mv-admin-list-item:hover .mv-admin-item-btns { opacity: 1; } - -.mv-icon-btn { width: 24px; height: 24px; border-radius: 5px; border: none; cursor: pointer; font-size: 9px; display: flex; align-items: center; justify-content: center; } -.mv-icon-btn-blue { background: rgba(66,165,245,0.25); color: #64B5F6; } -.mv-icon-btn-red { background: rgba(239,83,80,0.25); color: #EF9A9A; } -.mv-icon-btn:hover { opacity: 0.85; } - -/* ──────────────────── ADMIN FORM ──────────────────── */ - -.mv-admin-main { } - -.mv-btn-orange { - padding: 7px 14px; border-radius: 7px; - background: var(--accent); border: none; - color: white; font-family: "GilroyBold", sans-serif; - font-size: 11px; cursor: pointer; letter-spacing: 0.03em; - transition: background 0.15s; white-space: nowrap; - display: flex; align-items: center; gap: 5px; -} -.mv-btn-orange:hover { background: var(--accent-hover); } - -.mv-form-scroll { flex: 1; overflow-y: auto; padding: 14px; display: flex; flex-direction: column; gap: 12px; } -.mv-form-scroll::-webkit-scrollbar { width: 3px; } -.mv-form-scroll::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; } - -.mv-form-section { - background: rgba(255,255,255,0.02); - border: 1px solid var(--border); - border-radius: 9px; padding: 12px; -} -.mv-form-section-title { - font-family: "GilroyBold", sans-serif; font-size: 10px; - color: var(--text-muted); letter-spacing: 0.1em; text-transform: uppercase; - margin-bottom: 10px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; -} -.mv-form-section-title i { color: var(--accent); } - -.mv-hint-pill { - font-family: "GilroyLight", sans-serif; font-size: 10px; - color: rgba(232,131,10,0.7); background: var(--accent-dim); - padding: 2px 8px; border-radius: 10px; margin-left: 6px; - text-transform: none; letter-spacing: 0; font-weight: normal; -} - -.mv-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; } - -.mv-form-field { display: flex; flex-direction: column; gap: 4px; } -.mv-form-field label { font-size: 10px; color: var(--text-muted); } -.mv-field-hint { color: rgba(255,255,255,0.2); font-size: 9px; } -.mv-form-field-check { flex-direction: row; align-items: center; gap: 8px; } - -.mv-form-field input, .mv-form-field select { - padding: 7px 10px; - background: var(--bg-input); - border: 1px solid var(--border); - border-radius: 6px; color: white; - font-family: inherit; font-size: 11px; outline: none; - transition: border 0.15s; -} -.mv-form-field input:focus, .mv-form-field select:focus { border-color: rgba(232,131,10,0.4); } -.mv-form-field select option { background: #1a1a1a; } -.mv-form-field input:disabled { opacity: 0.45; cursor: not-allowed; } - -.mv-pos-block { margin-bottom: 10px; } -.mv-pos-label { font-size: 10px; color: var(--text-secondary); margin-bottom: 5px; } -.mv-pos-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 5px; margin-bottom: 5px; } -.mv-pos-row input { - padding: 6px 7px; background: var(--bg-input); - border: 1px solid var(--border); border-radius: 5px; - color: white; font-size: 10px; font-family: inherit; outline: none; -} -.mv-pos-row input:focus { border-color: rgba(232,131,10,0.35); } - -.mv-capture-btn { - padding: 5px 11px; border-radius: 5px; - background: rgba(232,131,10,0.12); - border: 1px solid rgba(232,131,10,0.25); - color: var(--accent); font-size: 10px; - font-family: inherit; cursor: pointer; transition: background 0.15s; - display: inline-flex; align-items: center; gap: 5px; -} -.mv-capture-btn:hover { background: rgba(232,131,10,0.2); } - -.mv-admin-empty { - flex: 1; display: flex; flex-direction: column; - align-items: center; justify-content: center; - color: var(--text-muted); gap: 10px; -} -.mv-admin-empty i { font-size: 2.5rem; } -.mv-admin-empty p { font-size: 12px; } - -/* ──────────────────── OVERLAYS ──────────────────── */ - -.mv-confirm-overlay, .mv-capture-overlay { - position: fixed; inset: 0; - background: rgba(0,0,0,0.65); - display: flex; align-items: center; justify-content: center; - z-index: 9999; -} -.mv-capture-overlay { pointer-events: none; } - -.mv-confirm-box, .mv-capture-box { - background: var(--bg-modal); - border: 1px solid var(--border); - border-radius: 12px; padding: 28px 24px; - text-align: center; max-width: 340px; width: 90%; - color: white; font-family: inherit; -} - -.mv-confirm-icon { font-size: 2rem; color: var(--red); margin-bottom: 12px; display: block; } -.mv-confirm-title { font-family: "GilroyBold", sans-serif; font-size: 15px; margin-bottom: 6px; } -.mv-confirm-sub { font-size: 12px; color: var(--text-secondary); margin-bottom: 16px; } -.mv-confirm-btns { display: flex; gap: 10px; justify-content: center; } - -.mv-btn-danger { - padding: 9px 20px; border-radius: 7px; - background: var(--red); border: none; - color: white; font-family: "GilroyBold", sans-serif; - font-size: 12px; cursor: pointer; transition: opacity 0.15s; - display: flex; align-items: center; gap: 5px; -} -.mv-btn-danger:hover { opacity: 0.85; } -.mv-btn-ghost { - padding: 9px 18px; border-radius: 7px; - background: rgba(255,255,255,0.06); - border: 1px solid var(--border-hover); - color: var(--text-secondary); - font-family: inherit; font-size: 12px; cursor: pointer; - transition: background 0.15s; -} -.mv-btn-ghost:hover { background: rgba(255,255,255,0.12); } - -.mv-capture-icon { font-size: 2.5rem; color: var(--accent); margin-bottom: 10px; display: block; } -.mv-capture-title { font-family: "GilroyBold", sans-serif; font-size: 15px; margin-bottom: 8px; } -.mv-capture-field { font-size: 12px; color: var(--accent); background: var(--accent-dim); padding: 4px 12px; border-radius: 5px; display: inline-block; margin-bottom: 10px; } -.mv-capture-hint { font-size: 12px; color: var(--text-secondary); margin-bottom: 4px; } -.mv-capture-cancel{ font-size: 11px; color: var(--text-muted); } - -kbd { - background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.15); - border-radius: 4px; padding: 1px 6px; font-size: 11px; - font-family: inherit; color: white; -} - -/* Nearby badge */ -.status-nearby { background: rgba(232,131,10,0.25); color: var(--accent); border: 1px solid rgba(232,131,10,0.4); } - -/* Einparken Button */ -.mv-parkin-btn { - padding: 13px; border-radius: 8px; - background: rgba(232,131,10,0.15); - border: 1px solid rgba(232,131,10,0.4); - color: var(--accent); - font-family: "GilroyBold", sans-serif; - font-size: 14px; cursor: pointer; letter-spacing: 0.04em; - transition: background 0.15s, transform 0.1s; - margin-top: 4px; -} -.mv-parkin-btn:hover { background: rgba(232,131,10,0.28); } -.mv-parkin-btn:active { transform: scale(0.98); } - -/* Job-Fahrzeuge Admin */ -.mv-job-vehicle-list { - display: flex; flex-direction: column; gap: 6px; - margin-bottom: 10px; -} -.mv-job-vehicle-item { - display: flex; align-items: center; justify-content: space-between; - background: rgba(255,255,255,0.04); - border: 1px solid rgba(255,255,255,0.08); - border-radius: 6px; padding: 8px 12px; -} -.mv-job-vehicle-name { - font-size: 13px; color: var(--text-secondary); -} -.mv-job-vehicle-name i { color: var(--accent); margin-right: 6px; } -.mv-job-vehicle-empty { - font-size: 12px; color: var(--text-muted); - padding: 8px; text-align: center; -} -.mv-job-vehicle-add { - display: flex; gap: 8px; align-items: center; -} -.mv-job-input { - flex: 1; padding: 8px 12px; - background: var(--bg-input); border: 1px solid var(--border); - border-radius: 8px; color: var(--text-secondary); - font-size: 13px; font-family: inherit; outline: none; -} -.mv-job-input:focus { border-color: var(--accent); } diff --git a/[core]/mercyv-garage/nui/vue.js b/[core]/mercyv-garage/nui/vue.js deleted file mode 100644 index 4ada213c..00000000 --- a/[core]/mercyv-garage/nui/vue.js +++ /dev/null @@ -1,11967 +0,0 @@ -/*! - * Vue.js v2.6.12 - * (c) 2014-2020 Evan You - * Released under the MIT License. - */ -(function (global, factory) { - typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : - typeof define === 'function' && define.amd ? define(factory) : - (global = global || self, global.Vue = factory()); - }(this, function () { 'use strict'; - - /* */ - - var emptyObject = Object.freeze({}); - - // These helpers produce better VM code in JS engines due to their - // explicitness and function inlining. - function isUndef (v) { - return v === undefined || v === null - } - - function isDef (v) { - return v !== undefined && v !== null - } - - function isTrue (v) { - return v === true - } - - function isFalse (v) { - return v === false - } - - /** - * Check if value is primitive. - */ - function isPrimitive (value) { - return ( - typeof value === 'string' || - typeof value === 'number' || - // $flow-disable-line - typeof value === 'symbol' || - typeof value === 'boolean' - ) - } - - /** - * Quick object check - this is primarily used to tell - * Objects from primitive values when we know the value - * is a JSON-compliant type. - */ - function isObject (obj) { - return obj !== null && typeof obj === 'object' - } - - /** - * Get the raw type string of a value, e.g., [object Object]. - */ - var _toString = Object.prototype.toString; - - function toRawType (value) { - return _toString.call(value).slice(8, -1) - } - - /** - * Strict object type check. Only returns true - * for plain JavaScript objects. - */ - function isPlainObject (obj) { - return _toString.call(obj) === '[object Object]' - } - - function isRegExp (v) { - return _toString.call(v) === '[object RegExp]' - } - - /** - * Check if val is a valid array index. - */ - function isValidArrayIndex (val) { - var n = parseFloat(String(val)); - return n >= 0 && Math.floor(n) === n && isFinite(val) - } - - function isPromise (val) { - return ( - isDef(val) && - typeof val.then === 'function' && - typeof val.catch === 'function' - ) - } - - /** - * Convert a value to a string that is actually rendered. - */ - function toString (val) { - return val == null - ? '' - : Array.isArray(val) || (isPlainObject(val) && val.toString === _toString) - ? JSON.stringify(val, null, 2) - : String(val) - } - - /** - * Convert an input value to a number for persistence. - * If the conversion fails, return original string. - */ - function toNumber (val) { - var n = parseFloat(val); - return isNaN(n) ? val : n - } - - /** - * Make a map and return a function for checking if a key - * is in that map. - */ - function makeMap ( - str, - expectsLowerCase - ) { - var map = Object.create(null); - var list = str.split(','); - for (var i = 0; i < list.length; i++) { - map[list[i]] = true; - } - return expectsLowerCase - ? function (val) { return map[val.toLowerCase()]; } - : function (val) { return map[val]; } - } - - /** - * Check if a tag is a built-in tag. - */ - var isBuiltInTag = makeMap('slot,component', true); - - /** - * Check if an attribute is a reserved attribute. - */ - var isReservedAttribute = makeMap('key,ref,slot,slot-scope,is'); - - /** - * Remove an item from an array. - */ - function remove (arr, item) { - if (arr.length) { - var index = arr.indexOf(item); - if (index > -1) { - return arr.splice(index, 1) - } - } - } - - /** - * Check whether an object has the property. - */ - var hasOwnProperty = Object.prototype.hasOwnProperty; - function hasOwn (obj, key) { - return hasOwnProperty.call(obj, key) - } - - /** - * Create a cached version of a pure function. - */ - function cached (fn) { - var cache = Object.create(null); - return (function cachedFn (str) { - var hit = cache[str]; - return hit || (cache[str] = fn(str)) - }) - } - - /** - * Camelize a hyphen-delimited string. - */ - var camelizeRE = /-(\w)/g; - var camelize = cached(function (str) { - return str.replace(camelizeRE, function (_, c) { return c ? c.toUpperCase() : ''; }) - }); - - /** - * Capitalize a string. - */ - var capitalize = cached(function (str) { - return str.charAt(0).toUpperCase() + str.slice(1) - }); - - /** - * Hyphenate a camelCase string. - */ - var hyphenateRE = /\B([A-Z])/g; - var hyphenate = cached(function (str) { - return str.replace(hyphenateRE, '-$1').toLowerCase() - }); - - /** - * Simple bind polyfill for environments that do not support it, - * e.g., PhantomJS 1.x. Technically, we don't need this anymore - * since native bind is now performant enough in most browsers. - * But removing it would mean breaking code that was able to run in - * PhantomJS 1.x, so this must be kept for backward compatibility. - */ - - /* istanbul ignore next */ - function polyfillBind (fn, ctx) { - function boundFn (a) { - var l = arguments.length; - return l - ? l > 1 - ? fn.apply(ctx, arguments) - : fn.call(ctx, a) - : fn.call(ctx) - } - - boundFn._length = fn.length; - return boundFn - } - - function nativeBind (fn, ctx) { - return fn.bind(ctx) - } - - var bind = Function.prototype.bind - ? nativeBind - : polyfillBind; - - /** - * Convert an Array-like object to a real Array. - */ - function toArray (list, start) { - start = start || 0; - var i = list.length - start; - var ret = new Array(i); - while (i--) { - ret[i] = list[i + start]; - } - return ret - } - - /** - * Mix properties into target object. - */ - function extend (to, _from) { - for (var key in _from) { - to[key] = _from[key]; - } - return to - } - - /** - * Merge an Array of Objects into a single Object. - */ - function toObject (arr) { - var res = {}; - for (var i = 0; i < arr.length; i++) { - if (arr[i]) { - extend(res, arr[i]); - } - } - return res - } - - /* eslint-disable no-unused-vars */ - - /** - * Perform no operation. - * Stubbing args to make Flow happy without leaving useless transpiled code - * with ...rest (https://flow.org/blog/2017/05/07/Strict-Function-Call-Arity/). - */ - function noop (a, b, c) {} - - /** - * Always return false. - */ - var no = function (a, b, c) { return false; }; - - /* eslint-enable no-unused-vars */ - - /** - * Return the same value. - */ - var identity = function (_) { return _; }; - - /** - * Generate a string containing static keys from compiler modules. - */ - function genStaticKeys (modules) { - return modules.reduce(function (keys, m) { - return keys.concat(m.staticKeys || []) - }, []).join(',') - } - - /** - * Check if two values are loosely equal - that is, - * if they are plain objects, do they have the same shape? - */ - function looseEqual (a, b) { - if (a === b) { return true } - var isObjectA = isObject(a); - var isObjectB = isObject(b); - if (isObjectA && isObjectB) { - try { - var isArrayA = Array.isArray(a); - var isArrayB = Array.isArray(b); - if (isArrayA && isArrayB) { - return a.length === b.length && a.every(function (e, i) { - return looseEqual(e, b[i]) - }) - } else if (a instanceof Date && b instanceof Date) { - return a.getTime() === b.getTime() - } else if (!isArrayA && !isArrayB) { - var keysA = Object.keys(a); - var keysB = Object.keys(b); - return keysA.length === keysB.length && keysA.every(function (key) { - return looseEqual(a[key], b[key]) - }) - } else { - /* istanbul ignore next */ - return false - } - } catch (e) { - /* istanbul ignore next */ - return false - } - } else if (!isObjectA && !isObjectB) { - return String(a) === String(b) - } else { - return false - } - } - - /** - * Return the first index at which a loosely equal value can be - * found in the array (if value is a plain object, the array must - * contain an object of the same shape), or -1 if it is not present. - */ - function looseIndexOf (arr, val) { - for (var i = 0; i < arr.length; i++) { - if (looseEqual(arr[i], val)) { return i } - } - return -1 - } - - /** - * Ensure a function is called only once. - */ - function once (fn) { - var called = false; - return function () { - if (!called) { - called = true; - fn.apply(this, arguments); - } - } - } - - var SSR_ATTR = 'data-server-rendered'; - - var ASSET_TYPES = [ - 'component', - 'directive', - 'filter' - ]; - - var LIFECYCLE_HOOKS = [ - 'beforeCreate', - 'created', - 'beforeMount', - 'mounted', - 'beforeUpdate', - 'updated', - 'beforeDestroy', - 'destroyed', - 'activated', - 'deactivated', - 'errorCaptured', - 'serverPrefetch' - ]; - - /* */ - - - - var config = ({ - /** - * Option merge strategies (used in core/util/options) - */ - // $flow-disable-line - optionMergeStrategies: Object.create(null), - - /** - * Whether to suppress warnings. - */ - silent: false, - - /** - * Show production mode tip message on boot? - */ - productionTip: "development" !== 'production', - - /** - * Whether to enable devtools - */ - devtools: "development" !== 'production', - - /** - * Whether to record perf - */ - performance: false, - - /** - * Error handler for watcher errors - */ - errorHandler: null, - - /** - * Warn handler for watcher warns - */ - warnHandler: null, - - /** - * Ignore certain custom elements - */ - ignoredElements: [], - - /** - * Custom user key aliases for v-on - */ - // $flow-disable-line - keyCodes: Object.create(null), - - /** - * Check if a tag is reserved so that it cannot be registered as a - * component. This is platform-dependent and may be overwritten. - */ - isReservedTag: no, - - /** - * Check if an attribute is reserved so that it cannot be used as a component - * prop. This is platform-dependent and may be overwritten. - */ - isReservedAttr: no, - - /** - * Check if a tag is an unknown element. - * Platform-dependent. - */ - isUnknownElement: no, - - /** - * Get the namespace of an element - */ - getTagNamespace: noop, - - /** - * Parse the real tag name for the specific platform. - */ - parsePlatformTagName: identity, - - /** - * Check if an attribute must be bound using property, e.g. value - * Platform-dependent. - */ - mustUseProp: no, - - /** - * Perform updates asynchronously. Intended to be used by Vue Test Utils - * This will significantly reduce performance if set to false. - */ - async: true, - - /** - * Exposed for legacy reasons - */ - _lifecycleHooks: LIFECYCLE_HOOKS - }); - - /* */ - - /** - * unicode letters used for parsing html tags, component names and property paths. - * using https://www.w3.org/TR/html53/semantics-scripting.html#potentialcustomelementname - * skipping \u10000-\uEFFFF due to it freezing up PhantomJS - */ - var unicodeRegExp = /a-zA-Z\u00B7\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u037D\u037F-\u1FFF\u200C-\u200D\u203F-\u2040\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD/; - - /** - * Check if a string starts with $ or _ - */ - function isReserved (str) { - var c = (str + '').charCodeAt(0); - return c === 0x24 || c === 0x5F - } - - /** - * Define a property. - */ - function def (obj, key, val, enumerable) { - Object.defineProperty(obj, key, { - value: val, - enumerable: !!enumerable, - writable: true, - configurable: true - }); - } - - /** - * Parse simple path. - */ - var bailRE = new RegExp(("[^" + (unicodeRegExp.source) + ".$_\\d]")); - function parsePath (path) { - if (bailRE.test(path)) { - return - } - var segments = path.split('.'); - return function (obj) { - for (var i = 0; i < segments.length; i++) { - if (!obj) { return } - obj = obj[segments[i]]; - } - return obj - } - } - - /* */ - - // can we use __proto__? - var hasProto = '__proto__' in {}; - - // Browser environment sniffing - var inBrowser = typeof window !== 'undefined'; - var inWeex = typeof WXEnvironment !== 'undefined' && !!WXEnvironment.platform; - var weexPlatform = inWeex && WXEnvironment.platform.toLowerCase(); - var UA = inBrowser && window.navigator.userAgent.toLowerCase(); - var isIE = UA && /msie|trident/.test(UA); - var isIE9 = UA && UA.indexOf('msie 9.0') > 0; - var isEdge = UA && UA.indexOf('edge/') > 0; - var isAndroid = (UA && UA.indexOf('android') > 0) || (weexPlatform === 'android'); - var isIOS = (UA && /iphone|ipad|ipod|ios/.test(UA)) || (weexPlatform === 'ios'); - var isChrome = UA && /chrome\/\d+/.test(UA) && !isEdge; - var isPhantomJS = UA && /phantomjs/.test(UA); - var isFF = UA && UA.match(/firefox\/(\d+)/); - - // Firefox has a "watch" function on Object.prototype... - var nativeWatch = ({}).watch; - - var supportsPassive = false; - if (inBrowser) { - try { - var opts = {}; - Object.defineProperty(opts, 'passive', ({ - get: function get () { - /* istanbul ignore next */ - supportsPassive = true; - } - })); // https://github.com/facebook/flow/issues/285 - window.addEventListener('test-passive', null, opts); - } catch (e) {} - } - - // this needs to be lazy-evaled because vue may be required before - // vue-server-renderer can set VUE_ENV - var _isServer; - var isServerRendering = function () { - if (_isServer === undefined) { - /* istanbul ignore if */ - if (!inBrowser && !inWeex && typeof global !== 'undefined') { - // detect presence of vue-server-renderer and avoid - // Webpack shimming the process - _isServer = global['process'] && global['process'].env.VUE_ENV === 'server'; - } else { - _isServer = false; - } - } - return _isServer - }; - - // detect devtools - var devtools = inBrowser && window.__VUE_DEVTOOLS_GLOBAL_HOOK__; - - /* istanbul ignore next */ - function isNative (Ctor) { - return typeof Ctor === 'function' && /native code/.test(Ctor.toString()) - } - - var hasSymbol = - typeof Symbol !== 'undefined' && isNative(Symbol) && - typeof Reflect !== 'undefined' && isNative(Reflect.ownKeys); - - var _Set; - /* istanbul ignore if */ // $flow-disable-line - if (typeof Set !== 'undefined' && isNative(Set)) { - // use native Set when available. - _Set = Set; - } else { - // a non-standard Set polyfill that only works with primitive keys. - _Set = /*@__PURE__*/(function () { - function Set () { - this.set = Object.create(null); - } - Set.prototype.has = function has (key) { - return this.set[key] === true - }; - Set.prototype.add = function add (key) { - this.set[key] = true; - }; - Set.prototype.clear = function clear () { - this.set = Object.create(null); - }; - - return Set; - }()); - } - - /* */ - - var warn = noop; - var tip = noop; - var generateComponentTrace = (noop); // work around flow check - var formatComponentName = (noop); - - { - var hasConsole = typeof console !== 'undefined'; - var classifyRE = /(?:^|[-_])(\w)/g; - var classify = function (str) { return str - .replace(classifyRE, function (c) { return c.toUpperCase(); }) - .replace(/[-_]/g, ''); }; - - warn = function (msg, vm) { - var trace = vm ? generateComponentTrace(vm) : ''; - - if (config.warnHandler) { - config.warnHandler.call(null, msg, vm, trace); - } else if (hasConsole && (!config.silent)) { - console.error(("[Vue warn]: " + msg + trace)); - } - }; - - tip = function (msg, vm) { - if (hasConsole && (!config.silent)) { - console.warn("[Vue tip]: " + msg + ( - vm ? generateComponentTrace(vm) : '' - )); - } - }; - - formatComponentName = function (vm, includeFile) { - if (vm.$root === vm) { - return '' - } - var options = typeof vm === 'function' && vm.cid != null - ? vm.options - : vm._isVue - ? vm.$options || vm.constructor.options - : vm; - var name = options.name || options._componentTag; - var file = options.__file; - if (!name && file) { - var match = file.match(/([^/\\]+)\.vue$/); - name = match && match[1]; - } - - return ( - (name ? ("<" + (classify(name)) + ">") : "") + - (file && includeFile !== false ? (" at " + file) : '') - ) - }; - - var repeat = function (str, n) { - var res = ''; - while (n) { - if (n % 2 === 1) { res += str; } - if (n > 1) { str += str; } - n >>= 1; - } - return res - }; - - generateComponentTrace = function (vm) { - if (vm._isVue && vm.$parent) { - var tree = []; - var currentRecursiveSequence = 0; - while (vm) { - if (tree.length > 0) { - var last = tree[tree.length - 1]; - if (last.constructor === vm.constructor) { - currentRecursiveSequence++; - vm = vm.$parent; - continue - } else if (currentRecursiveSequence > 0) { - tree[tree.length - 1] = [last, currentRecursiveSequence]; - currentRecursiveSequence = 0; - } - } - tree.push(vm); - vm = vm.$parent; - } - return '\n\nfound in\n\n' + tree - .map(function (vm, i) { return ("" + (i === 0 ? '---> ' : repeat(' ', 5 + i * 2)) + (Array.isArray(vm) - ? ((formatComponentName(vm[0])) + "... (" + (vm[1]) + " recursive calls)") - : formatComponentName(vm))); }) - .join('\n') - } else { - return ("\n\n(found in " + (formatComponentName(vm)) + ")") - } - }; - } - - /* */ - - var uid = 0; - - /** - * A dep is an observable that can have multiple - * directives subscribing to it. - */ - var Dep = function Dep () { - this.id = uid++; - this.subs = []; - }; - - Dep.prototype.addSub = function addSub (sub) { - this.subs.push(sub); - }; - - Dep.prototype.removeSub = function removeSub (sub) { - remove(this.subs, sub); - }; - - Dep.prototype.depend = function depend () { - if (Dep.target) { - Dep.target.addDep(this); - } - }; - - Dep.prototype.notify = function notify () { - // stabilize the subscriber list first - var subs = this.subs.slice(); - if (!config.async) { - // subs aren't sorted in scheduler if not running async - // we need to sort them now to make sure they fire in correct - // order - subs.sort(function (a, b) { return a.id - b.id; }); - } - for (var i = 0, l = subs.length; i < l; i++) { - subs[i].update(); - } - }; - - // The current target watcher being evaluated. - // This is globally unique because only one watcher - // can be evaluated at a time. - Dep.target = null; - var targetStack = []; - - function pushTarget (target) { - targetStack.push(target); - Dep.target = target; - } - - function popTarget () { - targetStack.pop(); - Dep.target = targetStack[targetStack.length - 1]; - } - - /* */ - - var VNode = function VNode ( - tag, - data, - children, - text, - elm, - context, - componentOptions, - asyncFactory - ) { - this.tag = tag; - this.data = data; - this.children = children; - this.text = text; - this.elm = elm; - this.ns = undefined; - this.context = context; - this.fnContext = undefined; - this.fnOptions = undefined; - this.fnScopeId = undefined; - this.key = data && data.key; - this.componentOptions = componentOptions; - this.componentInstance = undefined; - this.parent = undefined; - this.raw = false; - this.isStatic = false; - this.isRootInsert = true; - this.isComment = false; - this.isCloned = false; - this.isOnce = false; - this.asyncFactory = asyncFactory; - this.asyncMeta = undefined; - this.isAsyncPlaceholder = false; - }; - - var prototypeAccessors = { child: { configurable: true } }; - - // DEPRECATED: alias for componentInstance for backwards compat. - /* istanbul ignore next */ - prototypeAccessors.child.get = function () { - return this.componentInstance - }; - - Object.defineProperties( VNode.prototype, prototypeAccessors ); - - var createEmptyVNode = function (text) { - if ( text === void 0 ) text = ''; - - var node = new VNode(); - node.text = text; - node.isComment = true; - return node - }; - - function createTextVNode (val) { - return new VNode(undefined, undefined, undefined, String(val)) - } - - // optimized shallow clone - // used for static nodes and slot nodes because they may be reused across - // multiple renders, cloning them avoids errors when DOM manipulations rely - // on their elm reference. - function cloneVNode (vnode) { - var cloned = new VNode( - vnode.tag, - vnode.data, - // #7975 - // clone children array to avoid mutating original in case of cloning - // a child. - vnode.children && vnode.children.slice(), - vnode.text, - vnode.elm, - vnode.context, - vnode.componentOptions, - vnode.asyncFactory - ); - cloned.ns = vnode.ns; - cloned.isStatic = vnode.isStatic; - cloned.key = vnode.key; - cloned.isComment = vnode.isComment; - cloned.fnContext = vnode.fnContext; - cloned.fnOptions = vnode.fnOptions; - cloned.fnScopeId = vnode.fnScopeId; - cloned.asyncMeta = vnode.asyncMeta; - cloned.isCloned = true; - return cloned - } - - /* - * not type checking this file because flow doesn't play well with - * dynamically accessing methods on Array prototype - */ - - var arrayProto = Array.prototype; - var arrayMethods = Object.create(arrayProto); - - var methodsToPatch = [ - 'push', - 'pop', - 'shift', - 'unshift', - 'splice', - 'sort', - 'reverse' - ]; - - /** - * Intercept mutating methods and emit events - */ - methodsToPatch.forEach(function (method) { - // cache original method - var original = arrayProto[method]; - def(arrayMethods, method, function mutator () { - var args = [], len = arguments.length; - while ( len-- ) args[ len ] = arguments[ len ]; - - var result = original.apply(this, args); - var ob = this.__ob__; - var inserted; - switch (method) { - case 'push': - case 'unshift': - inserted = args; - break - case 'splice': - inserted = args.slice(2); - break - } - if (inserted) { ob.observeArray(inserted); } - // notify change - ob.dep.notify(); - return result - }); - }); - - /* */ - - var arrayKeys = Object.getOwnPropertyNames(arrayMethods); - - /** - * In some cases we may want to disable observation inside a component's - * update computation. - */ - var shouldObserve = true; - - function toggleObserving (value) { - shouldObserve = value; - } - - /** - * Observer class that is attached to each observed - * object. Once attached, the observer converts the target - * object's property keys into getter/setters that - * collect dependencies and dispatch updates. - */ - var Observer = function Observer (value) { - this.value = value; - this.dep = new Dep(); - this.vmCount = 0; - def(value, '__ob__', this); - if (Array.isArray(value)) { - if (hasProto) { - protoAugment(value, arrayMethods); - } else { - copyAugment(value, arrayMethods, arrayKeys); - } - this.observeArray(value); - } else { - this.walk(value); - } - }; - - /** - * Walk through all properties and convert them into - * getter/setters. This method should only be called when - * value type is Object. - */ - Observer.prototype.walk = function walk (obj) { - var keys = Object.keys(obj); - for (var i = 0; i < keys.length; i++) { - defineReactive$$1(obj, keys[i]); - } - }; - - /** - * Observe a list of Array items. - */ - Observer.prototype.observeArray = function observeArray (items) { - for (var i = 0, l = items.length; i < l; i++) { - observe(items[i]); - } - }; - - // helpers - - /** - * Augment a target Object or Array by intercepting - * the prototype chain using __proto__ - */ - function protoAugment (target, src) { - /* eslint-disable no-proto */ - target.__proto__ = src; - /* eslint-enable no-proto */ - } - - /** - * Augment a target Object or Array by defining - * hidden properties. - */ - /* istanbul ignore next */ - function copyAugment (target, src, keys) { - for (var i = 0, l = keys.length; i < l; i++) { - var key = keys[i]; - def(target, key, src[key]); - } - } - - /** - * Attempt to create an observer instance for a value, - * returns the new observer if successfully observed, - * or the existing observer if the value already has one. - */ - function observe (value, asRootData) { - if (!isObject(value) || value instanceof VNode) { - return - } - var ob; - if (hasOwn(value, '__ob__') && value.__ob__ instanceof Observer) { - ob = value.__ob__; - } else if ( - shouldObserve && - !isServerRendering() && - (Array.isArray(value) || isPlainObject(value)) && - Object.isExtensible(value) && - !value._isVue - ) { - ob = new Observer(value); - } - if (asRootData && ob) { - ob.vmCount++; - } - return ob - } - - /** - * Define a reactive property on an Object. - */ - function defineReactive$$1 ( - obj, - key, - val, - customSetter, - shallow - ) { - var dep = new Dep(); - - var property = Object.getOwnPropertyDescriptor(obj, key); - if (property && property.configurable === false) { - return - } - - // cater for pre-defined getter/setters - var getter = property && property.get; - var setter = property && property.set; - if ((!getter || setter) && arguments.length === 2) { - val = obj[key]; - } - - var childOb = !shallow && observe(val); - Object.defineProperty(obj, key, { - enumerable: true, - configurable: true, - get: function reactiveGetter () { - var value = getter ? getter.call(obj) : val; - if (Dep.target) { - dep.depend(); - if (childOb) { - childOb.dep.depend(); - if (Array.isArray(value)) { - dependArray(value); - } - } - } - return value - }, - set: function reactiveSetter (newVal) { - var value = getter ? getter.call(obj) : val; - /* eslint-disable no-self-compare */ - if (newVal === value || (newVal !== newVal && value !== value)) { - return - } - /* eslint-enable no-self-compare */ - if (customSetter) { - customSetter(); - } - // #7981: for accessor properties without setter - if (getter && !setter) { return } - if (setter) { - setter.call(obj, newVal); - } else { - val = newVal; - } - childOb = !shallow && observe(newVal); - dep.notify(); - } - }); - } - - /** - * Set a property on an object. Adds the new property and - * triggers change notification if the property doesn't - * already exist. - */ - function set (target, key, val) { - if (isUndef(target) || isPrimitive(target) - ) { - warn(("Cannot set reactive property on undefined, null, or primitive value: " + ((target)))); - } - if (Array.isArray(target) && isValidArrayIndex(key)) { - target.length = Math.max(target.length, key); - target.splice(key, 1, val); - return val - } - if (key in target && !(key in Object.prototype)) { - target[key] = val; - return val - } - var ob = (target).__ob__; - if (target._isVue || (ob && ob.vmCount)) { - warn( - 'Avoid adding reactive properties to a Vue instance or its root $data ' + - 'at runtime - declare it upfront in the data option.' - ); - return val - } - if (!ob) { - target[key] = val; - return val - } - defineReactive$$1(ob.value, key, val); - ob.dep.notify(); - return val - } - - /** - * Delete a property and trigger change if necessary. - */ - function del (target, key) { - if (isUndef(target) || isPrimitive(target) - ) { - warn(("Cannot delete reactive property on undefined, null, or primitive value: " + ((target)))); - } - if (Array.isArray(target) && isValidArrayIndex(key)) { - target.splice(key, 1); - return - } - var ob = (target).__ob__; - if (target._isVue || (ob && ob.vmCount)) { - warn( - 'Avoid deleting properties on a Vue instance or its root $data ' + - '- just set it to null.' - ); - return - } - if (!hasOwn(target, key)) { - return - } - delete target[key]; - if (!ob) { - return - } - ob.dep.notify(); - } - - /** - * Collect dependencies on array elements when the array is touched, since - * we cannot intercept array element access like property getters. - */ - function dependArray (value) { - for (var e = (void 0), i = 0, l = value.length; i < l; i++) { - e = value[i]; - e && e.__ob__ && e.__ob__.dep.depend(); - if (Array.isArray(e)) { - dependArray(e); - } - } - } - - /* */ - - /** - * Option overwriting strategies are functions that handle - * how to merge a parent option value and a child option - * value into the final value. - */ - var strats = config.optionMergeStrategies; - - /** - * Options with restrictions - */ - { - strats.el = strats.propsData = function (parent, child, vm, key) { - if (!vm) { - warn( - "option \"" + key + "\" can only be used during instance " + - 'creation with the `new` keyword.' - ); - } - return defaultStrat(parent, child) - }; - } - - /** - * Helper that recursively merges two data objects together. - */ - function mergeData (to, from) { - if (!from) { return to } - var key, toVal, fromVal; - - var keys = hasSymbol - ? Reflect.ownKeys(from) - : Object.keys(from); - - for (var i = 0; i < keys.length; i++) { - key = keys[i]; - // in case the object is already observed... - if (key === '__ob__') { continue } - toVal = to[key]; - fromVal = from[key]; - if (!hasOwn(to, key)) { - set(to, key, fromVal); - } else if ( - toVal !== fromVal && - isPlainObject(toVal) && - isPlainObject(fromVal) - ) { - mergeData(toVal, fromVal); - } - } - return to - } - - /** - * Data - */ - function mergeDataOrFn ( - parentVal, - childVal, - vm - ) { - if (!vm) { - // in a Vue.extend merge, both should be functions - if (!childVal) { - return parentVal - } - if (!parentVal) { - return childVal - } - // when parentVal & childVal are both present, - // we need to return a function that returns the - // merged result of both functions... no need to - // check if parentVal is a function here because - // it has to be a function to pass previous merges. - return function mergedDataFn () { - return mergeData( - typeof childVal === 'function' ? childVal.call(this, this) : childVal, - typeof parentVal === 'function' ? parentVal.call(this, this) : parentVal - ) - } - } else { - return function mergedInstanceDataFn () { - // instance merge - var instanceData = typeof childVal === 'function' - ? childVal.call(vm, vm) - : childVal; - var defaultData = typeof parentVal === 'function' - ? parentVal.call(vm, vm) - : parentVal; - if (instanceData) { - return mergeData(instanceData, defaultData) - } else { - return defaultData - } - } - } - } - - strats.data = function ( - parentVal, - childVal, - vm - ) { - if (!vm) { - if (childVal && typeof childVal !== 'function') { - warn( - 'The "data" option should be a function ' + - 'that returns a per-instance value in component ' + - 'definitions.', - vm - ); - - return parentVal - } - return mergeDataOrFn(parentVal, childVal) - } - - return mergeDataOrFn(parentVal, childVal, vm) - }; - - /** - * Hooks and props are merged as arrays. - */ - function mergeHook ( - parentVal, - childVal - ) { - var res = childVal - ? parentVal - ? parentVal.concat(childVal) - : Array.isArray(childVal) - ? childVal - : [childVal] - : parentVal; - return res - ? dedupeHooks(res) - : res - } - - function dedupeHooks (hooks) { - var res = []; - for (var i = 0; i < hooks.length; i++) { - if (res.indexOf(hooks[i]) === -1) { - res.push(hooks[i]); - } - } - return res - } - - LIFECYCLE_HOOKS.forEach(function (hook) { - strats[hook] = mergeHook; - }); - - /** - * Assets - * - * When a vm is present (instance creation), we need to do - * a three-way merge between constructor options, instance - * options and parent options. - */ - function mergeAssets ( - parentVal, - childVal, - vm, - key - ) { - var res = Object.create(parentVal || null); - if (childVal) { - assertObjectType(key, childVal, vm); - return extend(res, childVal) - } else { - return res - } - } - - ASSET_TYPES.forEach(function (type) { - strats[type + 's'] = mergeAssets; - }); - - /** - * Watchers. - * - * Watchers hashes should not overwrite one - * another, so we merge them as arrays. - */ - strats.watch = function ( - parentVal, - childVal, - vm, - key - ) { - // work around Firefox's Object.prototype.watch... - if (parentVal === nativeWatch) { parentVal = undefined; } - if (childVal === nativeWatch) { childVal = undefined; } - /* istanbul ignore if */ - if (!childVal) { return Object.create(parentVal || null) } - { - assertObjectType(key, childVal, vm); - } - if (!parentVal) { return childVal } - var ret = {}; - extend(ret, parentVal); - for (var key$1 in childVal) { - var parent = ret[key$1]; - var child = childVal[key$1]; - if (parent && !Array.isArray(parent)) { - parent = [parent]; - } - ret[key$1] = parent - ? parent.concat(child) - : Array.isArray(child) ? child : [child]; - } - return ret - }; - - /** - * Other object hashes. - */ - strats.props = - strats.methods = - strats.inject = - strats.computed = function ( - parentVal, - childVal, - vm, - key - ) { - if (childVal && "development" !== 'production') { - assertObjectType(key, childVal, vm); - } - if (!parentVal) { return childVal } - var ret = Object.create(null); - extend(ret, parentVal); - if (childVal) { extend(ret, childVal); } - return ret - }; - strats.provide = mergeDataOrFn; - - /** - * Default strategy. - */ - var defaultStrat = function (parentVal, childVal) { - return childVal === undefined - ? parentVal - : childVal - }; - - /** - * Validate component names - */ - function checkComponents (options) { - for (var key in options.components) { - validateComponentName(key); - } - } - - function validateComponentName (name) { - if (!new RegExp(("^[a-zA-Z][\\-\\.0-9_" + (unicodeRegExp.source) + "]*$")).test(name)) { - warn( - 'Invalid component name: "' + name + '". Component names ' + - 'should conform to valid custom element name in html5 specification.' - ); - } - if (isBuiltInTag(name) || config.isReservedTag(name)) { - warn( - 'Do not use built-in or reserved HTML elements as component ' + - 'id: ' + name - ); - } - } - - /** - * Ensure all props option syntax are normalized into the - * Object-based format. - */ - function normalizeProps (options, vm) { - var props = options.props; - if (!props) { return } - var res = {}; - var i, val, name; - if (Array.isArray(props)) { - i = props.length; - while (i--) { - val = props[i]; - if (typeof val === 'string') { - name = camelize(val); - res[name] = { type: null }; - } else { - warn('props must be strings when using array syntax.'); - } - } - } else if (isPlainObject(props)) { - for (var key in props) { - val = props[key]; - name = camelize(key); - res[name] = isPlainObject(val) - ? val - : { type: val }; - } - } else { - warn( - "Invalid value for option \"props\": expected an Array or an Object, " + - "but got " + (toRawType(props)) + ".", - vm - ); - } - options.props = res; - } - - /** - * Normalize all injections into Object-based format - */ - function normalizeInject (options, vm) { - var inject = options.inject; - if (!inject) { return } - var normalized = options.inject = {}; - if (Array.isArray(inject)) { - for (var i = 0; i < inject.length; i++) { - normalized[inject[i]] = { from: inject[i] }; - } - } else if (isPlainObject(inject)) { - for (var key in inject) { - var val = inject[key]; - normalized[key] = isPlainObject(val) - ? extend({ from: key }, val) - : { from: val }; - } - } else { - warn( - "Invalid value for option \"inject\": expected an Array or an Object, " + - "but got " + (toRawType(inject)) + ".", - vm - ); - } - } - - /** - * Normalize raw function directives into object format. - */ - function normalizeDirectives (options) { - var dirs = options.directives; - if (dirs) { - for (var key in dirs) { - var def$$1 = dirs[key]; - if (typeof def$$1 === 'function') { - dirs[key] = { bind: def$$1, update: def$$1 }; - } - } - } - } - - function assertObjectType (name, value, vm) { - if (!isPlainObject(value)) { - warn( - "Invalid value for option \"" + name + "\": expected an Object, " + - "but got " + (toRawType(value)) + ".", - vm - ); - } - } - - /** - * Merge two option objects into a new one. - * Core utility used in both instantiation and inheritance. - */ - function mergeOptions ( - parent, - child, - vm - ) { - { - checkComponents(child); - } - - if (typeof child === 'function') { - child = child.options; - } - - normalizeProps(child, vm); - normalizeInject(child, vm); - normalizeDirectives(child); - - // Apply extends and mixins on the child options, - // but only if it is a raw options object that isn't - // the result of another mergeOptions call. - // Only merged options has the _base property. - if (!child._base) { - if (child.extends) { - parent = mergeOptions(parent, child.extends, vm); - } - if (child.mixins) { - for (var i = 0, l = child.mixins.length; i < l; i++) { - parent = mergeOptions(parent, child.mixins[i], vm); - } - } - } - - var options = {}; - var key; - for (key in parent) { - mergeField(key); - } - for (key in child) { - if (!hasOwn(parent, key)) { - mergeField(key); - } - } - function mergeField (key) { - var strat = strats[key] || defaultStrat; - options[key] = strat(parent[key], child[key], vm, key); - } - return options - } - - /** - * Resolve an asset. - * This function is used because child instances need access - * to assets defined in its ancestor chain. - */ - function resolveAsset ( - options, - type, - id, - warnMissing - ) { - /* istanbul ignore if */ - if (typeof id !== 'string') { - return - } - var assets = options[type]; - // check local registration variations first - if (hasOwn(assets, id)) { return assets[id] } - var camelizedId = camelize(id); - if (hasOwn(assets, camelizedId)) { return assets[camelizedId] } - var PascalCaseId = capitalize(camelizedId); - if (hasOwn(assets, PascalCaseId)) { return assets[PascalCaseId] } - // fallback to prototype chain - var res = assets[id] || assets[camelizedId] || assets[PascalCaseId]; - if (warnMissing && !res) { - warn( - 'Failed to resolve ' + type.slice(0, -1) + ': ' + id, - options - ); - } - return res - } - - /* */ - - - - function validateProp ( - key, - propOptions, - propsData, - vm - ) { - var prop = propOptions[key]; - var absent = !hasOwn(propsData, key); - var value = propsData[key]; - // boolean casting - var booleanIndex = getTypeIndex(Boolean, prop.type); - if (booleanIndex > -1) { - if (absent && !hasOwn(prop, 'default')) { - value = false; - } else if (value === '' || value === hyphenate(key)) { - // only cast empty string / same name to boolean if - // boolean has higher priority - var stringIndex = getTypeIndex(String, prop.type); - if (stringIndex < 0 || booleanIndex < stringIndex) { - value = true; - } - } - } - // check default value - if (value === undefined) { - value = getPropDefaultValue(vm, prop, key); - // since the default value is a fresh copy, - // make sure to observe it. - var prevShouldObserve = shouldObserve; - toggleObserving(true); - observe(value); - toggleObserving(prevShouldObserve); - } - { - assertProp(prop, key, value, vm, absent); - } - return value - } - - /** - * Get the default value of a prop. - */ - function getPropDefaultValue (vm, prop, key) { - // no default, return undefined - if (!hasOwn(prop, 'default')) { - return undefined - } - var def = prop.default; - // warn against non-factory defaults for Object & Array - if (isObject(def)) { - warn( - 'Invalid default value for prop "' + key + '": ' + - 'Props with type Object/Array must use a factory function ' + - 'to return the default value.', - vm - ); - } - // the raw prop value was also undefined from previous render, - // return previous default value to avoid unnecessary watcher trigger - if (vm && vm.$options.propsData && - vm.$options.propsData[key] === undefined && - vm._props[key] !== undefined - ) { - return vm._props[key] - } - // call factory function for non-Function types - // a value is Function if its prototype is function even across different execution context - return typeof def === 'function' && getType(prop.type) !== 'Function' - ? def.call(vm) - : def - } - - /** - * Assert whether a prop is valid. - */ - function assertProp ( - prop, - name, - value, - vm, - absent - ) { - if (prop.required && absent) { - warn( - 'Missing required prop: "' + name + '"', - vm - ); - return - } - if (value == null && !prop.required) { - return - } - var type = prop.type; - var valid = !type || type === true; - var expectedTypes = []; - if (type) { - if (!Array.isArray(type)) { - type = [type]; - } - for (var i = 0; i < type.length && !valid; i++) { - var assertedType = assertType(value, type[i]); - expectedTypes.push(assertedType.expectedType || ''); - valid = assertedType.valid; - } - } - - if (!valid) { - warn( - getInvalidTypeMessage(name, value, expectedTypes), - vm - ); - return - } - var validator = prop.validator; - if (validator) { - if (!validator(value)) { - warn( - 'Invalid prop: custom validator check failed for prop "' + name + '".', - vm - ); - } - } - } - - var simpleCheckRE = /^(String|Number|Boolean|Function|Symbol)$/; - - function assertType (value, type) { - var valid; - var expectedType = getType(type); - if (simpleCheckRE.test(expectedType)) { - var t = typeof value; - valid = t === expectedType.toLowerCase(); - // for primitive wrapper objects - if (!valid && t === 'object') { - valid = value instanceof type; - } - } else if (expectedType === 'Object') { - valid = isPlainObject(value); - } else if (expectedType === 'Array') { - valid = Array.isArray(value); - } else { - valid = value instanceof type; - } - return { - valid: valid, - expectedType: expectedType - } - } - - /** - * Use function string name to check built-in types, - * because a simple equality check will fail when running - * across different vms / iframes. - */ - function getType (fn) { - var match = fn && fn.toString().match(/^\s*function (\w+)/); - return match ? match[1] : '' - } - - function isSameType (a, b) { - return getType(a) === getType(b) - } - - function getTypeIndex (type, expectedTypes) { - if (!Array.isArray(expectedTypes)) { - return isSameType(expectedTypes, type) ? 0 : -1 - } - for (var i = 0, len = expectedTypes.length; i < len; i++) { - if (isSameType(expectedTypes[i], type)) { - return i - } - } - return -1 - } - - function getInvalidTypeMessage (name, value, expectedTypes) { - var message = "Invalid prop: type check failed for prop \"" + name + "\"." + - " Expected " + (expectedTypes.map(capitalize).join(', ')); - var expectedType = expectedTypes[0]; - var receivedType = toRawType(value); - var expectedValue = styleValue(value, expectedType); - var receivedValue = styleValue(value, receivedType); - // check if we need to specify expected value - if (expectedTypes.length === 1 && - isExplicable(expectedType) && - !isBoolean(expectedType, receivedType)) { - message += " with value " + expectedValue; - } - message += ", got " + receivedType + " "; - // check if we need to specify received value - if (isExplicable(receivedType)) { - message += "with value " + receivedValue + "."; - } - return message - } - - function styleValue (value, type) { - if (type === 'String') { - return ("\"" + value + "\"") - } else if (type === 'Number') { - return ("" + (Number(value))) - } else { - return ("" + value) - } - } - - function isExplicable (value) { - var explicitTypes = ['string', 'number', 'boolean']; - return explicitTypes.some(function (elem) { return value.toLowerCase() === elem; }) - } - - function isBoolean () { - var args = [], len = arguments.length; - while ( len-- ) args[ len ] = arguments[ len ]; - - return args.some(function (elem) { return elem.toLowerCase() === 'boolean'; }) - } - - /* */ - - function handleError (err, vm, info) { - // Deactivate deps tracking while processing error handler to avoid possible infinite rendering. - // See: https://github.com/vuejs/vuex/issues/1505 - pushTarget(); - try { - if (vm) { - var cur = vm; - while ((cur = cur.$parent)) { - var hooks = cur.$options.errorCaptured; - if (hooks) { - for (var i = 0; i < hooks.length; i++) { - try { - var capture = hooks[i].call(cur, err, vm, info) === false; - if (capture) { return } - } catch (e) { - globalHandleError(e, cur, 'errorCaptured hook'); - } - } - } - } - } - globalHandleError(err, vm, info); - } finally { - popTarget(); - } - } - - function invokeWithErrorHandling ( - handler, - context, - args, - vm, - info - ) { - var res; - try { - res = args ? handler.apply(context, args) : handler.call(context); - if (res && !res._isVue && isPromise(res) && !res._handled) { - res.catch(function (e) { return handleError(e, vm, info + " (Promise/async)"); }); - // issue #9511 - // avoid catch triggering multiple times when nested calls - res._handled = true; - } - } catch (e) { - handleError(e, vm, info); - } - return res - } - - function globalHandleError (err, vm, info) { - if (config.errorHandler) { - try { - return config.errorHandler.call(null, err, vm, info) - } catch (e) { - // if the user intentionally throws the original error in the handler, - // do not log it twice - if (e !== err) { - logError(e, null, 'config.errorHandler'); - } - } - } - logError(err, vm, info); - } - - function logError (err, vm, info) { - { - warn(("Error in " + info + ": \"" + (err.toString()) + "\""), vm); - } - /* istanbul ignore else */ - if ((inBrowser || inWeex) && typeof console !== 'undefined') { - console.error(err); - } else { - throw err - } - } - - /* */ - - var isUsingMicroTask = false; - - var callbacks = []; - var pending = false; - - function flushCallbacks () { - pending = false; - var copies = callbacks.slice(0); - callbacks.length = 0; - for (var i = 0; i < copies.length; i++) { - copies[i](); - } - } - - // Here we have async deferring wrappers using microtasks. - // In 2.5 we used (macro) tasks (in combination with microtasks). - // However, it has subtle problems when state is changed right before repaint - // (e.g. #6813, out-in transitions). - // Also, using (macro) tasks in event handler would cause some weird behaviors - // that cannot be circumvented (e.g. #7109, #7153, #7546, #7834, #8109). - // So we now use microtasks everywhere, again. - // A major drawback of this tradeoff is that there are some scenarios - // where microtasks have too high a priority and fire in between supposedly - // sequential events (e.g. #4521, #6690, which have workarounds) - // or even between bubbling of the same event (#6566). - var timerFunc; - - // The nextTick behavior leverages the microtask queue, which can be accessed - // via either native Promise.then or MutationObserver. - // MutationObserver has wider support, however it is seriously bugged in - // UIWebView in iOS >= 9.3.3 when triggered in touch event handlers. It - // completely stops working after triggering a few times... so, if native - // Promise is available, we will use it: - /* istanbul ignore next, $flow-disable-line */ - if (typeof Promise !== 'undefined' && isNative(Promise)) { - var p = Promise.resolve(); - timerFunc = function () { - p.then(flushCallbacks); - // In problematic UIWebViews, Promise.then doesn't completely break, but - // it can get stuck in a weird state where callbacks are pushed into the - // microtask queue but the queue isn't being flushed, until the browser - // needs to do some other work, e.g. handle a timer. Therefore we can - // "force" the microtask queue to be flushed by adding an empty timer. - if (isIOS) { setTimeout(noop); } - }; - isUsingMicroTask = true; - } else if (!isIE && typeof MutationObserver !== 'undefined' && ( - isNative(MutationObserver) || - // PhantomJS and iOS 7.x - MutationObserver.toString() === '[object MutationObserverConstructor]' - )) { - // Use MutationObserver where native Promise is not available, - // e.g. PhantomJS, iOS7, Android 4.4 - // (#6466 MutationObserver is unreliable in IE11) - var counter = 1; - var observer = new MutationObserver(flushCallbacks); - var textNode = document.createTextNode(String(counter)); - observer.observe(textNode, { - characterData: true - }); - timerFunc = function () { - counter = (counter + 1) % 2; - textNode.data = String(counter); - }; - isUsingMicroTask = true; - } else if (typeof setImmediate !== 'undefined' && isNative(setImmediate)) { - // Fallback to setImmediate. - // Technically it leverages the (macro) task queue, - // but it is still a better choice than setTimeout. - timerFunc = function () { - setImmediate(flushCallbacks); - }; - } else { - // Fallback to setTimeout. - timerFunc = function () { - setTimeout(flushCallbacks, 0); - }; - } - - function nextTick (cb, ctx) { - var _resolve; - callbacks.push(function () { - if (cb) { - try { - cb.call(ctx); - } catch (e) { - handleError(e, ctx, 'nextTick'); - } - } else if (_resolve) { - _resolve(ctx); - } - }); - if (!pending) { - pending = true; - timerFunc(); - } - // $flow-disable-line - if (!cb && typeof Promise !== 'undefined') { - return new Promise(function (resolve) { - _resolve = resolve; - }) - } - } - - /* */ - - var mark; - var measure; - - { - var perf = inBrowser && window.performance; - /* istanbul ignore if */ - if ( - perf && - perf.mark && - perf.measure && - perf.clearMarks && - perf.clearMeasures - ) { - mark = function (tag) { return perf.mark(tag); }; - measure = function (name, startTag, endTag) { - perf.measure(name, startTag, endTag); - perf.clearMarks(startTag); - perf.clearMarks(endTag); - // perf.clearMeasures(name) - }; - } - } - - /* not type checking this file because flow doesn't play well with Proxy */ - - var initProxy; - - { - var allowedGlobals = makeMap( - 'Infinity,undefined,NaN,isFinite,isNaN,' + - 'parseFloat,parseInt,decodeURI,decodeURIComponent,encodeURI,encodeURIComponent,' + - 'Math,Number,Date,Array,Object,Boolean,String,RegExp,Map,Set,JSON,Intl,' + - 'require' // for Webpack/Browserify - ); - - var warnNonPresent = function (target, key) { - warn( - "Property or method \"" + key + "\" is not defined on the instance but " + - 'referenced during render. Make sure that this property is reactive, ' + - 'either in the data option, or for class-based components, by ' + - 'initializing the property. ' + - 'See: https://vuejs.org/v2/guide/reactivity.html#Declaring-Reactive-Properties.', - target - ); - }; - - var warnReservedPrefix = function (target, key) { - warn( - "Property \"" + key + "\" must be accessed with \"$data." + key + "\" because " + - 'properties starting with "$" or "_" are not proxied in the Vue instance to ' + - 'prevent conflicts with Vue internals. ' + - 'See: https://vuejs.org/v2/api/#data', - target - ); - }; - - var hasProxy = - typeof Proxy !== 'undefined' && isNative(Proxy); - - if (hasProxy) { - var isBuiltInModifier = makeMap('stop,prevent,self,ctrl,shift,alt,meta,exact'); - config.keyCodes = new Proxy(config.keyCodes, { - set: function set (target, key, value) { - if (isBuiltInModifier(key)) { - warn(("Avoid overwriting built-in modifier in config.keyCodes: ." + key)); - return false - } else { - target[key] = value; - return true - } - } - }); - } - - var hasHandler = { - has: function has (target, key) { - var has = key in target; - var isAllowed = allowedGlobals(key) || - (typeof key === 'string' && key.charAt(0) === '_' && !(key in target.$data)); - if (!has && !isAllowed) { - if (key in target.$data) { warnReservedPrefix(target, key); } - else { warnNonPresent(target, key); } - } - return has || !isAllowed - } - }; - - var getHandler = { - get: function get (target, key) { - if (typeof key === 'string' && !(key in target)) { - if (key in target.$data) { warnReservedPrefix(target, key); } - else { warnNonPresent(target, key); } - } - return target[key] - } - }; - - initProxy = function initProxy (vm) { - if (hasProxy) { - // determine which proxy handler to use - var options = vm.$options; - var handlers = options.render && options.render._withStripped - ? getHandler - : hasHandler; - vm._renderProxy = new Proxy(vm, handlers); - } else { - vm._renderProxy = vm; - } - }; - } - - /* */ - - var seenObjects = new _Set(); - - /** - * Recursively traverse an object to evoke all converted - * getters, so that every nested property inside the object - * is collected as a "deep" dependency. - */ - function traverse (val) { - _traverse(val, seenObjects); - seenObjects.clear(); - } - - function _traverse (val, seen) { - var i, keys; - var isA = Array.isArray(val); - if ((!isA && !isObject(val)) || Object.isFrozen(val) || val instanceof VNode) { - return - } - if (val.__ob__) { - var depId = val.__ob__.dep.id; - if (seen.has(depId)) { - return - } - seen.add(depId); - } - if (isA) { - i = val.length; - while (i--) { _traverse(val[i], seen); } - } else { - keys = Object.keys(val); - i = keys.length; - while (i--) { _traverse(val[keys[i]], seen); } - } - } - - /* */ - - var normalizeEvent = cached(function (name) { - var passive = name.charAt(0) === '&'; - name = passive ? name.slice(1) : name; - var once$$1 = name.charAt(0) === '~'; // Prefixed last, checked first - name = once$$1 ? name.slice(1) : name; - var capture = name.charAt(0) === '!'; - name = capture ? name.slice(1) : name; - return { - name: name, - once: once$$1, - capture: capture, - passive: passive - } - }); - - function createFnInvoker (fns, vm) { - function invoker () { - var arguments$1 = arguments; - - var fns = invoker.fns; - if (Array.isArray(fns)) { - var cloned = fns.slice(); - for (var i = 0; i < cloned.length; i++) { - invokeWithErrorHandling(cloned[i], null, arguments$1, vm, "v-on handler"); - } - } else { - // return handler return value for single handlers - return invokeWithErrorHandling(fns, null, arguments, vm, "v-on handler") - } - } - invoker.fns = fns; - return invoker - } - - function updateListeners ( - on, - oldOn, - add, - remove$$1, - createOnceHandler, - vm - ) { - var name, def$$1, cur, old, event; - for (name in on) { - def$$1 = cur = on[name]; - old = oldOn[name]; - event = normalizeEvent(name); - if (isUndef(cur)) { - warn( - "Invalid handler for event \"" + (event.name) + "\": got " + String(cur), - vm - ); - } else if (isUndef(old)) { - if (isUndef(cur.fns)) { - cur = on[name] = createFnInvoker(cur, vm); - } - if (isTrue(event.once)) { - cur = on[name] = createOnceHandler(event.name, cur, event.capture); - } - add(event.name, cur, event.capture, event.passive, event.params); - } else if (cur !== old) { - old.fns = cur; - on[name] = old; - } - } - for (name in oldOn) { - if (isUndef(on[name])) { - event = normalizeEvent(name); - remove$$1(event.name, oldOn[name], event.capture); - } - } - } - - /* */ - - function mergeVNodeHook (def, hookKey, hook) { - if (def instanceof VNode) { - def = def.data.hook || (def.data.hook = {}); - } - var invoker; - var oldHook = def[hookKey]; - - function wrappedHook () { - hook.apply(this, arguments); - // important: remove merged hook to ensure it's called only once - // and prevent memory leak - remove(invoker.fns, wrappedHook); - } - - if (isUndef(oldHook)) { - // no existing hook - invoker = createFnInvoker([wrappedHook]); - } else { - /* istanbul ignore if */ - if (isDef(oldHook.fns) && isTrue(oldHook.merged)) { - // already a merged invoker - invoker = oldHook; - invoker.fns.push(wrappedHook); - } else { - // existing plain hook - invoker = createFnInvoker([oldHook, wrappedHook]); - } - } - - invoker.merged = true; - def[hookKey] = invoker; - } - - /* */ - - function extractPropsFromVNodeData ( - data, - Ctor, - tag - ) { - // we are only extracting raw values here. - // validation and default values are handled in the child - // component itself. - var propOptions = Ctor.options.props; - if (isUndef(propOptions)) { - return - } - var res = {}; - var attrs = data.attrs; - var props = data.props; - if (isDef(attrs) || isDef(props)) { - for (var key in propOptions) { - var altKey = hyphenate(key); - { - var keyInLowerCase = key.toLowerCase(); - if ( - key !== keyInLowerCase && - attrs && hasOwn(attrs, keyInLowerCase) - ) { - tip( - "Prop \"" + keyInLowerCase + "\" is passed to component " + - (formatComponentName(tag || Ctor)) + ", but the declared prop name is" + - " \"" + key + "\". " + - "Note that HTML attributes are case-insensitive and camelCased " + - "props need to use their kebab-case equivalents when using in-DOM " + - "templates. You should probably use \"" + altKey + "\" instead of \"" + key + "\"." - ); - } - } - checkProp(res, props, key, altKey, true) || - checkProp(res, attrs, key, altKey, false); - } - } - return res - } - - function checkProp ( - res, - hash, - key, - altKey, - preserve - ) { - if (isDef(hash)) { - if (hasOwn(hash, key)) { - res[key] = hash[key]; - if (!preserve) { - delete hash[key]; - } - return true - } else if (hasOwn(hash, altKey)) { - res[key] = hash[altKey]; - if (!preserve) { - delete hash[altKey]; - } - return true - } - } - return false - } - - /* */ - - // The template compiler attempts to minimize the need for normalization by - // statically analyzing the template at compile time. - // - // For plain HTML markup, normalization can be completely skipped because the - // generated render function is guaranteed to return Array. There are - // two cases where extra normalization is needed: - - // 1. When the children contains components - because a functional component - // may return an Array instead of a single root. In this case, just a simple - // normalization is needed - if any child is an Array, we flatten the whole - // thing with Array.prototype.concat. It is guaranteed to be only 1-level deep - // because functional components already normalize their own children. - function simpleNormalizeChildren (children) { - for (var i = 0; i < children.length; i++) { - if (Array.isArray(children[i])) { - return Array.prototype.concat.apply([], children) - } - } - return children - } - - // 2. When the children contains constructs that always generated nested Arrays, - // e.g.