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

113 lines
4.7 KiB
Lua
Raw Normal View History

2025-07-27 05:45:43 +02:00
local QBCore = exports['qb-core']:GetCoreObject()
-- Schredder Inventar öffnen
2025-07-27 21:33:14 +02:00
RegisterNetEvent('shredder:server:openInventory', function(shredderID)
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-27 22:23:08 +02:00
-- Use the correct export for opening inventory
-- According to docs: OpenInventory(src, invType, invId, invData, openType)
exports["tgiann-inventory"]:OpenInventory(src, "stash", shredderID, {
maxweight = 50000, -- 50kg max
slots = 20, -- 20 Slots
label = 'Müllschredder'
})
2025-07-27 05:45:43 +02:00
end)
-- Items aus Schredder abrufen
2025-07-27 21:33:14 +02:00
RegisterNetEvent('shredder:server:getItems', function(shredderID)
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-27 22:23:08 +02:00
-- Use the correct export for getting secondary inventory items
-- According to docs: GetSecondaryInventoryItems(invType, invName)
local items = exports["tgiann-inventory"]:GetSecondaryInventoryItems("stash", shredderID)
2025-07-27 22:17:12 +02:00
2025-07-27 22:23:08 +02:00
-- If items is nil, provide an empty table
if items == nil then items = {} end
2025-07-27 05:45:43 +02:00
2025-07-27 22:17:12 +02:00
TriggerClientEvent('shredder:client:showMenu', src, items, shredderID)
2025-07-27 05:45:43 +02:00
end)
-- Einzelnes Item vernichten
2025-07-27 21:33:14 +02:00
RegisterNetEvent('shredder:server:destroySingle', function(itemName, amount, slot, shredderID)
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-27 22:23:08 +02:00
-- Use the correct export for removing item from secondary inventory
-- According to docs: RemoveItemFromSecondaryInventory(invType, invName, item, amount, slot, metadata)
local success = exports["tgiann-inventory"]:RemoveItemFromSecondaryInventory("stash", shredderID, itemName, amount, slot)
2025-07-27 05:45:43 +02:00
2025-07-27 22:23:08 +02:00
if success then
2025-07-27 05:45:43 +02:00
-- Log für Admins
print('^3[SHREDDER]^7 ' .. GetPlayerName(src) .. ' (' .. Player.PlayerData.citizenid .. ') hat ' .. amount .. 'x ' .. itemName .. ' vernichtet')
-- Discord Webhook
TriggerEvent('qb-log:server:CreateLog', 'shredder', 'Item Vernichtet', 'orange',
'**Spieler:** ' .. GetPlayerName(src) .. '\n**Citizen ID:** ' .. Player.PlayerData.citizenid .. '\n**Item:** ' .. amount .. 'x ' .. itemName .. '\n**Aktion:** Einzelnes Item vernichtet')
TriggerClientEvent('shredder:client:itemDestroyed', src, amount .. 'x ' .. itemName .. ' wurde vernichtet!')
-- Menü neu laden
Wait(1000)
2025-07-27 22:23:08 +02:00
TriggerServerEvent('shredder:server:getItems', shredderID)
2025-07-27 05:45:43 +02:00
else
TriggerClientEvent('QBCore:Notify', src, 'Fehler beim Vernichten des Items!', 'error')
end
end)
-- Alle Items vernichten
2025-07-27 21:33:14 +02:00
RegisterNetEvent('shredder:server:destroyAll', function(shredderID)
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-27 22:23:08 +02:00
-- Use the correct export for getting secondary inventory items
local items = exports["tgiann-inventory"]:GetSecondaryInventoryItems("stash", shredderID)
2025-07-27 05:45:43 +02:00
if not items or next(items) == nil then
TriggerClientEvent('QBCore:Notify', src, 'Der Schredder ist bereits leer!', 'error')
return
end
local destroyedItems = {}
local totalItems = 0
-- Alle Items vernichten
for slot, item in pairs(items) do
if item and item.amount and item.amount > 0 then
2025-07-27 22:23:08 +02:00
-- Use the correct export for removing item from secondary inventory
local success = exports["tgiann-inventory"]:RemoveItemFromSecondaryInventory("stash", shredderID, item.name, item.amount, slot)
if success then
2025-07-27 05:45:43 +02:00
table.insert(destroyedItems, {name = item.name, amount = item.amount})
totalItems = totalItems + item.amount
end
end
end
if #destroyedItems > 0 then
-- Log für Admins
print('^3[SHREDDER]^7 ' .. GetPlayerName(src) .. ' (' .. Player.PlayerData.citizenid .. ') hat ALLE Items vernichtet (' .. totalItems .. ' Items)')
-- Discord Webhook mit Item Liste
local itemList = ""
for _, item in pairs(destroyedItems) do
itemList = itemList .. '' .. item.amount .. 'x ' .. item.name .. '\n'
end
TriggerEvent('qb-log:server:CreateLog', 'shredder', 'Alle Items Vernichtet', 'red',
'**Spieler:** ' .. GetPlayerName(src) .. '\n**Citizen ID:** ' .. Player.PlayerData.citizenid .. '\n**Aktion:** Alle Items vernichtet\n**Anzahl Items:** ' .. totalItems .. '\n**Items:**\n' .. itemList)
TriggerClientEvent('shredder:client:itemDestroyed', src, 'ALLE Items (' .. totalItems .. ' Stück) wurden vernichtet!')
else
TriggerClientEvent('QBCore:Notify', src, 'Keine Items zum Vernichten gefunden!', 'error')
end
end)