2017-09-13 14:56:20 +00:00
|
|
|
--[[--
|
|
|
|
This widget displays a login dialog with a username and password.
|
|
|
|
]]
|
|
|
|
|
2017-09-11 08:32:39 +00:00
|
|
|
local Blitbuffer = require("ffi/blitbuffer")
|
2014-04-23 14:19:29 +00:00
|
|
|
local CenterContainer = require("ui/widget/container/centercontainer")
|
2017-09-11 08:32:39 +00:00
|
|
|
local FrameContainer = require("ui/widget/container/framecontainer")
|
|
|
|
local Geom = require("ui/geometry")
|
2014-04-23 14:19:29 +00:00
|
|
|
local InputDialog = require("ui/widget/inputdialog")
|
|
|
|
local InputText = require("ui/widget/inputtext")
|
2017-09-13 14:56:20 +00:00
|
|
|
local Size = require("ui/size")
|
2014-04-23 14:19:29 +00:00
|
|
|
local UIManager = require("ui/uimanager")
|
2017-09-11 08:32:39 +00:00
|
|
|
local VerticalGroup = require("ui/widget/verticalgroup")
|
2014-04-23 14:19:29 +00:00
|
|
|
local _ = require("gettext")
|
2017-09-11 08:32:39 +00:00
|
|
|
local Screen = require("device").screen
|
2014-04-23 14:19:29 +00:00
|
|
|
|
|
|
|
local LoginDialog = InputDialog:extend{
|
|
|
|
username = "",
|
|
|
|
username_hint = "username",
|
|
|
|
password = "",
|
|
|
|
password_hint = "password",
|
|
|
|
}
|
|
|
|
|
|
|
|
function LoginDialog:init()
|
|
|
|
-- init title and buttons in base class
|
|
|
|
InputDialog.init(self)
|
|
|
|
self.input_username = InputText:new{
|
|
|
|
text = self.username,
|
|
|
|
hint = self.username_hint,
|
|
|
|
face = self.input_face,
|
|
|
|
width = self.width * 0.9,
|
|
|
|
focused = true,
|
|
|
|
scroll = false,
|
|
|
|
parent = self,
|
|
|
|
}
|
|
|
|
|
|
|
|
self.input_password = InputText:new{
|
|
|
|
text = self.password,
|
|
|
|
hint = self.password_hint,
|
|
|
|
face = self.input_face,
|
|
|
|
width = self.width * 0.9,
|
|
|
|
text_type = "password",
|
|
|
|
focused = false,
|
|
|
|
scroll = false,
|
|
|
|
parent = self,
|
|
|
|
}
|
|
|
|
|
|
|
|
self.dialog_frame = FrameContainer:new{
|
2017-09-13 14:56:20 +00:00
|
|
|
radius = Size.radius.window,
|
2014-04-23 14:19:29 +00:00
|
|
|
padding = 0,
|
|
|
|
margin = 0,
|
2014-10-22 13:34:11 +00:00
|
|
|
background = Blitbuffer.COLOR_WHITE,
|
2014-04-23 14:19:29 +00:00
|
|
|
VerticalGroup:new{
|
|
|
|
align = "left",
|
|
|
|
self.title,
|
|
|
|
self.title_bar,
|
|
|
|
-- username input
|
|
|
|
CenterContainer:new{
|
|
|
|
dimen = Geom:new{
|
|
|
|
w = self.title_bar:getSize().w,
|
|
|
|
h = self.input_username:getSize().h,
|
|
|
|
},
|
|
|
|
self.input_username,
|
|
|
|
},
|
|
|
|
-- password input
|
|
|
|
CenterContainer:new{
|
|
|
|
dimen = Geom:new{
|
|
|
|
w = self.title_bar:getSize().w,
|
|
|
|
h = self.input_password:getSize().h,
|
|
|
|
},
|
|
|
|
self.input_password,
|
|
|
|
},
|
|
|
|
-- buttons
|
|
|
|
CenterContainer:new{
|
|
|
|
dimen = Geom:new{
|
|
|
|
w = self.title_bar:getSize().w,
|
|
|
|
h = self.button_table:getSize().h,
|
|
|
|
},
|
|
|
|
self.button_table,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-02-21 15:30:06 +00:00
|
|
|
self._input_widget = self.input_username
|
2014-04-23 14:19:29 +00:00
|
|
|
|
|
|
|
self[1] = CenterContainer:new{
|
|
|
|
dimen = Geom:new{
|
|
|
|
w = Screen:getWidth(),
|
2016-02-21 15:30:06 +00:00
|
|
|
h = Screen:getHeight() - self._input_widget:getKeyboardDimen().h,
|
2014-04-23 14:19:29 +00:00
|
|
|
},
|
|
|
|
self.dialog_frame,
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
function LoginDialog:getCredential()
|
|
|
|
local username = self.input_username:getText()
|
|
|
|
local password = self.input_password:getText()
|
|
|
|
return username, password
|
|
|
|
end
|
|
|
|
|
|
|
|
function LoginDialog:onSwitchFocus(inputbox)
|
|
|
|
-- unfocus current inputbox
|
2016-02-21 15:30:06 +00:00
|
|
|
self._input_widget:unfocus()
|
|
|
|
self._input_widget:onCloseKeyboard()
|
2014-04-23 14:19:29 +00:00
|
|
|
|
|
|
|
-- focus new inputbox
|
2016-02-21 15:30:06 +00:00
|
|
|
self._input_widget = inputbox
|
|
|
|
self._input_widget:focus()
|
|
|
|
self._input_widget:onShowKeyboard()
|
2014-04-23 14:19:29 +00:00
|
|
|
|
|
|
|
UIManager:show(self)
|
|
|
|
end
|
|
|
|
|
|
|
|
return LoginDialog
|
|
|
|
|