[open-ils-commits] r19543 - trunk/Open-ILS/xul/staff_client/server/admin (erickson)
svn at svn.open-ils.org
svn at svn.open-ils.org
Fri Feb 25 16:32:08 EST 2011
Author: erickson
Date: 2011-02-25 16:32:02 -0500 (Fri, 25 Feb 2011)
New Revision: 19543
Modified:
trunk/Open-ILS/xul/staff_client/server/admin/org_unit_settings.js
Log:
Updated org selector code in org setting UI
Removed some ad-hoc org-unit tree widget code and replaced with
the a standard solution from the openils dojo user lib.
Pass the auth on org value retrieval to pick up perm-protected settings.
Use STAFF_LOGIN for context selector perm, since each setting has its
own perm that is checked before fetching.
Modified: trunk/Open-ILS/xul/staff_client/server/admin/org_unit_settings.js
===================================================================
--- trunk/Open-ILS/xul/staff_client/server/admin/org_unit_settings.js 2011-02-25 19:14:02 UTC (rev 19542)
+++ trunk/Open-ILS/xul/staff_client/server/admin/org_unit_settings.js 2011-02-25 21:32:02 UTC (rev 19543)
@@ -19,7 +19,6 @@
var authtoken;
var contextOrg;
var user;
-var workOrgs;
var osSettings = {};
var ouSettingValues = {};
var osEditAutoWidget;
@@ -30,20 +29,8 @@
contextOrg = user.user.ws_ou();
openils.User.authtoken = authtoken;
- fieldmapper.standardRequest(
- [ 'open-ils.actor',
- 'open-ils.actor.user.get_work_ous.ids'],
- { async: true,
- params: [authtoken],
- oncomplete: function(r) {
- var list = r.recv().content();
- if(e = openils.Event.parse(list))
- return alert(e);
- workOrgs = list;
- buildMergedOrgSelector(list);
- }
- }
- );
+ var connect = function() { dojo.connect(contextOrg, 'onChange', osChangeContext); };
+ new openils.User().buildPermOrgSelector('STAFF_LOGIN', osContextSelector, null, connect);
osDraw();
}
@@ -81,7 +68,7 @@
[ 'open-ils.actor',
'open-ils.actor.ou_setting.ancestor_default.batch'],
{ async: true,
- params: [contextOrg, names],
+ params: [contextOrg, names, authtoken],
oncomplete: function(r) {
var data = r.recv().content();
if(e = openils.Event.parse(data))
@@ -95,58 +82,6 @@
);
}
-function insertTreePath(target,newPath,ifield,cfield) {
- var newTop = newPath.shift();
- var child = newPath[0];
-
- var subtarget = dojo.filter(target[cfield](), function (tc) {return tc[ifield]() == child[ifield]()});
-
- if (subtarget.length == 0) {
- target[cfield]().push(child);
- subtarget = [child];
- }
-
- if (newPath.length > 1) insertTreePath(subtarget[0],newPath,ifield,cfield);
-}
-
-function flattenTree(tree,cfield,sort_field,kill_kids,list) {
- if (!list) list = [];
- list.push(tree);
-
- var kids = tree[cfield]();
- if (sort_field) kids = kids.sort(function (a,b) { return a[sort_field]() > b[sort_field]() });
-
- dojo.forEach(kids, function (c) { return flattenTree(c,cfield,sort_field,kill_kids,list) });
-
- if (kill_kids) tree[cfield]([]);
- return list;
-}
-
-function buildMergedOrgSelector(orgList) {
- var orgTree;
- for(var i = 0; i < orgList.length; i++) {
- // add the work org path
- var node = fieldmapper.aou.findOrgUnit(orgList[i]).clone();
- node.children([]);
-
- var path = [node];
- while(node.parent_ou() != null) {
- node = fieldmapper.aou.findOrgUnit(node.parent_ou()).clone();
- node.children([]);
- path.push(node);
- }
-
- if (!orgTree) orgTree = path[0];
- insertTreePath(orgTree, path.reverse(), 'id', 'children');
-
- }
-
- var store = new dojo.data.ItemFileReadStore({data:aou.toStoreData(flattenTree(orgTree, 'children', 'shortname', true))});
- osContextSelector.store = store;
- osContextSelector.startup();
- osContextSelector.setValue(user.user.ws_ou());
-}
-
function osChangeContext() {
if(contextOrg == osContextSelector.getValue())
return;
More information about the open-ils-commits
mailing list