mirror of
https://github.com/trezor/trezor-firmware.git
synced 2024-12-31 18:40:56 +00:00
change wipe_device to use long-press confirm
This commit is contained in:
parent
b49ae3deee
commit
0637987c09
@ -18,6 +18,25 @@ async def confirm(session_id, content=None, code=None, **kwargs):
|
||||
return await dialog == CONFIRMED
|
||||
|
||||
|
||||
@unimport
|
||||
async def hold_to_confirm(session_id, code=None):
|
||||
from trezor.ui.button import Button, CONFIRM_BUTTON, CONFIRM_BUTTON_ACTIVE
|
||||
from trezor.ui.confirm import HoldToConfirmDialog, CONFIRMED
|
||||
from trezor.messages.ButtonRequest import ButtonRequest
|
||||
from trezor.messages.ButtonRequestType import Other
|
||||
from trezor.messages.wire_types import ButtonAck
|
||||
|
||||
button = Button((0, 240 - 48, 240, 48), 'Hold to confirm',
|
||||
normal_style=CONFIRM_BUTTON,
|
||||
active_style=CONFIRM_BUTTON_ACTIVE)
|
||||
dialog = HoldToConfirmDialog(button)
|
||||
|
||||
if code is None:
|
||||
code = Other
|
||||
await wire.reply_message(session_id, ButtonRequest(code=code), ButtonAck)
|
||||
return await dialog == CONFIRMED
|
||||
|
||||
|
||||
@unimport
|
||||
async def require_confirm(*args, **kwargs):
|
||||
from trezor.messages.FailureType import ActionCancelled
|
||||
|
@ -5,7 +5,7 @@ from trezor.utils import unimport
|
||||
@unimport
|
||||
async def layout_wipe_device(message, session_id):
|
||||
from trezor.messages.Success import Success
|
||||
from .confirm import require_confirm
|
||||
from .confirm import hold_to_confirm
|
||||
from .storage import clear_storage
|
||||
|
||||
ui.clear()
|
||||
@ -16,7 +16,7 @@ async def layout_wipe_device(message, session_id):
|
||||
ui.display.text(10, 164, 'All data will be lost.',
|
||||
ui.NORMAL, ui.WHITE, ui.BLACK)
|
||||
|
||||
await require_confirm(session_id)
|
||||
await hold_to_confirm(session_id)
|
||||
|
||||
clear_storage(session_id)
|
||||
|
||||
|
@ -1,7 +1,8 @@
|
||||
from .button import Button, BTN_CLICKED
|
||||
import utime
|
||||
from .button import Button, BTN_CLICKED, BTN_STARTED
|
||||
from .button import CONFIRM_BUTTON, CONFIRM_BUTTON_ACTIVE
|
||||
from .button import CANCEL_BUTTON, CANCEL_BUTTON_ACTIVE
|
||||
from trezor import loop
|
||||
from trezor import loop, ui
|
||||
|
||||
|
||||
CONFIRMED = const(1)
|
||||
@ -40,3 +41,105 @@ class ConfirmDialog():
|
||||
result = self.send(event, pos)
|
||||
if result is not None:
|
||||
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():
|
||||
|
||||
def __init__(self, button, content=None, *args, **kwargs):
|
||||
self.button = button
|
||||
self.content = content
|
||||
self.loader = Loader(*args, **kwargs)
|
||||
|
||||
def render(self):
|
||||
if not self.loader.render():
|
||||
if self.content is not None:
|
||||
self.content.render()
|
||||
else:
|
||||
ui.display.bar(0, 0, 240, 240 - 48, ui.BLACK)
|
||||
self.button.render()
|
||||
|
||||
def send(self, event, pos):
|
||||
if self.content is not None:
|
||||
self.content.send(pos)
|
||||
button = self.button
|
||||
was_started = button.state & BTN_STARTED
|
||||
button.send(event, pos)
|
||||
is_started = button.state & BTN_STARTED
|
||||
if is_started:
|
||||
if not was_started:
|
||||
self.loader.start()
|
||||
else:
|
||||
if was_started:
|
||||
if self.loader.stop():
|
||||
return CONFIRMED
|
||||
return None
|
||||
|
||||
async def __iter__(self):
|
||||
await loop.Wait([self._render_loop(),
|
||||
self._event_loop()])
|
||||
|
||||
def _render_loop(self):
|
||||
RENDER_DELAY = const(1000000 // 60)
|
||||
while True:
|
||||
self.render()
|
||||
yield loop.Sleep(RENDER_DELAY)
|
||||
|
||||
def _event_loop(self):
|
||||
while True:
|
||||
event, *pos = yield loop.Select(loop.TOUCH)
|
||||
result = self.send(event, pos)
|
||||
if result is not None:
|
||||
return result
|
||||
|
Loading…
Reference in New Issue
Block a user