Commit 298b1e5f authored by Bram Schoenmakers's avatar Bram Schoenmakers

Introduce UIView class to hold additional input data from the user.

This data should be stored for editing the view, or persisting it.
parent 525f7349
...@@ -32,6 +32,15 @@ from topydo.lib import TodoList ...@@ -32,6 +32,15 @@ from topydo.lib import TodoList
COLUMN_WIDTH = 40 COLUMN_WIDTH = 40
class UIView(View):
"""
A subclass of view holding user input data that constructed the view (i.e.
the sort expression and the filter expression, etc.)
"""
def __init__(self, p_sorter, p_filter, p_todolist, p_data):
super(UIView, self).__init__(p_sorter, p_filter, p_todolist)
self.data = p_data
class UIApplication(CLIApplicationBase): class UIApplication(CLIApplicationBase):
def __init__(self): def __init__(self):
super(UIApplication, self).__init__() super(UIApplication, self).__init__()
...@@ -136,7 +145,8 @@ class UIApplication(CLIApplicationBase): ...@@ -136,7 +145,8 @@ class UIApplication(CLIApplicationBase):
self._viewwidget_visible = True self._viewwidget_visible = True
def _edit_view(self): def _edit_view(self):
pass self.viewwidget.data = self.columns.focus.view.data
self._viewwidget_visible = True
def _delete_view(self): def _delete_view(self):
try: try:
...@@ -173,7 +183,7 @@ class UIApplication(CLIApplicationBase): ...@@ -173,7 +183,7 @@ class UIApplication(CLIApplicationBase):
def _viewdata_to_view(self, p_data): def _viewdata_to_view(self, p_data):
""" """
Converts a dictionary describing a view to an actual View instance. Converts a dictionary describing a view to an actual UIView instance.
""" """
sorter = Sorter(p_data['sortexpr']) sorter = Sorter(p_data['sortexpr'])
filters = [] filters = []
...@@ -184,17 +194,20 @@ class UIApplication(CLIApplicationBase): ...@@ -184,17 +194,20 @@ class UIApplication(CLIApplicationBase):
filters += get_filter_list(p_data['filterexpr']) filters += get_filter_list(p_data['filterexpr'])
return View(sorter, filters, self.todolist) return UIView(sorter, filters, self.todolist, p_data)
def _create_view(self, p_data): def _create_view(self, p_data):
""" Creates a view from the data entered in the view widget. """ """ Creates a view from the data entered in the view widget. """
view = self._viewdata_to_view(p_data) view = self._viewdata_to_view(p_data)
self._add_column(view, p_data['title']) self._add_column(view)
self._viewwidget_visible = False self._viewwidget_visible = False
def _add_column(self, p_view, p_title): def _add_column(self, p_view):
todolist = TodoListWidget(p_view, p_title) """
Given an UIView, adds a new column widget with the todos in that view.
"""
todolist = TodoListWidget(p_view, p_view.data['title'])
no_output = lambda _: None no_output = lambda _: None
urwid.connect_signal(todolist, 'execute_command', urwid.connect_signal(todolist, 'execute_command',
lambda cmd: self._execute_handler(cmd, no_output)) lambda cmd: self._execute_handler(cmd, no_output))
...@@ -259,8 +272,13 @@ class UIApplication(CLIApplicationBase): ...@@ -259,8 +272,13 @@ class UIApplication(CLIApplicationBase):
return user_input[0] return user_input[0]
def run(self): def run(self):
view1 = self.todolist.view(Sorter(), []) dummy = {
self._add_column(view1, "View 1") "title": "View 1",
"sortexpr": "desc:prio",
"filterexpr": "",
"show_all": True,
}
self._add_column(self._viewdata_to_view(dummy))
self.mainloop.run() self.mainloop.run()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment