toggle for displaying normal holds and cancelled holds in patron display
authorphasefx <phasefx@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Thu, 29 Oct 2009 19:46:48 +0000 (19:46 +0000)
committerphasefx <phasefx@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Thu, 29 Oct 2009 19:46:48 +0000 (19:46 +0000)
git-svn-id: svn://svn.open-ils.org/ILS/trunk@14682 dcc99617-32d9-48b4-a31d-7c20da2025e4

Open-ILS/web/opac/locale/en-US/lang.dtd
Open-ILS/xul/staff_client/chrome/content/main/constants.js
Open-ILS/xul/staff_client/server/patron/holds.js
Open-ILS/xul/staff_client/server/patron/holds_overlay.xul

index 687f6e7..6a754d4 100644 (file)
 <!ENTITY staff.patron.holds_overlay.print.accesskey "P">
 <!ENTITY staff.patron.holds_overlay.place_hold.label "Place Hold">
 <!ENTITY staff.patron.holds_overlay.place_hold.accesskey "H">
+<!ENTITY staff.patron.holds_overlay.show_cancelled_holds.label "Show Cancelled Holds">
+<!ENTITY staff.patron.holds_overlay.show_cancelled_holds.accesskey "">
+<!ENTITY staff.patron.holds_overlay.show_uncancelled_holds.label "Show Un-Cancelled Holds">
+<!ENTITY staff.patron.holds_overlay.show_uncancelled_holds.accesskey "">
 <!ENTITY staff.patron.info_group.clone.label "Register a New Group Member by Cloning Selected Patrons">
 <!ENTITY staff.patron.info_group.clone.accesskey "N">
 <!ENTITY staff.patron.info_group.remove.accesskey "R">
index abaf7e7..d2911e2 100644 (file)
@@ -102,6 +102,8 @@ const api = {
     'FM_AHR_RETRIEVE_VIA_AU' : { 'app' : 'open-ils.circ', 'method' : 'open-ils.circ.holds.retrieve' },
     'FM_AHR_ID_LIST_RETRIEVE_VIA_AU' : { 'app' : 'open-ils.circ', 'method' : 'open-ils.circ.holds.id_list.retrieve' },
     'FM_AHR_ID_LIST_RETRIEVE_VIA_AU.authoritative' : { 'app' : 'open-ils.circ', 'method' : 'open-ils.circ.holds.id_list.retrieve.authoritative' },
+    'FM_AHR_CANCELLED_ID_LIST_RETRIEVE_VIA_AU' : { 'app' : 'open-ils.circ', 'method' : 'open-ils.circ.holds.canceled.id_list.retrieve' },
+    'FM_AHR_CANCELLED_ID_LIST_RETRIEVE_VIA_AU.authoritative' : { 'app' : 'open-ils.circ', 'method' : 'open-ils.circ.holds.canceled.id_list.retrieve.authoritative' },
     'FM_AHR_RETRIEVE_VIA_BRE' : { 'app' : 'open-ils.circ', 'method' : 'open-ils.circ.open_holds.retrieve' },
     'FM_AHR_RETRIEVE_ALL_VIA_BRE' : { 'app' : 'open-ils.circ', 'method' : 'open-ils.circ.holds.retrieve_all_from_title' },
     'FM_AHR_RETRIEVE_VIA_PICKUP_AOU' : { 'app' : 'open-ils.circ', 'method' : 'open-ils.circ.holds.retrieve_by_pickup_lib' },
index 27039db..7181b1e 100644 (file)
@@ -229,6 +229,30 @@ patron.holds.prototype = {
                             }
                         },
                     ],
