author | Dan Fuhry <dan@enanocms.org> |
Wed, 13 Mar 2013 00:18:23 -0400 | |
changeset 346 | 35b0a72083ca |
parent 21 | 663fcf528726 |
permissions | -rw-r--r-- |
1 | 1 |
/* |
2 |
* Enano - an open source wiki-like CMS |
|
3 |
* Copyright (C) 2006-2007 Dan Fuhry |
|
4 |
* |
|
5 |
* This program is Free Software; you can redistribute and/or modify it under the terms of the GNU General Public License |
|
6 |
* as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. |
|
7 |
* |
|
8 |
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied |
|
9 |
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for details. |
|
10 |
*/ |
|
11 |
||
12 |
/* |
|
13 |
* Title: Tigra Tree |
|
14 |
* Description: See the demo at url |
|
15 |
* URL: http://www.softcomplex.com/products/tigra_tree_menu/ |
|
16 |
* Version: 1.1 |
|
17 |
* Date: 11-12-2002 (mm-dd-yyyy) |
|
18 |
* Notes: This script is free. Visit official site for further details. |
|
19 |
* |
|
15
ad5986a53197
Fixed complicated SQL injection vulnerability in URL handler, updated license info for Tigra Tree Menu, and killed one XSS vulnerability
Dan
parents:
1
diff
changeset
|
20 |
* Due to the unclear licensing conditions on this script, I contacted the author, who said that because Enano |
346 | 21 |
* is not a "competing product" I was allowed release the modified code as GPL. The conversation can be seen in the |
22 |
* licenses/tigra-menu.html document in the Enano distribution. |
|
1 | 23 |
*/ |
21
663fcf528726
Updated all version numbers back to Banshee; a few preliminary steps towards full UTF-8 support in page URLs
Dan
parents:
15
diff
changeset
|
24 |
|
346 | 25 |
if ( /admin_menu_state=/.test(document.cookie) ) |
1 | 26 |
{ |
346 | 27 |
var ck = (String(document.cookie).match(/admin_menu_state=([0-9]+)/))[1]; |
28 |
if(ck) |
|
29 |
{ |
|
30 |
ck = parseInt(ck); |
|
31 |
} |
|
32 |
else |
|
33 |
{ |
|
34 |
ck = 0; |
|
35 |
} |
|
36 |
ck = ( isNaN(ck) ) ? 0 : ck; |
|
1 | 37 |
} |
38 |
else |
|
39 |
{ |
|
346 | 40 |
var ck = 0; |
1 | 41 |
} |
42 |
||
346 | 43 |
function tree (a_items, a_template, s_target) { |
1 | 44 |
|
45 |
this.a_tpl = a_template; |
|
46 |
this.a_config = a_items; |
|
47 |
this.o_root = this; |
|
48 |
this.a_index = []; |
|
49 |
this.o_selected = null; |
|
50 |
this.n_depth = -1; |
|
51 |
||
52 |
var o_icone = new Image(), |
|
53 |
o_iconl = new Image(); |
|
54 |
o_icone.src = a_template['icon_e']; |
|
55 |
o_iconl.src = a_template['icon_l']; |
|
56 |
a_template['im_e'] = o_icone; |
|
57 |
a_template['im_l'] = o_iconl; |
|
58 |
for (var i = 0; i < 64; i++) |
|
59 |
if (a_template['icon_' + i]) { |
|
60 |
var o_icon = new Image(); |
|
61 |
a_template['im_' + i] = o_icon; |
|
62 |
o_icon.src = a_template['icon_' + i]; |
|
63 |
} |
|
64 |
||
65 |
this.toggle = function (n_id,co) { var o_item = this.a_index[n_id]; o_item.open(o_item.b_opened,co); }; |
|
346 | 66 |
this.open = function (n_id,co) { var o_item = this.a_index[n_id]; o_item.open(false,co); }; |
1 | 67 |
this.select = function (n_id) { return this.a_index[n_id].select(); }; |
68 |
this.mout = function (n_id) { this.a_index[n_id].upstatus(true) }; |
|
69 |
this.mover = function (n_id) { this.a_index[n_id].upstatus() }; |
|
70 |
||
71 |
this.a_children = []; |
|
72 |
for (var i = 0; i < a_items.length; i++) |
|
346 | 73 |
{ |
1 | 74 |
new tree_item(this, i); |
346 | 75 |
} |
1 | 76 |
|
77 |
this.n_id = trees.length; |
|
78 |
trees[this.n_id] = this; |
|
79 |
||
346 | 80 |
for (var i = 0; i < this.a_children.length; i++) |
81 |
{ |
|
82 |
if ( s_target ) |
|
83 |
document.getElementById(s_target).innerHTML += this.a_children[i].init(); |
|
84 |
else |
|
85 |
document.write(this.a_children[i].init()); |
|
1 | 86 |
this.a_children[i].open(false, true); |
87 |
} |
|
88 |
} |
|
89 |
function tree_item (o_parent, n_order) { |
|
90 |
||
91 |
this.n_depth = o_parent.n_depth + 1; |
|
92 |
this.a_config = o_parent.a_config[n_order + (this.n_depth ? 2 : 0)]; |
|
93 |
if (!this.a_config) return; |
|
94 |
||
95 |
this.o_root = o_parent.o_root; |
|
96 |
this.o_parent = o_parent; |
|
97 |
this.n_order = n_order; |
|
98 |
this.b_opened = !this.n_depth; |
|
99 |
||
100 |
this.n_id = this.o_root.a_index.length; |
|
101 |
this.o_root.a_index[this.n_id] = this; |
|
102 |
o_parent.a_children[n_order] = this; |
|
103 |
||
104 |
this.a_children = []; |
|
105 |
for (var i = 0; i < this.a_config.length - 2; i++) |
|
346 | 106 |
{ |
1 | 107 |
new tree_item(this, i); |
346 | 108 |
} |
109 |
||
1 | 110 |
this.get_icon = item_get_icon; |
111 |
this.open = item_open; |
|
112 |
this.select = item_select; |
|
113 |
this.init = item_init; |
|
114 |
this.upstatus = item_upstatus; |
|
115 |
this.is_last = function () { return this.n_order == this.o_parent.a_children.length - 1 }; |
|
346 | 116 |
|
117 |
// CODE MODIFICATION |
|
118 |
// added: |
|
119 |
// Do we need to open the branch? |
|
120 |
n = Math.pow(2, this.n_id); |
|
121 |
var disp = ( ck & n ) ? true : false; |
|
122 |
s = ( disp ) ? 'open' : 'closed'; |
|
123 |
//if(s=='open') alert(this.n_id + ': ' + s); |
|
124 |
if(disp) setTimeout('trees['+trees.length+'].open('+this.n_id+', true);', 10); |
|
125 |
// END MODIFICATIONS |
|
1 | 126 |
} |
127 |
||
128 |
function item_open (b_close, nocookie) { |
|
346 | 129 |
//alert('item_open('+this.n_id+');'); |
1 | 130 |
var o_idiv = get_element('i_div' + this.o_root.n_id + '_' + this.n_id); |
131 |
if (!o_idiv) return; |
|
132 |
||
133 |
if (!o_idiv.innerHTML) { |
|
134 |
var a_children = []; |
|
135 |
for (var i = 0; i < this.a_children.length; i++) |
|
346 | 136 |
{ |
1 | 137 |
a_children[i]= this.a_children[i].init(); |
346 | 138 |
} |
1 | 139 |
o_idiv.innerHTML = a_children.join(''); |
140 |
} |
|
141 |
o_idiv.style.display = (b_close ? 'none' : 'block'); |
|
346 | 142 |
|
143 |
// CODE MODIFICATION |
|
144 |
// added: |
|
145 |
if(!nocookie) |
|
146 |
{ |
|
147 |
// The idea here is to use a bitwise field. Nice 'n simple, right? Object of the game is to assemble |
|
148 |
// a binary number that depicts the open/closed state of the entire menu in one cookie. |
|
149 |
n = Math.pow(2, this.n_id); |
|
150 |
ck = ( b_close ) ? ck-n : ck+n; |
|
151 |
//alert('open(): doing the cookie routine for id '+this.n_id+"\nResult for bitwise op: "+ck); |
|
152 |
createCookie('admin_menu_state', ck, 365); |
|
153 |
} else { |
|
154 |
//alert('open(): NOT doing the cookie routine for id '+this.n_id); |
|
155 |
} |
|
156 |
// END MODIFICATIONS |
|
1 | 157 |
|
158 |
this.b_opened = !b_close; |
|
159 |
var o_jicon = document.images['j_img' + this.o_root.n_id + '_' + this.n_id], |
|
160 |
o_iicon = document.images['i_img' + this.o_root.n_id + '_' + this.n_id]; |
|
161 |
if (o_jicon) o_jicon.src = this.get_icon(true); |
|
162 |
if (o_iicon) o_iicon.src = this.get_icon(); |
|
163 |
this.upstatus(); |
|
164 |
} |
|
165 |
||
166 |
function item_select (b_deselect) { |
|
167 |
if (!b_deselect) { |
|
168 |
var o_olditem = this.o_root.o_selected; |
|
169 |
this.o_root.o_selected = this; |
|
170 |
if (o_olditem) o_olditem.select(true); |
|
171 |
} |
|
172 |
var o_iicon = document.images['i_img' + this.o_root.n_id + '_' + this.n_id]; |
|
173 |
if (o_iicon) o_iicon.src = this.get_icon(); |
|
174 |
get_element('i_txt' + this.o_root.n_id + '_' + this.n_id).style.fontWeight = b_deselect ? 'normal' : 'bold'; |
|
175 |
||
176 |
this.upstatus(); |
|
177 |
return Boolean(this.a_config[1]); |
|
178 |
} |
|
179 |
||
180 |
function item_upstatus (b_clear) { |
|
346 | 181 |
window.setTimeout('window.status="' + addslashes(b_clear ? '' : this.a_config[0] + (this.a_config[1] ? ' ('+ this.a_config[1] + ')' : '')) + '"', 10); |
1 | 182 |
} |
183 |
||
184 |
function item_init () { |
|
185 |
var a_offset = [], |
|
186 |
o_current_item = this.o_parent; |
|
187 |
for (var i = this.n_depth; i > 1; i--) { |
|
188 |
a_offset[i] = '<img src="' + this.o_root.a_tpl[o_current_item.is_last() ? 'icon_e' : 'icon_l'] + '" border="0" align="absbottom">'; |
|
189 |
o_current_item = o_current_item.o_parent; |
|
190 |
} |
|
191 |
return '<table cellpadding="0" cellspacing="0" border="0"><tr><td nowrap="nowrap">' + (this.n_depth ? a_offset.join('') + (this.a_children.length |
|
192 |
? '<a href="javascript: trees[' + this.o_root.n_id + '].toggle(' + this.n_id + ')" onmouseover="trees[' + this.o_root.n_id + '].mover(' + this.n_id + ')" onmouseout="trees[' + this.o_root.n_id + '].mout(' + this.n_id + ')"><img src="' + this.get_icon(true) + '" border="0" align="absbottom" name="j_img' + this.o_root.n_id + '_' + this.n_id + '"></a>' |
|
193 |
: '<img src="' + this.get_icon(true) + '" border="0" align="absbottom">') : '') |
|
346 | 194 |
// CODE MODIFICATION |
195 |
// [7/20/08: removed ondblclick property (unneeded)] |
|
196 |
// removed: |
|
1 | 197 |
// + '<a href="' + this.a_config[1] + '" target="' + this.o_root.a_tpl['target'] + '" onclick="return trees[' + this.o_root.n_id + '].select(' + this.n_id + ')" ondblclick="trees[' + this.o_root.n_id + '].toggle(' + this.n_id + ')" onmouseover="trees[' + this.o_root.n_id + '].mover(' + this.n_id + ')" onmouseout="trees[' + this.o_root.n_id + '].mout(' + this.n_id + ')" class="t' + this.o_root.n_id + 'i" id="i_txt' + this.o_root.n_id + '_' + this.n_id + '"><img src="' + this.get_icon() + '" border="0" align="absbottom" name="i_img' + this.o_root.n_id + '_' + this.n_id + '" class="t' + this.o_root.n_id + 'im">' + this.a_config[0] + '</a></td></tr></table>' + (this.a_children.length ? '<div id="i_div' + this.o_root.n_id + '_' + this.n_id + '" style="display:none"></div>' : ''); |
346 | 198 |
// added: |
199 |
+ '<a href="' + this.a_config[1] + '" target="' + this.o_root.a_tpl['target'] + '" onclick="return trees[' + this.o_root.n_id + '].select(' + this.n_id + ')" onmouseover="trees[' + this.o_root.n_id + '].mover(' + this.n_id + ')" onmouseout="trees[' + this.o_root.n_id + '].mout(' + this.n_id + ')" class="t' + this.o_root.n_id + 'i" id="i_txt' + this.o_root.n_id + '_' + this.n_id + '">' + this.a_config[0] + '</a></td></tr></table>' + (this.a_children.length ? '<div id="i_div' + this.o_root.n_id + '_' + this.n_id + '" style="display:none"></div>' : ''); |
|
200 |
// END MODIFICATIONS |
|
201 |
alert('i_div' + this.o_root.n_id + '_' + this.n_id); |
|
1 | 202 |
} |
203 |
||
204 |
function item_get_icon (b_junction) { |
|
205 |
return this.o_root.a_tpl['icon_' + ((this.n_depth ? 0 : 32) + (this.a_children.length ? 16 : 0) + (this.a_children.length && this.b_opened ? 8 : 0) + (!b_junction && this.o_root.o_selected == this ? 4 : 0) + (b_junction ? 2 : 0) + (b_junction && this.is_last() ? 1 : 0))]; |
|
206 |
} |
|
207 |
||
208 |
var trees = []; |
|
209 |
get_element = document.all ? |
|
210 |
function (s_id) { return document.all[s_id] } : |
|
211 |
function (s_id) { return document.getElementById(s_id) }; |
|
212 |
||
346 | 213 |
function addslashes(text) |
214 |
{ |
|
215 |
text = text.replace(/\\/g, '\\\\'); |
|
216 |
text = text.replace(/"/g, '\\"'); |
|
217 |
return text; |
|
218 |
} |
|
1 | 219 |
|
346 | 220 |
// ******************************************* |
221 |
// Table collapsing |
|
222 |
// ******************************************* |
|
223 |
||
224 |
function admin_table_onload(page) |
|
225 |
{ |
|
226 |
if ( page != namespace_list['Admin'] + 'GeneralConfig' ) |
|
227 |
{ |
|
228 |
return true; |
|
229 |
} |
|
230 |
var collapse_state = admin_table_get_cookie(page); |
|
231 |
if ( collapse_state == 0 ) |
|
232 |
collapse_state = 0xffffffff; |
|
233 |
$('#ajaxPageContainer > form > div.tblholder > table').each(function(i, table) |
|
234 |
{ |
|
235 |
// skip if this is a one-row table |
|
236 |
if ( $('tr:first', table).get(0) == $('tr:last', table).get(0) ) |
|
237 |
return; |
|
238 |
||
239 |
var open = (collapse_state >> i) & 1 > 0 ? true : false; |
|
240 |
||
241 |
var ypos = open ? 0 : 12; |
|
242 |
||
243 |
var div = document.createElement('div'); |
|
244 |
$(div).html(gen_sprite_html(scriptPath + '/themes/admin/images/thcollapse.png', 12, 12, ypos, 0)); |
|
245 |
$(div).click(function() |
|
246 |
{ |
|
247 |
admin_table_click(this); |
|
248 |
}).css('cursor', 'pointer').css('float', 'right'); |
|
249 |
div.thetable = table; |
|
250 |
div.index = i; |
|
251 |
div.thepage = page; |
|
252 |
div.openstate = open; |
|
253 |
$('tr > th:first', table).prepend(div); |
|
254 |
if ( !open ) |
|
255 |
admin_table_collapse(table, true); |
|
256 |
}); |
|
257 |
} |
|
258 |
||
259 |
function admin_table_click(mydiv) |
|
260 |
{ |
|
261 |
var table = mydiv.thetable; |
|
262 |
var i = mydiv.index; |
|
263 |
var page = mydiv.thepage; |
|
264 |
var collapse_state = admin_table_get_cookie(page); |
|
265 |
||
266 |
if ( mydiv.openstate ) |
|
267 |
{ |
|
268 |
$('img', mydiv).css('background-position', '0px -12px'); |
|
269 |
var new_collapse_state = collapse_state & ~Math.pow(2, i); |
|
270 |
console.debug(new_collapse_state); |
|
271 |
mydiv.openstate = false; |
|
272 |
admin_table_collapse(table); |
|
273 |
} |
|
274 |
else |
|
275 |
{ |
|
276 |
$('img', mydiv).css('background-position', '0px 0px'); |
|
277 |
var new_collapse_state = collapse_state | Math.pow(2, i); |
|
278 |
console.debug(new_collapse_state); |
|
279 |
mydiv.openstate = true; |
|
280 |
admin_table_expand(table); |
|
281 |
} |
|
282 |
createCookie('admin_th:' + page, new_collapse_state, 3650); |
|
283 |
} |
|
284 |
||
285 |
function admin_table_get_cookie(page) |
|
286 |
{ |
|
287 |
var cookievalue = parseInt(readCookie('admin_th:' + page)); |
|
288 |
if ( isNaN(cookievalue) ) |
|
289 |
cookievalue = 0; |
|
290 |
return cookievalue; |
|
291 |
} |
|
292 |
||
293 |
function admin_table_collapse(table, noanim) |
|
294 |
{ |
|
295 |
var targetheight = $('tr > th:first', table).height(); |
|
296 |
$('tr', table).hide(); |
|
297 |
$('tr:first', table).show(); |
|
298 |
} |
|
299 |
||
300 |
function admin_table_expand(table) |
|
301 |
{ |
|
302 |
$('tr', table).show(); |
|
303 |
} |