1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-03 12:00:59 +00:00

add Text, move Loader to ui.loader

This commit is contained in:
Jan Pochyla 2016-09-27 16:08:02 +02:00 committed by Pavol Rusnak
parent 44479b38d0
commit 3f4365eda6
No known key found for this signature in database
GPG Key ID: 91F3B339B9A02A3D
5 changed files with 97 additions and 71 deletions

View File

@ -3,13 +3,13 @@ from trezor.utils import unimport
@unimport @unimport
async def confirm(session_id, content=None, code=None, **kwargs): async def confirm(session_id, content=None, code=None, *args, **kwargs):
from trezor.ui.confirm import ConfirmDialog, CONFIRMED from trezor.ui.confirm import ConfirmDialog, CONFIRMED
from trezor.messages.ButtonRequest import ButtonRequest from trezor.messages.ButtonRequest import ButtonRequest
from trezor.messages.ButtonRequestType import Other from trezor.messages.ButtonRequestType import Other
from trezor.messages.wire_types import ButtonAck from trezor.messages.wire_types import ButtonAck
dialog = ConfirmDialog(content, **kwargs) dialog = ConfirmDialog(content, *args, **kwargs)
dialog.render() dialog.render()
if code is None: if code is None:
@ -19,7 +19,7 @@ async def confirm(session_id, content=None, code=None, **kwargs):
@unimport @unimport
async def hold_to_confirm(session_id, code=None): async def hold_to_confirm(session_id, content=None, code=None, *args, **kwargs):
from trezor.ui.button import Button, CONFIRM_BUTTON, CONFIRM_BUTTON_ACTIVE from trezor.ui.button import Button, CONFIRM_BUTTON, CONFIRM_BUTTON_ACTIVE
from trezor.ui.confirm import HoldToConfirmDialog, CONFIRMED from trezor.ui.confirm import HoldToConfirmDialog, CONFIRMED
from trezor.messages.ButtonRequest import ButtonRequest from trezor.messages.ButtonRequest import ButtonRequest
@ -29,7 +29,7 @@ async def hold_to_confirm(session_id, code=None):
button = Button((0, 240 - 48, 240, 48), 'Hold to confirm', button = Button((0, 240 - 48, 240, 48), 'Hold to confirm',
normal_style=CONFIRM_BUTTON, normal_style=CONFIRM_BUTTON,
active_style=CONFIRM_BUTTON_ACTIVE) active_style=CONFIRM_BUTTON_ACTIVE)
dialog = HoldToConfirmDialog(button) dialog = HoldToConfirmDialog(button, content, *args, **kwargs)
if code is None: if code is None:
code = Other code = Other

View File

@ -5,18 +5,18 @@ from trezor.utils import unimport
@unimport @unimport
async def layout_wipe_device(message, session_id): async def layout_wipe_device(message, session_id):
from trezor.messages.Success import Success from trezor.messages.Success import Success
from trezor.ui.text import Text
from .confirm import hold_to_confirm from .confirm import hold_to_confirm
from .storage import clear_storage from .storage import clear_storage
ui.clear() ui.clear()
ui.display.text(10, 30, 'Wiping device', ui.BOLD, ui.LIGHT_GREEN, ui.BLACK)
ui.display.text(10, 74, 'Do you really want to',
ui.BOLD, ui.WHITE, ui.BLACK)
ui.display.text(10, 104, 'wipe the device?', ui.BOLD, ui.WHITE, ui.BLACK)
ui.display.text(10, 164, 'All data will be lost.',
ui.NORMAL, ui.WHITE, ui.BLACK)
await hold_to_confirm(session_id) content = Text('Wiping device',
(ui.BOLD, 'Do you really want to'),
(ui.BOLD, 'wipe the device?'),
(ui.NORMAL, ''),
(ui.NORMAL, 'All data will be lost.'))
await hold_to_confirm(session_id, content)
clear_storage(session_id) clear_storage(session_id)

View File

