mirror of
https://github.com/britzl/monarch.git
synced 2025-11-26 19:00:53 +01:00
Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
679482f84d | ||
|
|
4c6e26fd71 | ||
|
|
00c30792a9 |
@@ -29,7 +29,7 @@ function on_input(self, action_id, action)
|
|||||||
end
|
end
|
||||||
elseif gui.pick_node(self.no, action.x, action.y) then
|
elseif gui.pick_node(self.no, action.x, action.y) then
|
||||||
print("no")
|
print("no")
|
||||||
monarch.back(function()
|
monarch.back(nil, nil, function()
|
||||||
print("back from popup done")
|
print("back from popup done")
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -27,7 +27,7 @@ function on_input(self, action_id, action)
|
|||||||
end)
|
end)
|
||||||
elseif gui.pick_node(self.cancel, action.x, action.y) then
|
elseif gui.pick_node(self.cancel, action.x, action.y) then
|
||||||
print("cancel")
|
print("cancel")
|
||||||
monarch.back(function()
|
monarch.back(nil, nil, function()
|
||||||
print("back from popup done")
|
print("back from popup done")
|
||||||
end)
|
end)
|
||||||
elseif gui.pick_node(self.about, action.x, action.y) then
|
elseif gui.pick_node(self.about, action.x, action.y) then
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ function on_input(self, action_id, action)
|
|||||||
end)
|
end)
|
||||||
elseif gui.pick_node(self.back, action.x, action.y) then
|
elseif gui.pick_node(self.back, action.x, action.y) then
|
||||||
print("back")
|
print("back")
|
||||||
monarch.back(function()
|
monarch.back(nil, nil, function()
|
||||||
print("back from pregame done")
|
print("back from pregame done")
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -462,8 +462,7 @@ local function preload(screen)
|
|||||||
screen.preloading = true
|
screen.preloading = true
|
||||||
if screen.proxy then
|
if screen.proxy then
|
||||||
log("preload() proxy")
|
log("preload() proxy")
|
||||||
local missing_resources = collectionproxy.missing_resources(screen.proxy)
|
if M.has_missing_resources(screen.id) then
|
||||||
if #missing_resources > 0 then
|
|
||||||
local error_message = ("preload() collection proxy %s is missing resources"):format(tostring(screen.id))
|
local error_message = ("preload() collection proxy %s is missing resources"):format(tostring(screen.id))
|
||||||
log(error_message)
|
log(error_message)
|
||||||
screen.preloading = false
|
screen.preloading = false
|
||||||
@@ -924,7 +923,7 @@ function M.hide(id, cb)
|
|||||||
log("hide() you can only hide the screen at the top of the stack", id)
|
log("hide() you can only hide the screen at the top of the stack", id)
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
return M.back(id, cb)
|
return M.back(nil, nil, cb)
|
||||||
else
|
else
|
||||||
log("hide() queuing action", id)
|
log("hide() queuing action", id)
|
||||||
queue_action(function(action_done, action_error)
|
queue_action(function(action_done, action_error)
|
||||||
@@ -986,17 +985,6 @@ end
|
|||||||
-- @param cb (function) - Optional callback to invoke when the previous screen is visible again
|
-- @param cb (function) - Optional callback to invoke when the previous screen is visible again
|
||||||
function M.back(options, data, cb)
|
function M.back(options, data, cb)
|
||||||
log("back() queuing action")
|
log("back() queuing action")
|
||||||
-- backwards compatibility with old version M.back(data, cb)
|
|
||||||
-- case when back(data, cb)
|
|
||||||
if type(data) == "function" then
|
|
||||||
cb = data
|
|
||||||
data = options
|
|
||||||
options = nil
|
|
||||||
-- case when back(data, nil)
|
|
||||||
elseif options ~= nil and data == nil and cb == nil then
|
|
||||||
data = options
|
|
||||||
options = nil
|
|
||||||
end
|
|
||||||
|
|
||||||
queue_action(function(action_done)
|
queue_action(function(action_done)
|
||||||
local callbacks = callback_tracker()
|
local callbacks = callback_tracker()
|
||||||
@@ -1142,6 +1130,20 @@ function M.preload(id, options, cb)
|
|||||||
return true -- return true for legacy reasons (before queue existed)
|
return true -- return true for legacy reasons (before queue existed)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--- Check if a screen has missing resources, always returns false for factory
|
||||||
|
-- @param id (string|hash) - Id of the screen to preload
|
||||||
|
function M.has_missing_resources(id)
|
||||||
|
assert(id, "You must provide a screen id")
|
||||||
|
id = tohash(id)
|
||||||
|
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
||||||
|
|
||||||
|
local screen = screens[id]
|
||||||
|
if screen.proxy then
|
||||||
|
local missing_resources = collectionproxy.missing_resources(screen.proxy)
|
||||||
|
return #missing_resources > 0
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
--- Unload a preloaded monarch screen
|
--- Unload a preloaded monarch screen
|
||||||
-- @param id (string|hash) - Id of the screen to unload
|
-- @param id (string|hash) - Id of the screen to unload
|
||||||
|
|||||||
Reference in New Issue
Block a user