[open-ils-commits] r14249 - in branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome: content/admin locale/en-US (phasefx)
svn at svn.open-ils.org
svn at svn.open-ils.org
Fri Oct 2 00:53:35 EDT 2009
Author: phasefx
Date: 2009-10-02 00:53:32 -0400 (Fri, 02 Oct 2009)
New Revision: 14249
Modified:
branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/content/admin/survey.js
branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/content/admin/survey_overlay.xul
branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/locale/en-US/offline.properties
Log:
backporting changeset 14244: Make the old survey wizard use work locations instead of home lib
Modified: branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/content/admin/survey.js
===================================================================
--- branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/content/admin/survey.js 2009-10-02 04:52:15 UTC (rev 14248)
+++ branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/content/admin/survey.js 2009-10-02 04:53:32 UTC (rev 14249)
@@ -4,53 +4,64 @@
var last_answer;
var last_button;
-function populate_lib_list_with_branch(menulist,menupopup,defaultlib,branch,id_flag) {
- JSAN.use('util.fm_utils');
- var default_menuitem;
- if (typeof defaultlib == 'object') {
- defaultlib = defaultlib.id();
- }
- var popup = menupopup;
- if (typeof(popup)!='object') popup = document.getElementById(menupopup);
- if (popup) {
- //empty_widget(popup);
- var padding_flag = true;
- var flat_branch = util.fm_utils.flatten_ou_branch( branch );
- for (var i in flat_branch) {
- var menuitem = document.createElement('menuitem');
- var padding = '';
- var depth = g.OpenILS.data.hash.aout[ flat_branch[i].ou_type() ].depth();
- if (padding_flag) {
- for (var j = 0; j < depth; j++) {
- padding = padding + ' ';
- }
- }
- menuitem.setAttribute('label', padding + flat_branch[i].name() );
- menuitem.setAttribute('value', flat_branch[i].id() );
- if (id_flag) menuitem.setAttribute('id', 'libitem' + flat_branch[i].id() );
- if (defaultlib == flat_branch[i].id()) {
- default_menuitem = menuitem;
- }
- popup.appendChild(menuitem);
- }
- var list = menulist;
- if (typeof(list)!='object') { list = document.getElementById(menulist); }
- if (list && defaultlib && default_menuitem) {
- if (list) { list.selectedItem = default_menuitem; }
- }
- } else {
- var err = ('populate_lib_list_with_branch: Could not find ' + menupopup + '\n');
- dump(err);
- alert(err);
- }
+function render_lib_menu() {
+ try {
+ JSAN.use('util.functional'); JSAN.use('util.fm_utils'); JSAN.use('util.widgets');
+
+ var work_ous = g.network.simple_request(
+ 'PERM_RETRIEVE_WORK_OU',
+ [ ses(), 'CREATE_SURVEY']
+ );
+ if (work_ous.length == 0) {
+ alert(document.getElementById('offlineStrings').getString('menu.cmd_survey_wizard.inadequate_perm'));
+ window.close();
+ return;
+ }
+ var my_libs = [];
+ for (var i = 0; i < work_ous.length; i++ ) {
+ var perm_depth = g.OpenILS.data.hash.aout[ g.OpenILS.data.hash.aou[ work_ous[i] ].ou_type() ].depth();
+
+ var my_libs_tree = g.network.simple_request(
+ 'FM_AOU_DESCENDANTS_RETRIEVE',
+ [ work_ous[i], perm_depth ]
+ );
+ if (!instanceOf(my_libs_tree,aou)) { /* FIXME - workaround for weird descendants call result */
+ my_libs_tree = my_libs_tree[0];
+ }
+ my_libs = my_libs.concat( util.fm_utils.flatten_ou_branch( my_libs_tree ) );
+ }
+
+ var x = document.getElementById('placeholder');
+ util.widgets.remove_children( x );
+
+ var default_lib = my_libs[0].id();
+
+ var ml = util.widgets.make_menulist(
+ util.functional.map_list(
+ my_libs,
+ function(obj) {
+ return [
+ obj.shortname(),
+ obj.id(),
+ false,
+ ( g.OpenILS.data.hash.aout[ obj.ou_type() ].depth() )
+ ];
+ }
+ ),
+ default_lib
+ );
+ ml.setAttribute('id','lib_menulist');
+
+ x.appendChild( ml );
+ } catch(E) {
+ alert('Error in survey.js, render_lib_menu(): ' + E);
+ }
}
function survey_init() {
dump('survey_init()\n');
- var user_ou = g.OpenILS.data.list.au[0].home_ou();
- var user_branch = g.OpenILS.data.hash.aou[ user_ou ];
- populate_lib_list_with_branch('lib_menulist','lib_menupopup',user_ou,user_branch);
+ render_lib_menu();
SURVEY['asv'] = new asv(); SURVEY['asv'].isnew('1');
SURVEY['num_of_questions'] = 0;
document.getElementById('survey_name').focus();
Modified: branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/content/admin/survey_overlay.xul
===================================================================
--- branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/content/admin/survey_overlay.xul 2009-10-02 04:52:15 UTC (rev 14248)
+++ branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/content/admin/survey_overlay.xul 2009-10-02 04:53:32 UTC (rev 14249)
@@ -21,9 +21,7 @@
<rows id="page1_grid1_rows">
<row id="page1_grid1_row1">
<label id="page1_row1_label1" value="&staff.admin.survey.available.label;" class="wizard_label"/>
- <menulist id="lib_menulist">
- <menupopup id="lib_menupopup"/>
- </menulist>
+ <hbox id="placeholder" />
</row>
<row id="page1_grid1_row2">
Modified: branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/locale/en-US/offline.properties
===================================================================
--- branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/locale/en-US/offline.properties 2009-10-02 04:52:15 UTC (rev 14248)
+++ branches/rel_1_4_0/Open-ILS/xul/staff_client/chrome/locale/en-US/offline.properties 2009-10-02 04:53:32 UTC (rev 14249)
@@ -186,4 +186,4 @@
openils.global_util.content_window_jsobject.error=Error with get_contentWindow(%1$s) and wrappedJSObject: %2$s
openils.global_util.content_window.error=Error with get_contentWindow(%1$s): %2$s
openils.global_util.font_size.error=Error adjusting the font size: %1$s
-
+menu.cmd_survey_wizard.inadequate_perm=You are lacking the CREATE_SURVEY permission and/or working locations.
More information about the open-ils-commits
mailing list