[open-ils-commits] r14165 - in trunk/Open-ILS: examples web/conify/global/actor (miker)

svn at svn.open-ils.org svn at svn.open-ils.org
Thu Sep 24 21:16:07 EDT 2009


Author: miker
Date: 2009-09-24 21:16:05 -0400 (Thu, 24 Sep 2009)
New Revision: 14165

Modified:
   trunk/Open-ILS/examples/fm_IDL.xml
   trunk/Open-ILS/web/conify/global/actor/org_unit.html
   trunk/Open-ILS/web/conify/global/actor/org_unit.js
Log:
Patch from Warren Layton at Laurentian university which addresses some issues
saving org unit data via the conify interfaces.

Thanks, Warren, and sorry for the delay.

M    Open-ILS/web/conify/global/actor/org_unit.js
M    Open-ILS/web/conify/global/actor/org_unit.html
M    Open-ILS/examples/fm_IDL.xml



Modified: trunk/Open-ILS/examples/fm_IDL.xml
===================================================================
--- trunk/Open-ILS/examples/fm_IDL.xml	2009-09-24 19:35:56 UTC (rev 14164)
+++ trunk/Open-ILS/examples/fm_IDL.xml	2009-09-25 01:16:05 UTC (rev 14165)
@@ -1511,14 +1511,14 @@
 			<field name="org_unit" oils_persist:virtual="true" reporter:datatype="org_unit"/>
 		</fields>
 		<links>
-			<link field="org_unit" reltype="might_have" key="id" map="" class="aou"/>
+			<link field="id" reltype="might_have" key="id" map="" class="aou"/>
 		</links>
         <permacrud xmlns="http://open-ils.org/spec/opensrf/IDL/permacrud/v1">
             <actions>
-                <create permission="CREATE_HOURS_OF_OPERATION" context_field="org_unit"/>
+                <create permission="CREATE_HOURS_OF_OPERATION" context_field="id"/>
                 <retrieve/>
-                <update permission="UPDATE_HOURS_OF_OPERATION" context_field="org_unit"/>
-                <delete permission="DELETE_HOURS_OF_OPERATION" context_field="org_unit"/>
+                <update permission="UPDATE_HOURS_OF_OPERATION" context_field="id"/>
+                <delete permission="DELETE_HOURS_OF_OPERATION" context_field="id"/>
             </actions>
         </permacrud>
 	</class>

Modified: trunk/Open-ILS/web/conify/global/actor/org_unit.html
===================================================================
--- trunk/Open-ILS/web/conify/global/actor/org_unit.html	2009-09-24 19:35:56 UTC (rev 14164)
+++ trunk/Open-ILS/web/conify/global/actor/org_unit.html	2009-09-25 01:16:05 UTC (rev 14165)
@@ -353,47 +353,37 @@
 										var modified_ou = new aou().fromStoreItem( current_ou );
 										modified_ou.isdeleted( 1 );
 	
-										pCRUD.request({
-											method : 'open-ils.pcrud.delete.aou',
+										pcrud.eliminate( modified_ou, {
 											timeout : 10,
-											params : [ ses, modified_ou ],
 											onerror : function (r) {
 												highlighter.editor_pane.red.play();
 												status_update(dojo.string.substitute(aou_strings.ERROR_DELETING, [old_name]));
 											},
 											oncomplete : function (r) {
-												var res = r.recv();
-												if ( res && res.content() ) {
-	
-													ou_list_store.fetch({
-														query : { id : ou_list_store.getValue( current_ou, 'id' ) },
-														queryOptions : { deep : true },
-														onItem : function (item, req) { try { if (this.isItem( item )) this.deleteItem( item ); } catch (e) { /* meh */ } },
-														scope : ou_list_store
-													});
-	
-													current_ou = null;
-	
-													new_kid_button.disabled = true;
-													save_ou_button.disabled = true;
-													delete_ou_button.disabled = true;
-			
-													var main_settings_fields = [ 'name', 'shortname', 'email', 'phone', 'ou_type', 'parent_ou' ];
-													for ( var i in main_settings_fields ) {
-														var field = main_settings_fields[i];
-														window["editor_pane_" + field].setValue( '' ); // unset the value
-														window["editor_pane_" + field].setDisplayedValue( '' ); // unset the value
-													}
-			
-													highlighter.editor_pane.green.play();
-													status_update(dojo.string.substitute(aou_strings.STATUS_DELETED, [old_name]));
-												} else {
-													highlighter.editor_pane.red.play();
-													status_update(dojo.string.substitute(aou_strings.ERROR_DELETING, [old_name]));
+												ou_list_store.fetch({
+													query : { id : ou_list_store.getValue( current_ou, 'id' ) },
+													queryOptions : { deep : true },
+													onItem : function (item, req) { try { if (this.isItem( item )) this.deleteItem( item ); } catch (e) { /* meh */ } },
+													scope : ou_list_store
+												});
+
+												current_ou = null;
+
+												new_kid_button.disabled = true;
+												save_ou_button.disabled = true;
+												delete_ou_button.disabled = true;
+
+												var main_settings_fields = [ 'name', 'shortname', 'email', 'phone', 'ou_type', 'parent_ou' ];
+												for ( var i in main_settings_fields ) {
+													var field = main_settings_fields[i];
+													window["editor_pane_" + field].setValue( '' ); // unset the value
+													window["editor_pane_" + field].setDisplayedValue( '' ); // unset the value
 												}
+
+												highlighter.editor_pane.green.play();
+												status_update(dojo.string.substitute(aou_strings.STATUS_DELETED, [old_name]));
 											}
-										}).send();
-	
+										});
 									}
 ]]>
 								</script>
