From 53204a4c7f881701193e6bff94d40c4d70c148bf Mon Sep 17 00:00:00 2001 From: Solareon <769465+solareon@users.noreply.github.com> Date: Sun, 29 Sep 2024 12:24:32 +0200 Subject: [PATCH] refactor(server): extract vehicle keys function to config (#105) --- config/server.lua | 9 ++++++++- server/main.lua | 18 +++++++++--------- 2 files changed, 17 insertions(+), 10 deletions(-) diff --git a/config/server.lua b/config/server.lua index b745188..f91799d 100644 --- a/config/server.lua +++ b/config/server.lua @@ -7,5 +7,12 @@ return { preventSelling = false, -- prevents players from using /transfervehicle if financed }, saleTimeout = 60000, -- Delay between attempts to sell/gift a vehicle. Prevents abuse - deleteUnpaidFinancedVehicle = false -- true to delete unpaid vehicles from database, otherwise it will edit citizenid to hide from db select + deleteUnpaidFinancedVehicle = false, -- true to delete unpaid vehicles from database, otherwise it will edit citizenid to hide from db select + + ---@param src number Player Server ID + ---@param plate string Vehicle Plate + ---@param vehicle number Vehicle Entity ID + giveKeys = function(src, plate, vehicle) + exports.qbx_vehiclekeys:GiveKeys(src, vehicle) + end } \ No newline at end of file diff --git a/server/main.lua b/server/main.lua index a81637e..6c5e5d9 100644 --- a/server/main.lua +++ b/server/main.lua @@ -285,13 +285,13 @@ end) ---@return number|nil local function spawnVehicle(src, data) local coords, vehicleId = data.coords, data.vehicleId - local vehicle = vehicleId and qbx_vehicles:GetPlayerVehicle(vehicleId) or data - if not vehicle then return end + local newVehicle = vehicleId and qbx_vehicles:GetPlayerVehicle(vehicleId) or data + if not newVehicle then return end - local plate = vehicle.plate or vehicle.props.plate + local plate = newVehicle.plate or newVehicle.props.plate - local netId, veh = qbx.spawnVehicle({ - model = vehicle.modelName, + local netId, vehicle = qbx.spawnVehicle({ + model = newVehicle.modelName, spawnSource = coords, warp = GetPlayerPed(src), props = { @@ -301,11 +301,11 @@ local function spawnVehicle(src, data) if not netId or netId == 0 then return end - if not veh or veh == 0 then return end + if not vehicle or vehicle == 0 then return end - if vehicleId then Entity(veh).state:set('vehicleid', vehicleId, false) end + if vehicleId then Entity(vehicle).state:set('vehicleid', vehicleId, false) end - TriggerClientEvent('vehiclekeys:client:SetOwner', src, plate) + config.giveKeys(src, plate, vehicle) return netId end @@ -707,7 +707,7 @@ lib.addCommand('transfervehicle', { end qbx_vehicles:SetPlayerVehicleOwner(row.id, targetcid) - TriggerClientEvent('vehiclekeys:client:SetOwner', buyerId, row.props.plate) + config.giveKeys(buyerId, row.plate, vehicle) local sellerMessage = sellAmount > 0 and locale('success.soldfor') .. lib.math.groupdigits(sellAmount) or locale('success.gifted') local buyerMessage = sellAmount > 0 and locale('success.boughtfor') .. lib.math.groupdigits(sellAmount) or locale('success.received_gift')