annotate getan/controller.py @ 563:5ec211c172ed

Removed the filter_input step in the processing of states. As far as I see it is not used anywhere.
author Sascha L. Teichmann <sascha.teichmann@intevation.de>
date Tue, 22 Sep 2020 17:30:02 +0200
parents 199b3e3657aa
children
rev   line source
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
1 # -*- coding: utf-8 -*-
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
2 #
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
3 # (c) 2010 by Ingo Weinzierl <ingo.weinzierl@intevation.de>
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
4 # (c) 2011 by Björn Ricks <bjoern.ricks@intevation.de>
488
463894654d77 Prepares for release 3.0
Magnus Schieder <mschieder@intevation.de>
parents: 479
diff changeset
5 # (c) 2017, 2018 Intevation GmbH
463894654d77 Prepares for release 3.0
Magnus Schieder <mschieder@intevation.de>
parents: 479
diff changeset
6 # Authors:
463894654d77 Prepares for release 3.0
Magnus Schieder <mschieder@intevation.de>
parents: 479
diff changeset
7 # * Magnus Schieder <magnus.schieder@intevation.de>
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
8 #
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
9 # A python worklog-alike to log what you have 'getan' (done).
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
10 #
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
11 # This is Free Software licensed under the terms of GPLv3 or later.
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
12 # For details see LICENSE coming with the source of 'getan'.
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
13 #
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
14
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
15 import logging
194
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
16 import urwid
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
17
297
b9f4cd43f341 Fix codingstyle for pep8
Björn Ricks <bjoern.ricks@intevation.de>
parents: 266
diff changeset
18 from datetime import datetime
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
19
318
27fc5f43a69b Move setting the ProjectList and EntryList instances into the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 316
diff changeset
20 from getan.view import GetanView, ProjectList, EntryList
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
21 from getan.states import PausedProjectsState
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
22 from getan.utils import format_time
149
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
23 from getan.config import Config
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
24
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
25 logger = logging.getLogger()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
26
297
b9f4cd43f341 Fix codingstyle for pep8
Björn Ricks <bjoern.ricks@intevation.de>
parents: 266
diff changeset
27
136
92b7582b8f44 Use new style classes
Björn Ricks <bjoern.ricks@intevation.de>
parents: 135
diff changeset
28 class GetanController(object):
92b7582b8f44 Use new style classes
Björn Ricks <bjoern.ricks@intevation.de>
parents: 135
diff changeset
29
318
27fc5f43a69b Move setting the ProjectList and EntryList instances into the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 316
diff changeset
30 def __init__(self, backend):
149
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
31 self.config = Config()
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
32
297
b9f4cd43f341 Fix codingstyle for pep8
Björn Ricks <bjoern.ricks@intevation.de>
parents: 266
diff changeset
33 self.backend = backend
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
34 projects, entries = self.load_projects()
499
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
35 self.load_recover()
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
36 self.projects = projects
297
b9f4cd43f341 Fix codingstyle for pep8
Björn Ricks <bjoern.ricks@intevation.de>
parents: 266
diff changeset
37 self.running = []
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
38
499
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
39
203
1188998929bc Init entries_view before project_view
Björn Ricks <bjoern.ricks@intevation.de>
parents: 202
diff changeset
40 self.view = None
318
27fc5f43a69b Move setting the ProjectList and EntryList instances into the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 316
diff changeset
41 self.entries_view = EntryList(entries)
27fc5f43a69b Move setting the ProjectList and EntryList instances into the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 316
diff changeset
42 self.project_view = ProjectList(self, self.projects)
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
43
297
b9f4cd43f341 Fix codingstyle for pep8
Björn Ricks <bjoern.ricks@intevation.de>
parents: 266
diff changeset
44 self.view = GetanView(self, self.project_view, self.entries_view)
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
45 self.state = PausedProjectsState(self, self.project_view)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
46
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
47 def main(self):
320
922935ebfdd5 Use the palette loaded from the config theme
Björn Ricks <bjoern.ricks@intevation.de>
parents: 318
diff changeset
48 theme = self.config.get_theme()
229
693cc3504a94 Set GetanView as main widget for MainLoop
Björn Ricks <bjoern.ricks@intevation.de>
parents: 204
diff changeset
49 self.loop = urwid.MainLoop(self.view,
320
922935ebfdd5 Use the palette loaded from the config theme
Björn Ricks <bjoern.ricks@intevation.de>
parents: 318
diff changeset
50 theme.get_palette(),
194
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
51 screen=urwid.raw_display.Screen(),
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
52 input_filter=self.input_filter)
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
53 self.loop.run()
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
54
479
75131561d098 Add a redraw function on key Control-L.
Magnus Schieder <mschieder@intevation.de>
parents: 471
diff changeset
55 def redraw(self):
75131561d098 Add a redraw function on key Control-L.
Magnus Schieder <mschieder@intevation.de>
parents: 471
diff changeset
56 self.loop.stop()
75131561d098 Add a redraw function on key Control-L.
Magnus Schieder <mschieder@intevation.de>
parents: 471
diff changeset
57 self.loop.start()
75131561d098 Add a redraw function on key Control-L.
Magnus Schieder <mschieder@intevation.de>
parents: 471
diff changeset
58 self.loop.screen_size = None
75131561d098 Add a redraw function on key Control-L.
Magnus Schieder <mschieder@intevation.de>
parents: 471
diff changeset
59 self.loop.draw_screen()
75131561d098 Add a redraw function on key Control-L.
Magnus Schieder <mschieder@intevation.de>
parents: 471
diff changeset
60
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
61 def input_filter(self, input, raw_input):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
62 if 'window resize' in input:
255
fcd0a8b09fcf Fix: Don't crash when the console window is resized
Björn Ricks <bjoern.ricks@intevation.de>
parents: 240
diff changeset
63 self.loop.screen_size = None
fcd0a8b09fcf Fix: Don't crash when the console window is resized
Björn Ricks <bjoern.ricks@intevation.de>
parents: 240
diff changeset
64 self.loop.draw_screen()
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
65 else:
199
3fa4ab9146dd Implement three phase user input handling
Björn Ricks <bjoern.ricks@intevation.de>
parents: 198
diff changeset
66 self.loop.process_input(input)
3fa4ab9146dd Implement three phase user input handling
Björn Ricks <bjoern.ricks@intevation.de>
parents: 198
diff changeset
67 self.state.handle_input(input)
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
68
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
69 def load_projects(self):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
70 projects = self.backend.load_projects()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
71 if projects:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
72 entries = self.backend.load_entries(projects[0].id)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
73 else:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
74 entries = []
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
75 return (projects, entries)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
76
499
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
77 def load_recover(self):
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
78 self.backend.load_recover()
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
79
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
80 def update_entries(self, project):
297
b9f4cd43f341 Fix codingstyle for pep8
Björn Ricks <bjoern.ricks@intevation.de>
parents: 266
diff changeset
81 logger.debug("GetanController: update entries for project %s." %
b9f4cd43f341 Fix codingstyle for pep8
Björn Ricks <bjoern.ricks@intevation.de>
parents: 266
diff changeset
82 project.id)
314
05cb2e7e705f Fix updating the entries of the project when one ore more entries are deleted
Björn Ricks <bjoern.ricks@intevation.de>
parents: 297
diff changeset
83
362
90c09cca49c3 Fix loading entries of a project
Björn Ricks <bjoern.ricks@intevation.de>
parents: 320
diff changeset
84 project.load_entries()
314
05cb2e7e705f Fix updating the entries of the project when one ore more entries are deleted
Björn Ricks <bjoern.ricks@intevation.de>
parents: 297
diff changeset
85
204
921e98f9aa87 Only update_entries if view is set
Björn Ricks <bjoern.ricks@intevation.de>
parents: 203
diff changeset
86 if self.view:
362
90c09cca49c3 Fix loading entries of a project
Björn Ricks <bjoern.ricks@intevation.de>
parents: 320
diff changeset
87 self.view.update_entries(project.entries)
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
88
238
e48d6052688f Add controller move_entries method
Björn Ricks <bjoern.ricks@intevation.de>
parents: 234
diff changeset
89 def move_entries(self, entries, project):
e48d6052688f Add controller move_entries method
Björn Ricks <bjoern.ricks@intevation.de>
parents: 234
diff changeset
90 old_project = self.project_by_id(entries[0].project_id)
e48d6052688f Add controller move_entries method
Björn Ricks <bjoern.ricks@intevation.de>
parents: 234
diff changeset
91 self.backend.move_entries(entries, project.id)
e48d6052688f Add controller move_entries method
Björn Ricks <bjoern.ricks@intevation.de>
parents: 234
diff changeset
92 self.update_entries(old_project)
471
3853cf82ca3c Update project time when moving an entrie.
Magnus Schieder <mschieder@intevation.de>
parents: 453
diff changeset
93 self.update_projects()
238
e48d6052688f Add controller move_entries method
Björn Ricks <bjoern.ricks@intevation.de>
parents: 234
diff changeset
94 self.project_view.update_rows()
471
3853cf82ca3c Update project time when moving an entrie.
Magnus Schieder <mschieder@intevation.de>
parents: 453
diff changeset
95 open_project = self.project_by_id(old_project.id)
3853cf82ca3c Update project time when moving an entrie.
Magnus Schieder <mschieder@intevation.de>
parents: 453
diff changeset
96 open_project.open = True
238
e48d6052688f Add controller move_entries method
Björn Ricks <bjoern.ricks@intevation.de>
parents: 234
diff changeset
97
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
98 def delete_entries(self, entry_nodes):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
99 if not entry_nodes:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
100 return
314
05cb2e7e705f Fix updating the entries of the project when one ore more entries are deleted
Björn Ricks <bjoern.ricks@intevation.de>
parents: 297
diff changeset
101 proj_id = entry_nodes[0].project_id
05cb2e7e705f Fix updating the entries of the project when one ore more entries are deleted
Björn Ricks <bjoern.ricks@intevation.de>
parents: 297
diff changeset
102 proj = self.project_by_id(proj_id)
05cb2e7e705f Fix updating the entries of the project when one ore more entries are deleted
Björn Ricks <bjoern.ricks@intevation.de>
parents: 297
diff changeset
103 if proj:
05cb2e7e705f Fix updating the entries of the project when one ore more entries are deleted
Björn Ricks <bjoern.ricks@intevation.de>
parents: 297
diff changeset
104 entries = entry_nodes
05cb2e7e705f Fix updating the entries of the project when one ore more entries are deleted
Björn Ricks <bjoern.ricks@intevation.de>
parents: 297
diff changeset
105 self.backend.delete_entries(entries)
05cb2e7e705f Fix updating the entries of the project when one ore more entries are deleted
Björn Ricks <bjoern.ricks@intevation.de>
parents: 297
diff changeset
106 self.update_entries(proj)
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
107
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
108 def project_by_key(self, key):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
109 for proj in self.projects:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
110 if proj.key == key:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
111 return proj
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
112 return None
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
113
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
114 def project_by_id(self, id):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
115 for proj in self.projects:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
116 if proj.id == id:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
117 return proj
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
118 return None
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
119
154
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
120 def find_projects_by_key(self, key):
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
121 projects = []
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
122 for proj in self.projects:
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
123 if proj.key.startswith(key):
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
124 projects.append(proj)
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
125 return projects
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
126
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
127 def start_project(self, project):
135
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
128 if not project:
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
129 return
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
130 self.running.append(project)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
131 project.start = datetime.now()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
132 logger.info("Start project '%s' at %s."
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
133 % (project.desc, format_time(datetime.now())))
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
134 self.view.set_footer_text(" Running on '%s'" % project.desc, 'running')
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
135 logger.debug('All running projects: %r' % self.running)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
136
316
b9fcd8771c85 Allow empty descriptions for project entires
Björn Ricks <bjoern.ricks@intevation.de>
parents: 314
diff changeset
137 def stop_project(self, desc=None, display=True):
b9fcd8771c85 Allow empty descriptions for project entires
Björn Ricks <bjoern.ricks@intevation.de>
parents: 314
diff changeset
138 desc = desc or '-no description-'
135
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
139 if not self.running:
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
140 return
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
141 project = self.running.pop()
135
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
142 if not project:
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
143 return
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
144 logger.info("Stop project '%s' at %s."
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
145 % (project.desc, format_time(datetime.now())))
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
146 project.stop = datetime.now()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
147 self.backend.insert_project_entry(project, datetime.now(), desc)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
148 if display:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
149 self.update_entries(project)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
150 logger.debug('Still running projects: %r' % self.running)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
151
499
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
152 def save_recovery_data(self):
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
153 desc = '-no description-'
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
154 if not self.running:
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
155 return
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
156 project = self.running[-1]
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
157 if not project:
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
158 return
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
159 project.stop = datetime.now()
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
160 self.backend.insert_recover(project, datetime.now(), desc)
199b3e3657aa Every minute the time of the current entry is saved.
Magnus Schieder <mschieder@intevation.de>
parents: 488
diff changeset
161
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
162 def add_project(self, key, description):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
163 if not key or not description:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
164 return
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
165 self.backend.insert_project(key, description)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
166 self.update_projects()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
167
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
168 def update_entry(self, entry):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
169 self.backend.update_entry(entry)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
170
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
171 def shutdown(self):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
172 for project in self.running:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
173 self.stop_project(display=False)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
174
175
5e069074b1c9 Add Controller method to update a project
Björn Ricks <bjoern.ricks@intevation.de>
parents: 154
diff changeset
175 def update_project(self, project):
5e069074b1c9 Add Controller method to update a project
Björn Ricks <bjoern.ricks@intevation.de>
parents: 154
diff changeset
176 self.backend.update_project(project)
5e069074b1c9 Add Controller method to update a project
Björn Ricks <bjoern.ricks@intevation.de>
parents: 154
diff changeset
177 self.update_projects()
5e069074b1c9 Add Controller method to update a project
Björn Ricks <bjoern.ricks@intevation.de>
parents: 154
diff changeset
178
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
179 def update_projects(self):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
180 projects, entries = self.load_projects()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
181 self.projects = projects
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
182 self.project_view.load_rows(projects)
266
c5baa934b24d Update total time when project list is updated
Björn Ricks <bjoern.ricks@intevation.de>
parents: 265
diff changeset
183 self.project_view.total_time()
149
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
184
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
185 def get_config(self):
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
186 return self.config
194
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
187
202
3ed024299214 Add a GetanController set_state method
Björn Ricks <bjoern.ricks@intevation.de>
parents: 201
diff changeset
188 def set_state(self, state):
3ed024299214 Add a GetanController set_state method
Björn Ricks <bjoern.ricks@intevation.de>
parents: 201
diff changeset
189 self.state = state
3ed024299214 Add a GetanController set_state method
Björn Ricks <bjoern.ricks@intevation.de>
parents: 201
diff changeset
190
194
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
191 def exit(self):
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
192 logger.info("GetanController: exit.")
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
193 raise urwid.ExitMainLoop()
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)