+                    'cmd_cancelled_holds_view' : [
+                        ['command'],
+                        function(ev) {
+                            document.getElementById('show_cancelled_deck').selectedIndex = 1;
+                            /* For some reason attribute propogation on the <command> element isn't working with hidden */
+                            document.getElementById('holds_cancel_btn').setAttribute('hidden','true');
+                            document.getElementById('holds_uncancel_btn').setAttribute('hidden','false');
+                            document.getElementById('holds_cancel_btn2').setAttribute('hidden','true');
+                            document.getElementById('holds_uncancel_btn2').setAttribute('hidden','false');
+                            obj.clear_and_retrieve();
+                        }
+                    ],
+                    'cmd_uncancelled_holds_view' : [
+                        ['command'],
+                        function(ev) {
+                            document.getElementById('show_cancelled_deck').selectedIndex = 0;
+                            /* For some reason attribute propogation on the <command> element isn't working with hidden */
+                            document.getElementById('holds_cancel_btn').setAttribute('hidden','false');
+                            document.getElementById('holds_uncancel_btn').setAttribute('hidden','true');
+                            document.getElementById('holds_cancel_btn2').setAttribute('hidden','false');
+                            document.getElementById('holds_uncancel_btn2').setAttribute('hidden','true');
+                            obj.clear_and_retrieve();
+                        }
+                    ],
                     'sel_mark_items_damaged' : [
                         ['command'],
                         function() {
@@ -1032,6 +1056,7 @@ patron.holds.prototype = {
         var x_lib_type_menu = document.getElementById('lib_type_menu');
         var x_lib_menu_placeholder = document.getElementById('lib_menu_placeholder');
         var x_lib_filter_checkbox = document.getElementById('lib_filter_checkbox');
+        var x_show_cancelled_deck = document.getElementById('show_cancelled_deck');
         switch(obj.hold_interface_type) {
             case 'shelf':
                 obj.render_lib_menus({'pickup_lib':true});
@@ -1054,6 +1079,7 @@ patron.holds.prototype = {
                 if (x_fetch_more) x_fetch_more.hidden = true;
                 if (x_lib_type_menu) x_lib_type_menu.hidden = true;
                 if (x_lib_menu_placeholder) x_lib_menu_placeholder.hidden = true;
+                if (x_show_cancelled_deck) x_show_cancelled_deck.hidden = false;
             break;
         }
         setTimeout( // We do this because render_lib_menus above creates and appends a DOM node, but until this thread exits, it doesn't really happen
@@ -1076,6 +1102,7 @@ patron.holds.prototype = {
                 obj.controller.view.cmd_alt_view.setAttribute('disabled','true');
                 obj.controller.view.cmd_holds_retarget.setAttribute('disabled','true');
                 obj.controller.view.cmd_holds_cancel.setAttribute('disabled','true');
+                obj.controller.view.cmd_holds_uncancel.setAttribute('disabled','true');
                 obj.controller.view.cmd_show_catalog.setAttribute('disabled','true');
             }, 0
         );
@@ -1131,7 +1158,11 @@ patron.holds.prototype = {
             var method; var params = [ ses() ];
             switch(obj.hold_interface_type) {
                 case 'patron' :
-                    method = 'FM_AHR_ID_LIST_RETRIEVE_VIA_AU.authoritative';
+                    if (document.getElementById('show_cancelled_deck').selectedIndex == 0) {
+                        method = 'FM_AHR_ID_LIST_RETRIEVE_VIA_AU.authoritative';
+                    } else {
+                        method = 'FM_AHR_CANCELLED_ID_LIST_RETRIEVE_VIA_AU.authoritative';
+                    }
                     params.push( obj.patron_id );
                     obj.controller.view.cmd_retrieve_patron.setAttribute('hidden','true');
                 break;
index 3844548..5ab5d32 100644 (file)
@@ -36,6 +36,8 @@
     <command id="cmd_search_opac" />
     <command id="save_columns" />
     <command id="cmd_alt_view" />
+    <command id="cmd_cancelled_holds_view" />
+    <command id="cmd_uncancelled_holds_view" />
     </commandset>
 
     <popupset id="holds_popupset">
@@ -61,8 +63,8 @@
         <menuitem command="sel_mark_items_damaged" label="&staff.circ.holds.mark_item_damaged;" accesskey="&staff.circ.holds.mark_item_damaged.accesskey;"/>
         <menuitem command="sel_mark_items_missing" label="&staff.circ.holds.mark_item_missing;" accesskey="&staff.circ.holds.mark_item_missing.accesskey;"/>
         <menuitem label="&staff.circ.holds.retarget;" command="cmd_holds_retarget" accesskey="&staff.circ.holds.retarget.accesskey;"/>
-        <menuitem label="&staff.circ.holds.cancel;" command="cmd_holds_cancel" accesskey="&staff.circ.holds.cancel.accesskey;"/>
-        <menuitem label="&staff.circ.holds.uncancel;" command="cmd_holds_uncancel" accesskey="&staff.circ.holds.uncancel.accesskey;"/>
+        <menuitem id="holds_cancel_btn" label="&staff.circ.holds.cancel;" command="cmd_holds_cancel" accesskey="&staff.circ.holds.cancel.accesskey;"/>
+        <menuitem id="holds_uncancel_btn" hidden="true" label="&staff.circ.holds.uncancel;" command="cmd_holds_uncancel" accesskey="&staff.circ.holds.uncancel.accesskey;"/>
         <menuseparator />
         <menuitem command="save_columns" label="&staff.circ.holds.save_columns;" accesskey="&staff.circ.holds.save_columns.accesskey;"/>
     </popup>
             </menupopup>
         </menulist>
         <vbox id="lib_menu_placeholder" hidden="true"/>
+        <deck id="show_cancelled_deck" hidden="true">
+            <button command="cmd_cancelled_holds_view" label="&staff.patron.holds_overlay.show_cancelled_holds.label;" accesskey="&staff.patron.holds_overlay.show_cancelled_holds.accesskey;"/>
+            <button command="cmd_uncancelled_holds_view" label="&staff.patron.holds_overlay.show_uncancelled_holds.label;" accesskey="&staff.patron.holds_overlay.show_uncancelled_holds.accesskey;"/>
+        </deck>
         <button id="fetch_more" label="&staff.patron.holds_overlay.fetch_more.label;" accesskey="&staff.patron.holds_overlay.fetch_more.accesskey;" hidden="true"/>
     <spacer flex="1"/>
         <progressmeter id="progress" type="determined" hidden="true" />
                     <menuitem command="sel_mark_items_damaged" label="&staff.circ.holds.mark_item_damaged;" accesskey="&staff.circ.holds.mark_item_damaged.accesskey;"/>
                     <menuitem command="sel_mark_items_missing" label="&staff.circ.holds.mark_item_missing;" accesskey="&staff.circ.holds.mark_item_missing.accesskey;"/>
                     <menuitem label="&staff.circ.holds.retarget;" command="cmd_holds_retarget" accesskey="&staff.circ.holds.retarget.accesskey;"/>
-                    <menuitem label="&staff.circ.holds.cancel;" command="cmd_holds_cancel" accesskey="&staff.circ.holds.cancel.accesskey;"/>
-                    <menuitem label="&staff.circ.holds.uncancel;" command="cmd_holds_uncancel" accesskey="&staff.circ.holds.uncancel.accesskey;"/>
+                    <menuitem id="holds_cancel_btn2" label="&staff.circ.holds.cancel;" command="cmd_holds_cancel" accesskey="&staff.circ.holds.cancel.accesskey;"/>
+                    <menuitem id="holds_uncancel_btn2" hidden="true" label="&staff.circ.holds.uncancel;" command="cmd_holds_uncancel" accesskey="&staff.circ.holds.uncancel.accesskey;"/>
                     <menuseparator />
                     <menuitem command="save_columns" label="&staff.circ.holds.save_columns;" accesskey="&staff.circ.holds.save_columns.accesskey;"/>
                 </menupopup>