You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Mekanome/dist/managers/bindings-manager.lua

326 lines
10 KiB

6 months ago
--[[ Generated with https://github.com/TypeScriptToLua/TypeScriptToLua ]]
-- Lua Library inline imports
local function __TS__Class(self)
local c = {prototype = {}}
c.prototype.__index = c.prototype
c.prototype.constructor = c
return c
end
local __TS__Symbol, Symbol
do
local symbolMetatable = {__tostring = function(self)
return ("Symbol(" .. (self.description or "")) .. ")"
end}
function __TS__Symbol(description)
return setmetatable({description = description}, symbolMetatable)
end
Symbol = {
asyncDispose = __TS__Symbol("Symbol.asyncDispose"),
dispose = __TS__Symbol("Symbol.dispose"),
iterator = __TS__Symbol("Symbol.iterator"),
hasInstance = __TS__Symbol("Symbol.hasInstance"),
species = __TS__Symbol("Symbol.species"),
toStringTag = __TS__Symbol("Symbol.toStringTag")
}
end
local __TS__Iterator
do
local function iteratorGeneratorStep(self)
local co = self.____coroutine
local status, value = coroutine.resume(co)
if not status then
error(value, 0)
end
if coroutine.status(co) == "dead" then
return
end
return true, value
end
local function iteratorIteratorStep(self)
local result = self:next()
if result.done then
return
end
return true, result.value
end
local function iteratorStringStep(self, index)
index = index + 1
if index > #self then
return
end
return index, string.sub(self, index, index)
end
function __TS__Iterator(iterable)
if type(iterable) == "string" then
return iteratorStringStep, iterable, 0
elseif iterable.____coroutine ~= nil then
return iteratorGeneratorStep, iterable
elseif iterable[Symbol.iterator] then
local iterator = iterable[Symbol.iterator](iterable)
return iteratorIteratorStep, iterator
else
return ipairs(iterable)
end
end
end
local Map
do
Map = __TS__Class()
Map.name = "Map"
function Map.prototype.____constructor(self, entries)
self[Symbol.toStringTag] = "Map"
self.items = {}
self.size = 0
self.nextKey = {}
self.previousKey = {}
if entries == nil then
return
end
local iterable = entries
if iterable[Symbol.iterator] then
local iterator = iterable[Symbol.iterator](iterable)
while true do
local result = iterator:next()
if result.done then
break
end
local value = result.value
self:set(value[1], value[2])
end
else
local array = entries
for ____, kvp in ipairs(array) do
self:set(kvp[1], kvp[2])
end
end
end
function Map.prototype.clear(self)
self.items = {}
self.nextKey = {}
self.previousKey = {}
self.firstKey = nil
self.lastKey = nil
self.size = 0
end
function Map.prototype.delete(self, key)
local contains = self:has(key)
if contains then
self.size = self.size - 1
local next = self.nextKey[key]
local previous = self.previousKey[key]
if next ~= nil and previous ~= nil then
self.nextKey[previous] = next
self.previousKey[next] = previous
elseif next ~= nil then
self.firstKey = next
self.previousKey[next] = nil
elseif previous ~= nil then
self.lastKey = previous
self.nextKey[previous] = nil
else
self.firstKey = nil
self.lastKey = nil
end
self.nextKey[key] = nil
self.previousKey[key] = nil
end
self.items[key] = nil
return contains
end
function Map.prototype.forEach(self, callback)
for ____, key in __TS__Iterator(self:keys()) do
callback(nil, self.items[key], key, self)
end
end
function Map.prototype.get(self, key)
return self.items[key]
end
function Map.prototype.has(self, key)
return self.nextKey[key] ~= nil or self.lastKey == key
end
function Map.prototype.set(self, key, value)
local isNewValue = not self:has(key)
if isNewValue then
self.size = self.size + 1
end
self.items[key] = value
if self.firstKey == nil then
self.firstKey = key
self.lastKey = key
elseif isNewValue then
self.nextKey[self.lastKey] = key
self.previousKey[key] = self.lastKey
self.lastKey = key
end
return self
end
Map.prototype[Symbol.iterator] = function(self)
return self:entries()
end
function Map.prototype.entries(self)
local items = self.items
local nextKey = self.nextKey
local key = self.firstKey
return {
[Symbol.iterator] = function(self)
return self
end,
next = function(self)
local result = {done = not key, value = {key, items[key]}}
key = nextKey[key]
return result
end
}
end
function Map.prototype.keys(self)
local nextKey = self.nextKey
local key = self.firstKey
return {
[Symbol.iterator] = function(self)
return self
end,
next = function(self)
local result = {done = not key, value = key}
key = nextKey[key]
return result
end
}
end
function Map.prototype.values(self)
local items = self.items
local nextKey = self.nextKey
local key = self.firstKey
return {
[Symbol.iterator] = function(self)
return self
end,
next = function(self)
local result = {done = not key, value = items[key]}
key = nextKey[key]
return result
end
}
end
Map[Symbol.species] = Map
end
local function __TS__New(target, ...)
local instance = setmetatable({}, target.prototype)
instance:____constructor(...)
return instance
end
-- End of Lua Library inline imports
local ____exports = {}
local _, _Mekanome = ...
local Mekanome = _Mekanome
local ActionBarButtonNames = {
"ActionButton",
"MultiBarBottomLeftButton",
"MultiBarBottomRightButton",
"MultiBarLeftButton",
"MultiBarRightButton",
"MultiBar5Button",
"MultiBar6Button",
"MultiBar7Button"
}
local BarMap = {
ActionButton = "ACTIONBUTTON",
MultiBarBottomLeftButton = "MULTIACTIONBAR1BUTTON",
MultiBarBottomRightButton = "MULTIACTIONBAR2BUTTON",
MultiBarRightButton = "MULTIACTIONBAR3BUTTON",
MultiBarLeftButton = "MULTIACTIONBAR4BUTTON",
MultiBar5Button = "MULTIACTIONBAR5BUTTON",
MultiBar6Button = "MULTIACTIONBAR6BUTTON"
}
local bindings = __TS__New(Map)
local isInitialized = false
--- Loops through all of the WoW action bar buttons, checks to see if there is a spell
-- or item on them, then stores that relationship for later use.
local function CheckBindings(self)
bindings:clear()
for ____, bar in ipairs(ActionBarButtonNames) do
for i = 1, 12 do
local actionButton = bar .. tostring(i)
local button = _G[actionButton]
if button ~= nil and type(button) == "table" and button.action ~= nil then
local ____type, id = GetActionInfo(button.action)
if ____type == "spell" or ____type == "item" then
local barName = BarMap[bar]
local binding = tostring(barName) .. tostring(i)
bindings:set(button.action, {binding = binding, id = id, type = ____type})
end
end
end
end
Mekanome.Print({
text = tostring(bindings.size),
prefix = "Bindings Update",
level = "warn"
})
end
--- Returns the ActionButtons binding for a given spell.
--
-- @param spell
-- @returns ActionButtons
local function GetBindingForSpell(spell)
local binding = nil
for ____, ____value in __TS__Iterator(bindings) do
local bindingInfo = ____value[2]
if bindingInfo.id == spell.id then
binding = bindingInfo.binding
break
end
end
return binding
end
local function CallBinding(binding)
RunBinding(binding)
RunBinding(binding, "up")
end
--- Initializes the bindings manager.
local function Init()
if isInitialized == false then
CheckBindings(nil)
Mekanome.EventManager.RegisterEventHandler(
"ACTIONBAR_SLOT_CHANGED",
function(____, args)
local slot = args[1]
local binding = bindings:get(slot)
local ____type, id = GetActionInfo(slot)
if binding ~= nil then
if ____type ~= binding.type or id ~= binding.id then
CheckBindings(nil)
end
else
if ____type == "spell" or ____type == "item" then
CheckBindings(nil)
end
end
end,
"bm_action_bar_slot_changed"
)
Mekanome.EventManager.RegisterEventHandler(
"UPDATE_BONUS_ACTIONBAR",
function()
CheckBindings(nil)
end,
"bm_player_mount_display"
)
Mekanome.EventManager.RegisterEventHandler(
"PLAYER_SPECIALIZATION_CHANGED",
function()
CheckBindings(nil)
end,
"bm_spec_change"
)
isInitialized = true
end
end
local _BindingsManager = {Init = Init, GetBindingForSpell = GetBindingForSpell, CallBinding = CallBinding}
Mekanome.BindingsManager = _BindingsManager
____exports.default = {}
return ____exports