@@ -418,10 +408,8 @@
 	
 								var new_obj;
 	
-								pCRUD.request({
-									method : 'open-ils.pcrud.create.aou',
+								pcrud.create( new_fm_obj, {
 									timeout : 10,
-									params : [ ses, new_fm_obj ],
 									onerror : function (r) {
 										highlighter.editor_pane.red.play();
 										status_update( aou_strings.ERROR_CREATING_CHILD_AOU );
@@ -437,8 +425,8 @@
 											highlighter.editor_pane.red.play();
 											status_update( aou_strings.ERROR_CREATING_CHILD_AOU );
 										}
-									},
-								}).send();
+									}
+								});
 	
 								highlighter.editor_pane.green.play();
 								highlighter.ou_tree.green.play();
@@ -490,30 +478,38 @@
 						</table>
 	
 						<button jsId="save_hoo_button" dojoType="dijit.form.Button" label="&conify.save_button.label;">
+                            <script type="dojo/connect" event="startup">
+                                this.disabled = true;
+                            </script>
 							<script type="dojo/connect" event="onClick">
 <![CDATA[
-								var method_name = 'open-ils.pcrud.update.aouhoo';
-								if (current_ou_hoo.isnew() == 1) method_name = 'open-ils.pcrud.create.aouhoo';
-	
-								pCRUD.request({
-									method : method_name,
-									params : [ ses, current_ou_hoo ],
-									onerror : function (r) {
-										highlighter.editor_pane.red.play();
-										status_update( dojo.string.substitute( aou_strings.ERROR_SAVING_HOO, [ou_list_store.getValue( current_ou, 'name' )] ) );
-									},
-									oncomplete : function (r) {
-										var res = r.recv();
-										if ( res && res.content() ) {
-											current_ou_hoo.isnew(0);
-											highlighter.editor_pane.green.play();
+								if (hoo_id.length == 0) {
+									pcrud.create( current_ou_hoo, {
+										timeout : 10,
+										onerror : function (r) {
+											highlighter.hoo_pane.red.play();
+											status_update( dojo.string.substitute( aou_strings.ERROR_SAVING_HOO, [ou_list_store.getValue( current_ou, 'name' )] ) );
+										},
+										oncomplete : function (r) {
+											hoo_id = pcrud.search( 'aouhoo',{id:ou_list_store.getValue( current_ou, 'id' )});
+											highlighter.hoo_pane.green.play();
 											status_update( dojo.string.substitute( aou_strings.SUCCESS_SAVING_HOO, [ou_list_store.getValue( current_ou, 'name' )] ) );
-										} else {
-											highlighter.editor_pane.red.play();
+										},
+									});
+								} else {
+									pcrud.update( current_ou_hoo, {
+										timeout : 10,
+										onerror : function (r) {
+											highlighter.hoo_pane.red.play();
 											status_update( dojo.string.substitute( aou_strings.ERROR_SAVING_HOO, [ou_list_store.getValue( current_ou, 'name' )] ) );
-										}
-									},
-								}).send();
+										},
+										oncomplete : function (r) {
+											highlighter.hoo_pane.green.play();
+											status_update( dojo.string.substitute( aou_strings.SUCCESS_SAVING_HOO, [ou_list_store.getValue( current_ou, 'name' )] ) );
+										},
+									});
+								}
+	
 ]]>
 							</script>
 						</button>

