refactor to ease overriding stable
authorSylvain Thénault <sylvain.thenault@logilab.fr>
Fri, 27 Nov 2009 09:09:14 +0100 (2009-11-27)
branchstable
changeset 3920 366b30a6f9f6
parent 3919 f91bd15f427c
child 3921 4f24b6ef3da9
refactor to ease overriding
web/views/workflow.py
--- a/web/views/workflow.py	Fri Nov 27 09:08:54 2009 +0100
+++ b/web/views/workflow.py	Fri Nov 27 09:09:14 2009 +0100
@@ -45,21 +45,26 @@
     def cell_call(self, row, col):
         entity = self.rset.get_entity(row, col)
         transition = self.req.entity_from_eid(self.req.form['treid'])
-        dest = transition.destination()
-        _ = self.req._
-        # specify both rset/row/col and entity in case implements selector (and
-        # not entity_implements) is used on custom form
-        form = self.vreg['forms'].select(
-            'changestate', self.req, rset=self.rset, row=row, col=col,
-            entity=entity, transition=transition,
-            redirect_path=self.redirectpath(entity))
+        form = self.get_form(entity, transition)
         self.w(form.error_message())
-        self.w(u'<h4>%s %s</h4>\n' % (_(transition.name),
+        self.w(u'<h4>%s %s</h4>\n' % (self.req._(transition.name),
                                       entity.view('oneline')))
         msg = _('status will change from %(st1)s to %(st2)s') % {
-            'st1': _(entity.current_state.name),
-            'st2': _(dest.name)}
+            'st1': entity.printable_state,
+            'st2': self.req._(transition.destination().name)}
         self.w(u'<p>%s</p>\n' % msg)
+        self.w(form.form_render(wf_info_for=entity.eid,
+                                by_transition=transition.eid))
+
+    def redirectpath(self, entity):
+        return entity.rest_path()
+
+    def get_form(self, entity, transition, **kwargs):
+        # XXX used to specify both rset/row/col and entity in case implements
+        # selector (and not entity_implements) is used on custom form
+        form = self.vreg['forms'].select(
+            'changestate', self.req, entity=entity, transition=transition,
+            redirect_path=self.redirectpath(entity), **kwargs)
         trinfo = self.vreg['etypes'].etype_class('TrInfo')(self.req)
         self.initialize_varmaker()
         trinfo.eid = self.varmaker.next()
@@ -67,11 +72,7 @@
                                             mainform=False)
         subform.field_by_name('by_transition').widget = fwdgs.HiddenInput()
         form.add_subform(subform)
-        self.w(form.form_render(wf_info_for=entity.eid,
-                                by_transition=transition.eid))
-
-    def redirectpath(self, entity):
-        return entity.rest_path()
+        return form
 
 
 class WFHistoryView(EntityView):