1
0
Fork 0
forked from Simnation/Main
Main/resources/[inventory]/nordi_schredder/server.lua

122 lines
4.4 KiB
Lua
Raw Normal View History

2025-07-27 05:45:43 +02:00
local QBCore = exports['qb-core']:GetCoreObject()
2025-07-28 01:38:05 +02:00
-- Container inventory open
2025-07-28 01:57:56 +02:00
RegisterNetEvent('disposal:server:openInventory', function(containerID)
2025-07-27 05:45:43 +02:00
local src = source
local Player = QBCore.Functions.GetPlayer(src)
if not Player then return end
2025-07-28 01:38:05 +02:00
-- Open the inventory
2025-07-28 01:05:18 +02:00
exports["tgiann-inventory"]:OpenInventory(src, "stash", containerID, {
2025-07-27 22:23:08 +02:00
maxweight = 50000, -- 50kg max
slots = 20, -- 20 Slots
2025-07-28 01:57:56 +02:00
label = 'Müllschredder'
2025-07-27 22:23:08 +02:00
})
2025-07-27 05:45:43 +02:00
end)
2025-07-28 01:38:05 +02:00
-- Get items from container
2025-07-28 01:57:56 +02:00
RegisterNetEvent('disposal:server:getItems', function(containerID)
2025-07-27 05:45:43 +02:00
local src = source
local Player = QBCore.Functions.GetPlayer(src)
if not Player then return end
2025-07-28 01:38:05 +02:00
-- Get items from the container
2025-07-28 01:05:18 +02:00
local items = exports["tgiann-inventory"]:GetSecondaryInventoryItems("stash", containerID)
2025-07-27 22:17:12 +02:00
2025-07-28 01:38:05 +02:00
-- If items is nil, provide an empty table
2025-07-27 22:23:08 +02:00
if items == nil then items = {} end
2025-07-27 05:45:43 +02:00
2025-07-28 01:57:56 +02:00
TriggerClientEvent('disposal:client:showMenu', src, items, containerID)
2025-07-27 05:45:43 +02:00
end)
2025-07-28 01:38:05 +02:00
-- Dispose single item
2025-07-28 01:57:56 +02:00
RegisterNetEvent('disposal:server:disposeSingle', function(itemName, amount, slot, containerID)
2025-07-27 05:45:43 +02:00
local src = source
local Player = QBCore.Functions.GetPlayer(src)
if not Player then return end
2025-07-28 01:52:45 +02:00
-- Remove the item from the container
local success = exports["tgiann-inventory"]:RemoveItemFromSecondaryInventory("stash", containerID, itemName, amount, slot)
if success then
2025-07-28 01:38:05 +02:00
-- Log for admins
2025-07-28 01:57:56 +02:00
print('^3[DISPOSAL]^7 ' .. GetPlayerName(src) .. ' (' .. Player.PlayerData.citizenid .. ') has destroyed ' .. amount .. 'x ' .. itemName)
2025-07-27 05:45:43 +02:00
-- Discord Webhook
2025-07-28 01:38:05 +02:00
TriggerEvent('qb-log:server:CreateLog', 'disposal',
2025-07-28 01:57:56 +02:00
'Item Destroyed',
'orange',
2025-07-28 01:38:05 +02:00
'**Player:** ' .. GetPlayerName(src) ..
2025-07-28 01:05:18 +02:00
'\n**Citizen ID:** ' .. Player.PlayerData.citizenid ..
'\n**Item:** ' .. amount .. 'x ' .. itemName ..
2025-07-28 01:57:56 +02:00
'\n**Action:** Item destroyed')
2025-07-28 01:52:45 +02:00
2025-07-28 01:57:56 +02:00
local message = amount .. 'x ' .. itemName .. ' wurde vernichtet!'
TriggerClientEvent('disposal:client:itemDisposed', src, message)
2025-07-27 05:45:43 +02:00
2025-07-28 01:38:05 +02:00
-- Reload menu
2025-07-27 05:45:43 +02:00
Wait(1000)
2025-07-28 01:57:56 +02:00
TriggerEvent('disposal:server:getItems', containerID)
2025-07-28 01:52:45 +02:00
else
TriggerClientEvent('QBCore:Notify', src, 'Fehler beim Entsorgen des Items!', 'error')
2025-07-27 05:45:43 +02:00
end
end)
2025-07-28 01:38:05 +02:00
-- Dispose all items
2025-07-28 01:57:56 +02:00
RegisterNetEvent('disposal:server:disposeAll', function(containerID)
2025-07-27 05:45:43 +02:00
local src = source
local Player = QBCore.Functions.GetPlayer(src)
if not Player then return end
2025-07-28 01:38:05 +02:00
-- Get all items in the container
2025-07-28 01:05:18 +02:00
local items = exports["tgiann-inventory"]:GetSecondaryInventoryItems("stash", containerID)
2025-07-27 05:45:43 +02:00
if not items or next(items) == nil then
2025-07-28 01:57:56 +02:00
TriggerClientEvent('QBCore:Notify', src, 'Der Schredder ist bereits leer!', 'error')
2025-07-27 05:45:43 +02:00
return
end
2025-07-28 01:52:45 +02:00
local disposedItems = {}
local totalItems = 0
-- Dispose all items
for slot, item in pairs(items) do
if item and item.amount and item.amount > 0 then
local success = exports["tgiann-inventory"]:RemoveItemFromSecondaryInventory("stash", containerID, item.name, item.amount, slot)
if success then
table.insert(disposedItems, {name = item.name, amount = item.amount})
2025-07-27 05:45:43 +02:00
totalItems = totalItems + item.amount
end
end
2025-07-28 01:52:45 +02:00
end
if #disposedItems > 0 then
2025-07-28 01:38:05 +02:00
-- Log for admins
2025-07-28 01:57:56 +02:00
print('^3[DISPOSAL]^7 ' .. GetPlayerName(src) .. ' (' .. Player.PlayerData.citizenid .. ') has destroyed ALL items (' .. totalItems .. ' items)')
2025-07-27 05:45:43 +02:00
2025-07-28 01:38:05 +02:00
-- Discord Webhook with item list
2025-07-27 05:45:43 +02:00
local itemList = ""
2025-07-28 01:52:45 +02:00
for _, item in pairs(disposedItems) do
itemList = itemList .. '' .. item.amount .. 'x ' .. item.name .. '\n'
2025-07-27 05:45:43 +02:00
end
2025-07-28 01:38:05 +02:00
TriggerEvent('qb-log:server:CreateLog', 'disposal',
2025-07-28 01:57:56 +02:00
'All Items Destroyed',
'red',
2025-07-28 01:38:05 +02:00
'**Player:** ' .. GetPlayerName(src) ..
2025-07-28 01:05:18 +02:00
'\n**Citizen ID:** ' .. Player.PlayerData.citizenid ..
2025-07-28 01:57:56 +02:00
'\n**Action:** All items destroyed' ..
2025-07-28 01:38:05 +02:00
'\n**Total Items:** ' .. totalItems ..
2025-07-28 01:05:18 +02:00
'\n**Items:**\n' .. itemList)
2025-07-28 01:57:56 +02:00
local message = 'ALLE Items (' .. totalItems .. ' Stück) wurden vernichtet!'
TriggerClientEvent('disposal:client:itemDisposed', src, message)
2025-07-28 01:52:45 +02:00
else
TriggerClientEvent('QBCore:Notify', src, 'Keine Items zum Entsorgen gefunden!', 'error')
2025-07-27 05:45:43 +02:00
end
end)