author | Sylvain Thénault <sylvain.thenault@logilab.fr> |
Fri, 02 Oct 2009 14:17:22 +0200 | |
branch | stable |
changeset 3552 | 8facb3324170 |
parent 3534 | 81cfec545e1b |
child 3536 | f6c9a5df80fb |
child 3586 | 52b00c5e441a |
permissions | -rw-r--r-- |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
1 |
"""Set of HTML automatic forms to create, delete, copy or edit a single entity |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
2 |
or a list of entities of the same type |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
3 |
|
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
4 |
:organization: Logilab |
1977
606923dff11b
big bunch of copyright / docstring update
Adrien Di Mascio <Adrien.DiMascio@logilab.fr>
parents:
1965
diff
changeset
|
5 |
:copyright: 2001-2009 LOGILAB S.A. (Paris, FRANCE), license is LGPL v2. |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
6 |
:contact: http://www.logilab.fr/ -- mailto:contact@logilab.fr |
1977
606923dff11b
big bunch of copyright / docstring update
Adrien Di Mascio <Adrien.DiMascio@logilab.fr>
parents:
1965
diff
changeset
|
7 |
:license: GNU Lesser General Public License, v2.1 - http://www.gnu.org/licenses |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
8 |
""" |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
9 |
__docformat__ = "restructuredtext en" |
1965 | 10 |
_ = unicode |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
11 |
|
1147 | 12 |
from copy import copy |
13 |
||
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
14 |
from simplejson import dumps |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
15 |
|
2312
af4d8f75c5db
use xml_escape
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2247
diff
changeset
|
16 |
from logilab.mtconverter import xml_escape |
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
17 |
from logilab.common.decorators import cached |
1147 | 18 |
|
3532
df045bc51d00
[inlined forms] nicer add_hiddens implementation relying on standard entity forms handling
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3518
diff
changeset
|
19 |
from cubicweb import neg_role |
1147 | 20 |
from cubicweb.selectors import (match_kwargs, one_line_rset, non_final_entity, |
21 |
specified_etype_implements, yes) |
|
2678
0308dc159b96
use yams api
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2675
diff
changeset
|
22 |
from cubicweb.utils import make_uid |
1132 | 23 |
from cubicweb.view import EntityView |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
24 |
from cubicweb.common import tags |
3078
186ccbe0ba3f
missing import
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3077
diff
changeset
|
25 |
from cubicweb.web import INTERNAL_FIELD_VALUE, RequestError, stdmsgs, eid_param |
186ccbe0ba3f
missing import
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3077
diff
changeset
|
26 |
from cubicweb.web import uicfg |
2672
c66f52d44394
[reledit] don't try to use rel-edit on attributes without assicated fields (e.g _format field)
Adrien Di Mascio <Adrien.DiMascio@logilab.fr>
parents:
2576
diff
changeset
|
27 |
from cubicweb.web.form import FormViewMixIn, FieldNotFound |
2328
206735882b8e
[reledit] use guess_field, thus fixing select widget lacking a multiple attr. in case of * cardinality
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2327
diff
changeset
|
28 |
from cubicweb.web.formfields import guess_field |
206735882b8e
[reledit] use guess_field, thus fixing select widget lacking a multiple attr. in case of * cardinality
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2327
diff
changeset
|
29 |
from cubicweb.web.formwidgets import Button, SubmitButton, ResetButton |
2005
e8032965f37a
turn every form class into appobject. They should not be instantiated manually anymore.
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1995
diff
changeset
|
30 |
from cubicweb.web.views import forms |
1491
742aff97dbf7
move AutomaticEntityForm and PrimaryView into their own module
sylvain.thenault@logilab.fr
parents:
1459
diff
changeset
|
31 |
|
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
32 |
|
1147 | 33 |
def relation_id(eid, rtype, role, reid): |
34 |
"""return an identifier for a relation between two entities""" |
|
35 |
if role == 'subject': |
|
36 |
return u'%s:%s:%s' % (eid, rtype, reid) |
|
37 |
return u'%s:%s:%s' % (reid, rtype, eid) |
|
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
38 |
|
1528
864ae7c15ef5
other fixlets
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1498
diff
changeset
|
39 |
def toggleable_relation_link(eid, nodeid, label='x'): |
1147 | 40 |
"""return javascript snippet to delete/undelete a relation between two |
41 |
entities |
|
42 |
""" |
|
1320 | 43 |
js = u"javascript: togglePendingDelete('%s', %s);" % ( |
2312
af4d8f75c5db
use xml_escape
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2247
diff
changeset
|
44 |
nodeid, xml_escape(dumps(eid))) |
1320 | 45 |
return u'[<a class="handle" href="%s" id="handle%s">%s</a>]' % ( |
46 |
js, nodeid, label) |
|
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
47 |
|
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
48 |
|
2572
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
49 |
class DeleteConfForm(forms.CompositeForm): |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
50 |
id = 'deleteconf' |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
51 |
__select__ = non_final_entity() |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
52 |
|
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
53 |
domid = 'deleteconf' |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
54 |
copy_nav_params = True |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
55 |
form_buttons = [Button(stdmsgs.YES, cwaction='delete'), |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
56 |
Button(stdmsgs.NO, cwaction='cancel')] |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
57 |
@property |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
58 |
def action(self): |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
59 |
return self.build_url('edit') |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
60 |
|
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
61 |
def __init__(self, *args, **kwargs): |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
62 |
super(DeleteConfForm, self).__init__(*args, **kwargs) |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
63 |
done = set() |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
64 |
for entity in self.rset.entities(): |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
65 |
if entity.eid in done: |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
66 |
continue |
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
67 |
done.add(entity.eid) |
2650
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
68 |
subform = self.vreg['forms'].select('base', self.req, entity=entity, |
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
69 |
mainform=False) |
3513
c002f6488631
[form] replace is_subform by parent_form, carrying more information at the same cost
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3355
diff
changeset
|
70 |
self.add_subform(subform) |
2572
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
71 |
|
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
72 |
|
58556f9317c9
[notification view] consider row/col
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2538
diff
changeset
|
73 |
class DeleteConfFormView(FormViewMixIn, EntityView): |
1147 | 74 |
"""form used to confirm deletion of some entities""" |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
75 |
id = 'deleteconf' |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
76 |
title = _('delete') |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
77 |
# don't use navigation, all entities asked to be deleted should be displayed |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
78 |
# else we will only delete the displayed page |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
79 |
need_navigation = False |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
80 |
|
1852
f04da596da6c
give back onsubmit customizability (oops)
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1847
diff
changeset
|
81 |
def call(self, onsubmit=None): |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
82 |
"""ask for confirmation before real deletion""" |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
83 |
req, w = self.req, self.w |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
84 |
_ = req._ |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
85 |
w(u'<script type="text/javascript">updateMessage(\'%s\');</script>\n' |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
86 |
% _('this action is not reversible!')) |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
87 |
# XXX above message should have style of a warning |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
88 |
w(u'<h4>%s</h4>\n' % _('Do you want to delete the following element(s) ?')) |
2650
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
89 |
form = self.vreg['forms'].select(self.id, req, rset=self.rset, |
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
90 |
onsubmit=onsubmit) |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
91 |
w(u'<ul>\n') |
1147 | 92 |
for entity in self.rset.entities(): |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
93 |
# don't use outofcontext view or any other that may contain inline edition form |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
94 |
w(u'<li>%s</li>' % tags.a(entity.view('textoutofcontext'), |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
95 |
href=entity.absolute_url())) |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
96 |
w(u'</ul>\n') |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
97 |
w(form.form_render()) |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
98 |
|
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
99 |
|
1318
50e1a778c5ee
new FormViewMixIn class, cleanup FormMixIn (to remove once cubes doesn't use it anymore)
sylvain.thenault@logilab.fr
parents:
1313
diff
changeset
|
100 |
class ClickAndEditFormView(FormViewMixIn, EntityView): |
2686 | 101 |
"""form used to permit ajax edition of a relation or attribute of an entity |
102 |
in a view, if logged user have the permission to edit it. |
|
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
103 |
|
2686 | 104 |
(double-click on the field to see an appropriate edition widget). |
1147 | 105 |
""" |
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
106 |
id = 'doreledit' |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
107 |
__select__ = non_final_entity() & match_kwargs('rtype') |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
108 |
# FIXME editableField class could be toggleable from userprefs |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
109 |
|
2504
f28b1ffc3c91
some reledit fixes: actually needs metadata in form's attrcategories, check autoform_section for attributes (XXX need check for relation), no <not specified> visible when attribute isn't editable
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2484
diff
changeset
|
110 |
# add metadata to allow edition of metadata attributes (not considered by |
f28b1ffc3c91
some reledit fixes: actually needs metadata in form's attrcategories, check autoform_section for attributes (XXX need check for relation), no <not specified> visible when attribute isn't editable
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2484
diff
changeset
|
111 |
# edition form by default) |
f28b1ffc3c91
some reledit fixes: actually needs metadata in form's attrcategories, check autoform_section for attributes (XXX need check for relation), no <not specified> visible when attribute isn't editable
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2484
diff
changeset
|
112 |
attrcategories = ('primary', 'secondary', 'metadata') |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
113 |
|
2365
9f5e911eab07
[reledit] allow composite edition if the composite is object
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2361
diff
changeset
|
114 |
_onclick = u"showInlineEditionForm(%(eid)s, '%(rtype)s', '%(divid)s')" |
2484
7e9283731db8
[reledit] a nicer icon
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2483
diff
changeset
|
115 |
_defaultlandingzone = (u'<img title="%(msg)s" ' |
7e9283731db8
[reledit] a nicer icon
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2483
diff
changeset
|
116 |
'src="data/accessories-text-editor.png" ' |
7e9283731db8
[reledit] a nicer icon
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2483
diff
changeset
|
117 |
'alt="%(msg)s"/>') |
2335
b78249be8a4b
[reledit] fix reload type (was a string), use simple clicks instead of doubles
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2334
diff
changeset
|
118 |
_landingzonemsg = _('click to edit this field') |
2332
b04d80f19075
[reledit] try to be smart at getting a good default vid for relations, factor computing cardinality from reledit and formfields
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2331
diff
changeset
|
119 |
# default relation vids according to cardinality |
b04d80f19075
[reledit] try to be smart at getting a good default vid for relations, factor computing cardinality from reledit and formfields
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2331
diff
changeset
|
120 |
_one_rvid = 'incontext' |
b04d80f19075
[reledit] try to be smart at getting a good default vid for relations, factor computing cardinality from reledit and formfields
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2331
diff
changeset
|
121 |
_many_rvid = 'csv' |
b04d80f19075
[reledit] try to be smart at getting a good default vid for relations, factor computing cardinality from reledit and formfields
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2331
diff
changeset
|
122 |
|
2678
0308dc159b96
use yams api
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2675
diff
changeset
|
123 |
def _compute_best_vid(self, eschema, rschema, role): |
0308dc159b96
use yams api
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2675
diff
changeset
|
124 |
if eschema.cardinality(rschema, role) in '+*': |
2332
b04d80f19075
[reledit] try to be smart at getting a good default vid for relations, factor computing cardinality from reledit and formfields
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2331
diff
changeset
|
125 |
return self._many_rvid |
b04d80f19075
[reledit] try to be smart at getting a good default vid for relations, factor computing cardinality from reledit and formfields
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2331
diff
changeset
|
126 |
return self._one_rvid |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
127 |
|
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2365
diff
changeset
|
128 |
def _build_landing_zone(self, lzone): |
2482
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
129 |
return lzone or self._defaultlandingzone % {'msg' : xml_escape(self.req._(self._landingzonemsg))} |
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2365
diff
changeset
|
130 |
|
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2365
diff
changeset
|
131 |
def _build_renderer(self, entity, rtype, role): |
2650
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
132 |
return self.vreg['formrenderers'].select( |
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
133 |
'base', self.req, entity=entity, display_label=False, |
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
134 |
display_help=False, display_fields=[(rtype, role)], table_class='', |
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
135 |
button_bar_class='buttonbar', display_progress_div=False) |
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2365
diff
changeset
|
136 |
|
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
137 |
def _build_form(self, entity, rtype, role, formid, default, onsubmit, reload, |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
138 |
extradata=None, **formargs): |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
139 |
divid = 'd%s' % make_uid('%s-%s' % (rtype, entity.eid)) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
140 |
event_data = {'divid' : divid, 'eid' : entity.eid, 'rtype' : rtype, |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
141 |
'reload' : dumps(reload), 'default' : default} |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
142 |
if extradata: |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
143 |
event_data.update(extradata) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
144 |
onsubmit %= event_data |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
145 |
cancelclick = "hideInlineEdit(%s,\'%s\',\'%s\')" % (entity.eid, rtype, |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
146 |
divid) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
147 |
form = self.vreg['forms'].select( |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
148 |
formid, self.req, entity=entity, domid='%s-form' % divid, |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
149 |
cssstyle='display: none', onsubmit=onsubmit, action='#', |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
150 |
form_buttons=[SubmitButton(), Button(stdmsgs.BUTTON_CANCEL, |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
151 |
onclick=cancelclick)], |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
152 |
**formargs) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
153 |
form.event_data = event_data |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
154 |
return form |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
155 |
|
2329
8b5a1af6dc35
[reledit] small cleanup and add escape param to control xml_escapability of the value, also rename vid arg which clashes with entity.view(...) args
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2328
diff
changeset
|
156 |
def cell_call(self, row, col, rtype=None, role='subject', |
2336
a15d3f54f0f2
[reledit] left in by accident
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2335
diff
changeset
|
157 |
reload=False, # controls reloading the whole page after change |
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
158 |
rvid=None, # vid to be applied to other side of rtype (non final relations only) |
2332
b04d80f19075
[reledit] try to be smart at getting a good default vid for relations, factor computing cardinality from reledit and formfields
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2331
diff
changeset
|
159 |
default=None, # default value |
b04d80f19075
[reledit] try to be smart at getting a good default vid for relations, factor computing cardinality from reledit and formfields
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2331
diff
changeset
|
160 |
landing_zone=None # prepend value with a separate html element to click onto |
b04d80f19075
[reledit] try to be smart at getting a good default vid for relations, factor computing cardinality from reledit and formfields
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2331
diff
changeset
|
161 |
# (esp. needed when values are links) |
2329
8b5a1af6dc35
[reledit] small cleanup and add escape param to control xml_escapability of the value, also rename vid arg which clashes with entity.view(...) args
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2328
diff
changeset
|
162 |
): |
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2365
diff
changeset
|
163 |
"""display field to edit entity's `rtype` relation on click""" |
2329
8b5a1af6dc35
[reledit] small cleanup and add escape param to control xml_escapability of the value, also rename vid arg which clashes with entity.view(...) args
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2328
diff
changeset
|
164 |
assert rtype |
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2365
diff
changeset
|
165 |
assert role in ('subject', 'object') |
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2365
diff
changeset
|
166 |
if default is None: |
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2365
diff
changeset
|
167 |
default = xml_escape(self.req._('<no value>')) |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
168 |
entity = self.entity(row, col) |
2332
b04d80f19075
[reledit] try to be smart at getting a good default vid for relations, factor computing cardinality from reledit and formfields
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2331
diff
changeset
|
169 |
rschema = entity.schema.rschema(rtype) |
2482
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
170 |
lzone = self._build_landing_zone(landing_zone) |
2333
1de22d3e985b
[reledit] landing zone useful only for relations; cleanup
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2332
diff
changeset
|
171 |
# compute value, checking perms, build form |
1579 | 172 |
if rschema.is_final(): |
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
173 |
onsubmit = ("return inlineValidateAttributeForm('%(rtype)s', '%(eid)s', '%(divid)s', " |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
174 |
"%(reload)s, '%(default)s');") |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
175 |
form = self._build_form( |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
176 |
entity, rtype, role, 'edition', default, onsubmit, reload, |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
177 |
attrcategories=self.attrcategories) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
178 |
if not self.should_edit_attribute(entity, rschema, role, form): |
2224
52041b014949
fix #344046 and #344322: check relation permission, set to default when edition allowed and no value (for final *and* non final relations)
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2049
diff
changeset
|
179 |
return |
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
180 |
value = entity.printable_value(rtype) or default |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
181 |
self.attribute_form(lzone, value, form, |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
182 |
self._build_renderer(entity, rtype, role)) |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
183 |
else: |
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
184 |
if rvid is None: |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
185 |
rvid = self._compute_best_vid(entity.e_schema, rschema, role) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
186 |
if not self.should_edit_relation(entity, rschema, role, rvid): |
2380
5d980ba57632
[reledit] restore primaryview_display_ctrl usage by default in reledit (including bugfix over last implementation)
Adrien Di Mascio <Adrien.DiMascio@logilab.fr>
parents:
2376
diff
changeset
|
187 |
return |
1579 | 188 |
rset = entity.related(rtype, role) |
2504
f28b1ffc3c91
some reledit fixes: actually needs metadata in form's attrcategories, check autoform_section for attributes (XXX need check for relation), no <not specified> visible when attribute isn't editable
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2484
diff
changeset
|
189 |
if rset: |
f28b1ffc3c91
some reledit fixes: actually needs metadata in form's attrcategories, check autoform_section for attributes (XXX need check for relation), no <not specified> visible when attribute isn't editable
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2484
diff
changeset
|
190 |
value = self.view(rvid, rset) |
f28b1ffc3c91
some reledit fixes: actually needs metadata in form's attrcategories, check autoform_section for attributes (XXX need check for relation), no <not specified> visible when attribute isn't editable
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2484
diff
changeset
|
191 |
else: |
f28b1ffc3c91
some reledit fixes: actually needs metadata in form's attrcategories, check autoform_section for attributes (XXX need check for relation), no <not specified> visible when attribute isn't editable
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2484
diff
changeset
|
192 |
value = default |
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
193 |
onsubmit = ("return inlineValidateRelationForm('%(rtype)s', '%(role)s', '%(eid)s', " |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
194 |
"'%(divid)s', %(reload)s, '%(vid)s', '%(default)s', '%(lzone)s');") |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
195 |
form = self._build_form( |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
196 |
entity, rtype, role, 'base', default, onsubmit, reload, |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
197 |
dict(vid=rvid, role=role, lzone=lzone)) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
198 |
field = guess_field(entity.e_schema, entity.schema.rschema(rtype), role) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
199 |
form.append_field(field) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
200 |
self.relation_form(lzone, value, form, |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
201 |
self._build_renderer(entity, rtype, role)) |
2365
9f5e911eab07
[reledit] allow composite edition if the composite is object
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2361
diff
changeset
|
202 |
|
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
203 |
def should_edit_attribute(self, entity, rschema, role, form): |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
204 |
rtype = str(rschema) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
205 |
ttype = rschema.targets(entity.id, role)[0] |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
206 |
afs = uicfg.autoform_section.etype_get(entity.id, rtype, role, ttype) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
207 |
if not (afs in self.attrcategories and entity.has_perm('update')): |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
208 |
self.w(entity.printable_value(rtype)) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
209 |
return False |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
210 |
try: |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
211 |
field = form.field_by_name(rtype, role) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
212 |
except FieldNotFound: |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
213 |
self.w(entity.printable_value(rtype)) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
214 |
return False |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
215 |
return True |
1759
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1750
diff
changeset
|
216 |
|
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
217 |
def should_edit_relation(self, entity, rschema, role, rvid): |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
218 |
if ((role == 'subject' and not rschema.has_perm(self.req, 'add', |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
219 |
fromeid=entity.eid)) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
220 |
or |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
221 |
(role == 'object' and not rschema.has_perm(self.req, 'add', |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
222 |
toeid=entity.eid))): |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
223 |
self.wview(rvid, entity.related(str(rschema), role), 'null') |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
224 |
return False |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
225 |
return True |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
226 |
|
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
227 |
def attribute_form(self, lzone, value, form, renderer): |
2482
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
228 |
"""div (class=field) |
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
229 |
+-xxx div |
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
230 |
| +-xxx div (class=editableField) |
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
231 |
| | +-landing zone |
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
232 |
| +-value-xxx div |
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
233 |
| +-value |
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
234 |
+-form-xxx div |
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
235 |
""" |
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
236 |
w = self.w |
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
237 |
w(u'<div class="field">') |
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
238 |
w(u'<div id="%s" style="display: inline">' % form.event_data['divid']) |
2482
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
239 |
w(tags.div(lzone, klass='editableField', |
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
240 |
onclick=self._onclick % form.event_data)) |
2482
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
241 |
w(u'<div id="value-%s" style="display: inline">%s</div>' % |
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
242 |
(form.event_data['divid'], value)) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
243 |
w(u'</div>') |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
244 |
w(form.form_render(renderer=renderer)) |
2482
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
245 |
w(u'</div>') |
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
246 |
|
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
247 |
def relation_form(self, lzone, value, form, renderer): |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
248 |
"""xxx-reledit div (class=field) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
249 |
+-xxx div (class="editableField") |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
250 |
| +-landing zone |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
251 |
+-value |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
252 |
+-form-xxx div |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
253 |
""" |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
254 |
w = self.w |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
255 |
w(u'<div id="%s-reledit" class="field">' % form.event_data['divid']) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
256 |
w(tags.div(lzone, klass='editableField', id=form.event_data['divid'], |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
257 |
onclick=self._onclick % form.event_data)) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
258 |
w(value) |
2482
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
259 |
w(form.form_render(renderer=renderer)) |
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2392
diff
changeset
|
260 |
w(u'</div>') |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
261 |
|
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
262 |
|
2679
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
263 |
class AutoClickAndEditFormView(ClickAndEditFormView): |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
264 |
"""same as ClickAndEditFormView but checking if the view *should* be applied |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
265 |
by checking uicfg configuration and composite relation property. |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
266 |
""" |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
267 |
id = 'reledit' |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
268 |
|
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
269 |
def should_edit_relation(self, entity, rschema, role, rvid): |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
270 |
eschema = entity.e_schema |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
271 |
rtype = str(rschema) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
272 |
# XXX check autoform_section. what if 'generic'? |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
273 |
dispctrl = uicfg.primaryview_display_ctrl.etype_get(eschema, rtype, role) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
274 |
vid = dispctrl.get('vid', 'reledit') |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
275 |
if vid != 'reledit': # reledit explicitly disabled |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
276 |
self.wview(vid, entity.related(rtype, role), 'null') |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
277 |
return False |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
278 |
if eschema.role_rproperty(role, rschema, 'composite') == role: |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
279 |
self.wview(rvid, entity.related(rtype, role), 'null') |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
280 |
return False |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
281 |
return super(AutoClickAndEditFormView, self).should_edit_relation( |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
282 |
entity, rschema, role, rvid) |
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
283 |
|
3fa8c0cec760
[reledit] refactor, split into reledit/doreledit where the former try to tell if edition *should* be done, and the later tell if edition *can* be done
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2678
diff
changeset
|
284 |
|
1318
50e1a778c5ee
new FormViewMixIn class, cleanup FormMixIn (to remove once cubes doesn't use it anymore)
sylvain.thenault@logilab.fr
parents:
1313
diff
changeset
|
285 |
class EditionFormView(FormViewMixIn, EntityView): |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
286 |
"""display primary entity edition form""" |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
287 |
id = 'edition' |
1147 | 288 |
# add yes() so it takes precedence over deprecated views in baseforms, |
289 |
# though not baseforms based customized view |
|
290 |
__select__ = one_line_rset() & non_final_entity() & yes() |
|
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
291 |
|
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
292 |
title = _('edition') |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
293 |
|
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
294 |
def cell_call(self, row, col, **kwargs): |
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
295 |
entity = self.complete_entity(row, col) |
1147 | 296 |
self.render_form(entity) |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
297 |
|
1147 | 298 |
def render_form(self, entity): |
299 |
"""fetch and render the form""" |
|
300 |
self.form_title(entity) |
|
2650
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
301 |
form = self.vreg['forms'].select('edition', self.req, rset=entity.rset, |
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
302 |
row=entity.row, col=entity.col, entity=entity, |
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
303 |
submitmsg=self.submited_message()) |
1147 | 304 |
self.init_form(form, entity) |
1995
ec95eaa2b711
turn renderers into appobjects
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
305 |
self.w(form.form_render(formvid=u'edition')) |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
306 |
|
1147 | 307 |
def init_form(self, form, entity): |
308 |
"""customize your form before rendering here""" |
|
2049
b9baedffeb8b
set __maineid in EntityFieldsForm
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2048
diff
changeset
|
309 |
pass |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
310 |
|
1147 | 311 |
def form_title(self, entity): |
312 |
"""the form view title""" |
|
313 |
ptitle = self.req._(self.title) |
|
314 |
self.w(u'<div class="formTitle"><span>%s %s</span></div>' % ( |
|
315 |
entity.dc_type(), ptitle and '(%s)' % ptitle)) |
|
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
316 |
|
1147 | 317 |
def submited_message(self): |
318 |
"""return the message that will be displayed on successful edition""" |
|
319 |
return self.req._('entity edited') |
|
320 |
||
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
321 |
|
1147 | 322 |
class CreationFormView(EditionFormView): |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
323 |
"""display primary entity creation form""" |
1147 | 324 |
id = 'creation' |
325 |
__select__ = specified_etype_implements('Any') & yes() |
|
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
326 |
|
1147 | 327 |
title = _('creation') |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
328 |
|
1147 | 329 |
def call(self, **kwargs): |
330 |
"""creation view for an entity""" |
|
3346
b1fd9d4ef579
fix case insensitive selector for entity creation
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3331
diff
changeset
|
331 |
# at this point we know etype is a valid entity type, thanks to our |
b1fd9d4ef579
fix case insensitive selector for entity creation
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3331
diff
changeset
|
332 |
# selector |
1147 | 333 |
etype = kwargs.pop('etype', self.req.form.get('etype')) |
3077
6c92323667a6
case insensitive add/XXX url
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3062
diff
changeset
|
334 |
entity = self.vreg['etypes'].etype_class(etype)(self.req) |
6c92323667a6
case insensitive add/XXX url
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3062
diff
changeset
|
335 |
self.initialize_varmaker() |
6c92323667a6
case insensitive add/XXX url
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3062
diff
changeset
|
336 |
entity.eid = self.varmaker.next() |
6c92323667a6
case insensitive add/XXX url
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3062
diff
changeset
|
337 |
self.render_form(entity) |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
338 |
|
1147 | 339 |
def form_title(self, entity): |
340 |
"""the form view title""" |
|
341 |
if '__linkto' in self.req.form: |
|
342 |
if isinstance(self.req.form['__linkto'], list): |
|
343 |
# XXX which one should be considered (case: add a ticket to a |
|
344 |
# version in jpl) |
|
345 |
rtype, linkto_eid, role = self.req.form['__linkto'][0].split(':') |
|
346 |
else: |
|
347 |
rtype, linkto_eid, role = self.req.form['__linkto'].split(':') |
|
348 |
linkto_rset = self.req.eid_rset(linkto_eid) |
|
349 |
linkto_type = linkto_rset.description[0][0] |
|
350 |
if role == 'subject': |
|
351 |
title = self.req.__('creating %s (%s %s %s %%(linkto)s)' % ( |
|
352 |
entity.e_schema, entity.e_schema, rtype, linkto_type)) |
|
353 |
else: |
|
354 |
title = self.req.__('creating %s (%s %%(linkto)s %s %s)' % ( |
|
355 |
entity.e_schema, linkto_type, rtype, entity.e_schema)) |
|
356 |
msg = title % {'linkto' : self.view('incontext', linkto_rset)} |
|
357 |
self.w(u'<div class="formTitle notransform"><span>%s</span></div>' % msg) |
|
358 |
else: |
|
359 |
super(CreationFormView, self).form_title(entity) |
|
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
360 |
|
1147 | 361 |
def url(self): |
362 |
"""return the url associated with this view""" |
|
363 |
return self.create_url(self.req.form.get('etype')) |
|
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
364 |
|
1147 | 365 |
def submited_message(self): |
366 |
"""return the message that will be displayed on successful edition""" |
|
367 |
return self.req._('entity created') |
|
368 |
||
369 |
||
370 |
class CopyFormView(EditionFormView): |
|
371 |
"""display primary entity creation form initialized with values from another |
|
372 |
entity |
|
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
373 |
""" |
1147 | 374 |
id = 'copy' |
3062
a8e901fc4457
ease overriding of copy warning
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2686
diff
changeset
|
375 |
warning_message = _('Please note that this is only a shallow copy') |
a8e901fc4457
ease overriding of copy warning
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2686
diff
changeset
|
376 |
|
1147 | 377 |
def render_form(self, entity): |
378 |
"""fetch and render the form""" |
|
379 |
# make a copy of entity to avoid altering the entity in the |
|
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
380 |
# request's cache. |
1685
3c59ae0e6548
fix copy edition view
Graziella Toutoungis <graziella.toutoungis@logilab.fr>
parents:
1629
diff
changeset
|
381 |
entity.complete() |
1147 | 382 |
self.newentity = copy(entity) |
1703
a2b5dfdb4b62
should prefill cached values for relation in the primary or secondary category
sylvain.thenault@logilab.fr
parents:
1692
diff
changeset
|
383 |
self.copying = entity |
1685
3c59ae0e6548
fix copy edition view
Graziella Toutoungis <graziella.toutoungis@logilab.fr>
parents:
1629
diff
changeset
|
384 |
self.initialize_varmaker() |
3c59ae0e6548
fix copy edition view
Graziella Toutoungis <graziella.toutoungis@logilab.fr>
parents:
1629
diff
changeset
|
385 |
self.newentity.eid = self.varmaker.next() |
1147 | 386 |
self.w(u'<script type="text/javascript">updateMessage("%s");</script>\n' |
3062
a8e901fc4457
ease overriding of copy warning
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2686
diff
changeset
|
387 |
% self.req._(self.warning_message)) |
1685
3c59ae0e6548
fix copy edition view
Graziella Toutoungis <graziella.toutoungis@logilab.fr>
parents:
1629
diff
changeset
|
388 |
super(CopyFormView, self).render_form(self.newentity) |
1147 | 389 |
del self.newentity |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
390 |
|
1147 | 391 |
def init_form(self, form, entity): |
392 |
"""customize your form before rendering here""" |
|
393 |
super(CopyFormView, self).init_form(form, entity) |
|
394 |
if entity.eid == self.newentity.eid: |
|
1703
a2b5dfdb4b62
should prefill cached values for relation in the primary or secondary category
sylvain.thenault@logilab.fr
parents:
1692
diff
changeset
|
395 |
form.form_add_hidden(eid_param('__cloned_eid', entity.eid), |
a2b5dfdb4b62
should prefill cached values for relation in the primary or secondary category
sylvain.thenault@logilab.fr
parents:
1692
diff
changeset
|
396 |
self.copying.eid) |
a2b5dfdb4b62
should prefill cached values for relation in the primary or secondary category
sylvain.thenault@logilab.fr
parents:
1692
diff
changeset
|
397 |
for rschema, _, role in form.relations_by_category(form.attrcategories, |
a2b5dfdb4b62
should prefill cached values for relation in the primary or secondary category
sylvain.thenault@logilab.fr
parents:
1692
diff
changeset
|
398 |
'add'): |
a2b5dfdb4b62
should prefill cached values for relation in the primary or secondary category
sylvain.thenault@logilab.fr
parents:
1692
diff
changeset
|
399 |
if not rschema.is_final(): |
a2b5dfdb4b62
should prefill cached values for relation in the primary or secondary category
sylvain.thenault@logilab.fr
parents:
1692
diff
changeset
|
400 |
# ensure relation cache is filed |
a2b5dfdb4b62
should prefill cached values for relation in the primary or secondary category
sylvain.thenault@logilab.fr
parents:
1692
diff
changeset
|
401 |
rset = self.copying.related(rschema, role) |
a2b5dfdb4b62
should prefill cached values for relation in the primary or secondary category
sylvain.thenault@logilab.fr
parents:
1692
diff
changeset
|
402 |
self.newentity.set_related_cache(rschema, role, rset) |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
403 |
|
1147 | 404 |
def submited_message(self): |
405 |
"""return the message that will be displayed on successful edition""" |
|
406 |
return self.req._('entity copied') |
|
407 |
||
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
408 |
|
2005
e8032965f37a
turn every form class into appobject. They should not be instantiated manually anymore.
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1995
diff
changeset
|
409 |
class TableEditForm(forms.CompositeForm): |
1147 | 410 |
id = 'muledit' |
1692 | 411 |
domid = 'entityForm' |
412 |
onsubmit = "return validateForm('%s', null);" % domid |
|
1304 | 413 |
form_buttons = [SubmitButton(_('validate modifications on selected items')), |
414 |
ResetButton(_('revert changes'))] |
|
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
415 |
|
1692 | 416 |
def __init__(self, req, rset, **kwargs): |
417 |
kwargs.setdefault('__redirectrql', rset.printable_rql()) |
|
418 |
super(TableEditForm, self).__init__(req, rset, **kwargs) |
|
1147 | 419 |
for row in xrange(len(self.rset)): |
2650
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
420 |
form = self.vreg['forms'].select('edition', self.req, |
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
421 |
rset=self.rset, row=row, |
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
422 |
attrcategories=('primary',), |
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
423 |
mainform=False) |
1324 | 424 |
# XXX rely on the EntityCompositeFormRenderer to put the eid input |
1147 | 425 |
form.remove_field(form.field_by_name('eid')) |
3513
c002f6488631
[form] replace is_subform by parent_form, carrying more information at the same cost
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3355
diff
changeset
|
426 |
self.add_subform(form) |
1091
b5e253c0dd13
a bit of reorganisation inside web/views:
sylvain.thenault@logilab.fr
parents:
diff
changeset
|
427 |
|
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
428 |
|
1318
50e1a778c5ee
new FormViewMixIn class, cleanup FormMixIn (to remove once cubes doesn't use it anymore)
sylvain.thenault@logilab.fr
parents:
1313
diff
changeset
|
429 |
class TableEditFormView(FormViewMixIn, EntityView): |
1147 | 430 |
id = 'muledit' |
431 |
__select__ = EntityView.__select__ & yes() |
|
432 |
title = _('multiple edit') |
|
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
433 |
|
1147 | 434 |
def call(self, **kwargs): |
435 |
"""a view to edit multiple entities of the same type the first column |
|
436 |
should be the eid |
|
437 |
""" |
|
438 |
#self.form_title(entity) |
|
2650
18aec79ec3a3
R [vreg] important refactoring of the vregistry, moving behaviour to end dictionnary (and so leaving room for more flexibility ; keep bw compat ; update api usage in cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2576
diff
changeset
|
439 |
form = self.vreg['forms'].select(self.id, self.req, rset=self.rset) |
1995
ec95eaa2b711
turn renderers into appobjects
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
440 |
self.w(form.form_render()) |
1147 | 441 |
|
442 |
||
1318
50e1a778c5ee
new FormViewMixIn class, cleanup FormMixIn (to remove once cubes doesn't use it anymore)
sylvain.thenault@logilab.fr
parents:
1313
diff
changeset
|
443 |
class InlineEntityEditionFormView(FormViewMixIn, EntityView): |
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
444 |
""" |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
445 |
:attr peid: the parent entity's eid hosting the inline form |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
446 |
:attr rtype: the relation bridging `etype` and `peid` |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
447 |
:attr role: the role played by the `peid` in the relation |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
448 |
:attr pform: the parent form where this inlined form is being displayed |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
449 |
""" |
1147 | 450 |
id = 'inline-edition' |
451 |
__select__ = non_final_entity() & match_kwargs('peid', 'rtype') |
|
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
452 |
|
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
453 |
_select_attrs = ('peid', 'rtype', 'role', 'pform') |
1147 | 454 |
removejs = "removeInlinedEntity('%s', '%s', '%s')" |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
455 |
|
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
456 |
def __init__(self, *args, **kwargs): |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
457 |
for attr in self._select_attrs: |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
458 |
setattr(self, attr, kwargs.pop(attr, None)) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
459 |
super(InlineEntityEditionFormView, self).__init__(*args, **kwargs) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
460 |
|
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
461 |
def _entity(self): |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
462 |
assert self.row is not None, self |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
463 |
return self.rset.get_entity(self.row, self.col) |
1147 | 464 |
|
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
465 |
@property |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
466 |
@cached |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
467 |
def form(self): |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
468 |
entity = self._entity() |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
469 |
form = self.vreg['forms'].select('edition', self.req, |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
470 |
entity=entity, |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
471 |
form_renderer_id='inline', |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
472 |
mainform=False, copy_nav_params=False, |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
473 |
**self.extra_kwargs) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
474 |
form.parent_form = self.pform |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
475 |
self.add_hiddens(form, entity) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
476 |
return form |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
477 |
|
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
478 |
def cell_call(self, row, col, i18nctx, **kwargs): |
1147 | 479 |
""" |
480 |
:param peid: the parent entity's eid hosting the inline form |
|
481 |
:param rtype: the relation bridging `etype` and `peid` |
|
482 |
:param role: the role played by the `peid` in the relation |
|
483 |
""" |
|
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
484 |
entity = self._entity() |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
485 |
divonclick = "restoreInlinedEntity('%s', '%s', '%s')" % ( |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
486 |
self.peid, self.rtype, entity.eid) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
487 |
self.render_form(i18nctx, divonclick=divonclick, **kwargs) |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
488 |
|
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
489 |
def render_form(self, i18nctx, **kwargs): |
1147 | 490 |
"""fetch and render the form""" |
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
491 |
entity = self._entity() |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
492 |
divid = '%s-%s-%s' % (self.peid, self.rtype, entity.eid) |
3327
44efba78afac
fix/enhance i18n context usage for inlined forms
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3078
diff
changeset
|
493 |
title = self.req.pgettext(i18nctx, 'This %s' % entity.e_schema) |
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
494 |
removejs = self.removejs % (self.peid, self.rtype, entity.eid) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
495 |
countkey = '%s_count' % self.rtype |
2247
9dbbe6a4c9b0
use a counter of displayed inlined forms
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2224
diff
changeset
|
496 |
try: |
9dbbe6a4c9b0
use a counter of displayed inlined forms
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2224
diff
changeset
|
497 |
self.req.data[countkey] += 1 |
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
498 |
except KeyError: |
2247
9dbbe6a4c9b0
use a counter of displayed inlined forms
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2224
diff
changeset
|
499 |
self.req.data[countkey] = 1 |
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
500 |
self.w(self.form.form_render( |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
501 |
divid=divid, title=title, removejs=removejs, i18nctx=i18nctx, |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
502 |
counter=self.req.data[countkey], **kwargs)) |
1396 | 503 |
|
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
504 |
def add_hiddens(self, form, entity): |
3532
df045bc51d00
[inlined forms] nicer add_hiddens implementation relying on standard entity forms handling
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3518
diff
changeset
|
505 |
"""to ease overriding (see cubes.vcsfile.views.forms for instance)""" |
df045bc51d00
[inlined forms] nicer add_hiddens implementation relying on standard entity forms handling
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3518
diff
changeset
|
506 |
iid = 'rel-%s-%s-%s' % (self.peid, self.rtype, entity.eid) |
3534
81cfec545e1b
ensure str is given as field's name
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3532
diff
changeset
|
507 |
# * str(self.rtype) in case it's a schema object |
81cfec545e1b
ensure str is given as field's name
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3532
diff
changeset
|
508 |
# * neged_role() since role is the for parent entity, we want the role |
81cfec545e1b
ensure str is given as field's name
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3532
diff
changeset
|
509 |
# of the inlined entity |
81cfec545e1b
ensure str is given as field's name
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3532
diff
changeset
|
510 |
form.form_add_hidden(name=str(self.rtype), value=self.peid, |
3532
df045bc51d00
[inlined forms] nicer add_hiddens implementation relying on standard entity forms handling
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3518
diff
changeset
|
511 |
role=neg_role(self.role), eidparam=True, id=iid) |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
512 |
|
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
513 |
def keep_entity(self, form, entity): |
1147 | 514 |
if not entity.has_eid(): |
515 |
return True |
|
516 |
# are we regenerating form because of a validation error ? |
|
1750 | 517 |
if form.form_previous_values: |
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
518 |
cdvalues = self.req.list_form_param(eid_param(self.rtype, self.peid), |
1710
8c717cc0b353
refactor error handling: get validation error information from a form attribute instead of req.data to avoid pb when multiple forms are displayed
sylvain.thenault@logilab.fr
parents:
1703
diff
changeset
|
519 |
form.form_previous_values) |
1147 | 520 |
if unicode(entity.eid) not in cdvalues: |
521 |
return False |
|
522 |
return True |
|
523 |
||
524 |
||
525 |
class InlineEntityCreationFormView(InlineEntityEditionFormView): |
|
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
526 |
""" |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
527 |
:attr etype: the entity type being created in the inline form |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
528 |
""" |
1147 | 529 |
id = 'inline-creation' |
530 |
__select__ = (match_kwargs('peid', 'rtype') |
|
531 |
& specified_etype_implements('Any')) |
|
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
532 |
_select_attrs = InlineEntityEditionFormView._select_attrs + ('etype',) |
1423
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
533 |
removejs = "removeInlineForm('%s', '%s', '%s')" |
39320a58faac
missing overriding of removejs in inline-creation form view
sylvain.thenault@logilab.fr
parents:
1396
diff
changeset
|
534 |
|
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
535 |
@cached |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
536 |
def _entity(self): |
1147 | 537 |
try: |
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
538 |
cls = self.vreg['etypes'].etype_class(self.etype) |
1147 | 539 |
except: |
540 |
self.w(self.req._('no such entity type %s') % etype) |
|
541 |
return |
|
542 |
self.initialize_varmaker() |
|
3331
8e63b72287b1
cleaner code
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3327
diff
changeset
|
543 |
entity = cls(self.req) |
1147 | 544 |
entity.eid = self.varmaker.next() |
3518
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
545 |
return entity |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
546 |
|
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
547 |
def call(self, i18nctx, **kwargs): |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
548 |
self.render_form(i18nctx, **kwargs) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
549 |
|
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
550 |
|
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
551 |
class InlineAddNewLinkView(InlineEntityCreationFormView): |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
552 |
""" |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
553 |
:attr card: the cardinality of the relation according to role of `peid` |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
554 |
""" |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
555 |
id = 'inline-addnew-link' |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
556 |
__select__ = (match_kwargs('peid', 'rtype') |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
557 |
& specified_etype_implements('Any')) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
558 |
|
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
559 |
_select_attrs = InlineEntityCreationFormView._select_attrs + ('card',) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
560 |
form = None # no actual form wrapped |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
561 |
|
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
562 |
def call(self, i18nctx, **kwargs): |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
563 |
divid = "addNew%s%s%s:%s" % (self.etype, self.rtype, self.role, self.peid) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
564 |
self.w(u'<div class="inlinedform" id="%s" cubicweb:limit="true">' |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
565 |
% divid) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
566 |
js = "addInlineCreationForm('%s', '%s', '%s', '%s', '%s')" % ( |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
567 |
self.peid, self.etype, self.rtype, self.role, i18nctx) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
568 |
if self.pform.should_hide_add_new_relation_link(self.rtype, self.card): |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
569 |
js = "toggleVisibility('%s'); %s" % (divid, js) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
570 |
__ = self.req.pgettext |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
571 |
self.w(u'<a class="addEntity" id="add%s:%slink" href="javascript: %s" >+ %s.</a>' |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
572 |
% (self.rtype, self.peid, js, __(i18nctx, 'add a %s' % self.etype))) |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
573 |
self.w(u'</div>') |
11ce4682187d
[form] important refactoring of inlined forms to get proper separation of form object creation / rendering
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3513
diff
changeset
|
574 |
self.w(u'<div class="trame_grise"> </div>') |