author | Nicolas Chauvat <nicolas.chauvat@logilab.fr> |
Fri, 14 Aug 2009 18:55:31 +0200 | |
branch | stable |
changeset 2858 | 322272c5d67f |
parent 2852 | 858b33162e9d |
child 2859 | 822258915ff0 |
permissions | -rw-r--r-- |
0 | 1 |
/* |
2 |
* :organization: Logilab |
|
1419 | 3 |
* :copyright: 2003-2009 LOGILAB S.A. (Paris, FRANCE), all rights reserved. |
0 | 4 |
* :contact: http://www.logilab.fr/ -- mailto:contact@logilab.fr |
5 |
*/ |
|
6 |
||
7 |
CubicWeb.require('python.js'); |
|
8 |
CubicWeb.require('htmlhelpers.js'); |
|
9 |
CubicWeb.require('ajax.js'); |
|
10 |
||
11 |
||
12 |
//============= Eproperty form functions =====================================// |
|
13 |
||
14 |
/* called on Eproperty key selection: |
|
15 |
* - get the selected value |
|
16 |
* - get a widget according to the key by a sync query to the server |
|
17 |
* - fill associated div with the returned html |
|
18 |
* |
|
19 |
* @param varname the name of the variable as used in the original creation form |
|
20 |
* @param tabindex the tabindex that should be set on the widget |
|
21 |
*/ |
|
22 |
function setPropValueWidget(varname, tabindex) { |
|
1314
dc5499bff1a9
fix primary edition of eproperty (weird js pb remaining though)
sylvain.thenault@logilab.fr
parents:
1292
diff
changeset
|
23 |
var key = firstSelected(document.getElementById('pkey:'+varname)); |
0 | 24 |
if (key) { |
1419 | 25 |
var args = {fname: 'prop_widget', pageid: pageid, |
26 |
arg: map(jQuery.toJSON, [key, varname, tabindex])}; |
|
1314
dc5499bff1a9
fix primary edition of eproperty (weird js pb remaining though)
sylvain.thenault@logilab.fr
parents:
1292
diff
changeset
|
27 |
jqNode('div:value:'+varname).loadxhtml(JSON_BASE_URL, args, 'post'); |
0 | 28 |
} |
29 |
} |
|
30 |
||
31 |
||
32 |
// *** EDITION FUNCTIONS ****************************************** // |
|
33 |
||
34 |
/* |
|
35 |
* this function is called when an AJAX form was generated to |
|
36 |
* make sure tabindex remains consistent |
|
37 |
*/ |
|
38 |
function reorderTabindex(start) { |
|
39 |
var form = getNode('entityForm'); |
|
40 |
var inputTypes = ['INPUT', 'SELECT', 'TEXTAREA']; |
|
41 |
var tabindex = (start==null)?15:start; |
|
42 |
nodeWalkDepthFirst(form, function(elem) { |
|
43 |
var tagName = elem.tagName.toUpperCase(); |
|
44 |
if (inputTypes.contains(tagName)) { |
|
45 |
if (getNodeAttribute(elem, 'tabindex') != null) { |
|
46 |
tabindex += 1; |
|
47 |
elem.setAttribute('tabindex', tabindex); |
|
48 |
} |
|
49 |
return null; |
|
50 |
} |
|
51 |
return filter(isElementNode, elem.childNodes); |
|
52 |
}); |
|
53 |
} |
|
54 |
||
1419 | 55 |
|
0 | 56 |
function showMatchingSelect(selectedValue, eid) { |
57 |
if (selectedValue) { |
|
58 |
divId = 'div' + selectedValue + '_' + eid; |
|
59 |
var divNode = jQuery('#' + divId); |
|
60 |
if (!divNode.length) { |
|
61 |
var args = {vid: 'unrelateddivs', relation: selectedValue, |
|
1419 | 62 |
rql: rql_for_eid(eid), '__notemplate': 1, |
63 |
callback: function() {_showMatchingSelect(eid, jQuery('#' + divId))}}; |
|
64 |
jQuery('#unrelatedDivs_' + eid).loadxhtml(baseuri() + 'view', args, 'post', 'append'); |
|
0 | 65 |
} else { |
66 |
_showMatchingSelect(eid, divNode); |
|
67 |
} |
|
1419 | 68 |
} else { |
0 | 69 |
_showMatchingSelect(eid, null); |
70 |
} |
|
71 |
} |
|
72 |
||
73 |
||
74 |
// @param divNode is a jQuery selection |
|
75 |
function _showMatchingSelect(eid, divNode) { |
|
76 |
// hide all divs, and then show the matching one |
|
77 |
// (would actually be better to directly hide the displayed one) |
|
78 |
jQuery('#unrelatedDivs_' + eid).children().hide(); |
|
79 |
// divNode not found means 'no relation selected' (i.e. first blank item) |
|
80 |
if (divNode && divNode.length) { |
|
81 |
divNode.show(); |
|
82 |
} |
|
83 |
} |
|
84 |
||
85 |
// this function builds a Handle to cancel pending insertion |
|
86 |
function buildPendingInsertHandle(elementId, element_name, selectNodeId, eid) { |
|
87 |
jscall = "javascript: cancelPendingInsert('" + [elementId, element_name, selectNodeId, eid].join("', '") + "')"; |
|
88 |
return A({'class' : 'handle', 'href' : jscall, |
|
89 |
'title' : _("cancel this insert")}, '[x]'); |
|
90 |
} |
|
91 |
||
92 |
function buildEntityLine(relationName, selectedOptionNode, comboId, eid) { |
|
93 |
// textContent doesn't seem to work on selectedOptionNode |
|
94 |
var content = selectedOptionNode.firstChild.nodeValue; |
|
95 |
var handle = buildPendingInsertHandle(selectedOptionNode.id, 'tr', comboId, eid); |
|
96 |
var link = A({'href' : 'view?rql=' + selectedOptionNode.value, |
|
97 |
'class' : 'editionPending', 'id' : 'a' + selectedOptionNode.id}, |
|
98 |
content); |
|
99 |
var tr = TR({'id' : 'tr' + selectedOptionNode.id}, [ TH(null, relationName), |
|
100 |
TD(null, [handle, link]) |
|
101 |
]); |
|
102 |
try { |
|
103 |
var separator = getNode('relationSelectorRow_' + eid); |
|
104 |
//dump('relationSelectorRow_' + eid) XXX warn dump is not implemented in konqueror (at least) |
|
105 |
// XXX Warning: separator.parentNode is not (always ?) the |
|
106 |
// table itself, but an intermediate node (TableSectionElement) |
|
107 |
var tableBody = separator.parentNode; |
|
108 |
tableBody.insertBefore(tr, separator); |
|
109 |
} catch(ex) { |
|
110 |
log("got exception(2)!" + ex); |
|
111 |
} |
|
112 |
} |
|
113 |
||
114 |
function buildEntityCell(relationName, selectedOptionNode, comboId, eid) { |
|
115 |
var handle = buildPendingInsertHandle(selectedOptionNode.id, 'div_insert_', comboId, eid); |
|
116 |
var link = A({'href' : 'view?rql=' + selectedOptionNode.value, |
|
117 |
'class' : 'editionPending', 'id' : 'a' + selectedOptionNode.id}, |
|
118 |
content); |
|
119 |
var div = DIV({'id' : 'div_insert_' + selectedOptionNode.id}, [handle, link]); |
|
120 |
try { |
|
121 |
var td = jQuery('#cell'+ relationName +'_'+eid); |
|
122 |
td.appendChild(div); |
|
123 |
} catch(ex) { |
|
124 |
alert("got exception(3)!" + ex); |
|
125 |
} |
|
126 |
} |
|
127 |
||
128 |
function addPendingInsert(optionNode, eid, cell, relname) { |
|
129 |
var value = getNodeAttribute(optionNode, 'value'); |
|
130 |
if (!value) { |
|
131 |
// occurs when the first element in the box is selected (which is not |
|
132 |
// an entity but the combobox title) |
|
133 |
return; |
|
134 |
} |
|
135 |
// 2nd special case |
|
136 |
if (value.indexOf('http') == 0) { |
|
137 |
document.location = value; |
|
138 |
return; |
|
139 |
} |
|
140 |
// add hidden parameter |
|
141 |
var entityForm = jQuery('#entityForm'); |
|
142 |
var oid = optionNode.id.substring(2); // option id is prefixed by "id" |
|
1419 | 143 |
remoteExec('add_pending_inserts', [oid.split(':')]); |
0 | 144 |
var selectNode = optionNode.parentNode; |
145 |
// remove option node |
|
146 |
selectNode.removeChild(optionNode); |
|
147 |
// add line in table |
|
148 |
if (cell) { |
|
149 |
// new relation as a cell in multiple edit |
|
150 |
// var relation_name = relationSelected.getAttribute('value'); |
|
151 |
// relation_name = relation_name.slice(0, relation_name.lastIndexOf('_')); |
|
152 |
buildEntityCell(relname, optionNode, selectNode.id, eid); |
|
153 |
} |
|
154 |
else { |
|
155 |
var relationSelector = getNode('relationSelector_'+eid); |
|
156 |
var relationSelected = relationSelector.options[relationSelector.selectedIndex]; |
|
157 |
// new relation as a line in simple edit |
|
158 |
buildEntityLine(relationSelected.text, optionNode, selectNode.id, eid); |
|
159 |
} |
|
160 |
} |
|
161 |
||
162 |
function cancelPendingInsert(elementId, element_name, comboId, eid) { |
|
163 |
// remove matching insert element |
|
164 |
var entityView = jqNode('a' + elementId).text(); |
|
165 |
jqNode(element_name + elementId).remove(); |
|
166 |
if (comboId) { |
|
167 |
// re-insert option in combobox if it was taken from there |
|
168 |
var selectNode = getNode(comboId); |
|
1713
d817f23439ba
bix a bug: correct the sended parameter 'no need for id in the string parameter name'
Graziella Toutoungis <graziella.toutoungis@logilab.fr>
parents:
1419
diff
changeset
|
169 |
// XXX what on object relation |
0 | 170 |
if (selectNode){ |
171 |
var options = selectNode.options; |
|
172 |
var node_id = elementId.substring(0, elementId.indexOf(':')); |
|
173 |
options[options.length] = OPTION({'id' : elementId, 'value' : node_id}, entityView); |
|
174 |
} |
|
175 |
} |
|
1713
d817f23439ba
bix a bug: correct the sended parameter 'no need for id in the string parameter name'
Graziella Toutoungis <graziella.toutoungis@logilab.fr>
parents:
1419
diff
changeset
|
176 |
elementId = elementId.substring(2, elementId.length); |
1419 | 177 |
remoteExec('remove_pending_insert', elementId.split(':')); |
0 | 178 |
} |
179 |
||
180 |
// this function builds a Handle to cancel pending insertion |
|
181 |
function buildPendingDeleteHandle(elementId, eid) { |
|
182 |
var jscall = "javascript: addPendingDelete('" + elementId + ', ' + eid + "');"; |
|
183 |
return A({'href' : jscall, 'class' : 'pendingDeleteHandle', |
|
184 |
'title' : _("delete this relation")}, '[x]'); |
|
185 |
} |
|
186 |
||
187 |
// @param nodeId eid_from:r_type:eid_to |
|
188 |
function addPendingDelete(nodeId, eid) { |
|
1419 | 189 |
var d = asyncRemoteExec('add_pending_delete', nodeId.split(':')); |
0 | 190 |
d.addCallback(function () { |
191 |
// and strike entity view |
|
192 |
jqNode('span' + nodeId).addClass('pendingDelete'); |
|
193 |
// replace handle text |
|
194 |
jqNode('handle' + nodeId).text('+'); |
|
195 |
}); |
|
196 |
} |
|
197 |
||
198 |
// @param nodeId eid_from:r_type:eid_to |
|
199 |
function cancelPendingDelete(nodeId, eid) { |
|
1419 | 200 |
var d = asyncRemoteExec('remove_pending_delete', nodeId.split(':')); |
0 | 201 |
d.addCallback(function () { |
202 |
// reset link's CSS class |
|
203 |
jqNode('span' + nodeId).removeClass('pendingDelete'); |
|
204 |
// replace handle text |
|
205 |
jqNode('handle' + nodeId).text('x'); |
|
206 |
}); |
|
207 |
} |
|
208 |
||
209 |
// @param nodeId eid_from:r_type:eid_to |
|
210 |
function togglePendingDelete(nodeId, eid) { |
|
211 |
// node found means we should cancel deletion |
|
212 |
if ( hasElementClass(getNode('span' + nodeId), 'pendingDelete') ) { |
|
213 |
cancelPendingDelete(nodeId, eid); |
|
214 |
} else { |
|
215 |
addPendingDelete(nodeId, eid); |
|
216 |
} |
|
217 |
} |
|
218 |
||
219 |
||
220 |
function selectForAssociation(tripletIdsString, originalEid) { |
|
221 |
var tripletlist = map(function (x) { return x.split(':'); }, |
|
222 |
tripletIdsString.split('-')); |
|
1419 | 223 |
var d = asyncRemoteExec('add_pending_inserts', tripletlist); |
0 | 224 |
d.addCallback(function () { |
225 |
var args = {vid: 'edition', __mode: 'normal', |
|
226 |
rql: rql_for_eid(originalEid)}; |
|
1419 | 227 |
document.location = 'view?' + asURL(args); |
0 | 228 |
}); |
229 |
||
230 |
} |
|
231 |
||
232 |
||
233 |
function updateInlinedEntitiesCounters(rtype) { |
|
234 |
jQuery('#inline' + rtype + 'slot span.icounter').each(function (i) { |
|
235 |
this.innerHTML = i+1; |
|
236 |
}); |
|
237 |
} |
|
238 |
||
1419 | 239 |
|
0 | 240 |
/* |
241 |
* makes an AJAX request to get an inline-creation view's content |
|
242 |
* @param peid : the parent entity eid |
|
243 |
* @param ttype : the target (inlined) entity type |
|
244 |
* @param rtype : the relation type between both entities |
|
245 |
*/ |
|
1292
18a86192c9c4
inline_creation_form doesn't take ptype argument anymore
sylvain.thenault@logilab.fr
parents:
992
diff
changeset
|
246 |
function addInlineCreationForm(peid, ttype, rtype, role) { |
1419 | 247 |
var d = asyncRemoteExec('inline_creation_form', peid, ttype, rtype, role); |
0 | 248 |
d.addCallback(function (response) { |
249 |
var linknode = getNode('add' + rtype + ':' + peid + 'link'); |
|
992
d5fe2626695b
call postAjaxLoad in addInlineCreationForm javascript function in order to call buildWysiwygEditors when a section of the page is reloaded
Stephanie Marcu <stephanie.marcu@logilab.fr>
parents:
977
diff
changeset
|
250 |
var dom = getDomFromResponse(response); |
2852
858b33162e9d
[ajax] allow inlineCreationForms to add their own JS / CSS
Adrien Di Mascio <Adrien.DiMascio@logilab.fr>
parents:
2538
diff
changeset
|
251 |
preprocessAjaxLoad(null, dom); |
992
d5fe2626695b
call postAjaxLoad in addInlineCreationForm javascript function in order to call buildWysiwygEditors when a section of the page is reloaded
Stephanie Marcu <stephanie.marcu@logilab.fr>
parents:
977
diff
changeset
|
252 |
var form = jQuery(dom); |
0 | 253 |
form.css('display', 'none'); |
254 |
form.insertBefore(linknode.parentNode).slideDown('fast'); |
|
255 |
updateInlinedEntitiesCounters(rtype); |
|
256 |
reorderTabindex(); |
|
257 |
form.trigger('inlinedform-added'); |
|
992
d5fe2626695b
call postAjaxLoad in addInlineCreationForm javascript function in order to call buildWysiwygEditors when a section of the page is reloaded
Stephanie Marcu <stephanie.marcu@logilab.fr>
parents:
977
diff
changeset
|
258 |
postAjaxLoad(dom); |
0 | 259 |
}); |
260 |
d.addErrback(function (xxx) { |
|
261 |
log('xxx =', xxx); |
|
262 |
}); |
|
263 |
} |
|
264 |
||
265 |
/* |
|
266 |
* removes the part of the form used to edit an inlined entity |
|
267 |
*/ |
|
268 |
function removeInlineForm(peid, rtype, eid) { |
|
269 |
jqNode(['div', peid, rtype, eid].join('-')).slideUp('fast', function() { |
|
270 |
$(this).remove(); |
|
271 |
updateInlinedEntitiesCounters(rtype); |
|
272 |
}); |
|
273 |
} |
|
274 |
||
275 |
/* |
|
276 |
* alternatively adds or removes the hidden input that make the |
|
277 |
* edition of the relation `rtype` possible between `peid` and `eid` |
|
278 |
* @param peid : the parent entity eid |
|
279 |
* @param rtype : the relation type between both entities |
|
280 |
* @param eid : the inlined entity eid |
|
281 |
*/ |
|
282 |
function removeInlinedEntity(peid, rtype, eid) { |
|
283 |
var nodeid = ['rel', peid, rtype, eid].join('-'); |
|
284 |
var node = jqNode(nodeid); |
|
285 |
if (node && node.length) { |
|
286 |
node.remove(); |
|
1419 | 287 |
var divid = ['div', peid, rtype, eid].join('-'); |
0 | 288 |
jqNode(divid).fadeTo('fast', 0.5); |
1419 | 289 |
var noticeid = ['notice', peid, rtype, eid].join('-'); |
0 | 290 |
jqNode(noticeid).fadeIn('fast'); |
291 |
} |
|
292 |
} |
|
293 |
||
294 |
function restoreInlinedEntity(peid, rtype, eid) { |
|
295 |
var nodeid = ['rel', peid, rtype, eid].join('-'); |
|
296 |
var divid = ['div', peid, rtype, eid].join('-'); |
|
297 |
var noticeid = ['notice', peid, rtype, eid].join('-'); |
|
298 |
var node = jqNode(nodeid); |
|
299 |
if (!(node && node.length)) { |
|
300 |
node = INPUT({type: 'hidden', id: nodeid, |
|
301 |
name: rtype+':'+peid, value: eid}); |
|
302 |
jqNode(['fs', peid, rtype, eid].join('-')).append(node); |
|
303 |
jqNode(divid).fadeTo('fast', 1); |
|
304 |
jqNode(noticeid).hide(); |
|
305 |
} |
|
306 |
} |
|
307 |
||
308 |
function _clearPreviousErrors(formid) { |
|
2246
e89c15221a8a
remove error class from fields as well
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2242
diff
changeset
|
309 |
jQuery('#' + formid + 'ErrorMessage').remove(); |
0 | 310 |
jQuery('#' + formid + ' span.error').remove(); |
2246
e89c15221a8a
remove error class from fields as well
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2242
diff
changeset
|
311 |
jQuery('#' + formid + ' .error').removeClass('error'); |
0 | 312 |
} |
313 |
||
314 |
function _displayValidationerrors(formid, eid, errors) { |
|
315 |
var globalerrors = []; |
|
316 |
var firsterrfield = null; |
|
317 |
for (fieldname in errors) { |
|
318 |
var errmsg = errors[fieldname]; |
|
319 |
var fieldid = fieldname + ':' + eid; |
|
320 |
var field = jqNode(fieldname + ':' + eid); |
|
321 |
if (field && getNodeAttribute(field, 'type') != 'hidden') { |
|
322 |
if ( !firsterrfield ) { |
|
323 |
firsterrfield = 'err-' + fieldid; |
|
324 |
} |
|
325 |
addElementClass(field, 'error'); |
|
326 |
var span = SPAN({'id': 'err-' + fieldid, 'class': "error"}, errmsg); |
|
327 |
field.before(span); |
|
328 |
} else { |
|
329 |
firsterrfield = formid; |
|
2242
6772f8e859c2
translate not found fields, also clear global errors
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1971
diff
changeset
|
330 |
globalerrors.push(_(fieldname) + ' : ' + errmsg); |
0 | 331 |
} |
332 |
} |
|
333 |
if (globalerrors.length) { |
|
334 |
if (globalerrors.length == 1) { |
|
335 |
var innernode = SPAN(null, globalerrors[0]); |
|
336 |
} else { |
|
337 |
var innernode = UL(null, map(LI, globalerrors)); |
|
338 |
} |
|
339 |
// insert DIV and innernode before the form |
|
2246
e89c15221a8a
remove error class from fields as well
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2242
diff
changeset
|
340 |
var div = DIV({'class' : "errorMessage", 'id': formid + 'ErrorMessage'}); |
0 | 341 |
div.appendChild(innernode); |
342 |
jQuery('#' + formid).before(div); |
|
343 |
} |
|
344 |
return firsterrfield || formid; |
|
345 |
} |
|
346 |
||
347 |
||
1864
4ceaf8f2709b
add onfailure fonction for validateForm, return formid on success
Katia Saurfelt <katia.saurfelt@logilab.fr>
parents:
1798
diff
changeset
|
348 |
function handleFormValidationResponse(formid, onsuccess, onfailure, result) { |
0 | 349 |
// Success |
350 |
if (result[0]) { |
|
351 |
if (onsuccess) { |
|
2364
fa16d36d60cb
[js] small cleanup
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2345
diff
changeset
|
352 |
onsuccess(result[1], formid); |
0 | 353 |
} else { |
354 |
document.location.href = result[1]; |
|
355 |
} |
|
2364
fa16d36d60cb
[js] small cleanup
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2345
diff
changeset
|
356 |
return; |
0 | 357 |
} |
358 |
unfreezeFormButtons(formid); |
|
359 |
// Failures |
|
360 |
_clearPreviousErrors(formid); |
|
361 |
var descr = result[1]; |
|
362 |
// Unknown structure |
|
363 |
if ( !isArrayLike(descr) || descr.length != 2 ) { |
|
364 |
log('got strange error :', descr); |
|
365 |
updateMessage(descr); |
|
2364
fa16d36d60cb
[js] small cleanup
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2345
diff
changeset
|
366 |
return; |
0 | 367 |
} |
368 |
_displayValidationerrors(formid, descr[0], descr[1]); |
|
369 |
updateMessage(_("please correct errors below")); |
|
370 |
document.location.hash = '#header'; |
|
1864
4ceaf8f2709b
add onfailure fonction for validateForm, return formid on success
Katia Saurfelt <katia.saurfelt@logilab.fr>
parents:
1798
diff
changeset
|
371 |
if (onfailure){ |
4ceaf8f2709b
add onfailure fonction for validateForm, return formid on success
Katia Saurfelt <katia.saurfelt@logilab.fr>
parents:
1798
diff
changeset
|
372 |
onfailure(formid); |
4ceaf8f2709b
add onfailure fonction for validateForm, return formid on success
Katia Saurfelt <katia.saurfelt@logilab.fr>
parents:
1798
diff
changeset
|
373 |
} |
2364
fa16d36d60cb
[js] small cleanup
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2345
diff
changeset
|
374 |
return; |
0 | 375 |
} |
376 |
||
377 |
||
378 |
/* unfreeze form buttons when the validation process is over*/ |
|
379 |
function unfreezeFormButtons(formid) { |
|
380 |
jQuery('#progress').hide(); |
|
381 |
jQuery('#' + formid + ' input.validateButton').removeAttr('disabled'); |
|
382 |
return true; |
|
383 |
} |
|
384 |
||
385 |
/* disable form buttons while the validation is being done */ |
|
386 |
function freezeFormButtons(formid) { |
|
387 |
jQuery('#progress').show(); |
|
977 | 388 |
jQuery('#' + formid + ' input.validateButton').attr('disabled', 'disabled'); |
0 | 389 |
return true; |
390 |
} |
|
391 |
||
392 |
/* used by additional submit buttons to remember which button was clicked */ |
|
393 |
function postForm(bname, bvalue, formid) { |
|
394 |
var form = getNode(formid); |
|
395 |
if (bname) { |
|
396 |
form.appendChild(INPUT({type: 'hidden', name: bname, value: bvalue})); |
|
397 |
} |
|
398 |
var onsubmit = form.onsubmit; |
|
399 |
if (!onsubmit || (onsubmit && onsubmit())) { |
|
400 |
form.submit(); |
|
401 |
} |
|
402 |
} |
|
403 |
||
404 |
||
405 |
/* called on load to set target and iframeso object. |
|
406 |
* NOTE: this is a hack to make the XHTML compliant. |
|
407 |
* NOTE2: `object` nodes might be a potential replacement for iframes |
|
408 |
* NOTE3: there is a XHTML module allowing iframe elements but there |
|
409 |
* is still the problem of the form's `target` attribute |
|
410 |
*/ |
|
411 |
function setFormsTarget() { |
|
412 |
jQuery('form.entityForm').each(function () { |
|
413 |
var form = jQuery(this); |
|
414 |
var target = form.attr('cubicweb:target'); |
|
415 |
if (target) { |
|
416 |
form.attr('target', target); |
|
1419 | 417 |
/* do not use display: none because some browsers ignore iframe |
418 |
* with no display */ |
|
0 | 419 |
form.append(IFRAME({name: target, id: target, |
420 |
src: 'javascript: void(0)', |
|
421 |
width: '0px', height: '0px'})); |
|
422 |
} |
|
423 |
}); |
|
424 |
} |
|
425 |
||
2364
fa16d36d60cb
[js] small cleanup
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2345
diff
changeset
|
426 |
jQuery(document).ready(setFormsTarget); |
0 | 427 |
|
428 |
||
429 |
/* |
|
430 |
* called on traditionnal form submission : the idea is to try |
|
431 |
* to post the form. If the post is successful, `validateForm` redirects |
|
432 |
* to the appropriate URL. Otherwise, the validation errors are displayed |
|
433 |
* around the corresponding input fields. |
|
434 |
*/ |
|
1864
4ceaf8f2709b
add onfailure fonction for validateForm, return formid on success
Katia Saurfelt <katia.saurfelt@logilab.fr>
parents:
1798
diff
changeset
|
435 |
function validateForm(formid, action, onsuccess, onfailure) { |
0 | 436 |
try { |
1419 | 437 |
var zipped = formContents(formid); |
438 |
var d = asyncRemoteExec('validate_form', action, zipped[0], zipped[1]); |
|
0 | 439 |
} catch (ex) { |
440 |
log('got exception', ex); |
|
441 |
return false; |
|
442 |
} |
|
443 |
function _callback(result, req) { |
|
1864
4ceaf8f2709b
add onfailure fonction for validateForm, return formid on success
Katia Saurfelt <katia.saurfelt@logilab.fr>
parents:
1798
diff
changeset
|
444 |
handleFormValidationResponse(formid, onsuccess, onfailure, result); |
0 | 445 |
} |
446 |
d.addCallback(_callback); |
|
447 |
return false; |
|
448 |
} |
|
449 |
||
1419 | 450 |
|
0 | 451 |
/* |
1759
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
452 |
* called by reledit forms to submit changes |
0 | 453 |
* @param formid : the dom id of the form used |
454 |
* @param rtype : the attribute being edited |
|
455 |
* @param eid : the eid of the entity being edited |
|
456 |
* @param reload: boolean to reload page if true (when changing URL dependant 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:
2382
diff
changeset
|
457 |
* @param default_value : value if the field is empty |
dead2d56f711
[reledit] attributes : have a laning zone after all (less intrusive), fix likely bug of relation edition
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2382
diff
changeset
|
458 |
* @param lzone : html fragment (string) for a clic-zone triggering actual edition |
0 | 459 |
*/ |
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
460 |
function inlineValidateAttributeForm(rtype, eid, divid, reload, default_value) { |
0 | 461 |
try { |
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
462 |
var form = getNode(divid+'-form'); |
0 | 463 |
if (typeof FCKeditorAPI != "undefined") { |
464 |
for ( var name in FCKeditorAPI.__Instances ) { |
|
465 |
var oEditor = FCKeditorAPI.__Instances[name] ; |
|
466 |
if ( oEditor.GetParentForm() == form ) { |
|
467 |
oEditor.UpdateLinkedField(); |
|
468 |
} |
|
469 |
} |
|
470 |
} |
|
471 |
var zipped = formContents(form); |
|
1798
cc86fe8efaaa
pass default values along the whole call chain, fix hidden field update bug
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1760
diff
changeset
|
472 |
var d = asyncRemoteExec('edit_field', 'apply', zipped[0], zipped[1], |
2345
16e3d0e47ee6
[reledit] there is nothing to escape, also cleanup lzone for attributes
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2334
diff
changeset
|
473 |
rtype, eid, default_value); |
0 | 474 |
} catch (ex) { |
475 |
log('got exception', ex); |
|
476 |
return false; |
|
477 |
} |
|
478 |
d.addCallback(function (result, req) { |
|
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
479 |
handleFormValidationResponse(divid+'-form', noop, noop, result); |
0 | 480 |
if (reload) { |
2490
b0771c03f531
[reledit] do NOT peruse the likely ?vid=edition part
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2483
diff
changeset
|
481 |
document.location.href = result[1].split('?')[0]; |
0 | 482 |
} else { |
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:
2382
diff
changeset
|
483 |
var fieldview = getNode('value-' + divid); |
0 | 484 |
// XXX using innerHTML is very fragile and won't work if |
485 |
// we mix XHTML and HTML |
|
486 |
fieldview.innerHTML = result[2]; |
|
487 |
// switch inline form off only if no error |
|
488 |
if (result[0]) { |
|
489 |
// hide global error messages |
|
490 |
jQuery('div.errorMessage').remove(); |
|
491 |
jQuery('#appMsg').hide(); |
|
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
492 |
hideInlineEdit(eid, rtype, divid); |
0 | 493 |
} |
494 |
} |
|
495 |
return false; |
|
496 |
}); |
|
497 |
return false; |
|
498 |
} |
|
499 |
||
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
500 |
function inlineValidateRelationForm(rtype, role, eid, divid, reload, vid, |
2345
16e3d0e47ee6
[reledit] there is nothing to escape, also cleanup lzone for attributes
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2334
diff
changeset
|
501 |
default_value, lzone) { |
1759
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
502 |
try { |
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
503 |
var form = getNode(divid+'-form'); |
1798
cc86fe8efaaa
pass default values along the whole call chain, fix hidden field update bug
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1760
diff
changeset
|
504 |
var relname = rtype + ':' + eid; |
cc86fe8efaaa
pass default values along the whole call chain, fix hidden field update bug
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1760
diff
changeset
|
505 |
var newtarget = jQuery('[name=' + relname + ']').val(); |
1759
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
506 |
var zipped = formContents(form); |
2382
c1dcb5aef4b4
[reledit] simplify a bit more
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2371
diff
changeset
|
507 |
var d = asyncRemoteExec('validate_form', 'apply', zipped[0], zipped[1]); |
1759
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
508 |
} catch (ex) { |
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
509 |
log('got exception', ex); |
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
510 |
return false; |
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
511 |
} |
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
512 |
d.addCallback(function (result, req) { |
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
513 |
handleFormValidationResponse(divid+'-form', noop, noop, result); |
2334
464c896bee65
[reledit] reload support for relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2330
diff
changeset
|
514 |
if (reload) { |
464c896bee65
[reledit] reload support for relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2330
diff
changeset
|
515 |
document.location.href = result[1]; |
464c896bee65
[reledit] reload support for relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2330
diff
changeset
|
516 |
} else { |
464c896bee65
[reledit] reload support for relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2330
diff
changeset
|
517 |
if (result[0]) { |
2382
c1dcb5aef4b4
[reledit] simplify a bit more
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2371
diff
changeset
|
518 |
var d = asyncRemoteExec('reledit_form', eid, rtype, role, default_value, lzone); |
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
519 |
d.addCallback(function (result) { |
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:
2382
diff
changeset
|
520 |
// XXX brittle ... replace with loadxhtml |
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
521 |
jQuery('#'+divid+'-reledit').replaceWith(result); |
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
522 |
}); |
2334
464c896bee65
[reledit] reload support for relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2330
diff
changeset
|
523 |
} |
1759
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
524 |
} |
1760
6b97d286eb5a
[reledit] relation edition : cleanup a bit #343123
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1759
diff
changeset
|
525 |
return false; |
1759
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
526 |
}); |
1760
6b97d286eb5a
[reledit] relation edition : cleanup a bit #343123
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1759
diff
changeset
|
527 |
return false; |
1759
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
528 |
} |
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
529 |
|
61d026ced19f
preliminary support for inline edition of relations
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
1713
diff
changeset
|
530 |
|
0 | 531 |
/**** inline edition ****/ |
532 |
function showInlineEditionForm(eid, rtype, divid) { |
|
533 |
jQuery('#' + divid).hide(); |
|
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
534 |
jQuery('#' + divid+'-form').show(); |
0 | 535 |
} |
536 |
||
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
537 |
function hideInlineEdit(eid, rtype, divid) { |
0 | 538 |
jQuery('#' + divid).show(); |
2371
76bf522c27be
[reledit] simplify, fixing #344545
Aurelien Campeas <aurelien.campeas@logilab.fr>
parents:
2364
diff
changeset
|
539 |
jQuery('#' + divid+'-form').hide(); |
0 | 540 |
} |
541 |
||
542 |
CubicWeb.provide('edition.js'); |