mirror of
https://github.com/koreader/koreader.git
synced 2025-08-10 00:52:38 +00:00
Menu/GoTo: tweak go to page/letter dialog layout (#8056)
2 columns instead of 3, to get larger buttons and avoid truncation with some translations.
This commit is contained in:
@@ -7,8 +7,6 @@ local _ = require("gettext")
|
||||
local T = require("ffi/util").template
|
||||
|
||||
local ReaderGoto = InputContainer:new{
|
||||
goto_menu_title = _("Go to page"),
|
||||
skim_menu_title = _("Skim document"),
|
||||
}
|
||||
|
||||
function ReaderGoto:init()
|
||||
@@ -16,15 +14,14 @@ function ReaderGoto:init()
|
||||
end
|
||||
|
||||
function ReaderGoto:addToMainMenu(menu_items)
|
||||
-- insert goto command to main reader menu
|
||||
menu_items.go_to = {
|
||||
text = self.goto_menu_title,
|
||||
text = _("Go to page"),
|
||||
callback = function()
|
||||
self:onShowGotoDialog()
|
||||
end,
|
||||
}
|
||||
menu_items.skim_to = {
|
||||
text = self.skim_menu_title,
|
||||
text = _("Skim document"),
|
||||
callback = function()
|
||||
self:onShowSkimtoDialog()
|
||||
end,
|
||||
@@ -59,14 +56,21 @@ x for an absolute page number
|
||||
{
|
||||
{
|
||||
text = _("Cancel"),
|
||||
enabled = true,
|
||||
callback = function()
|
||||
self:close()
|
||||
end,
|
||||
},
|
||||
{
|
||||
text = _("Skim"),
|
||||
enabled = true,
|
||||
text = _("Go to page"),
|
||||
is_enter_default = true,
|
||||
callback = function()
|
||||
self:gotoPage()
|
||||
end,
|
||||
}
|
||||
},
|
||||
{
|
||||
{
|
||||
text = _("Skim document"),
|
||||
callback = function()
|
||||
self:close()
|
||||
self.skimto = SkimToWidget:new{
|
||||
@@ -81,12 +85,6 @@ x for an absolute page number
|
||||
|
||||
end,
|
||||
},
|
||||
{
|
||||
text = _("Go to page"),
|
||||
enabled = true,
|
||||
is_enter_default = true,
|
||||
callback = function() self:gotoPage() end,
|
||||
}
|
||||
},
|
||||
},
|
||||
input_type = "number",
|
||||
|
||||
@@ -8,6 +8,7 @@ local BottomContainer = require("ui/widget/container/bottomcontainer")
|
||||
local Button = require("ui/widget/button")
|
||||
local CenterContainer = require("ui/widget/container/centercontainer")
|
||||
local Device = require("device")
|
||||
local Event = require("ui/event")
|
||||
local FFIUtil = require("ffi/util")
|
||||
local FocusManager = require("ui/widget/focusmanager")
|
||||
local Font = require("ui/font")
|
||||
@@ -27,10 +28,12 @@ local TextBoxWidget = require("ui/widget/textboxwidget")
|
||||
local TextWidget = require("ui/widget/textwidget")
|
||||
local UIManager = require("ui/uimanager")
|
||||
local UnderlineContainer = require("ui/widget/container/underlinecontainer")
|
||||
local Utf8Proc = require("ffi/utf8proc")
|
||||
local VerticalGroup = require("ui/widget/verticalgroup")
|
||||
local VerticalSpan = require("ui/widget/verticalspan")
|
||||
local WidgetContainer = require("ui/widget/container/widgetcontainer")
|
||||
local logger = require("logger")
|
||||
local util = require("util")
|
||||
local _ = require("gettext")
|
||||
local Input = Device.input
|
||||
local Screen = Device.screen
|
||||
@@ -806,7 +809,7 @@ function Menu:init()
|
||||
},
|
||||
{
|
||||
text = _("Go to page"),
|
||||
is_enter_default = true,
|
||||
is_enter_default = not self.goto_letter,
|
||||
callback = function()
|
||||
local page = tonumber(self.page_info_text.input_dialog:getInputText())
|
||||
if page and page >= 1 and page <= self.page_num then
|
||||
@@ -819,29 +822,38 @@ function Menu:init()
|
||||
}
|
||||
|
||||
if self.goto_letter then
|
||||
title_goto = _("Enter page number or letter")
|
||||
title_goto = _("Enter letter or page number")
|
||||
type_goto = "string"
|
||||
hint_func = function()
|
||||
-- @translators First group is a page number range, second group the standard range for alphabetic searches
|
||||
return T(_("(1 - %1) or (a - z)"), self.page_num)
|
||||
-- @translators First group is the standard range for alphabetic searches, second group is a page number range
|
||||
return T(_("(a - z) or (1 - %1)"), self.page_num)
|
||||
end
|
||||
table.insert(buttons[1], {
|
||||
text = _("Go to letter"),
|
||||
is_enter_default = true,
|
||||
callback = function()
|
||||
for k, v in ipairs(self.item_table) do
|
||||
--- @todo Support utf8 lowercase.
|
||||
local filename = FFIUtil.basename(v.path):lower()
|
||||
local search_string = self.page_info_text.input_dialog:getInputText():lower()
|
||||
table.insert(buttons, 1, {
|
||||
{
|
||||
text = _("File search"),
|
||||
callback = function()
|
||||
self.page_info_text:closeInputDialog()
|
||||
UIManager:sendEvent(Event:new("ShowFileSearch", self.page_info_text.input_dialog:getInputText()))
|
||||
end,
|
||||
},
|
||||
{
|
||||
text = _("Go to letter"),
|
||||
is_enter_default = true,
|
||||
callback = function()
|
||||
local search_string = self.page_info_text.input_dialog:getInputText()
|
||||
if search_string == "" then return end
|
||||
local i, _ = filename:find(search_string)
|
||||
if i == 1 and not v.is_go_up then
|
||||
self:onGotoPage(math.ceil(k / self.perpage))
|
||||
break
|
||||
search_string = Utf8Proc.lowercase(util.fixUtf8(search_string, "?"))
|
||||
for k, v in ipairs(self.item_table) do
|
||||
local filename = Utf8Proc.lowercase(util.fixUtf8(FFIUtil.basename(v.path), "?"))
|
||||
local i, _ = filename:find(search_string)
|
||||
if i == 1 and not v.is_go_up then
|
||||
self:onGotoPage(math.ceil(k / self.perpage))
|
||||
break
|
||||
end
|
||||
end
|
||||
end
|
||||
self.page_info_text:closeInputDialog()
|
||||
end,
|
||||
self.page_info_text:closeInputDialog()
|
||||
end,
|
||||
},
|
||||
})
|
||||
else
|
||||
title_goto = _("Enter page number")
|
||||
|
||||
Reference in New Issue
Block a user