| author | Production Moz <dev@sopinspace.com> |
| Sat, 19 May 2012 10:21:54 +0200 | |
| changeset 438 | fcc5e2f0befd |
| parent 373 | f6fe14eb51bc |
| child 504 | b2e0186daa5b |
| permissions | -rw-r--r-- |
| 0 | 1 |
// DOM MANIPULATION TO DYNAMICALLY RENDER COMMENTS SCOPES IN TEXT |
2 |
||
3 |
// cf. http://www.quirksmode.org/dom/w3c_core.html#nodemanipulation (informative!) |
|
4 |
||
5 |
// classes : |
|
6 |
// c-s is for 'textnode wrapper span' |
|
7 |
// c-c is a comment marker |
|
8 |
||
9 |
paintCommentScope = function(comment) { |
|
| 341 | 10 |
if (comment.reply_to_id == null && comment['start_wrapper'] != -1) { |
11 |
var selection = { 'start' : { 'elt' : document.getElementById("sv_"+comment['start_wrapper']), 'offset' : comment['start_offset'] }, |
|
12 |
'end' : { 'elt' : document.getElementById("sv_"+comment['end_wrapper']), 'offset' : comment['end_offset'] } |
|
13 |
} ; |
|
14 |
if (document.getElementById("sv_"+comment['start_wrapper'])== null) { |
|
15 |
warn_server({'from':'paintCommentScope', 'start_wrapper':comment['start_wrapper']}) ; |
|
16 |
} |
|
17 |
else { |
|
18 |
if (document.getElementById("sv_"+comment['end_wrapper'])== null) |
|
19 |
warn_server({'from':'paintCommentScope', 'end_wrapper':comment['end_wrapper']}) ; |
|
20 |
else { |
|
21 |
selection['start'] = _convertSelectionFromCSToCC(selection['start']) ; |
|
22 |
selection['end'] = _convertSelectionFromCSToCC(selection['end']) ; |
|
23 |
|
|
24 |
renderComment(selection, comment['id']) ; |
|
25 |
} |
|
26 |
} |
|
27 |
} |
|
| 0 | 28 |
} ; |
29 |
||
30 |
getCommentIdsFromClasses = function (elt) { |
|
| 341 | 31 |
var commentIds = [] ; |
32 |
var classes = elt['className'].split(" ") ; |
|
33 |
for (var i = 0, ilen = classes.length ; i < ilen ; i++) { |
|
34 |
if (classes[i].indexOf('c-id-') == 0) { |
|
35 |
commentIds.push(parseInt(classes[i].substring('c-id-'.length))) ; |
|
36 |
} |
|
37 |
} |
|
38 |
return commentIds ; |
|
| 0 | 39 |
} ; |
40 |
||
41 |
renderComment = function (selection, commentId) { |
|
| 341 | 42 |
var startOffset = selection['start']['offset'] ; |
43 |
var endOffset = selection['end']['offset'] ; |
|
44 |
var startElt = selection['start']['elt'] ; |
|
45 |
var endElt = selection['end']['elt'] ; |
|
| 0 | 46 |
|
| 341 | 47 |
|
| 0 | 48 |
if ((startElt != null) && (endElt != null) && _getTextNodeContent(startElt) != '' && _getTextNodeContent(endElt) != ''){ |
49 |
// log('startElt.id : ' + startElt.id) ; |
|
50 |
// log('endElt.id : ' + endElt.id) ; |
|
| 341 | 51 |
// log('startElt.innerHTML : ' + startElt.innerHTML) ; |
52 |
// log('endElt.innerHTML : ' + endElt.innerHTML) ; |
|
53 |
markWholeNodesAsComments(startElt, endElt, commentId) ; |
|
54 |
markEndsAsComments(startElt, startOffset, endElt, endOffset, commentId) ; |
|
55 |
} |
|
| 0 | 56 |
} ; |
57 |
||
58 |
markWholeNodesAsComments = function (startElt, endElt, commentId) { |
|
59 |
var commonAncestor = _findCommonAncestor(startElt, endElt) ; |
|
60 |
_dynSpanToAnc(startElt, commonAncestor, commentId, false) ; |
|
61 |
|
|
62 |
_dynSpanToAnc(endElt, commonAncestor, commentId, true) ; |
|
63 |
||
64 |
_dynSpanInBetween(commonAncestor, startElt, endElt, commentId) ; |
|
65 |
} ; |
|
66 |
||
67 |
_setTextNodeContent = function(txtNodeParent, contentString) { |
|
68 |
CY.DOM.setText(txtNodeParent, contentString); |
|
69 |
} ; |
|
70 |
||
71 |
_getTextNodeContent = function(txtNodeParent) { |
|
72 |
return CY.DOM.getText(txtNodeParent); |
|
73 |
} ; |
|
74 |
||
75 |
markEndsAsComments = function(startElt, startOffset, endElt, endOffset, commentId) { |
|
| 341 | 76 |
|
77 |
// alert('starting with: ' + startElt.childNodes.length + 'and a length of : ' + startElt.firstChild.data.length) ; |
|
78 |
// alert('2 and a length of : ' + CY.DOM.getText(startElt).length) ; |
|
| 0 | 79 |
|
| 341 | 80 |
var beforeStart = _getTextNodeContent(startElt).substring(0, startOffset) ; |
81 |
var afterStart = _getTextNodeContent(startElt).substring(startOffset) ; |
|
82 |
var beforeEnd = _getTextNodeContent(endElt).substring(0, endOffset) ; |
|
83 |
var afterEnd = _getTextNodeContent(endElt).substring(endOffset) ; |
|
| 0 | 84 |
|
85 |
var sameNode = (startElt === endElt) ; |
|
86 |
|
|
87 |
// log('beforeStart : ' + beforeStart + ' , afterStart : ' + afterStart + ' , beforeEnd : ' + beforeEnd + ' , afterEnd : ' + afterEnd + ' , sameNode : ' + sameNode) ; |
|
88 |
|
|
89 |
// taking care of start node : (and 'sameNode' case when start and end lie |
|
| 341 | 90 |
// on same node) |
| 0 | 91 |
if (afterStart != "") { // otherwise nothing to do on the start node |
| 341 | 92 |
if (CY.DOM.hasClass(startElt, 'c-c')) { |
93 |
var lastElt = null, afterStartElt = null, afterEndElt = null, beforeStartElt = null ; |
|
94 |
|
|
95 |
var btw = (sameNode) ? _getTextNodeContent(startElt).substring(startOffset, endOffset) : afterStart ; |
|
96 |
|
|
| 0 | 97 |
|
| 341 | 98 |
if (sameNode && (afterEnd != "")) { |
99 |
afterEndElt = startElt ; |
|
100 |
lastElt = afterEndElt ; |
|
101 |
} |
|
102 |
if (btw != "") { |
|
103 |
if (lastElt == null) { |
|
104 |
afterStartElt = startElt ; |
|
105 |
} |
|
106 |
else { |
|
107 |
afterStartElt = _yuiCloneNode(startElt) ; |
|
108 |
lastElt.parentNode.insertBefore(afterStartElt, lastElt) ; |
|
109 |
} |
|
110 |
lastElt = afterStartElt ; |
|
111 |
} |
|
112 |
if (beforeStart != "") { |
|
113 |
if (lastElt == null) { |
|
114 |
beforeStartElt = startElt ; |
|
115 |
} |
|
116 |
else { |
|
117 |
beforeStartElt = _yuiCloneNode(startElt) ; |
|
118 |
lastElt.parentNode.insertBefore(beforeStartElt, lastElt) ; |
|
119 |
} |
|
120 |
lastElt = beforeStartElt ; |
|
121 |
} |
|
122 |
|
|
123 |
if (afterEndElt != null) { |
|
124 |
_setTextNodeContent(afterEndElt, afterEnd) ; |
|
125 |
} |
|
126 |
|
|
127 |
if (afterStartElt != null) { |
|
128 |
_setTextNodeContent(afterStartElt, btw) ; |
|
129 |
_addIdClass(afterStartElt, commentId) ; |
|
130 |
} |
|
| 0 | 131 |
|
| 341 | 132 |
// alert('beforeStartElt.firstChild.data.length: ' + beforeStartElt.firstChild.data.length); |
133 |
// alert('beforeStartElt.childNodes.length: ' + beforeStartElt.childNodes.length); |
|
134 |
if (beforeStartElt != null) { |
|
135 |
_setTextNodeContent(beforeStartElt, beforeStart) ; |
|
136 |
} |
|
137 |
// alert('beforeStartElt.childNodes.length: ' + beforeStartElt.childNodes.length); |
|
138 |
//alert('typeof beforeStartElt: ' + typeof beforeStartElt); |
|
139 |
// alert('beforeStartElt.lastChild == beforeStartElt.firstChild : ' + (beforeStartElt.lastChild == beforeStartElt.firstChild)); |
|
140 |
|
|
141 |
// alert('beforeStartElt.firstChild.id : ' + beforeStartElt.firstChild.id); |
|
142 |
// alert('beforeStartElt.lastChild.data : ' + beforeStartElt.lastChild.data); |
|
143 |
// alert('beforeStartElt.firstChild.data : ' + beforeStartElt.firstChild.data); |
|
144 |
// alert('afterStartElt.firstChild.data : ' + afterStartElt.firstChild.data); |
|
145 |
// alert('afterEndElt.firstChild.data : ' + afterEndElt.firstChild.data); |
|
146 |
|
|
147 |
} |
|
| 0 | 148 |
} |
149 |
if ( ( !sameNode ) && ( beforeEnd != "" ) ) { // otherwise nothing to do |
|
| 341 | 150 |
// on the end node |
151 |
if (CY.DOM.hasClass(endElt, 'c-c')) { |
|
152 |
var lastElt = null, beforeEndElt = null, afterEndElt = null ; |
|
153 |
|
|
154 |
if (afterEnd != "") { |
|
155 |
afterEndElt = endElt ; |
|
156 |
lastElt = endElt ; |
|
157 |
} |
|
158 |
|
|
159 |
if (beforeEnd != "") { |
|
160 |
if (lastElt == null) |
|
161 |
beforeEndElt = endElt ; |
|
162 |
else { |
|
163 |
beforeEndElt = _yuiCloneNode(endElt) ; |
|
164 |
lastElt.parentNode.insertBefore(beforeEndElt, lastElt) ; |
|
165 |
} |
|
166 |
lastElt = beforeEndElt ; |
|
167 |
} |
|
168 |
if (afterEndElt != null) { |
|
169 |
_setTextNodeContent(afterEndElt, afterEnd) ; |
|
170 |
} |
|
171 |
|
|
172 |
if (beforeEndElt != null) { |
|
173 |
_addIdClass(beforeEndElt, commentId) ; |
|
174 |
_setTextNodeContent(beforeEndElt, beforeEnd) ; |
|
175 |
} |
|
176 |
} |
|
| 0 | 177 |
} |
178 |
} ; |
|
179 |
||
180 |
// WARNING (200891108): had to use YUI cloneNode instead of the native cloneNode |
|
181 |
// (because of the _yuid that is cloned under IE, cf tests made in textYUIcloneNode.html) |
|
182 |
// so code like : |
|
183 |
// afterStartElt = startElt.cloneNode(true) ; |
|
184 |
// afterStartElt.id = CY.guid() ; |
|
185 |
// was replaced with : |
|
186 |
// afterStartElt = _yuiCloneNode(startElt) ; |
|
187 |
_yuiCloneNode = function (srcElt) { |
|
| 341 | 188 |
var ret = CY.Node.getDOMNode(CY.get('#'+srcElt.id).cloneNode(true)) ; |
189 |
ret.id = CY.guid(); |
|
190 |
return ret ; |
|
| 0 | 191 |
} ; |
192 |
||
193 |
// will wrap textNodes into c-c spans going up the DOM tree from elt to ancestor |
|
194 |
// textNodes impacted here will be those that are : |
|
195 |
// the same generation or older than elt (but elt is excluded) |
|
196 |
// AND not older than grand children of to |
|
197 |
// assumption : |
|
198 |
// 1 ancestor is an ancestor of elt (we'll be going up the DOM tree) |
|
199 |
// 2 elt is a textNode. |
|
200 |
// argumentss : |
|
201 |
// prev : will spannify previous siblings if true, next siblings otherwise |
|
202 |
_dynSpanToAnc = function (elt, ancestor, commentId, prev) { |
|
203 |
// log('in : _dynSpanToAnc, elt : ' + elt.id) ; |
|
| 341 | 204 |
var c = elt ; |
| 0 | 205 |
while ((c != null) && (c !== ancestor) && (c.parentNode !== ancestor)) { |
| 341 | 206 |
var c_sib = null ; |
207 |
if (prev) { |
|
208 |
c_sib = c.previousSibling ; |
|
209 |
} |
|
210 |
else { |
|
211 |
c_sib = c.nextSibling ; |
|
212 |
} |
|
213 |
|
|
214 |
if (c_sib == null) { |
|
215 |
c = c.parentNode ; |
|
216 |
} |
|
217 |
else { |
|
218 |
c = c_sib ; |
|
219 |
_recAddComment(c, commentId) ; |
|
220 |
} |
|
221 |
} ; |
|
| 0 | 222 |
} ; |
223 |
||
224 |
// between elt1 and elt2 (which are excluded) |
|
225 |
_dynSpanInBetween = function (anc, elt1, elt2, commentId) { |
|
| 341 | 226 |
var a = elt1 ; |
227 |
var elt1Anc = null ; |
|
| 0 | 228 |
while (a) { |
229 |
if (a.parentNode === anc) { |
|
| 341 | 230 |
elt1Anc = a ; |
231 |
break; |
|
| 0 | 232 |
} |
233 |
a = a.parentNode; |
|
234 |
} |
|
| 341 | 235 |
if (elt1Anc != null) { |
236 |
a = elt2 ; |
|
237 |
var elt2Anc = null ; |
|
238 |
while (a) { |
|
239 |
if (a.parentNode === anc) { |
|
240 |
elt2Anc = a ; |
|
241 |
break; |
|
242 |
} |
|
243 |
a = a.parentNode; |
|
244 |
} |
|
245 |
if (elt2Anc != null) { // found both ancestor, now doing the work |
|
246 |
a = elt1Anc.nextSibling ; |
|
247 |
while ((a != null) && (a !== elt2Anc)) { |
|
248 |
_recAddComment(a, commentId) ; |
|
249 |
a = a.nextSibling ; |
|
250 |
} |
|
251 |
} |
|
252 |
} |
|
| 0 | 253 |
} ; |
254 |
||
255 |
// (copied from YUI dom-base) |
|
256 |
_bruteContains = function(element, needle) { |
|
257 |
while (needle) { |
|
258 |
if (element === needle) { |
|
259 |
return true; |
|
260 |
} |
|
261 |
needle = needle.parentNode; |
|
262 |
} |
|
263 |
return false; |
|
264 |
}, |
|
265 |
||
266 |
//elt is supposed to be c-c classed |
|
267 |
_addIdClass = function (elt, commentId) { |
|
| 341 | 268 |
CY.DOM.addClass(elt, 'c-id-' + commentId) ; |
269 |
_updateCommentCounter(elt) ; |
|
| 0 | 270 |
} ; |
271 |
||
272 |
//elt is supposed to be c-c classed |
|
273 |
_removeIdClass = function (elt, commentId) { |
|
| 341 | 274 |
CY.DOM.removeClass(elt, 'c-id-' + commentId) ; |
275 |
_updateCommentCounter(elt) ; |
|
| 0 | 276 |
} ; |
277 |
||
278 |
//elt is supposed to be c-c classed |
|
279 |
_removeIdClasses = function (elt) { |
|
| 341 | 280 |
var re = _cgetRegExp('(?:^|\\s+)c-id-(?:\\d+)', 'g'); |
281 |
elt['className'] = elt['className'].replace(re, " ") ; |
|
282 |
_updateCommentCounter(elt) ; |
|
| 0 | 283 |
} ; |
284 |
||
285 |
_recAddComment = function (elt, commentId) { |
|
| 341 | 286 |
if (CY.DOM.hasClass(elt, 'c-c')) { |
287 |
_addIdClass(elt, commentId) ; |
|
288 |
} |
|
289 |
else { |
|
290 |
var c = elt.firstChild ; |
|
| 0 | 291 |
while (c != null) { |
| 341 | 292 |
_recAddComment(c, commentId) ; |
293 |
c = c.nextSibling ; |
|
| 0 | 294 |
} |
295 |
} |
|
296 |
} ; |
|
297 |
||
298 |
// might be expensive ... (? maybe should use contains when available, instead |
|
299 |
// of custom _bruteContains) |
|
300 |
_findCommonAncestor = function (elt1, elt2) { |
|
| 341 | 301 |
if (_bruteContains(elt1, elt2)) |
302 |
return elt1 ; |
|
303 |
else { |
|
304 |
var e = elt2 ; |
|
305 |
while ((e != null) && !_bruteContains(e, elt1)) { |
|
306 |
e = e.parentNode ; |
|
307 |
} |
|
308 |
return e ; |
|
309 |
} |
|
| 0 | 310 |
} ; |
311 |
||
312 |
_cregexCache = {} ; |
|
313 |
// inspired (copied) from dom-base-debug in yui |
|
314 |
_cgetRegExp = function(str, flags) { |
|
315 |
flags = flags || ''; |
|
316 |
if (!_cregexCache[str + flags]) { |
|
317 |
_cregexCache[str + flags] = new RegExp(str, flags); |
|
318 |
} |
|
319 |
return _cregexCache[str + flags]; |
|
320 |
} ; |
|
321 |
||
322 |
//c-c should be classed with a c-count-x where x is a number for color graduation |
|
323 |
//c-c should be classed with many c-id-xid where xid is the comment db id of comment that apply to it |
|
324 |
_updateCommentCounter = function (elt) { |
|
| 341 | 325 |
var re = _cgetRegExp('(?:^|\\s+)c-id-(?:\\d+)', 'g'); |
326 |
var matches = elt['className'].match(re); |
|
327 |
var countIds = (matches == null) ? 0 : matches.length ; |
|
328 |
|
|
329 |
re = _cgetRegExp('(?:^|\\s+)c-count-(?:\\d+)', 'g'); |
|
330 |
elt['className'] = elt['className'].replace(re, " ") ; |
|
331 |
CY.DOM.addClass(elt, 'c-count-'+countIds+' ') ; |
|
|
373
f6fe14eb51bc
Add a title attribute on comment scopes to indicate the number of comments in the scope.
Simon Descarpentries <sid1@sopinspace.com>
parents:
341
diff
changeset
|
332 |
if (countIds > 0) { |
|
f6fe14eb51bc
Add a title attribute on comment scopes to indicate the number of comments in the scope.
Simon Descarpentries <sid1@sopinspace.com>
parents:
341
diff
changeset
|
333 |
elt.setAttribute ('title', countIds + ngettext(' comment', ' comments', countIds)); |
|
f6fe14eb51bc
Add a title attribute on comment scopes to indicate the number of comments in the scope.
Simon Descarpentries <sid1@sopinspace.com>
parents:
341
diff
changeset
|
334 |
if (countIds > 25) { |
|
f6fe14eb51bc
Add a title attribute on comment scopes to indicate the number of comments in the scope.
Simon Descarpentries <sid1@sopinspace.com>
parents:
341
diff
changeset
|
335 |
// ensure that we have the last color even if there are too many comments on the same place |
|
f6fe14eb51bc
Add a title attribute on comment scopes to indicate the number of comments in the scope.
Simon Descarpentries <sid1@sopinspace.com>
parents:
341
diff
changeset
|
336 |
CY.DOM.addClass(elt, 'c-count-25') ; |
|
f6fe14eb51bc
Add a title attribute on comment scopes to indicate the number of comments in the scope.
Simon Descarpentries <sid1@sopinspace.com>
parents:
341
diff
changeset
|
337 |
} |
|
f6fe14eb51bc
Add a title attribute on comment scopes to indicate the number of comments in the scope.
Simon Descarpentries <sid1@sopinspace.com>
parents:
341
diff
changeset
|
338 |
} |
| 0 | 339 |
} ; |
340 |
||
341 |
_convertSelectionFromCCToCS = function (sel) { |
|
| 341 | 342 |
var offset = sel['offset'] ; |
343 |
var elt = sel['elt'].parentNode ; |
|
344 |
|
|
345 |
var e = sel['elt'].previousSibling ; |
|
346 |
while (e != null) { |
|
347 |
offset += _getTextNodeContent(e).length ; |
|
348 |
e = e.previousSibling ; // will be a c-c !! |
|
349 |
} |
|
350 |
|
|
351 |
return {'elt':elt, 'offset':offset} ; |
|
| 0 | 352 |
} ; |
353 |
||
354 |
_convertSelectionFromCSToCC = function (sel) { |
|
| 341 | 355 |
var ret = {'elt':null, 'offset':-1} ; |
356 |
|
|
357 |
var cc = null ; |
|
358 |
var ccElt = sel['elt'].firstChild ; |
|
359 |
var length = 0 ; |
|
360 |
while (ccElt != null) { |
|
361 |
var prevLength = length ; |
|
362 |
length += _getTextNodeContent(ccElt).length ; |
|
363 |
if (length >= sel['offset']) { |
|
364 |
ret['elt'] = ccElt ; |
|
365 |
ret['offset'] = sel['offset'] - prevLength ; |
|
366 |
break ; |
|
367 |
} |
|
368 |
ccElt = ccElt.nextSibling ; // will be a c-c !! |
|
369 |
} |
|
370 |
return ret ; |
|
| 0 | 371 |
} ; |
372 |
||
373 |
||
374 |
/*******************************************************************************/ |
|
375 |
/* SCOPE REMOVAL */ |
|
376 |
/*******************************************************************************/ |
|
377 |
||
378 |
unpaintCommentScope = function(comment) { |
|
379 |
var dbId = comment.id; |
|
380 |
||
| 341 | 381 |
var classeId = 'c-id-' + dbId ; |
382 |
var toBeRemovedElts = [] ; |
|
| 0 | 383 |
|
| 341 | 384 |
var cNodeList = CY.all("."+classeId) ; |
385 |
if (cNodeList != null) { // null in case of a reply ... |
|
386 |
for (var i = 0, ilen = cNodeList.size() ; i < ilen ; i++) { |
|
387 |
var c = cNodeList.item(i) ; |
|
388 |
if (c.hasClass('c-c')) { // always will !! |
|
389 |
var cElt = CY.Node.getDOMNode(c) ; |
|
390 |
_removeIdClass(cElt, dbId) ; |
|
391 |
|
|
392 |
var cIds = getCommentIdsFromClasses(cElt) ; |
|
393 |
quicksort(cIds) ; |
|
394 |
|
|
395 |
var p = c.get('previousSibling') ; |
|
396 |
if (p != null) { |
|
397 |
var pElt = CY.Node.getDOMNode(p) ; |
|
398 |
var pIds = getCommentIdsFromClasses(pElt) ; |
|
399 |
quicksort(pIds) ; |
|
400 |
if (areSortedArraysEqual(cIds, pIds)) { |
|
401 |
_setTextNodeContent(cElt, _getTextNodeContent(pElt) + _getTextNodeContent(cElt)) ; |
|
402 |
toBeRemovedElts.push(pElt) ; |
|
403 |
} |
|
404 |
} |
|
405 |
|
|
406 |
var n = c.get('nextSibling') ; |
|
407 |
if (n != null) { |
|
408 |
var nElt = CY.Node.getDOMNode(n) ; |
|
409 |
var nIds = getCommentIdsFromClasses(nElt) ; |
|
410 |
quicksort(nIds) ; |
|
411 |
if (areSortedArraysEqual(cIds, nIds)) { |
|
412 |
cElt.firstChild.data = cElt.firstChild.data + nElt.firstChild.data; |
|
413 |
toBeRemovedElts.push(nElt) ; |
|
414 |
} |
|
415 |
} |
|
416 |
} |
|
417 |
else { |
|
418 |
alert('HAS NO c-c ? : ' + commentNode.get('id') + " , innerHTML :" + commentNode.get('innerHTML')) ; |
|
419 |
return ; |
|
420 |
} |
|
421 |
} |
|
422 |
} |
|
423 |
for (var i = 0, ilen = toBeRemovedElts.length ; i < ilen ; i++) { |
|
424 |
toBeRemovedElts[i].parentNode.removeChild(toBeRemovedElts[i]) ; |
|
425 |
} |
|
| 0 | 426 |
} ; |
427 |
||
428 |
// not related to the unpaintCommentScope function (faster) |
|
429 |
unpaintAllComments = function() { |
|
| 341 | 430 |
var cNodeList= CY.all(".c-s") ; |
431 |
var toBeRemovedElts = [] ; |
|
432 |
for (var i = 0, ilen = cNodeList.size() ; i < ilen ; i++) { |
|
433 |
var c = cNodeList.item(i) ; |
|
434 |
|
|
435 |
// remove Classes |
|
436 |
var fc = c.get('firstChild') ; |
|
437 |
var fcElt = CY.Node.getDOMNode(c.get('firstChild')) ; |
|
438 |
_removeIdClasses(fcElt) ; |
|
439 |
|
|
440 |
// merge nodes |
|
441 |
var n = fc.get('nextSibling') ; |
|
442 |
while (n != null) { |
|
443 |
var nElt = CY.Node.getDOMNode(n) ; |
|
444 |
fcElt.firstChild.data = fcElt.firstChild.data + nElt.firstChild.data; |
|
445 |
toBeRemovedElts.push(nElt) ; |
|
446 |
n = n.get('nextSibling') ; |
|
447 |
} |
|
448 |
} |
|
449 |
for (var i = 0, ilen = toBeRemovedElts.length ; i < ilen ; i++) { |
|
450 |
toBeRemovedElts[i].parentNode.removeChild(toBeRemovedElts[i]) ; |
|
451 |
} |
|
| 0 | 452 |
|
453 |
} ; |
|
454 |
||
455 |
showScope = function(commentDbId) { |
|
| 341 | 456 |
var s = CY.all('.c-id-' + commentDbId); |
457 |
if (s != null) |
|
458 |
s.addClass('c-scope') ; |
|
| 0 | 459 |
} ; |
460 |
||
461 |
hideScopeAnyway = function() { |
|
| 341 | 462 |
var s = CY.all('.c-scope'); |
463 |
if (s != null) |
|
464 |
s.removeClass('c-scope') ; |
|
| 0 | 465 |
} |
466 |