##// END OF EJS Templates
inline comment button fix
marcink -
r1759:d6c6ea17 beta
parent child Browse files
Show More
@@ -1,598 +1,598 b''
1 /**
1 /**
2 RhodeCode JS Files
2 RhodeCode JS Files
3 **/
3 **/
4
4
5 if (typeof console == "undefined" || typeof console.log == "undefined"){
5 if (typeof console == "undefined" || typeof console.log == "undefined"){
6 console = { log: function() {} }
6 console = { log: function() {} }
7 }
7 }
8
8
9
9
10 var str_repeat = function(i, m) {
10 var str_repeat = function(i, m) {
11 for (var o = []; m > 0; o[--m] = i);
11 for (var o = []; m > 0; o[--m] = i);
12 return o.join('');
12 return o.join('');
13 };
13 };
14
14
15 /**
15 /**
16 * INJECT .format function into String
16 * INJECT .format function into String
17 * Usage: "My name is {0} {1}".format("Johny","Bravo")
17 * Usage: "My name is {0} {1}".format("Johny","Bravo")
18 * Return "My name is Johny Bravo"
18 * Return "My name is Johny Bravo"
19 * Inspired by https://gist.github.com/1049426
19 * Inspired by https://gist.github.com/1049426
20 */
20 */
21 String.prototype.format = function() {
21 String.prototype.format = function() {
22
22
23 function format() {
23 function format() {
24 var str = this;
24 var str = this;
25 var len = arguments.length+1;
25 var len = arguments.length+1;
26 var safe = undefined;
26 var safe = undefined;
27 var arg = undefined;
27 var arg = undefined;
28
28
29 // For each {0} {1} {n...} replace with the argument in that position. If
29 // For each {0} {1} {n...} replace with the argument in that position. If
30 // the argument is an object or an array it will be stringified to JSON.
30 // the argument is an object or an array it will be stringified to JSON.
31 for (var i=0; i < len; arg = arguments[i++]) {
31 for (var i=0; i < len; arg = arguments[i++]) {
32 safe = typeof arg === 'object' ? JSON.stringify(arg) : arg;
32 safe = typeof arg === 'object' ? JSON.stringify(arg) : arg;
33 str = str.replace(RegExp('\\{'+(i-1)+'\\}', 'g'), safe);
33 str = str.replace(RegExp('\\{'+(i-1)+'\\}', 'g'), safe);
34 }
34 }
35 return str;
35 return str;
36 }
36 }
37
37
38 // Save a reference of what may already exist under the property native.
38 // Save a reference of what may already exist under the property native.
39 // Allows for doing something like: if("".format.native) { /* use native */ }
39 // Allows for doing something like: if("".format.native) { /* use native */ }
40 format.native = String.prototype.format;
40 format.native = String.prototype.format;
41
41
42 // Replace the prototype property
42 // Replace the prototype property
43 return format;
43 return format;
44
44
45 }();
45 }();
46
46
47
47
48 /**
48 /**
49 * SmartColorGenerator
49 * SmartColorGenerator
50 *
50 *
51 *usage::
51 *usage::
52 * var CG = new ColorGenerator();
52 * var CG = new ColorGenerator();
53 * var col = CG.getColor(key); //returns array of RGB
53 * var col = CG.getColor(key); //returns array of RGB
54 * 'rgb({0})'.format(col.join(',')
54 * 'rgb({0})'.format(col.join(',')
55 *
55 *
56 * @returns {ColorGenerator}
56 * @returns {ColorGenerator}
57 */
57 */
58 var ColorGenerator = function(){
58 var ColorGenerator = function(){
59 this.GOLDEN_RATIO = 0.618033988749895;
59 this.GOLDEN_RATIO = 0.618033988749895;
60 this.CURRENT_RATIO = 0.22717784590367374 // this can be random
60 this.CURRENT_RATIO = 0.22717784590367374 // this can be random
61 this.HSV_1 = 0.75;//saturation
61 this.HSV_1 = 0.75;//saturation
62 this.HSV_2 = 0.95;
62 this.HSV_2 = 0.95;
63 this.color;
63 this.color;
64 this.cacheColorMap = {};
64 this.cacheColorMap = {};
65 };
65 };
66
66
67 ColorGenerator.prototype = {
67 ColorGenerator.prototype = {
68 getColor:function(key){
68 getColor:function(key){
69 if(this.cacheColorMap[key] !== undefined){
69 if(this.cacheColorMap[key] !== undefined){
70 return this.cacheColorMap[key];
70 return this.cacheColorMap[key];
71 }
71 }
72 else{
72 else{
73 this.cacheColorMap[key] = this.generateColor();
73 this.cacheColorMap[key] = this.generateColor();
74 return this.cacheColorMap[key];
74 return this.cacheColorMap[key];
75 }
75 }
76 },
76 },
77 _hsvToRgb:function(h,s,v){
77 _hsvToRgb:function(h,s,v){
78 if (s == 0.0)
78 if (s == 0.0)
79 return [v, v, v];
79 return [v, v, v];
80 i = parseInt(h * 6.0)
80 i = parseInt(h * 6.0)
81 f = (h * 6.0) - i
81 f = (h * 6.0) - i
82 p = v * (1.0 - s)
82 p = v * (1.0 - s)
83 q = v * (1.0 - s * f)
83 q = v * (1.0 - s * f)
84 t = v * (1.0 - s * (1.0 - f))
84 t = v * (1.0 - s * (1.0 - f))
85 i = i % 6
85 i = i % 6
86 if (i == 0)
86 if (i == 0)
87 return [v, t, p]
87 return [v, t, p]
88 if (i == 1)
88 if (i == 1)
89 return [q, v, p]
89 return [q, v, p]
90 if (i == 2)
90 if (i == 2)
91 return [p, v, t]
91 return [p, v, t]
92 if (i == 3)
92 if (i == 3)
93 return [p, q, v]
93 return [p, q, v]
94 if (i == 4)
94 if (i == 4)
95 return [t, p, v]
95 return [t, p, v]
96 if (i == 5)
96 if (i == 5)
97 return [v, p, q]
97 return [v, p, q]
98 },
98 },
99 generateColor:function(){
99 generateColor:function(){
100 this.CURRENT_RATIO = this.CURRENT_RATIO+this.GOLDEN_RATIO;
100 this.CURRENT_RATIO = this.CURRENT_RATIO+this.GOLDEN_RATIO;
101 this.CURRENT_RATIO = this.CURRENT_RATIO %= 1;
101 this.CURRENT_RATIO = this.CURRENT_RATIO %= 1;
102 HSV_tuple = [this.CURRENT_RATIO, this.HSV_1, this.HSV_2]
102 HSV_tuple = [this.CURRENT_RATIO, this.HSV_1, this.HSV_2]
103 RGB_tuple = this._hsvToRgb(HSV_tuple[0],HSV_tuple[1],HSV_tuple[2]);
103 RGB_tuple = this._hsvToRgb(HSV_tuple[0],HSV_tuple[1],HSV_tuple[2]);
104 function toRgb(v){
104 function toRgb(v){
105 return ""+parseInt(v*256)
105 return ""+parseInt(v*256)
106 }
106 }
107 return [toRgb(RGB_tuple[0]),toRgb(RGB_tuple[1]),toRgb(RGB_tuple[2])];
107 return [toRgb(RGB_tuple[0]),toRgb(RGB_tuple[1]),toRgb(RGB_tuple[2])];
108
108
109 }
109 }
110 }
110 }
111
111
112
112
113
113
114
114
115
115
116 /**
116 /**
117 * GLOBAL YUI Shortcuts
117 * GLOBAL YUI Shortcuts
118 */
118 */
119 var YUC = YAHOO.util.Connect;
119 var YUC = YAHOO.util.Connect;
120 var YUD = YAHOO.util.Dom;
120 var YUD = YAHOO.util.Dom;
121 var YUE = YAHOO.util.Event;
121 var YUE = YAHOO.util.Event;
122 var YUQ = YAHOO.util.Selector.query;
122 var YUQ = YAHOO.util.Selector.query;
123
123
124 // defines if push state is enabled for this browser ?
124 // defines if push state is enabled for this browser ?
125 var push_state_enabled = Boolean(
125 var push_state_enabled = Boolean(
126 window.history && window.history.pushState && window.history.replaceState
126 window.history && window.history.pushState && window.history.replaceState
127 && !( /* disable for versions of iOS before version 4.3 (8F190) */
127 && !( /* disable for versions of iOS before version 4.3 (8F190) */
128 (/ Mobile\/([1-7][a-z]|(8([abcde]|f(1[0-8]))))/i).test(navigator.userAgent)
128 (/ Mobile\/([1-7][a-z]|(8([abcde]|f(1[0-8]))))/i).test(navigator.userAgent)
129 /* disable for the mercury iOS browser, or at least older versions of the webkit engine */
129 /* disable for the mercury iOS browser, or at least older versions of the webkit engine */
130 || (/AppleWebKit\/5([0-2]|3[0-2])/i).test(navigator.userAgent)
130 || (/AppleWebKit\/5([0-2]|3[0-2])/i).test(navigator.userAgent)
131 )
131 )
132 );
132 );
133
133
134 var _run_callbacks = function(callbacks){
134 var _run_callbacks = function(callbacks){
135 if (callbacks !== undefined){
135 if (callbacks !== undefined){
136 var _l = callbacks.length;
136 var _l = callbacks.length;
137 for (var i=0;i<_l;i++){
137 for (var i=0;i<_l;i++){
138 var func = callbacks[i];
138 var func = callbacks[i];
139 if(typeof(func)=='function'){
139 if(typeof(func)=='function'){
140 try{
140 try{
141 func();
141 func();
142 }catch (err){};
142 }catch (err){};
143 }
143 }
144 }
144 }
145 }
145 }
146 }
146 }
147
147
148 /**
148 /**
149 * Partial Ajax Implementation
149 * Partial Ajax Implementation
150 *
150 *
151 * @param url: defines url to make partial request
151 * @param url: defines url to make partial request
152 * @param container: defines id of container to input partial result
152 * @param container: defines id of container to input partial result
153 * @param s_call: success callback function that takes o as arg
153 * @param s_call: success callback function that takes o as arg
154 * o.tId
154 * o.tId
155 * o.status
155 * o.status
156 * o.statusText
156 * o.statusText
157 * o.getResponseHeader[ ]
157 * o.getResponseHeader[ ]
158 * o.getAllResponseHeaders
158 * o.getAllResponseHeaders
159 * o.responseText
159 * o.responseText
160 * o.responseXML
160 * o.responseXML
161 * o.argument
161 * o.argument
162 * @param f_call: failure callback
162 * @param f_call: failure callback
163 * @param args arguments
163 * @param args arguments
164 */
164 */
165 function ypjax(url,container,s_call,f_call,args){
165 function ypjax(url,container,s_call,f_call,args){
166 var method='GET';
166 var method='GET';
167 if(args===undefined){
167 if(args===undefined){
168 args=null;
168 args=null;
169 }
169 }
170
170
171 // Set special header for partial ajax == HTTP_X_PARTIAL_XHR
171 // Set special header for partial ajax == HTTP_X_PARTIAL_XHR
172 YUC.initHeader('X-PARTIAL-XHR',true);
172 YUC.initHeader('X-PARTIAL-XHR',true);
173
173
174 // wrapper of passed callback
174 // wrapper of passed callback
175 var s_wrapper = (function(o){
175 var s_wrapper = (function(o){
176 return function(o){
176 return function(o){
177 YUD.get(container).innerHTML=o.responseText;
177 YUD.get(container).innerHTML=o.responseText;
178 YUD.setStyle(container,'opacity','1.0');
178 YUD.setStyle(container,'opacity','1.0');
179 //execute the given original callback
179 //execute the given original callback
180 if (s_call !== undefined){
180 if (s_call !== undefined){
181 s_call(o);
181 s_call(o);
182 }
182 }
183 }
183 }
184 })()
184 })()
185 YUD.setStyle(container,'opacity','0.3');
185 YUD.setStyle(container,'opacity','0.3');
186 YUC.asyncRequest(method,url,{
186 YUC.asyncRequest(method,url,{
187 success:s_wrapper,
187 success:s_wrapper,
188 failure:function(o){
188 failure:function(o){
189 console.log(o);
189 console.log(o);
190 YUD.get(container).innerHTML='ERROR';
190 YUD.get(container).innerHTML='ERROR';
191 YUD.setStyle(container,'opacity','1.0');
191 YUD.setStyle(container,'opacity','1.0');
192 YUD.setStyle(container,'color','red');
192 YUD.setStyle(container,'color','red');
193 }
193 }
194 },args);
194 },args);
195
195
196 };
196 };
197
197
198 /**
198 /**
199 * tooltip activate
199 * tooltip activate
200 */
200 */
201 var tooltip_activate = function(){
201 var tooltip_activate = function(){
202 function toolTipsId(){
202 function toolTipsId(){
203 var ids = [];
203 var ids = [];
204 var tts = YUQ('.tooltip');
204 var tts = YUQ('.tooltip');
205 for (var i = 0; i < tts.length; i++) {
205 for (var i = 0; i < tts.length; i++) {
206 // if element doesn't not have and id
206 // if element doesn't not have and id
207 // autogenerate one for tooltip
207 // autogenerate one for tooltip
208 if (!tts[i].id){
208 if (!tts[i].id){
209 tts[i].id='tt'+((i*100)+tts.length);
209 tts[i].id='tt'+((i*100)+tts.length);
210 }
210 }
211 ids.push(tts[i].id);
211 ids.push(tts[i].id);
212 }
212 }
213 return ids
213 return ids
214 };
214 };
215 var myToolTips = new YAHOO.widget.Tooltip("tooltip", {
215 var myToolTips = new YAHOO.widget.Tooltip("tooltip", {
216 context: [[toolTipsId()],"tl","bl",null,[0,5]],
216 context: [[toolTipsId()],"tl","bl",null,[0,5]],
217 monitorresize:false,
217 monitorresize:false,
218 xyoffset :[0,0],
218 xyoffset :[0,0],
219 autodismissdelay:300000,
219 autodismissdelay:300000,
220 hidedelay:5,
220 hidedelay:5,
221 showdelay:20,
221 showdelay:20,
222 });
222 });
223 };
223 };
224
224
225 /**
225 /**
226 * show more
226 * show more
227 */
227 */
228 var show_more_event = function(){
228 var show_more_event = function(){
229 YUE.on(YUD.getElementsByClassName('show_more'),'click',function(e){
229 YUE.on(YUD.getElementsByClassName('show_more'),'click',function(e){
230 var el = e.target;
230 var el = e.target;
231 YUD.setStyle(YUD.get(el.id.substring(1)),'display','');
231 YUD.setStyle(YUD.get(el.id.substring(1)),'display','');
232 YUD.setStyle(el.parentNode,'display','none');
232 YUD.setStyle(el.parentNode,'display','none');
233 });
233 });
234 };
234 };
235
235
236
236
237 /**
237 /**
238 * Quick filter widget
238 * Quick filter widget
239 *
239 *
240 * @param target: filter input target
240 * @param target: filter input target
241 * @param nodes: list of nodes in html we want to filter.
241 * @param nodes: list of nodes in html we want to filter.
242 * @param display_element function that takes current node from nodes and
242 * @param display_element function that takes current node from nodes and
243 * does hide or show based on the node
243 * does hide or show based on the node
244 *
244 *
245 */
245 */
246 var q_filter = function(target,nodes,display_element){
246 var q_filter = function(target,nodes,display_element){
247
247
248 var nodes = nodes;
248 var nodes = nodes;
249 var q_filter_field = YUD.get(target);
249 var q_filter_field = YUD.get(target);
250 var F = YAHOO.namespace(target);
250 var F = YAHOO.namespace(target);
251
251
252 YUE.on(q_filter_field,'click',function(){
252 YUE.on(q_filter_field,'click',function(){
253 q_filter_field.value = '';
253 q_filter_field.value = '';
254 });
254 });
255
255
256 YUE.on(q_filter_field,'keyup',function(e){
256 YUE.on(q_filter_field,'keyup',function(e){
257 clearTimeout(F.filterTimeout);
257 clearTimeout(F.filterTimeout);
258 F.filterTimeout = setTimeout(F.updateFilter,600);
258 F.filterTimeout = setTimeout(F.updateFilter,600);
259 });
259 });
260
260
261 F.filterTimeout = null;
261 F.filterTimeout = null;
262
262
263 var show_node = function(node){
263 var show_node = function(node){
264 YUD.setStyle(node,'display','')
264 YUD.setStyle(node,'display','')
265 }
265 }
266 var hide_node = function(node){
266 var hide_node = function(node){
267 YUD.setStyle(node,'display','none');
267 YUD.setStyle(node,'display','none');
268 }
268 }
269
269
270 F.updateFilter = function() {
270 F.updateFilter = function() {
271 // Reset timeout
271 // Reset timeout
272 F.filterTimeout = null;
272 F.filterTimeout = null;
273
273
274 var obsolete = [];
274 var obsolete = [];
275
275
276 var req = q_filter_field.value.toLowerCase();
276 var req = q_filter_field.value.toLowerCase();
277
277
278 var l = nodes.length;
278 var l = nodes.length;
279 var i;
279 var i;
280 var showing = 0;
280 var showing = 0;
281
281
282 for (i=0;i<l;i++ ){
282 for (i=0;i<l;i++ ){
283 var n = nodes[i];
283 var n = nodes[i];
284 var target_element = display_element(n)
284 var target_element = display_element(n)
285 if(req && n.innerHTML.toLowerCase().indexOf(req) == -1){
285 if(req && n.innerHTML.toLowerCase().indexOf(req) == -1){
286 hide_node(target_element);
286 hide_node(target_element);
287 }
287 }
288 else{
288 else{
289 show_node(target_element);
289 show_node(target_element);
290 showing+=1;
290 showing+=1;
291 }
291 }
292 }
292 }
293
293
294 // if repo_count is set update the number
294 // if repo_count is set update the number
295 var cnt = YUD.get('repo_count');
295 var cnt = YUD.get('repo_count');
296 if(cnt){
296 if(cnt){
297 YUD.get('repo_count').innerHTML = showing;
297 YUD.get('repo_count').innerHTML = showing;
298 }
298 }
299
299
300 }
300 }
301 };
301 };
302
302
303 var ajaxPOST = function(url,postData,success) {
303 var ajaxPOST = function(url,postData,success) {
304 var sUrl = url;
304 var sUrl = url;
305 var callback = {
305 var callback = {
306 success: success,
306 success: success,
307 failure: function (o) {
307 failure: function (o) {
308 alert("error");
308 alert("error");
309 },
309 },
310 };
310 };
311 var postData = postData;
311 var postData = postData;
312 var request = YAHOO.util.Connect.asyncRequest('POST', sUrl, callback, postData);
312 var request = YAHOO.util.Connect.asyncRequest('POST', sUrl, callback, postData);
313 };
313 };
314
314
315
315
316 /** comments **/
316 /** comments **/
317 var removeInlineForm = function(form) {
317 var removeInlineForm = function(form) {
318 form.parentNode.removeChild(form);
318 form.parentNode.removeChild(form);
319 };
319 };
320
320
321 var tableTr = function(cls,body){
321 var tableTr = function(cls,body){
322 var form = document.createElement('tr');
322 var form = document.createElement('tr');
323 YUD.addClass(form, cls);
323 YUD.addClass(form, cls);
324 form.innerHTML = '<td class="lineno-inline new-inline"></td>'+
324 form.innerHTML = '<td class="lineno-inline new-inline"></td>'+
325 '<td class="lineno-inline old-inline"></td>'+
325 '<td class="lineno-inline old-inline"></td>'+
326 '<td>{0}</td>'.format(body);
326 '<td>{0}</td>'.format(body);
327 return form;
327 return form;
328 };
328 };
329
329
330 var createInlineForm = function(parent_tr, f_path, line) {
330 var createInlineForm = function(parent_tr, f_path, line) {
331 var tmpl = YUD.get('comment-inline-form-template').innerHTML;
331 var tmpl = YUD.get('comment-inline-form-template').innerHTML;
332 tmpl = tmpl.format(f_path, line);
332 tmpl = tmpl.format(f_path, line);
333 var form = tableTr('comment-form-inline',tmpl)
333 var form = tableTr('comment-form-inline',tmpl)
334
334
335 // create event for hide button
335 // create event for hide button
336 form = new YAHOO.util.Element(form);
336 form = new YAHOO.util.Element(form);
337 var form_hide_button = new YAHOO.util.Element(form.getElementsByClassName('hide-inline-form')[0]);
337 var form_hide_button = new YAHOO.util.Element(form.getElementsByClassName('hide-inline-form')[0]);
338 form_hide_button.on('click', function(e) {
338 form_hide_button.on('click', function(e) {
339 var newtr = e.currentTarget.parentNode.parentNode.parentNode.parentNode.parentNode;
339 var newtr = e.currentTarget.parentNode.parentNode.parentNode.parentNode.parentNode;
340 removeInlineForm(newtr);
340 removeInlineForm(newtr);
341 YUD.removeClass(parent_tr, 'form-open');
341 YUD.removeClass(parent_tr, 'form-open');
342 });
342 });
343 return form
343 return form
344 };
344 };
345 var injectInlineForm = function(tr){
345 var injectInlineForm = function(tr){
346 if(YUD.hasClass(tr,'form-open') || YUD.hasClass(tr,'context')){
346 if(YUD.hasClass(tr,'form-open') || YUD.hasClass(tr,'context')){
347 return
347 return
348 }
348 }
349 YUD.addClass(tr,'form-open');
349 YUD.addClass(tr,'form-open');
350 var node = tr.parentNode.parentNode.parentNode.getElementsByClassName('full_f_path')[0];
350 var node = tr.parentNode.parentNode.parentNode.getElementsByClassName('full_f_path')[0];
351 var f_path = YUD.getAttribute(node,'path');
351 var f_path = YUD.getAttribute(node,'path');
352 var lineno = getLineNo(tr);
352 var lineno = getLineNo(tr);
353 var form = createInlineForm(tr, f_path, lineno);
353 var form = createInlineForm(tr, f_path, lineno);
354 var target_tr = tr;
354 var target_tr = tr;
355 if(YUD.hasClass(YUD.getNextSibling(tr),'inline-comments')){
355 if(YUD.hasClass(YUD.getNextSibling(tr),'inline-comments')){
356 target_tr = YUD.getNextSibling(tr);
356 target_tr = YUD.getNextSibling(tr);
357 }
357 }
358 YUD.insertAfter(form,target_tr);
358 YUD.insertAfter(form,target_tr);
359 YUD.get('text_'+lineno).focus();
359 YUD.get('text_'+lineno).focus();
360 };
360 };
361
361
362 var createInlineAddButton = function(tr,label){
362 var createInlineAddButton = function(tr,label){
363 var html = '<div class="add-comment"><span class="ui-button-small">{0}</span></div>'.format(label);
363 var html = '<div class="add-comment"><span class="ui-btn">{0}</span></div>'.format(label);
364
364
365 var add = new YAHOO.util.Element(tableTr('inline-comments-button',html));
365 var add = new YAHOO.util.Element(tableTr('inline-comments-button',html));
366 add.on('click', function(e) {
366 add.on('click', function(e) {
367 injectInlineForm(tr);
367 injectInlineForm(tr);
368 });
368 });
369 return add;
369 return add;
370 };
370 };
371
371
372 var getLineNo = function(tr) {
372 var getLineNo = function(tr) {
373 var line;
373 var line;
374 var o = tr.children[0].id.split('_');
374 var o = tr.children[0].id.split('_');
375 var n = tr.children[1].id.split('_');
375 var n = tr.children[1].id.split('_');
376
376
377 if (n.length >= 2) {
377 if (n.length >= 2) {
378 line = n[n.length-1];
378 line = n[n.length-1];
379 } else if (o.length >= 2) {
379 } else if (o.length >= 2) {
380 line = o[o.length-1];
380 line = o[o.length-1];
381 }
381 }
382
382
383 return line
383 return line
384 };
384 };
385
385
386
386
387 var fileBrowserListeners = function(current_url, node_list_url, url_base,
387 var fileBrowserListeners = function(current_url, node_list_url, url_base,
388 truncated_lbl, nomatch_lbl){
388 truncated_lbl, nomatch_lbl){
389 var current_url_branch = +"?branch=__BRANCH__";
389 var current_url_branch = +"?branch=__BRANCH__";
390 var url = url_base;
390 var url = url_base;
391 var node_url = node_list_url;
391 var node_url = node_list_url;
392
392
393 YUE.on('stay_at_branch','click',function(e){
393 YUE.on('stay_at_branch','click',function(e){
394 if(e.target.checked){
394 if(e.target.checked){
395 var uri = current_url_branch;
395 var uri = current_url_branch;
396 uri = uri.replace('__BRANCH__',e.target.value);
396 uri = uri.replace('__BRANCH__',e.target.value);
397 window.location = uri;
397 window.location = uri;
398 }
398 }
399 else{
399 else{
400 window.location = current_url;
400 window.location = current_url;
401 }
401 }
402 })
402 })
403
403
404 var n_filter = YUD.get('node_filter');
404 var n_filter = YUD.get('node_filter');
405 var F = YAHOO.namespace('node_filter');
405 var F = YAHOO.namespace('node_filter');
406
406
407 F.filterTimeout = null;
407 F.filterTimeout = null;
408 var nodes = null;
408 var nodes = null;
409
409
410 F.initFilter = function(){
410 F.initFilter = function(){
411 YUD.setStyle('node_filter_box_loading','display','');
411 YUD.setStyle('node_filter_box_loading','display','');
412 YUD.setStyle('search_activate_id','display','none');
412 YUD.setStyle('search_activate_id','display','none');
413 YUD.setStyle('add_node_id','display','none');
413 YUD.setStyle('add_node_id','display','none');
414 YUC.initHeader('X-PARTIAL-XHR',true);
414 YUC.initHeader('X-PARTIAL-XHR',true);
415 YUC.asyncRequest('GET',url,{
415 YUC.asyncRequest('GET',url,{
416 success:function(o){
416 success:function(o){
417 nodes = JSON.parse(o.responseText);
417 nodes = JSON.parse(o.responseText);
418 YUD.setStyle('node_filter_box_loading','display','none');
418 YUD.setStyle('node_filter_box_loading','display','none');
419 YUD.setStyle('node_filter_box','display','');
419 YUD.setStyle('node_filter_box','display','');
420 },
420 },
421 failure:function(o){
421 failure:function(o){
422 console.log('failed to load');
422 console.log('failed to load');
423 }
423 }
424 },null);
424 },null);
425 }
425 }
426
426
427 F.updateFilter = function(e) {
427 F.updateFilter = function(e) {
428
428
429 return function(){
429 return function(){
430 // Reset timeout
430 // Reset timeout
431 F.filterTimeout = null;
431 F.filterTimeout = null;
432 var query = e.target.value;
432 var query = e.target.value;
433 var match = [];
433 var match = [];
434 var matches = 0;
434 var matches = 0;
435 var matches_max = 20;
435 var matches_max = 20;
436 if (query != ""){
436 if (query != ""){
437 for(var i=0;i<nodes.length;i++){
437 for(var i=0;i<nodes.length;i++){
438 var pos = nodes[i].toLowerCase().indexOf(query)
438 var pos = nodes[i].toLowerCase().indexOf(query)
439 if(query && pos != -1){
439 if(query && pos != -1){
440
440
441 matches++
441 matches++
442 //show only certain amount to not kill browser
442 //show only certain amount to not kill browser
443 if (matches > matches_max){
443 if (matches > matches_max){
444 break;
444 break;
445 }
445 }
446
446
447 var n = nodes[i];
447 var n = nodes[i];
448 var n_hl = n.substring(0,pos)
448 var n_hl = n.substring(0,pos)
449 +"<b>{0}</b>".format(n.substring(pos,pos+query.length))
449 +"<b>{0}</b>".format(n.substring(pos,pos+query.length))
450 +n.substring(pos+query.length)
450 +n.substring(pos+query.length)
451 match.push('<tr><td><a class="browser-file" href="{0}">{1}</a></td><td colspan="5"></td></tr>'.format(node_url.replace('__FPATH__',n),n_hl));
451 match.push('<tr><td><a class="browser-file" href="{0}">{1}</a></td><td colspan="5"></td></tr>'.format(node_url.replace('__FPATH__',n),n_hl));
452 }
452 }
453 if(match.length >= matches_max){
453 if(match.length >= matches_max){
454 match.push('<tr><td>{0}</td><td colspan="5"></td></tr>'.format(truncated_lbl));
454 match.push('<tr><td>{0}</td><td colspan="5"></td></tr>'.format(truncated_lbl));
455 }
455 }
456
456
457 }
457 }
458 }
458 }
459 if(query != ""){
459 if(query != ""){
460 YUD.setStyle('tbody','display','none');
460 YUD.setStyle('tbody','display','none');
461 YUD.setStyle('tbody_filtered','display','');
461 YUD.setStyle('tbody_filtered','display','');
462
462
463 if (match.length==0){
463 if (match.length==0){
464 match.push('<tr><td>{0}</td><td colspan="5"></td></tr>'.format(nomatch_lbl));
464 match.push('<tr><td>{0}</td><td colspan="5"></td></tr>'.format(nomatch_lbl));
465 }
465 }
466
466
467 YUD.get('tbody_filtered').innerHTML = match.join("");
467 YUD.get('tbody_filtered').innerHTML = match.join("");
468 }
468 }
469 else{
469 else{
470 YUD.setStyle('tbody','display','');
470 YUD.setStyle('tbody','display','');
471 YUD.setStyle('tbody_filtered','display','none');
471 YUD.setStyle('tbody_filtered','display','none');
472 }
472 }
473
473
474 }
474 }
475 };
475 };
476
476
477 YUE.on(YUD.get('filter_activate'),'click',function(){
477 YUE.on(YUD.get('filter_activate'),'click',function(){
478 F.initFilter();
478 F.initFilter();
479 })
479 })
480 YUE.on(n_filter,'click',function(){
480 YUE.on(n_filter,'click',function(){
481 n_filter.value = '';
481 n_filter.value = '';
482 });
482 });
483 YUE.on(n_filter,'keyup',function(e){
483 YUE.on(n_filter,'keyup',function(e){
484 clearTimeout(F.filterTimeout);
484 clearTimeout(F.filterTimeout);
485 F.filterTimeout = setTimeout(F.updateFilter(e),600);
485 F.filterTimeout = setTimeout(F.updateFilter(e),600);
486 });
486 });
487 };
487 };
488
488
489
489
490 var initCodeMirror = function(textAreadId,resetUrl){
490 var initCodeMirror = function(textAreadId,resetUrl){
491 var myCodeMirror = CodeMirror.fromTextArea(YUD.get(textAreadId),{
491 var myCodeMirror = CodeMirror.fromTextArea(YUD.get(textAreadId),{
492 mode: "null",
492 mode: "null",
493 lineNumbers:true
493 lineNumbers:true
494 });
494 });
495 YUE.on('reset','click',function(e){
495 YUE.on('reset','click',function(e){
496 window.location=resetUrl
496 window.location=resetUrl
497 });
497 });
498
498
499 YUE.on('file_enable','click',function(){
499 YUE.on('file_enable','click',function(){
500 YUD.setStyle('editor_container','display','');
500 YUD.setStyle('editor_container','display','');
501 YUD.setStyle('upload_file_container','display','none');
501 YUD.setStyle('upload_file_container','display','none');
502 YUD.setStyle('filename_container','display','');
502 YUD.setStyle('filename_container','display','');
503 });
503 });
504
504
505 YUE.on('upload_file_enable','click',function(){
505 YUE.on('upload_file_enable','click',function(){
506 YUD.setStyle('editor_container','display','none');
506 YUD.setStyle('editor_container','display','none');
507 YUD.setStyle('upload_file_container','display','');
507 YUD.setStyle('upload_file_container','display','');
508 YUD.setStyle('filename_container','display','none');
508 YUD.setStyle('filename_container','display','none');
509 });
509 });
510 };
510 };
511
511
512
512
513
513
514 var getIdentNode = function(n){
514 var getIdentNode = function(n){
515 //iterate thru nodes untill matched interesting node !
515 //iterate thru nodes untill matched interesting node !
516
516
517 if (typeof n == 'undefined'){
517 if (typeof n == 'undefined'){
518 return -1
518 return -1
519 }
519 }
520
520
521 if(typeof n.id != "undefined" && n.id.match('L[0-9]+')){
521 if(typeof n.id != "undefined" && n.id.match('L[0-9]+')){
522 return n
522 return n
523 }
523 }
524 else{
524 else{
525 return getIdentNode(n.parentNode);
525 return getIdentNode(n.parentNode);
526 }
526 }
527 };
527 };
528
528
529 var getSelectionLink = function(selection_link_label) {
529 var getSelectionLink = function(selection_link_label) {
530 return function(){
530 return function(){
531 //get selection from start/to nodes
531 //get selection from start/to nodes
532 if (typeof window.getSelection != "undefined") {
532 if (typeof window.getSelection != "undefined") {
533 s = window.getSelection();
533 s = window.getSelection();
534
534
535 from = getIdentNode(s.anchorNode);
535 from = getIdentNode(s.anchorNode);
536 till = getIdentNode(s.focusNode);
536 till = getIdentNode(s.focusNode);
537
537
538 f_int = parseInt(from.id.replace('L',''));
538 f_int = parseInt(from.id.replace('L',''));
539 t_int = parseInt(till.id.replace('L',''));
539 t_int = parseInt(till.id.replace('L',''));
540
540
541 if (f_int > t_int){
541 if (f_int > t_int){
542 //highlight from bottom
542 //highlight from bottom
543 offset = -35;
543 offset = -35;
544 ranges = [t_int,f_int];
544 ranges = [t_int,f_int];
545
545
546 }
546 }
547 else{
547 else{
548 //highligth from top
548 //highligth from top
549 offset = 35;
549 offset = 35;
550 ranges = [f_int,t_int];
550 ranges = [f_int,t_int];
551 }
551 }
552
552
553 if (ranges[0] != ranges[1]){
553 if (ranges[0] != ranges[1]){
554 if(YUD.get('linktt') == null){
554 if(YUD.get('linktt') == null){
555 hl_div = document.createElement('div');
555 hl_div = document.createElement('div');
556 hl_div.id = 'linktt';
556 hl_div.id = 'linktt';
557 }
557 }
558 anchor = '#L'+ranges[0]+'-'+ranges[1];
558 anchor = '#L'+ranges[0]+'-'+ranges[1];
559 hl_div.innerHTML = '';
559 hl_div.innerHTML = '';
560 l = document.createElement('a');
560 l = document.createElement('a');
561 l.href = location.href.substring(0,location.href.indexOf('#'))+anchor;
561 l.href = location.href.substring(0,location.href.indexOf('#'))+anchor;
562 l.innerHTML = selection_link_label;
562 l.innerHTML = selection_link_label;
563 hl_div.appendChild(l);
563 hl_div.appendChild(l);
564
564
565 YUD.get('body').appendChild(hl_div);
565 YUD.get('body').appendChild(hl_div);
566
566
567 xy = YUD.getXY(till.id);
567 xy = YUD.getXY(till.id);
568
568
569 YUD.addClass('linktt','yui-tt');
569 YUD.addClass('linktt','yui-tt');
570 YUD.setStyle('linktt','top',xy[1]+offset+'px');
570 YUD.setStyle('linktt','top',xy[1]+offset+'px');
571 YUD.setStyle('linktt','left',xy[0]+'px');
571 YUD.setStyle('linktt','left',xy[0]+'px');
572 YUD.setStyle('linktt','visibility','visible');
572 YUD.setStyle('linktt','visibility','visible');
573 }
573 }
574 else{
574 else{
575 YUD.setStyle('linktt','visibility','hidden');
575 YUD.setStyle('linktt','visibility','hidden');
576 }
576 }
577 }
577 }
578 }
578 }
579 };
579 };
580
580
581 var deleteNotification = function(url, notification_id,callbacks){
581 var deleteNotification = function(url, notification_id,callbacks){
582 var callback = {
582 var callback = {
583 success:function(o){
583 success:function(o){
584 var obj = YUD.get(String("notification_"+notification_id));
584 var obj = YUD.get(String("notification_"+notification_id));
585 if(obj.parentNode !== undefined){
585 if(obj.parentNode !== undefined){
586 obj.parentNode.removeChild(obj);
586 obj.parentNode.removeChild(obj);
587 }
587 }
588 _run_callbacks(callbacks);
588 _run_callbacks(callbacks);
589 },
589 },
590 failure:function(o){
590 failure:function(o){
591 alert("error");
591 alert("error");
592 },
592 },
593 };
593 };
594 var postData = '_method=delete';
594 var postData = '_method=delete';
595 var sUrl = url.replace('__NOTIFICATION_ID__',notification_id);
595 var sUrl = url.replace('__NOTIFICATION_ID__',notification_id);
596 var request = YAHOO.util.Connect.asyncRequest('POST', sUrl,
596 var request = YAHOO.util.Connect.asyncRequest('POST', sUrl,
597 callback, postData);
597 callback, postData);
598 };
598 };
General Comments 0
You need to be logged in to leave comments. Login now