refactoring module registration in readerui

now every module can be looked up in readerui so that
unit test of these modules is possible.
pull/977/head
chrox 10 years ago
parent d01ae145b8
commit e34ad5ffe5

@ -12,7 +12,9 @@ local _ = require("gettext")
local ReaderHighlight = InputContainer:new{} local ReaderHighlight = InputContainer:new{}
function ReaderHighlight:init() function ReaderHighlight:init()
self.ui.menu:registerToMainMenu(self) self.ui:registerPostInitCallback(function()
self.ui.menu:registerToMainMenu(self)
end)
end end
function ReaderHighlight:initGesListener() function ReaderHighlight:initGesListener()

@ -17,7 +17,9 @@ function ReaderLink:init()
if Device:isTouchDevice() then if Device:isTouchDevice() then
self:initGesListener() self:initGesListener()
end end
self.ui.menu:registerToMainMenu(self) self.ui:registerPostInitCallback(function()
self.ui.menu:registerToMainMenu(self)
end)
end end
function ReaderLink:onReadSettings(config) function ReaderLink:onReadSettings(config)

@ -67,6 +67,15 @@ local ReaderUI = InputContainer:new{
postInitCallback = nil, postInitCallback = nil,
} }
function ReaderUI:registerModule(name, module, always_active)
if name then self[name] = module end
table.insert(always_active and self.active_widgets or self, module)
end
function ReaderUI:registerPostInitCallback(callback)
table.insert(self.postInitCallback, callback)
end
function ReaderUI:init() function ReaderUI:init()
self.postInitCallback = {} self.postInitCallback = {}
-- if we are not the top level dialog ourselves, it must be given in the table -- if we are not the top level dialog ourselves, it must be given in the table
@ -83,204 +92,194 @@ function ReaderUI:init()
self.doc_settings = DocSettings:open(self.document.file) self.doc_settings = DocSettings:open(self.document.file)
-- a view container (so it must be child #1!) -- a view container (so it must be child #1!)
self[1] = ReaderView:new{ self:registerModule("view", ReaderView:new{
dialog = self.dialog, dialog = self.dialog,
dimen = self.dimen, dimen = self.dimen,
ui = self, ui = self,
document = self.document, document = self.document,
} })
-- reader menu controller -- goto link controller
-- hold reference to menu widget self:registerModule("link", ReaderLink:new{
self.menu = ReaderMenu:new{
view = self[1],
ui = self
}
-- link
table.insert(self, ReaderLink:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self, ui = self,
document = self.document, document = self.document,
}) })
-- text highlight -- text highlight
table.insert(self, ReaderHighlight:new{ self:registerModule("highlight", ReaderHighlight:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self, ui = self,
document = self.document, document = self.document,
}) })
-- menu widget should be registered after link widget and highlight widget -- menu widget should be registered after link widget and highlight widget
-- so that taps on link and highlight areas won't popup reader menu -- so that taps on link and highlight areas won't popup reader menu
table.insert(self, self.menu) -- reader menu controller
self:registerModule("menu", ReaderMenu:new{
view = self.view,
ui = self
})
-- rotation controller -- rotation controller
table.insert(self, ReaderRotation:new{ self:registerModule("rotation", ReaderRotation:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
}) })
-- Table of content controller -- Table of content controller
-- hold reference to bm widget self:registerModule("toc", ReaderToc:new{
self.toc = ReaderToc:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
} })
table.insert(self, self.toc)
-- bookmark controller -- bookmark controller
table.insert(self, ReaderBookmark:new{ self:registerModule("bookmark", ReaderBookmark:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
}) })
-- reader goto controller -- reader goto controller
table.insert(self, ReaderGoto:new{ -- "goto" being a dirty keyword in Lua?
self:registerModule("gotopage", ReaderGoto:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self, ui = self,
document = self.document, document = self.document,
}) })
-- dictionary -- dictionary
table.insert(self, ReaderDictionary:new{ self:registerModule("dictionary", ReaderDictionary:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self, ui = self,
document = self.document, document = self.document,
}) })
-- wikipedia -- wikipedia
table.insert(self, ReaderWikipedia:new{ self:registerModule("wikipedia", ReaderWikipedia:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self, ui = self,
document = self.document, document = self.document,
}) })
-- screenshot controller -- screenshot controller
table.insert(self.active_widgets, ReaderScreenshot:new{ self:registerModule("screenshot", ReaderScreenshot:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
}) }, true)
-- frontlight controller -- frontlight controller
if Device:hasFrontlight() then if Device:hasFrontlight() then
table.insert(self, ReaderFrontLight:new{ self:registerModule("frontlight", ReaderFrontLight:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
}) })
end end
-- configuable controller -- configuable controller
if self.document.info.configurable then if self.document.info.configurable then
-- config panel controller -- config panel controller
table.insert(self, ReaderConfig:new{ self:registerModule("config", ReaderConfig:new{
configurable = self.document.configurable, configurable = self.document.configurable,
options = self.document.options, options = self.document.options,
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
}) })
if not self.document.info.has_pages then if self.document.info.has_pages then
-- kopt option controller
self:registerModule("koptlistener", ReaderKoptListener:new{
dialog = self.dialog,
view = self.view,
ui = self,
document = self.document,
})
else
-- cre option controller -- cre option controller
table.insert(self, ReaderCoptListener:new{ self:registerModule("crelistener", ReaderCoptListener:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self, ui = self,
document = self.document, document = self.document,
}) })
end end
-- activity indicator when some configurations take long take to affect
self:registerModule("activityindicator", ReaderActivityIndicator:new{
dialog = self.dialog,
view = self.view,
ui = self,
document = self.document,
})
end end
-- for page specific controller -- for page specific controller
if self.document.info.has_pages then if self.document.info.has_pages then
-- cropping controller -- cropping controller
table.insert(self, ReaderCropping:new{ self:registerModule("cropping", ReaderCropping:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self, ui = self,
document = self.document, document = self.document,
}) })
-- paging controller -- paging controller
table.insert(self, ReaderPaging:new{ self:registerModule("paging", ReaderPaging:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
}) })
-- zooming controller -- zooming controller
local zoom = ReaderZooming:new{ self:registerModule("zooming", ReaderZooming:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
} })
table.insert(self, zoom)
-- panning controller -- panning controller
table.insert(self, ReaderPanning:new{ self:registerModule("panning", ReaderPanning:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
}) })
-- hinting controller -- hinting controller
table.insert(self, ReaderHinting:new{ self:registerModule("hinting", ReaderHinting:new{
dialog = self.dialog, dialog = self.dialog,
zoom = zoom, zoom = self.zooming,
view = self[1], view = self.view,
ui = self, ui = self,
document = self.document, document = self.document,
}) })
else else
-- make sure we render document first before calling any callback -- make sure we render document first before calling any callback
table.insert(self.postInitCallback, function() self:registerPostInitCallback(function()
self.document:render() self.document:render()
end) end)
-- typeset controller -- typeset controller
table.insert(self, ReaderTypeset:new{ self:registerModule("typeset", ReaderTypeset:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
}) })
-- font menu -- font menu
self.font = ReaderFont:new{ self:registerModule("font", ReaderFont:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
} })
table.insert(self, self.font) -- hold reference to font menu
-- hyphenation menu -- hyphenation menu
self.hyphenation = ReaderHyphenation:new{ self:registerModule("hyphenation", ReaderHyphenation:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
} })
table.insert(self, self.hyphenation) -- hold reference to hyphenation menu
-- rolling controller -- rolling controller
table.insert(self, ReaderRolling:new{ self:registerModule("rolling", ReaderRolling:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self ui = self
}) })
end end
-- configuable controller
if self.document.info.configurable then
if self.document.info.has_pages then
-- kopt option controller
table.insert(self, ReaderKoptListener:new{
dialog = self.dialog,
view = self[1],
ui = self,
document = self.document,
})
end
-- activity indicator
table.insert(self, ReaderActivityIndicator:new{
dialog = self.dialog,
view = self[1],
ui = self,
document = self.document,
})
end
-- koreader plugins -- koreader plugins
for _,module in ipairs(PluginLoader:loadPlugins()) do for _,module in ipairs(PluginLoader:loadPlugins()) do
DEBUG("Loaded plugin", module.path) DEBUG("Loaded plugin", module.name, "at", module.path)
table.insert(self, module:new{ self:registerModule(module.name, module:new{
dialog = self.dialog, dialog = self.dialog,
view = self[1], view = self.view,
ui = self, ui = self,
document = self.document, document = self.document,
}) })

Loading…
Cancel
Save