Updated org selector code in org setting UI
authorerickson <erickson@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Fri, 25 Feb 2011 21:33:10 +0000 (21:33 +0000)
committererickson <erickson@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Fri, 25 Feb 2011 21:33:10 +0000 (21:33 +0000)
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.

git-svn-id: svn://svn.open-ils.org/ILS/branches/rel_2_1@19544 dcc99617-32d9-48b4-a31d-7c20da2025e4

Open-ILS/xul/staff_client/server/admin/org_unit_settings.js

index e7e7243..b275eb7 100644 (file)
@@ -19,7 +19,6 @@ dojo.require('openils.widget.ProgressDialog');
 var authtoken;
 var contextOrg;
 var user;
-var workOrgs;
 var osSettings = {};
 var ouSettingValues = {};
 var osEditAutoWidget;
@@ -30,20 +29,8 @@ function osInit(data) {
     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 @@ function osDraw(specific_setting) {
         [   '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 osDraw(specific_setting) {
     );
 }
 
-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;