10|9 Films

Hotel Script Fivem Apr 2026

-- Target interaction exports['ox_target']:addLocalEntity(npc, { { name = 'hotel_reception', label = 'Rent a Room', icon = 'fas fa-key', onSelect = function() TriggerServerEvent('hotel:checkRentStatus') end } }) end)

if roomNumber == nil then -- Find free room MySQL.query('SELECT room_number FROM hotel_rentals WHERE paid_until > ?', {os.time()}, function(occupied) local occupiedRooms = {} for _, v in pairs(occupied) do occupiedRooms[v.room_number] = true end

window.addEventListener('message', function(event) { if (event.data.action === 'openPayment') { currentRoom = event.data.room; currentPrice = event.data.price; document.getElementById('roomDisplay').innerText = currentRoom ? `Room: ${currentRoom}` : 'Room: Any available'; document.getElementById('price').innerText = currentPrice; } }); hotel script fivem

-- Payment interval (in minutes) Config.PaymentInterval = 60

function removeMoney(source, amount) if Config.Framework == 'esx' then local xPlayer = ESX.GetPlayerFromId(source) if xPlayer.getMoney() >= amount then xPlayer.removeMoney(amount) return true end else local Player = QBCore.Functions.GetPlayer(source) if Player.Functions.RemoveMoney('cash', amount) then return true end end return false end ' for $'

shared_scripts { '@ox_lib/init.lua', -- optional but recommended '@es_extended/imports.lua' -- if using ESX }

TriggerClientEvent('hotel:assignRoom', src, roomNumber) Notify(src, 'You rented room ' .. roomNumber .. ' for $' .. price, 'success') else Notify(src, 'Not enough money', 'error') end end) ' for $' .. price

-- Receive notification to open payment UI RegisterNetEvent('hotel:requestPayment') AddEventHandler('hotel:requestPayment', function(roomNumber, price) SetNuiFocus(true, true) SendNUIMessage({ action = 'openPayment', room = roomNumber, price = price }) end)

server_scripts { 'config.lua', 'server.lua' }

client_scripts { 'config.lua', 'client.lua' }

MySQL.query('SELECT room_number, paid_until FROM hotel_rentals WHERE citizenid = ?', {identifier}, function(result) if result[1] then local paidUntil = result[1].paid_until if os.time() < paidUntil then TriggerClientEvent('hotel:requestPayment', src, result[1].room_number, Config.RoomPrice) else MySQL.query('DELETE FROM hotel_rentals WHERE citizenid = ?', {identifier}) TriggerClientEvent('hotel:requestPayment', src, nil, Config.RoomPrice) end else TriggerClientEvent('hotel:requestPayment', src, nil, Config.RoomPrice) end end) end)