@ -1,8 +1,8 @@
import utime
from .button import Button, BTN_CLICKED, BTN_STARTED from .button import Button, BTN_CLICKED, BTN_STARTED
from .button import CONFIRM_BUTTON, CONFIRM_BUTTON_ACTIVE from .button import CONFIRM_BUTTON, CONFIRM_BUTTON_ACTIVE
from .button import CANCEL_BUTTON, CANCEL_BUTTON_ACTIVE from .button import CANCEL_BUTTON, CANCEL_BUTTON_ACTIVE
from trezor import loop, ui from .loader import Loader
from trezor import loop
CONFIRMED = const(1) CONFIRMED = const(1)
@ -43,59 +43,6 @@ class ConfirmDialog():
return result return result
DEFAULT_LOADER = {
'bg-color': ui.BLACK,
'fg-color': ui.WHITE,
'icon': None,
'icon-fg-color': None,
}
DEFAULT_LOADER_ACTIVE = {
'bg-color': ui.BLACK,
'fg-color': ui.LIGHT_GREEN,
'icon': None,
'icon-fg-color': None,
}
LOADER_MSEC = const(1000)
class Loader():
def __init__(self, normal_style=None, active_style=None):
self.start_ticks_ms = None
self.normal_style = normal_style or DEFAULT_LOADER
self.active_style = active_style or DEFAULT_LOADER_ACTIVE
def start(self):
self.start_ticks_ms = utime.ticks_ms()
def stop(self):
ticks_diff = utime.ticks_ms() - self.start_ticks_ms
self.start_ticks_ms = None
return ticks_diff >= LOADER_MSEC
def render(self):
if self.start_ticks_ms is None:
return False
progress = min(utime.ticks_ms() - self.start_ticks_ms, LOADER_MSEC)
if progress == LOADER_MSEC:
style = self.active_style
else:
style = self.normal_style
if style['icon'] is None:
ui.display.loader(progress, style['fg-color'], style['bg-color'])
elif style['icon-fg-color'] is None:
ui.display.loader(
progress, style['fg-color'], style['bg-color'], style['icon'])
else:
ui.display.loader(
progress, style['fg-color'], style['bg-color'], style['icon'], style['icon-fg-color'])
return True
class HoldToConfirmDialog(): class HoldToConfirmDialog():
def __init__(self, button, content=None, *args, **kwargs): def __init__(self, button, content=None, *args, **kwargs):
@ -107,13 +54,9 @@ class HoldToConfirmDialog():
if not self.loader.render(): if not self.loader.render():
if self.content is not None: if self.content is not None:
self.content.render() self.content.render()
else:
ui.display.bar(0, 0, 240, 240 - 48, ui.BLACK)
self.button.render() self.button.render()
def send(self, event, pos): def send(self, event, pos):
if self.content is not None:
self.content.send(pos)
button = self.button button = self.button
was_started = button.state & BTN_STARTED was_started = button.state & BTN_STARTED
button.send(event, pos) button.send(event, pos)
@ -125,7 +68,8 @@ class HoldToConfirmDialog():
if was_started: if was_started:
if self.loader.stop(): if self.loader.stop():
return CONFIRMED return CONFIRMED
return None if self.content is not None:
return self.content.send(event, pos)
async def __iter__(self): async def __iter__(self):
await loop.Wait([self._render_loop(), await loop.Wait([self._render_loop(),

57
src/trezor/ui/loader.py Normal file
View File

@ -0,0 +1,57 @@
import utime
from trezor import ui
DEFAULT_LOADER = {
'bg-color': ui.BLACK,
'fg-color': ui.WHITE,
'icon': None,
'icon-fg-color': None,
}
DEFAULT_LOADER_ACTIVE = {
'bg-color': ui.BLACK,
'fg-color': ui.LIGHT_GREEN,
'icon': None,
'icon-fg-color': None,
}
LOADER_MSEC = const(1000)
class Loader():
def __init__(self, normal_style=None, active_style=None):
self.start_ticks_ms = None
self.normal_style = normal_style or DEFAULT_LOADER
self.active_style = active_style or DEFAULT_LOADER_ACTIVE
def start(self):
self.start_ticks_ms = utime.ticks_ms()
ui.display.bar(0, 0, 240, 240 - 48, ui.BLACK)
def stop(self):
ui.display.bar(0, 0, 240, 240 - 48, ui.BLACK)
ticks_diff = utime.ticks_ms() - self.start_ticks_ms
self.start_ticks_ms = None
return ticks_diff >= LOADER_MSEC
def render(self):
if self.start_ticks_ms is None:
return False
progress = min(utime.ticks_ms() - self.start_ticks_ms, LOADER_MSEC)
if progress == LOADER_MSEC:
style = self.active_style
else:
style = self.normal_style
if style['icon'] is None:
ui.display.loader(progress, style['fg-color'], style['bg-color'])
elif style['icon-fg-color'] is None:
ui.display.loader(
progress, style['fg-color'], style['bg-color'], style['icon'])
else:
ui.display.loader(
progress, style['fg-color'], style['bg-color'], style['icon'], style['icon-fg-color'])
return True

25
src/trezor/ui/text.py Normal file
View File

@ -0,0 +1,25 @@
from trezor import ui
TEXT_HEADER_HEIGHT = const(44)
TEXT_LINE_HEIGHT = const(30)
TEXT_MARGIN_LEFT = const(10)
class Text:
def __init__(self, header, *lines):
self.header = header
self.lines = lines
def render(self):
offset = TEXT_LINE_HEIGHT
ui.display.text(TEXT_MARGIN_LEFT, offset,
self.header, ui.BOLD, ui.LIGHT_GREEN, ui.BLACK)
offset += TEXT_HEADER_HEIGHT
for style, line in self.lines:
ui.display.text(TEXT_MARGIN_LEFT, offset,
line, style, ui.WHITE, ui.BLACK)
offset += TEXT_LINE_HEIGHT
def send(self, event, pos):
pass