1
+ − 1
// Javascript routines for the ACL editor
+ − 2
+ − 3
var aclManagerID = 'enano_aclmanager_' + Math.floor(Math.random() * 1000000);
+ − 4
var aclPermList = false;
+ − 5
var aclDataCache = false;
+ − 6
151
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 7
// Can be set to true by slow themes (St. Patty)
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 8
var aclDisableTransitionFX = false;
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 9
1
+ − 10
function ajaxOpenACLManager(page_id, namespace)
+ − 11
{
+ − 12
if(IE)
+ − 13
return true;
+ − 14
if(!page_id || !namespace)
+ − 15
{
+ − 16
var data = strToPageID(title);
+ − 17
var page_id = data[0];
+ − 18
var namespace = data[1];
+ − 19
}
+ − 20
var params = {
+ − 21
'mode' : 'listgroups',
+ − 22
'page_id' : page_id,
+ − 23
'namespace' : namespace
+ − 24
};
+ − 25
params = toJSONString(params);
+ − 26
params = ajaxEscape(params);
+ − 27
ajaxPost(stdAjaxPrefix+'&_mode=acljson', 'acl_params='+params, function() {
407
+ − 28
if ( ajax.readyState == 4 && ajax.status == 200 )
1
+ − 29
{
327
+ − 30
var response = String(ajax.responseText + '');
+ − 31
if ( response.substr(0, 1) != '{' )
+ − 32
{
+ − 33
handle_invalid_json(ajax.responseText);
+ − 34
return false;
+ − 35
}
+ − 36
try {
+ − 37
data = parseJSON(ajax.responseText);
+ − 38
} catch(e) {
+ − 39
handle_invalid_json(ajax.responseText);
+ − 40
}
1
+ − 41
__aclBuildWizardWindow();
+ − 42
groups = parseJSON(ajax.responseText);
40
+ − 43
if ( groups.mode == 'error' )
+ − 44
{
+ − 45
alert(groups.error);
+ − 46
killACLManager();
+ − 47
return false;
+ − 48
}
1
+ − 49
aclDataCache = groups;
+ − 50
__aclBuildSelector(groups);
+ − 51
}
335
67bd3121a12e
Replaced TinyMCE 2.x with 3.0 beta 3. Supports everything but IE. Also rewrote the editor interface completely from the ground up.
Dan
diff
changeset
+ − 52
}, true);
1
+ − 53
return false;
+ − 54
}
+ − 55
+ − 56
function ajaxACLSwitchToSelector()
+ − 57
{
+ − 58
params = {
+ − 59
'mode' : 'listgroups'
+ − 60
};
+ − 61
if ( aclDataCache.page_id && aclDataCache.namespace )
+ − 62
{
+ − 63
params.page_id = aclDataCache.page_id;
+ − 64
params.namespace = aclDataCache.namespace;
+ − 65
}
+ − 66
params = toJSONString(params);
+ − 67
params = ajaxEscape(params);
+ − 68
ajaxPost(stdAjaxPrefix+'&_mode=acljson', 'acl_params='+params, function() {
407
+ − 69
if ( ajax.readyState == 4 && ajax.status == 200 )
1
+ − 70
{
+ − 71
document.getElementById(aclManagerID+'_main').innerHTML = '';
+ − 72
document.getElementById(aclManagerID + '_back').style.display = 'none';
218
+ − 73
document.getElementById(aclManagerID + '_next').value = $lang.get('etc_wizard_next');
1
+ − 74
groups = parseJSON(ajax.responseText);
40
+ − 75
if ( groups.mode == 'error' )
+ − 76
{
+ − 77
alert(groups.error);
+ − 78
killACLManager();
+ − 79
return false;
+ − 80
}
1
+ − 81
aclDataCache = groups;
+ − 82
thispage = strToPageID(title);
+ − 83
groups.page_id = thispage[0];
+ − 84
groups.namespace = thispage[1];
+ − 85
__aclBuildSelector(groups);
+ − 86
}
335
67bd3121a12e
Replaced TinyMCE 2.x with 3.0 beta 3. Supports everything but IE. Also rewrote the editor interface completely from the ground up.
Dan
diff
changeset
+ − 87
}, true);
1
+ − 88
}
+ − 89
+ − 90
function __aclBuildSelector(groups)
+ − 91
{
+ − 92
thispage = strToPageID(title);
+ − 93
do_scopesel = ( thispage[0] == groups.page_id && thispage[1] == groups.namespace );
+ − 94
+ − 95
seed = Math.floor(Math.random() * 1000000);
+ − 96
+ − 97
main = document.getElementById(aclManagerID + '_main');
+ − 98
main.style.padding = '10px';
+ − 99
+ − 100
selector = document.createElement('div');
+ − 101
+ − 102
grpsel = __aclBuildGroupsHTML(groups);
+ − 103
grpsel.name = 'group_id';
+ − 104
+ − 105
span = document.createElement('div');
+ − 106
span.id = "enACL_grpbox_"+seed+"";
+ − 107
+ − 108
// Build the selector
+ − 109
grpb = document.createElement('input');
+ − 110
grpb.type = 'radio';
+ − 111
grpb.name = 'target_type';
40
+ − 112
grpb.value = '1'; // ACL_TYPE_GROUP
1
+ − 113
grpb.checked = 'checked';
+ − 114
grpb.className = seed;
+ − 115
grpb.onclick = function() { seed = this.className; document.getElementById('enACL_grpbox_'+seed).style.display = 'block'; document.getElementById('enACL_usrbox_'+seed).style.display = 'none'; };
+ − 116
lbl = document.createElement('label');
+ − 117
lbl.appendChild(grpb);
218
+ − 118
lbl.appendChild(document.createTextNode($lang.get('acl_radio_usergroup')));
1
+ − 119
lbl.style.display = 'block';
+ − 120
span.appendChild(grpsel);
+ − 121
42
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 122
anoninfo = document.createElement('div');
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 123
anoninfo.className = 'info-box-mini';
218
+ − 124
anoninfo.appendChild(document.createTextNode($lang.get('acl_msg_guest_howto')));
42
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 125
span.appendChild(document.createElement('br'));
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 126
span.appendChild(anoninfo);
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 127
1
+ − 128
usrb = document.createElement('input');
+ − 129
usrb.type = 'radio';
+ − 130
usrb.name = 'target_type';
40
+ − 131
usrb.value = '2'; // ACL_TYPE_USER
1
+ − 132
usrb.className = seed;
+ − 133
usrb.onclick = function() { seed = this.className; document.getElementById('enACL_grpbox_'+seed).style.display = 'none'; document.getElementById('enACL_usrbox_'+seed).style.display = 'block'; };
+ − 134
lbl2 = document.createElement('label');
+ − 135
lbl2.appendChild(usrb);
218
+ − 136
lbl2.appendChild(document.createTextNode($lang.get('acl_radio_user')));
1
+ − 137
lbl2.style.display = 'block';
+ − 138
+ − 139
usrsel = document.createElement('input');
+ − 140
usrsel.type = 'text';
+ − 141
usrsel.name = 'username';
184
+ − 142
usrsel.onkeyup = function() { new AutofillUsername(this, undefined, true); };
1
+ − 143
usrsel.id = 'userfield_' + aclManagerID;
+ − 144
try {
+ − 145
usrsel.setAttribute("autocomplete","off");
+ − 146
} catch(e) {};
+ − 147
+ − 148
span2 = document.createElement('div');
+ − 149
span2.id = "enACL_usrbox_"+seed+"";
+ − 150
span2.style.display = 'none';
+ − 151
span2.appendChild(usrsel);
+ − 152
+ − 153
// Scope selector
+ − 154
if(do_scopesel)
+ − 155
{
+ − 156
scopediv1 = document.createElement('div');
+ − 157
scopediv2 = document.createElement('div');
73
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 158
scopediv3 = document.createElement('div');
1
+ − 159
scopeRadioPage = document.createElement('input');
+ − 160
scopeRadioPage.type = 'radio';
+ − 161
scopeRadioPage.name = 'scope';
+ − 162
scopeRadioPage.value = 'page';
+ − 163
scopeRadioPage.checked = 'checked';
73
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 164
scopeRadioPage.className = '1048576';
76
+ − 165
if ( groups.page_groups.length > 0 ) scopeRadioPage.onclick = function() { var id = 'enACL_pgsel_' + this.className; document.getElementById(id).style.display = 'none'; };
1
+ − 166
scopeRadioGlobal = document.createElement('input');
+ − 167
scopeRadioGlobal.type = 'radio';
+ − 168
scopeRadioGlobal.name = 'scope';
+ − 169
scopeRadioGlobal.value = 'global';
73
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 170
scopeRadioGlobal.className = '1048576';
76
+ − 171
if ( groups.page_groups.length > 0 ) scopeRadioGlobal.onclick = function() { var id = 'enACL_pgsel_' + this.className; document.getElementById(id).style.display = 'none'; };
73
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 172
scopeRadioGroup = document.createElement('input');
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 173
scopeRadioGroup.type = 'radio';
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 174
scopeRadioGroup.name = 'scope';
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 175
scopeRadioGroup.value = 'group';
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 176
scopeRadioGroup.className = '1048576';
76
+ − 177
if ( groups.page_groups.length > 0 ) scopeRadioGroup.onclick = function() { var id = 'enACL_pgsel_' + this.className; document.getElementById(id).style.display = 'block'; };
1
+ − 178
lblPage = document.createElement('label');
+ − 179
lblPage.style.display = 'block';
+ − 180
lblPage.appendChild(scopeRadioPage);
218
+ − 181
lblPage.appendChild(document.createTextNode($lang.get('acl_radio_scope_thispage')));
1
+ − 182
lblGlobal = document.createElement('label');
+ − 183
lblGlobal.style.display = 'block';
+ − 184
lblGlobal.appendChild(scopeRadioGlobal);
218
+ − 185
lblGlobal.appendChild(document.createTextNode($lang.get('acl_radio_scope_wholesite')));
73
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 186
lblGroup = document.createElement('label');
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 187
lblGroup.style.display = 'block';
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 188
lblGroup.appendChild(scopeRadioGroup);
218
+ − 189
lblGroup.appendChild(document.createTextNode($lang.get('acl_radio_scope_pagegroup')));
1
+ − 190
scopediv1.appendChild(lblPage);
73
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 191
scopediv2.appendChild(lblGroup);
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 192
scopediv3.appendChild(lblGlobal);
1
+ − 193
+ − 194
scopedesc = document.createElement('p');
218
+ − 195
scopedesc.appendChild(document.createTextNode($lang.get('acl_lbl_scope')));
73
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 196
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 197
scopePGrp = document.createElement('select');
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 198
scopePGrp.style.marginLeft = '13px';
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 199
scopePGrp.style.display = 'none';
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 200
scopePGrp.id = "enACL_pgsel_1048576";
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 201
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 202
var opt;
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 203
for ( var i = 0; i < groups.page_groups.length; i++ )
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 204
{
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 205
opt = document.createElement('option');
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 206
opt.value = groups.page_groups[i].id;
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 207
opt.appendChild(document.createTextNode(groups.page_groups[i].name));
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 208
scopePGrp.appendChild(opt);
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 209
}
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 210
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 211
scopediv2.appendChild(scopePGrp);
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 212
1
+ − 213
}
+ − 214
+ − 215
// Styles
+ − 216
span.style.marginLeft = '13px';
+ − 217
span.style.padding = '5px 0';
+ − 218
span2.style.marginLeft = '13px';
+ − 219
span2.style.padding = '5px 0';
+ − 220
+ − 221
selector.appendChild(lbl);
+ − 222
selector.appendChild(span);
+ − 223
+ − 224
selector.appendChild(lbl2);
+ − 225
selector.appendChild(span2);
+ − 226
+ − 227
container = document.createElement('div');
+ − 228
container.style.margin = 'auto';
+ − 229
container.style.width = '360px';
73
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 230
container.style.paddingTop = '50px';
1
+ − 231
+ − 232
head = document.createElement('h2');
218
+ − 233
head.appendChild(document.createTextNode($lang.get('acl_lbl_welcome_title')));
1
+ − 234
+ − 235
desc = document.createElement('p');
218
+ − 236
desc.appendChild(document.createTextNode($lang.get('acl_lbl_welcome_body')));
1
+ − 237
+ − 238
container.appendChild(head);
+ − 239
container.appendChild(desc);
+ − 240
container.appendChild(selector);
+ − 241
+ − 242
if(do_scopesel)
+ − 243
{
+ − 244
container.appendChild(scopedesc);
+ − 245
container.appendChild(scopediv1);
76
+ − 246
if ( groups.page_groups.length > 0 )
+ − 247
{
+ − 248
container.appendChild(scopediv2);
+ − 249
}
73
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 250
container.appendChild(scopediv3);
1
+ − 251
}
+ − 252
+ − 253
main.appendChild(container);
+ − 254
+ − 255
var mode = document.createElement('input');
+ − 256
mode.name = 'mode';
+ − 257
mode.type = 'hidden';
+ − 258
mode.id = aclManagerID + '_mode';
+ − 259
mode.value = 'seltarget';
+ − 260
+ − 261
var theform = document.getElementById(aclManagerID + '_formobj_id');
+ − 262
if ( !theform.mode )
+ − 263
{
+ − 264
theform.appendChild(mode);
+ − 265
}
+ − 266
else
+ − 267
{
+ − 268
theform.removeChild(theform.mode);
+ − 269
theform.appendChild(mode);
+ − 270
}
+ − 271
}
+ − 272
+ − 273
var aclDebugWin = false;
+ − 274
+ − 275
function aclDebug(text)
+ − 276
{
+ − 277
if(!aclDebugWin)
+ − 278
aclDebugWin = pseudoWindowOpen("data:text/html;plain,<html><head><title>debug win</title></head><body><h1>Debug window</h1></body></html>", "aclDebugWin");
+ − 279
setTimeout(function() {
+ − 280
aclDebugWin.pre = aclDebugWin.document.createElement('pre');
+ − 281
aclDebugWin.pre.appendChild(aclDebugWin.document.createTextNode(text));
+ − 282
aclDebugWin.b = aclDebugWin.document.getElementsByTagName('body')[0];
+ − 283
aclDebugWin.b.appendChild(aclDebugWin.pre);}, 1000);
+ − 284
}
+ − 285
+ − 286
var pseudoWindows = new Object();
+ − 287
+ − 288
function pseudoWindowOpen(url, id)
+ − 289
{
+ − 290
if(pseudoWindows[id])
+ − 291
{
+ − 292
document.getElementById('pseudowin_ifr_'+id).src = url;
+ − 293
}
+ − 294
else
+ − 295
{
+ − 296
win = document.createElement('iframe');
+ − 297
win.style.position='fixed';
+ − 298
win.style.width = '640px';
+ − 299
win.style.height = '480px';
+ − 300
win.style.top = '0px';
+ − 301
win.style.left = '0px';
+ − 302
win.style.zIndex = getHighestZ() + 1;
+ − 303
win.style.backgroundColor = '#FFFFFF';
+ − 304
win.name = 'pseudo_ifr_'+id;
+ − 305
win.id = 'pseudowindow_ifr_'+id;
+ − 306
win.src = url;
+ − 307
body = document.getElementsByTagName('body')[0];
+ − 308
body.appendChild(win);
+ − 309
}
+ − 310
win_obj = eval("( pseudo_ifr_"+id+" )");
+ − 311
return win_obj;
+ − 312
}
+ − 313
+ − 314
function __aclJSONSubmitAjaxHandler(params)
+ − 315
{
+ − 316
params = toJSONString(params);
+ − 317
params = ajaxEscape(params);
+ − 318
ajaxPost(stdAjaxPrefix+'&_mode=acljson', 'acl_params='+params, function() {
407
+ − 319
if ( ajax.readyState == 4 && ajax.status == 200 )
1
+ − 320
{
327
+ − 321
var response = String(ajax.responseText + '');
+ − 322
if ( response.substr(0, 1) != '{' )
+ − 323
{
+ − 324
handle_invalid_json(ajax.responseText);
+ − 325
return false;
+ − 326
}
1
+ − 327
try {
+ − 328
data = parseJSON(ajax.responseText);
+ − 329
} catch(e) {
327
+ − 330
handle_invalid_json(ajax.responseText);
1
+ − 331
}
+ − 332
aclDataCache = data;
+ − 333
switch(data.mode)
+ − 334
{
+ − 335
case 'seltarget':
+ − 336
+ − 337
// Build the ACL edit form
+ − 338
// try {
218
+ − 339
+ − 340
var act_desc = ( data.type == 'new' ) ? $lang.get('acl_lbl_editwin_title_create') : $lang.get('acl_lbl_editwin_title_edit');
+ − 341
var target_type_t = ( data.target_type == 1 ) ? $lang.get('acl_target_type_group') : $lang.get('acl_target_type_user');
+ − 342
var target_name_t = data.target_name;
+ − 343
var scope_type = ( data.page_id == false && data.namespace == false ) ? $lang.get('acl_scope_type_wholesite') : ( data.namespace == '__PageGroup' ) ? $lang.get('acl_scope_type_pagegroup') : $lang.get('acl_scope_type_thispage');
+ − 344
+ − 345
html = '<h2>'+act_desc+'</h2>';
+ − 346
html += '<p>' + $lang.get('acl_lbl_editwin_body', { target_type: target_type_t, target: target_name_t, scope_type: scope_type }) + '</p>';
1
+ − 347
parser = new templateParser(data.template.acl_field_begin);
+ − 348
html += parser.run();
+ − 349
+ − 350
cls = 'row2';
+ − 351
for(var i in data.acl_types)
+ − 352
{
+ − 353
if(typeof(data.acl_types[i]) == 'number')
+ − 354
{
+ − 355
cls = ( cls == 'row1' ) ? 'row2' : 'row1';
+ − 356
p = new templateParser(data.template.acl_field_item);
+ − 357
vars = new Object();
218
+ − 358
if ( data.acl_descs[i].match(/^([a-z0-9_]+)$/) )
+ − 359
{
+ − 360
vars['FIELD_DESC'] = $lang.get(data.acl_descs[i]);
+ − 361
}
+ − 362
else
+ − 363
{
+ − 364
vars['FIELD_DESC'] = data.acl_descs[i];
+ − 365
}
345
4ccdfeee9a11
WiP commit for admin panel localization. All modules up to Admin:UserManager (working down the list) are localized except Admin:ThemeManager, which is due for a rewrite
Dan
diff
changeset
+ − 366
vars['FIELD_INHERIT_CHECKED'] = '';
1
+ − 367
vars['FIELD_DENY_CHECKED'] = '';
+ − 368
vars['FIELD_DISALLOW_CHECKED'] = '';
+ − 369
vars['FIELD_WIKIMODE_CHECKED'] = '';
+ − 370
vars['FIELD_ALLOW_CHECKED'] = '';
+ − 371
vars['FIELD_NAME'] = i;
345
4ccdfeee9a11
WiP commit for admin panel localization. All modules up to Admin:UserManager (working down the list) are localized except Admin:ThemeManager, which is due for a rewrite
Dan
diff
changeset
+ − 372
if ( !data.current_perms[i] )
4ccdfeee9a11
WiP commit for admin panel localization. All modules up to Admin:UserManager (working down the list) are localized except Admin:ThemeManager, which is due for a rewrite
Dan
diff
changeset
+ − 373
{
4ccdfeee9a11
WiP commit for admin panel localization. All modules up to Admin:UserManager (working down the list) are localized except Admin:ThemeManager, which is due for a rewrite
Dan
diff
changeset
+ − 374
data.current_perms[i] = 'i';
4ccdfeee9a11
WiP commit for admin panel localization. All modules up to Admin:UserManager (working down the list) are localized except Admin:ThemeManager, which is due for a rewrite
Dan
diff
changeset
+ − 375
}
1
+ − 376
switch(data.current_perms[i])
+ − 377
{
345
4ccdfeee9a11
WiP commit for admin panel localization. All modules up to Admin:UserManager (working down the list) are localized except Admin:ThemeManager, which is due for a rewrite
Dan
diff
changeset
+ − 378
case 'i':
4ccdfeee9a11
WiP commit for admin panel localization. All modules up to Admin:UserManager (working down the list) are localized except Admin:ThemeManager, which is due for a rewrite
Dan
diff
changeset
+ − 379
default:
4ccdfeee9a11
WiP commit for admin panel localization. All modules up to Admin:UserManager (working down the list) are localized except Admin:ThemeManager, which is due for a rewrite
Dan
diff
changeset
+ − 380
vars['FIELD_INHERIT_CHECKED'] = 'checked="checked"';
4ccdfeee9a11
WiP commit for admin panel localization. All modules up to Admin:UserManager (working down the list) are localized except Admin:ThemeManager, which is due for a rewrite
Dan
diff
changeset
+ − 381
break;
1
+ − 382
case 1:
+ − 383
vars['FIELD_DENY_CHECKED'] = 'checked="checked"';
+ − 384
break;
+ − 385
case 2:
+ − 386
vars['FIELD_DISALLOW_CHECKED'] = 'checked="checked"';
+ − 387
break;
+ − 388
case 3:
+ − 389
vars['FIELD_WIKIMODE_CHECKED'] = 'checked="checked"';
+ − 390
break;
+ − 391
case 4:
+ − 392
vars['FIELD_ALLOW_CHECKED'] = 'checked="checked"';
+ − 393
break;
+ − 394
}
+ − 395
vars['ROW_CLASS'] = cls;
+ − 396
p.assign_vars(vars);
+ − 397
html += p.run();
+ − 398
}
+ − 399
}
+ − 400
+ − 401
var parser = new templateParser(data.template.acl_field_end);
+ − 402
html += parser.run();
+ − 403
+ − 404
if(data.type == 'edit')
218
+ − 405
html += '<p id="'+aclManagerID+'_deletelnk" style="text-align: right;"><a href="#delete_acl_rule" onclick="if(confirm(\'' + $lang.get('acl_msg_deleterule_confirm') + '\')) __aclDeleteRule(); return false;" style="color: red;">' + $lang.get('acl_lbl_deleterule') + '</a></p>';
1
+ − 406
+ − 407
var main = document.getElementById(aclManagerID + '_main');
+ − 408
main.innerHTML = html;
+ − 409
+ − 410
var form = document.getElementById(aclManagerID + '_formobj_id');
+ − 411
+ − 412
var modeobj = form_fetch_field(form, 'mode');
+ − 413
if ( modeobj )
+ − 414
modeobj.value = 'save_' + data.type;
+ − 415
else
+ − 416
alert('modeobj is invalid: '+modeobj);
+ − 417
+ − 418
aclPermList = array_keys(data.acl_types);
+ − 419
+ − 420
document.getElementById(aclManagerID + '_back').style.display = 'inline';
218
+ − 421
document.getElementById(aclManagerID + '_next').value = $lang.get('etc_save_changes');
1
+ − 422
+ − 423
// } catch(e) { alert(e); aclDebug(ajax.responseText); }
+ − 424
+ − 425
break;
+ − 426
case 'success':
+ − 427
var note = document.createElement('div');
+ − 428
note.className = 'info-box';
+ − 429
note.style.marginLeft = '0';
+ − 430
var b = document.createElement('b');
218
+ − 431
b.appendChild(document.createTextNode($lang.get('acl_lbl_save_success_title')));
1
+ − 432
note.appendChild(b);
+ − 433
note.appendChild(document.createElement('br'));
218
+ − 434
note.appendChild(document.createTextNode($lang.get('acl_lbl_save_success_body', { target_name: data.target_name })));
1
+ − 435
note.appendChild(document.createElement('br'));
+ − 436
var a = document.createElement('a');
335
67bd3121a12e
Replaced TinyMCE 2.x with 3.0 beta 3. Supports everything but IE. Also rewrote the editor interface completely from the ground up.
Dan
diff
changeset
+ − 437
a.href = '#';
419
b8b4e38825db
Unsuccessful attempt at fixing "dismiss"/"close manager" buttons in ACL editor; non-breaking change to template API to allow plugins to add "normal" sidebar widgets in addition to the special "raw" block type, specified as the third parameter to $template->sidebar_widget(). Defaults to false, which is old behavior; new behavior (enabled by passing TRUE as the 3rd param) means that the content of the block is primarily block-level links.
Dan
diff
changeset
+ − 438
a.id = aclManagerID + '_btn_dismiss';
218
+ − 439
a.appendChild(document.createTextNode('[ ' + $lang.get('acl_btn_success_dismiss') + ' :'));
1
+ − 440
note.appendChild(a);
+ − 441
var a2 = document.createElement('a');
335
67bd3121a12e
Replaced TinyMCE 2.x with 3.0 beta 3. Supports everything but IE. Also rewrote the editor interface completely from the ground up.
Dan
diff
changeset
+ − 442
a2.href = '#';
419
b8b4e38825db
Unsuccessful attempt at fixing "dismiss"/"close manager" buttons in ACL editor; non-breaking change to template API to allow plugins to add "normal" sidebar widgets in addition to the special "raw" block type, specified as the third parameter to $template->sidebar_widget(). Defaults to false, which is old behavior; new behavior (enabled by passing TRUE as the 3rd param) means that the content of the block is primarily block-level links.
Dan
diff
changeset
+ − 443
a.id = aclManagerID + '_btn_close';
218
+ − 444
a2.appendChild(document.createTextNode(': ' + $lang.get('acl_btn_success_close') + ' ]'));
1
+ − 445
note.appendChild(a2);
+ − 446
document.getElementById(aclManagerID + '_main').insertBefore(note, document.getElementById(aclManagerID + '_main').firstChild);
+ − 447
if(!document.getElementById(aclManagerID+'_deletelnk'))
218
+ − 448
document.getElementById(aclManagerID + '_main').innerHTML += '<p id="'+aclManagerID+'_deletelnk" style="text-align: right;"><a href="#delete_acl_rule" onclick="if(confirm(\'' + $lang.get('acl_msg_deleterule_confirm') + '\')) __aclDeleteRule(); return false;" style="color: red;">' + $lang.get('acl_lbl_deleterule') + '</a></p>';
1
+ − 449
//fadeInfoBoxes();
40
+ − 450
document.getElementById(aclManagerID+'_main').scrollTop = 0;
42
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 451
419
b8b4e38825db
Unsuccessful attempt at fixing "dismiss"/"close manager" buttons in ACL editor; non-breaking change to template API to allow plugins to add "normal" sidebar widgets in addition to the special "raw" block type, specified as the third parameter to $template->sidebar_widget(). Defaults to false, which is old behavior; new behavior (enabled by passing TRUE as the 3rd param) means that the content of the block is primarily block-level links.
Dan
diff
changeset
+ − 452
var a = document.getElementById(aclManagerID + '_btn_dismiss');
b8b4e38825db
Unsuccessful attempt at fixing "dismiss"/"close manager" buttons in ACL editor; non-breaking change to template API to allow plugins to add "normal" sidebar widgets in addition to the special "raw" block type, specified as the third parameter to $template->sidebar_widget(). Defaults to false, which is old behavior; new behavior (enabled by passing TRUE as the 3rd param) means that the content of the block is primarily block-level links.
Dan
diff
changeset
+ − 453
var a2 = document.getElementById(aclManagerID + '_btn_close');
b8b4e38825db
Unsuccessful attempt at fixing "dismiss"/"close manager" buttons in ACL editor; non-breaking change to template API to allow plugins to add "normal" sidebar widgets in addition to the special "raw" block type, specified as the third parameter to $template->sidebar_widget(). Defaults to false, which is old behavior; new behavior (enabled by passing TRUE as the 3rd param) means that the content of the block is primarily block-level links.
Dan
diff
changeset
+ − 454
b8b4e38825db
Unsuccessful attempt at fixing "dismiss"/"close manager" buttons in ACL editor; non-breaking change to template API to allow plugins to add "normal" sidebar widgets in addition to the special "raw" block type, specified as the third parameter to $template->sidebar_widget(). Defaults to false, which is old behavior; new behavior (enabled by passing TRUE as the 3rd param) means that the content of the block is primarily block-level links.
Dan
diff
changeset
+ − 455
a.setAttribute('onclick', function(e) { this.parentNode.parentNode.removeChild(this.parentNode); return false; });
b8b4e38825db
Unsuccessful attempt at fixing "dismiss"/"close manager" buttons in ACL editor; non-breaking change to template API to allow plugins to add "normal" sidebar widgets in addition to the special "raw" block type, specified as the third parameter to $template->sidebar_widget(). Defaults to false, which is old behavior; new behavior (enabled by passing TRUE as the 3rd param) means that the content of the block is primarily block-level links.
Dan
diff
changeset
+ − 456
a2.setAttribute('onclick', function(e) { killACLManager(); return false; });
b8b4e38825db
Unsuccessful attempt at fixing "dismiss"/"close manager" buttons in ACL editor; non-breaking change to template API to allow plugins to add "normal" sidebar widgets in addition to the special "raw" block type, specified as the third parameter to $template->sidebar_widget(). Defaults to false, which is old behavior; new behavior (enabled by passing TRUE as the 3rd param) means that the content of the block is primarily block-level links.
Dan
diff
changeset
+ − 457
42
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 458
aclDataCache.mode = 'save_edit';
1
+ − 459
break;
+ − 460
case 'delete':
+ − 461
+ − 462
params = {
+ − 463
'mode' : 'listgroups'
+ − 464
};
+ − 465
params = toJSONString(params);
+ − 466
params = ajaxEscape(params);
+ − 467
ajaxPost(stdAjaxPrefix+'&_mode=acljson', 'acl_params='+params, function() {
407
+ − 468
if ( ajax.readyState == 4 && ajax.status == 200 )
1
+ − 469
{
+ − 470
document.getElementById(aclManagerID+'_main').innerHTML = '';
+ − 471
document.getElementById(aclManagerID + '_back').style.display = 'none';
218
+ − 472
document.getElementById(aclManagerID + '_next').value = $lang.get('etc_wizard_next');
1
+ − 473
var thispage = strToPageID(title);
+ − 474
groups.page_id = thispage[0];
+ − 475
groups.namespace = thispage[1];
+ − 476
__aclBuildSelector(groups);
+ − 477
+ − 478
note = document.createElement('div');
+ − 479
note.className = 'info-box';
+ − 480
note.style.marginLeft = '0';
42
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 481
note.style.position = 'absolute';
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 482
note.style.width = '558px';
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 483
note.id = 'aclSuccessNotice_' + Math.floor(Math.random() * 100000);
1
+ − 484
b = document.createElement('b');
218
+ − 485
b.appendChild(document.createTextNode($lang.get('acl_lbl_delete_success_title')));
1
+ − 486
note.appendChild(b);
+ − 487
note.appendChild(document.createElement('br'));
336
+ − 488
note.appendChild(document.createTextNode($lang.get('acl_lbl_delete_success_body', { target_name: aclDataCache.target_name })));
1
+ − 489
note.appendChild(document.createElement('br'));
+ − 490
a = document.createElement('a');
+ − 491
a.href = '#';
42
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 492
a.onclick = function() { opacity(this.parentNode.id, 100, 0, 1000); setTimeout('var div = document.getElementById("' + this.parentNode.id + '"); div.parentNode.removeChild(div);', 1100); return false; };
218
+ − 493
a.appendChild(document.createTextNode('[ ' + $lang.get('acl_btn_success_dismiss') + ' :'));
1
+ − 494
note.appendChild(a);
+ − 495
a = document.createElement('a');
+ − 496
a.href = '#';
+ − 497
a.onclick = function() { killACLManager(); return false; };
218
+ − 498
a.appendChild(document.createTextNode(': ' + $lang.get('acl_btn_success_close') + ' ]'));
1
+ − 499
note.appendChild(a);
+ − 500
document.getElementById(aclManagerID + '_main').insertBefore(note, document.getElementById(aclManagerID + '_main').firstChild);
+ − 501
//fadeInfoBoxes();
+ − 502
+ − 503
}
335
67bd3121a12e
Replaced TinyMCE 2.x with 3.0 beta 3. Supports everything but IE. Also rewrote the editor interface completely from the ground up.
Dan
diff
changeset
+ − 504
}, true);
1
+ − 505
+ − 506
break;
+ − 507
case 'error':
+ − 508
alert("Server side processing error:\n"+data.error);
+ − 509
break;
+ − 510
case 'debug':
+ − 511
aclDebug(data.text);
+ − 512
break;
+ − 513
default:
327
+ − 514
handle_invalid_json(ajax.responseText);
1
+ − 515
break;
+ − 516
}
+ − 517
}
335
67bd3121a12e
Replaced TinyMCE 2.x with 3.0 beta 3. Supports everything but IE. Also rewrote the editor interface completely from the ground up.
Dan
diff
changeset
+ − 518
}, true);
1
+ − 519
}
+ − 520
+ − 521
function __aclBuildGroupsHTML(groups)
+ − 522
{
+ − 523
groups = groups.groups;
+ − 524
select = document.createElement('select');
+ − 525
for(var i in groups)
+ − 526
{
+ − 527
if(typeof(groups[i]['name']) == 'string' && i != 'toJSONString')
+ − 528
{
+ − 529
o = document.createElement('option');
+ − 530
o.value = groups[i]['id'];
+ − 531
t = document.createTextNode(groups[i]['name']);
+ − 532
o.appendChild(t);
+ − 533
select.appendChild(o);
+ − 534
}
+ − 535
}
+ − 536
return select;
+ − 537
}
+ − 538
+ − 539
function __aclBuildWizardWindow()
+ − 540
{
151
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 541
darken(aclDisableTransitionFX);
1
+ − 542
box = document.createElement('div');
+ − 543
box.style.width = '640px'
+ − 544
box.style.height = '440px';
+ − 545
box.style.position = 'fixed';
+ − 546
width = getWidth();
+ − 547
height = getHeight();
+ − 548
box.style.left = ( width / 2 - 320 ) + 'px';
+ − 549
box.style.top = ( height / 2 - 250 ) + 'px';
+ − 550
box.style.backgroundColor = 'white';
+ − 551
box.style.zIndex = getHighestZ() + 1;
+ − 552
box.id = aclManagerID;
+ − 553
box.style.opacity = '0';
+ − 554
box.style.filter = 'alpha(opacity=0)';
+ − 555
box.style.display = 'none';
+ − 556
+ − 557
mainwin = document.createElement('div');
+ − 558
mainwin.id = aclManagerID + '_main';
+ − 559
mainwin.style.clip = 'rect(0px,640px,440px,0px)';
+ − 560
mainwin.style.overflow = 'auto';
+ − 561
mainwin.style.width = '620px';
+ − 562
mainwin.style.height = '420px';
+ − 563
+ − 564
panel = document.createElement('div');
+ − 565
panel.style.width = '620px';
+ − 566
panel.style.padding = '10px';
+ − 567
panel.style.lineHeight = '40px';
+ − 568
panel.style.textAlign = 'right';
+ − 569
panel.style.position = 'fixed';
+ − 570
panel.style.left = ( width / 2 - 320 ) + 'px';
+ − 571
panel.style.top = ( height / 2 + 190 ) + 'px';
+ − 572
panel.style.backgroundColor = '#D0D0D0';
+ − 573
panel.style.opacity = '0';
+ − 574
panel.style.filter = 'alpha(opacity=0)';
+ − 575
panel.id = aclManagerID + '_panel';
+ − 576
+ − 577
form = document.createElement('form');
+ − 578
form.method = 'post';
+ − 579
form.action = 'javascript:void(0)';
+ − 580
form.onsubmit = function() { if(this.username && !submitAuthorized) return false; __aclSubmitManager(this); return false; };
+ − 581
form.name = aclManagerID + '_formobj';
+ − 582
form.id = aclManagerID + '_formobj_id';
+ − 583
+ − 584
back = document.createElement('input');
+ − 585
back.type = 'button';
218
+ − 586
back.value = $lang.get('etc_wizard_back');
1
+ − 587
back.style.fontWeight = 'normal';
+ − 588
back.onclick = function() { ajaxACLSwitchToSelector(); return false; };
+ − 589
back.style.display = 'none';
+ − 590
back.id = aclManagerID + '_back';
+ − 591
+ − 592
saver = document.createElement('input');
+ − 593
saver.type = 'submit';
218
+ − 594
saver.value = $lang.get('etc_wizard_next');
1
+ − 595
saver.style.fontWeight = 'bold';
+ − 596
saver.id = aclManagerID + '_next';
+ − 597
+ − 598
closer = document.createElement('input');
+ − 599
closer.type = 'button';
218
+ − 600
closer.value = $lang.get('etc_cancel_changes');
+ − 601
closer.onclick = function() { if(!confirm($lang.get('acl_msg_closeacl_confirm'))) return false; killACLManager(); return false; }
1
+ − 602
+ − 603
spacer1 = document.createTextNode(' ');
+ − 604
spacer2 = document.createTextNode(' ');
+ − 605
+ − 606
panel.appendChild(back);
+ − 607
panel.appendChild(spacer1);
+ − 608
panel.appendChild(saver);
+ − 609
panel.appendChild(spacer2);
+ − 610
panel.appendChild(closer);
+ − 611
form.appendChild(mainwin);
+ − 612
form.appendChild(panel);
+ − 613
box.appendChild(form);
+ − 614
+ − 615
body = document.getElementsByTagName('body')[0];
+ − 616
body.appendChild(box);
151
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 617
if ( aclDisableTransitionFX )
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 618
{
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 619
document.getElementById(aclManagerID).style.display = 'block';
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 620
changeOpac(100, aclManagerID);
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 621
changeOpac(100, aclManagerID + '_panel');
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 622
}
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 623
else
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 624
{
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 625
setTimeout("document.getElementById('"+aclManagerID+"').style.display = 'block'; opacity('"+aclManagerID+"', 0, 100, 500); opacity('"+aclManagerID + '_panel'+"', 0, 100, 500);", 1000);
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 626
}
1
+ − 627
}
+ − 628
+ − 629
function killACLManager()
+ − 630
{
+ − 631
el = document.getElementById(aclManagerID);
+ − 632
if(el)
+ − 633
{
151
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 634
if ( aclDisableTransitionFX )
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 635
{
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 636
enlighten(true);
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 637
el.parentNode.removeChild(el);
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 638
}
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 639
else
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 640
{
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 641
opacity(aclManagerID, 100, 0, 500);
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 642
setTimeout('var el = document.getElementById(aclManagerID); el.parentNode.removeChild(el); enlighten();', 750);
824821224153
Added a new Javascript variable, aclDisableTransitionFX, that will switch off effects on message boxes and the ACL editor when set to true
Dan
diff
changeset
+ − 643
}
1
+ − 644
}
+ − 645
}
+ − 646
+ − 647
function __aclSubmitManager(form)
+ − 648
{
+ − 649
var thefrm = document.forms[form.name];
+ − 650
var modeobj = form_fetch_field(thefrm, 'mode');
+ − 651
if ( typeof(modeobj) == 'object' )
+ − 652
{
+ − 653
var mode = (thefrm.mode.value) ? thefrm.mode.value : 'cant_get';
+ − 654
}
+ − 655
else
+ − 656
{
+ − 657
var mode = '';
+ − 658
}
+ − 659
switch(mode)
+ − 660
{
+ − 661
case 'cant_get':
+ − 662
alert('BUG: can\'t get the state value from the form field.');
+ − 663
break;
+ − 664
case 'seltarget':
40
+ − 665
var target_type = parseInt(getRadioState(thefrm, 'target_type', ['1', '2']));
1
+ − 666
if(isNaN(target_type))
+ − 667
{
218
+ − 668
alert($lang.get('acl_err_pleaseselect_targettype'));
1
+ − 669
return false;
+ − 670
}
+ − 671
target_id = ( target_type == 1 ) ? parseInt(thefrm.group_id.value) : thefrm.username.value;
+ − 672
+ − 673
obj = { 'mode' : mode, 'target_type' : target_type, 'target_id' : target_id };
+ − 674
+ − 675
thispage = strToPageID(title);
+ − 676
do_scopesel = ( thispage[0] == aclDataCache.page_id && thispage[1] == aclDataCache.namespace );
+ − 677
+ − 678
if(do_scopesel)
+ − 679
{
40
+ − 680
scope = getRadioState(thefrm, 'scope', ['page', 'global']);
1
+ − 681
if(scope == 'page')
+ − 682
{
+ − 683
pageid = strToPageID(title);
+ − 684
obj['page_id'] = pageid[0];
+ − 685
obj['namespace'] = pageid[1];
+ − 686
}
+ − 687
else if(scope == 'global')
+ − 688
{
+ − 689
obj['page_id'] = false;
+ − 690
obj['namespace'] = false;
+ − 691
}
73
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 692
else if(scope == 'group')
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 693
{
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 694
obj['page_id'] = document.getElementById('enACL_pgsel_1048576').value;
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 695
obj['namespace'] = '__PageGroup';
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 696
}
1
+ − 697
else
+ − 698
{
+ − 699
alert('Invalid scope');
+ − 700
return false;
+ − 701
}
+ − 702
}
+ − 703
else
+ − 704
{
+ − 705
obj['page_id'] = aclDataCache.page_id;
+ − 706
obj['namespace'] = aclDataCache.namespace;
+ − 707
}
+ − 708
if(target_id == '')
+ − 709
{
218
+ − 710
alert($lang.get('acl_err_pleaseselect_username'));
1
+ − 711
return false;
+ − 712
}
+ − 713
__aclJSONSubmitAjaxHandler(obj);
+ − 714
break;
+ − 715
case 'save_edit':
+ − 716
case 'save_new':
+ − 717
var form = document.forms[aclManagerID + '_formobj'];
+ − 718
selections = new Object();
40
+ − 719
var dbg = '';
1
+ − 720
for(var i in aclPermList)
+ − 721
{
40
+ − 722
selections[aclPermList[i]] = getRadioState(form, aclPermList[i], [1, 2, 3, 4]);
+ − 723
dbg += aclPermList[i] + ': ' + selections[aclPermList[i]] + "\n";
+ − 724
if(!selections[aclPermList[i]])
1
+ − 725
{
40
+ − 726
alert("Invalid return from getRadioState: "+i+": "+selections[i]+" ("+typeof(selections[i])+")");
+ − 727
return false;
1
+ − 728
}
+ − 729
}
+ − 730
obj = new Object();
+ − 731
obj['perms'] = selections;
+ − 732
obj['mode'] = mode;
+ − 733
obj['target_type'] = aclDataCache.target_type;
+ − 734
obj['target_id'] = aclDataCache.target_id;
+ − 735
obj['target_name'] = aclDataCache.target_name;
+ − 736
obj['page_id'] = aclDataCache.page_id;
+ − 737
obj['namespace'] = aclDataCache.namespace;
+ − 738
__aclJSONSubmitAjaxHandler(obj);
+ − 739
break;
+ − 740
default:
+ − 741
alert("JSON form submit: invalid mode string "+mode+", stopping execution");
+ − 742
return false;
+ − 743
break;
+ − 744
}
+ − 745
}
+ − 746
40
+ − 747
function getRadioState(form, name, valArray)
1
+ − 748
{
40
+ − 749
// Konqueror/Safari fix
+ − 750
if ( form[name] )
+ − 751
{
+ − 752
var formitem = form[name];
+ − 753
if ( String(formitem) == '[object DOMNamedNodesCollection]' || is_Safari )
+ − 754
{
+ − 755
var i = 0;
+ − 756
var radios = new Array();
+ − 757
var radioids = new Array();
+ − 758
while(true)
+ − 759
{
+ − 760
var elem = formitem[i];
+ − 761
if ( !elem )
+ − 762
break;
+ − 763
radios.push(elem);
+ − 764
if ( !elem.id )
+ − 765
{
+ − 766
elem.id = 'autoRadioBtn_' + Math.floor(Math.random() * 1000000);
+ − 767
}
+ − 768
radioids.push(elem.id);
+ − 769
i++;
+ − 770
}
+ − 771
var cr;
+ − 772
for ( var i = 0; i < radios.length; i++ )
+ − 773
{
+ − 774
cr = document.getElementById(radioids[i]);
+ − 775
if ( cr.value == 'on' || cr.checked == true )
+ − 776
{
+ − 777
try {
+ − 778
return ( typeof ( valArray[i] ) != 'undefined' ) ? valArray[i] : false;
+ − 779
} catch(e) {
+ − 780
// alert('Didn\'t get value for index: ' + i);
+ − 781
return false;
+ − 782
}
+ − 783
}
+ − 784
}
+ − 785
return false;
+ − 786
}
+ − 787
}
1
+ − 788
inputs = form.getElementsByTagName('input');
+ − 789
radios = new Array();
+ − 790
for(var i in inputs)
+ − 791
{
+ − 792
if(inputs[i]) if(inputs[i].type == 'radio')
+ − 793
radios.push(inputs[i]);
+ − 794
}
+ − 795
for(var i in radios)
+ − 796
{
+ − 797
if(radios[i].checked && radios[i].name == name)
+ − 798
return radios[i].value;
+ − 799
}
+ − 800
return false;
+ − 801
}
+ − 802
40
+ − 803
function __aclSetAllRadios(val, valArray)
1
+ − 804
{
40
+ − 805
val = String(val);
+ − 806
var form = document.forms[aclManagerID + '_formobj'];
1
+ − 807
if (!form)
40
+ − 808
{
1
+ − 809
return false;
40
+ − 810
}
+ − 811
var inputs = form.getElementsByTagName('input');
+ − 812
var radios = new Array();
+ − 813
var dbg = '';
+ − 814
for(var i = 0; i < inputs.length; i++)
1
+ − 815
{
40
+ − 816
dbg += String(inputs[i]) + "\n";
1
+ − 817
if(inputs[i].type == 'radio')
+ − 818
radios.push(inputs[i]);
+ − 819
}
+ − 820
for(var i in radios)
+ − 821
{
+ − 822
if(radios[i].value == val)
+ − 823
radios[i].checked = true;
+ − 824
else
+ − 825
radios[i].checked = false;
+ − 826
}
+ − 827
}
+ − 828
+ − 829
function __aclDeleteRule()
+ − 830
{
42
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 831
if(!aclDataCache)
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 832
{
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 833
if ( window.console )
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 834
{
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 835
try{ console.error('ACL editor: can\'t load data cache on delete'); } catch(e) {};
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 836
}
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 837
return false;
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 838
}
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 839
if(aclDataCache.mode != 'seltarget' && aclDataCache.mode != 'save_new' && aclDataCache.mode != 'save_edit')
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 840
{
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 841
if ( window.console )
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 842
{
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 843
try{ console.error('ACL editor: wrong mode on aclDataCache: ' + aclDataCache.mode); } catch(e) {};
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 844
}
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 845
return false;
45ebe475ff75
I dunno how many times I'm gonna have to fix the "problem seems to be the hex conversion" bug, but this is at least the fourth try.
Dan
diff
changeset
+ − 846
}
1
+ − 847
parms = {
+ − 848
'target_type' : aclDataCache.target_type,
+ − 849
'target_id' : aclDataCache.target_id,
+ − 850
'target_name' : aclDataCache.target_name,
+ − 851
'page_id' : aclDataCache.page_id,
+ − 852
'namespace' : aclDataCache.namespace,
+ − 853
'mode' : 'delete'
+ − 854
};
+ − 855
__aclJSONSubmitAjaxHandler(parms);
+ − 856
}
+ − 857
+ − 858
function array_keys(obj)
+ − 859
{
+ − 860
keys = new Array();
+ − 861
for(var i in obj)
+ − 862
keys.push(i);
+ − 863
return keys;
+ − 864
}
+ − 865
+ − 866
function form_fetch_field(form, name)
+ − 867
{
+ − 868
var fields = form.getElementsByTagName('input');
+ − 869
if ( fields.length < 1 )
+ − 870
return false;
+ − 871
for ( var i = 0; i < fields.length; i++ )
+ − 872
{
+ − 873
var field = fields[i];
+ − 874
if ( field.name == name )
+ − 875
return field;
+ − 876
}
+ − 877
return false;
+ − 878
}
+ − 879