Implements #40 Co-authored-by: Raymond Li <hi@raymond.li> Reviewed-on: #41 Co-authored-by: Raymond Li <raymo@csclub.uwaterloo.ca> Co-committed-by: Raymond Li <raymo@csclub.uwaterloo.ca>
This commit is contained in:
parent
d7b6ac2307
commit
f45efefaca
|
@ -1,7 +1,9 @@
|
||||||
|
from threading import Thread
|
||||||
|
|
||||||
from asciimatics.widgets import Layout, Label, Text
|
from asciimatics.widgets import Layout, Label, Text
|
||||||
from zope import component
|
from zope import component
|
||||||
|
|
||||||
from ...utils import defer, http_post
|
from ...utils import defer, http_post, http_get
|
||||||
from ..CeoFrame import CeoFrame
|
from ..CeoFrame import CeoFrame
|
||||||
from .GetPositionsView import position_names
|
from .GetPositionsView import position_names
|
||||||
from ceo_common.interfaces import IConfig
|
from ceo_common.interfaces import IConfig
|
||||||
|
@ -9,6 +11,24 @@ from ceod.transactions.members.UpdateMemberPositionsTransaction import UpdateMem
|
||||||
|
|
||||||
|
|
||||||
class SetPositionsView(CeoFrame):
|
class SetPositionsView(CeoFrame):
|
||||||
|
|
||||||
|
"""
|
||||||
|
Reset the positions to the currently set positions
|
||||||
|
"""
|
||||||
|
def reset_positions(self):
|
||||||
|
def target():
|
||||||
|
self.flash_message('Looking up positions...')
|
||||||
|
try:
|
||||||
|
resp = http_get('/api/positions')
|
||||||
|
if not resp.ok:
|
||||||
|
return
|
||||||
|
positions = resp.json()
|
||||||
|
for pos, username in positions.items():
|
||||||
|
self._widgets[pos].value = username
|
||||||
|
finally:
|
||||||
|
self.clear_flash_message(force_update=True)
|
||||||
|
Thread(target=target).start()
|
||||||
|
|
||||||
def __init__(self, screen, width, height, model):
|
def __init__(self, screen, width, height, model):
|
||||||
super().__init__(
|
super().__init__(
|
||||||
screen, height, width, model, 'SetPositions',
|
screen, height, width, model, 'SetPositions',
|
||||||
|
@ -19,11 +39,11 @@ class SetPositionsView(CeoFrame):
|
||||||
|
|
||||||
layout = Layout([100], fill_frame=True)
|
layout = Layout([100], fill_frame=True)
|
||||||
self.add_layout(layout)
|
self.add_layout(layout)
|
||||||
self._widgets = []
|
self._widgets = {}
|
||||||
for pos in avail:
|
for pos in avail:
|
||||||
suffix = ' (*)' if pos in required else ''
|
suffix = ' (*)' if pos in required else ''
|
||||||
widget = Text(position_names[pos] + suffix, pos)
|
widget = Text(position_names[pos] + suffix, pos)
|
||||||
self._widgets.append(widget)
|
self._widgets[pos] = widget
|
||||||
layout.add_widget(widget)
|
layout.add_widget(widget)
|
||||||
|
|
||||||
layout = Layout([100])
|
layout = Layout([100])
|
||||||
|
@ -34,12 +54,12 @@ class SetPositionsView(CeoFrame):
|
||||||
self.add_buttons(
|
self.add_buttons(
|
||||||
back_btn=True,
|
back_btn=True,
|
||||||
next_scene='Confirm', on_next=self._next)
|
next_scene='Confirm', on_next=self._next)
|
||||||
|
self.reset_positions()
|
||||||
self.fix()
|
self.fix()
|
||||||
|
|
||||||
def _ceoframe_on_reset(self):
|
def _ceoframe_on_reset(self):
|
||||||
super()._ceoframe_on_reset()
|
super()._ceoframe_on_reset()
|
||||||
for widget in self._widgets:
|
self.reset_positions()
|
||||||
widget.value = None
|
|
||||||
|
|
||||||
def _next(self):
|
def _next(self):
|
||||||
self.save()
|
self.save()
|
||||||
|
|
Loading…
Reference in New Issue