Modified: trunk/Open-ILS/web/conify/global/actor/org_unit.js
===================================================================
--- trunk/Open-ILS/web/conify/global/actor/org_unit.js	2009-09-24 19:35:56 UTC (rev 14164)
+++ trunk/Open-ILS/web/conify/global/actor/org_unit.js	2009-09-25 01:16:05 UTC (rev 14165)
@@ -42,7 +42,7 @@
 var pCRUD = new OpenSRF.ClientSession('open-ils.pcrud');
 var pcrud = new openils.PermaCrud({ authtoken : ses });
 
-var current_ou, current_ou_hoo, ou_list_store
+var current_ou, current_ou_hoo, ou_list_store, hoo_id;
 var dirtyStore = [];
 var virgin_ou_id = -1;
 
@@ -65,7 +65,7 @@
 	var modified_ou = new aou().fromStoreItem( current_ou );
 	modified_ou.ischanged( 1 );
 
-    pcrud.apply( modified_ou, {
+	pcrud.update( modified_ou, {
         timeout : 10, // makes it synchronous
 		onerror : function (r) {
 			highlighter.editor_pane.red.play();
@@ -87,46 +87,33 @@
 }
 	
 function hoo_load () {
-	// empty result not coming through ...
-	current_ou_hoo = new aouhoo().fromHash({id:ou_list_store.getValue( current_ou, 'id' )});
-	current_ou_hoo.isnew(1);
+	save_hoo_button.disabled = false;
 
-	pCRUD.request({
-		method : 'open-ils.pcrud.retrieve.aouhoo',
-		params : [ ses, ou_list_store.getValue( current_ou, 'id' ) ],
-		onerror : function (r) { 
-			throw dojo.string.substitute(aou_strings.ERROR_FETCHING_HOURS, [ou_list_store.getValue( current_ou, 'name' )]);
-		},
-		oncomplete : function (r) {
-			current_ou_hoo = null;
-
-			var res = r.recv();
-			if (res) {
-				if (res.content()) current_ou_hoo = res.content();
+	hoo_id = pcrud.search( 'aouhoo',{id:ou_list_store.getValue( current_ou, 'id' )});
+	if (hoo_id.length == 0) {
+		current_ou_hoo = new aouhoo().fromHash({id:ou_list_store.getValue( current_ou, 'id' )});
+		for (var i = 0; i < 7; i++) {
+			current_ou_hoo['dow_' + i + '_open']('09:00:00');
+			current_ou_hoo['dow_' + i + '_close']('17:00:00');
+		}
+	} else {
+		current_ou_hoo = pcrud.retrieve( 'aouhoo', ou_list_store.getValue( current_ou, 'id' ), {
+			onerror : function (r) {
+				throw dojo.string.substitute(aou_strings.ERROR_FETCHING_HOURS,[ou_list_store.getValue( current_ou, 'name' )]);
 			}
+		});
+	}
 
-			if (!current_ou_hoo) {
-				current_ou_hoo = new aouhoo().fromHash({id:ou_list_store.getValue( current_ou, 'id' )});
-				current_ou_hoo.isnew(1);
-				for (var i = 0; i < 7; i++) {
-					current_ou_hoo['dow_' + i + '_open']('09:00:00');
-					current_ou_hoo['dow_' + i + '_close']('17:00:00');
-				}
-			}
+	for (var i = 0; i < 7; i++) {
+		window['dow_' + i + '_open'].setValue(
+			dojo.date.stamp.fromISOString( 'T' + current_ou_hoo['dow_' + i + '_open']() )
+		);
+		window['dow_' + i + '_close'].setValue(
+			dojo.date.stamp.fromISOString( 'T' + current_ou_hoo['dow_' + i + '_close']() )
+		);
+	}
 
-			for (var i = 0; i < 7; i++) {
-				window['dow_' + i + '_open'].setValue(
-					dojo.date.stamp.fromISOString( 'T' + current_ou_hoo['dow_' + i + '_open']() )
-				);
-				window['dow_' + i + '_close'].setValue(
-					dojo.date.stamp.fromISOString( 'T' + current_ou_hoo['dow_' + i + '_close']() )
-				);
-			}
-
-			highlighter.hoo_pane.green.play();
-		}
-	}).send();
-
+	highlighter.hoo_pane.green.play();
 }
 
 function addr_load () {



More information about the open-ils-commits mailing list