Scripts/resources/[standalone]/ox_lib/imports/addKeybind/client.lua

84 lines
2.4 KiB
Lua
Raw Normal View History

2024-12-29 20:02:43 +00:00
if cache.game == 'redm' then return end
---@class KeybindProps
---@field name string
---@field description string
---@field defaultMapper? string (see: https://docs.fivem.net/docs/game-references/input-mapper-parameter-ids/)
---@field defaultKey? string
---@field disabled? boolean
---@field disable? fun(self: CKeybind, toggle: boolean)
---@field onPressed? fun(self: CKeybind)
---@field onReleased? fun(self: CKeybind)
---@field [string] any
---@class CKeybind : KeybindProps
---@field currentKey string
---@field disabled boolean
2024-12-30 10:15:34 +00:00
---@field isPressed boolean
2024-12-29 20:02:43 +00:00
---@field hash number
---@field getCurrentKey fun(): string
2024-12-30 10:15:34 +00:00
---@field isControlPressed fun(): boolean
2024-12-29 20:02:43 +00:00
local keybinds = {}
local IsPauseMenuActive = IsPauseMenuActive
local GetControlInstructionalButton = GetControlInstructionalButton
local keybind_mt = {
disabled = false,
2024-12-30 10:15:34 +00:00
isPressed = false,
2024-12-29 20:02:43 +00:00
defaultKey = '',
defaultMapper = 'keyboard',
}
function keybind_mt:__index(index)
return index == 'currentKey' and self:getCurrentKey() or keybind_mt[index]
end
function keybind_mt:getCurrentKey()
return GetControlInstructionalButton(0, self.hash, true):sub(3)
end
2024-12-30 10:15:34 +00:00
function keybind_mt:isControlPressed()
return self.isPressed
end
2024-12-29 20:02:43 +00:00
function keybind_mt:disable(toggle)
self.disabled = toggle
end
---@param data KeybindProps
---@return CKeybind
function lib.addKeybind(data)
---@cast data CKeybind
data.hash = joaat('+' .. data.name) | 0x80000000
keybinds[data.name] = setmetatable(data, keybind_mt)
RegisterCommand('+' .. data.name, function()
2024-12-30 10:15:34 +00:00
if data.disabled or IsPauseMenuActive() then return end
data.isPressed = true
if data.onPressed then data:onPressed() end
2024-12-29 20:02:43 +00:00
end)
RegisterCommand('-' .. data.name, function()
2024-12-30 10:15:34 +00:00
if data.disabled or IsPauseMenuActive() then return end
data.isPressed = false
if data.onReleased then data:onReleased() end
2024-12-29 20:02:43 +00:00
end)
RegisterKeyMapping('+' .. data.name, data.description, data.defaultMapper, data.defaultKey)
if data.secondaryKey then
RegisterKeyMapping('~!+' .. data.name, data.description, data.secondaryMapper or data.defaultMapper, data.secondaryKey)
end
SetTimeout(500, function()
TriggerEvent('chat:removeSuggestion', ('/+%s'):format(data.name))
TriggerEvent('chat:removeSuggestion', ('/-%s'):format(data.name))
end)
return data
end
return lib.addKeybind