1 dump('entering cat.record_buckets.js\n');
3 if (typeof cat == 'undefined') cat = {};
4 cat.record_buckets = function (params) {
6 JSAN.use('util.error'); this.error = new util.error();
7 JSAN.use('util.network'); this.network = new util.network();
9 JSAN.use('OpenILS.data'); this.data = new OpenILS.data(); this.data.init({'via':'stash'});
12 cat.record_buckets.prototype = {
13 'selection_list1' : [],
14 'selection_list2' : [],
15 'bucket_id_name_map' : {},
17 'render_pending_records' : function() {
20 for (var i = 0; i < obj.record_ids.length; i++) {
21 var item = obj.flesh_item_for_list( obj.record_ids[i] );
22 if (item) obj.list1.append( item );
26 'init' : function( params ) {
30 obj.record_ids = params['record_ids'] || [];
32 JSAN.use('circ.util');
33 var columns = circ.util.columns(
35 'title' : { 'hidden' : false },
36 'author' : { 'hidden' : false },
37 'edition' : { 'hidden' : false },
38 'publisher' : { 'hidden' : false },
39 'pubdate' : { 'hidden' : false },
40 'isbn' : { 'hidden' : false },
41 'tcn' : { 'hidden' : false },
45 JSAN.use('util.list');
47 obj.list1 = new util.list('pending_records_list');
51 'map_row_to_column' : circ.util.std_map_row_to_column(),
52 'on_select' : function(ev) {
54 JSAN.use('util.functional');
55 var sel = obj.list1.retrieve_selection();
56 obj.selection_list1 = util.functional.map_list(
58 function(o) { return JSON2js(o.getAttribute('retrieve_id')); }
60 obj.error.sdump('D_TRACE','circ/record_buckets: selection list 1 = ' + js2JSON(obj.selection_list1) );
61 if (obj.selection_list1.length == 0) {
62 obj.controller.view.record_buckets_sel_add.disabled = true;
64 obj.controller.view.record_buckets_sel_add.disabled = false;
74 obj.render_pending_records();
76 obj.list2 = new util.list('records_in_bucket_list');
80 'map_row_to_column' : circ.util.std_map_row_to_column(),
81 'on_select' : function(ev) {
83 JSAN.use('util.functional');
84 var sel = obj.list2.retrieve_selection();
85 obj.selection_list2 = util.functional.map_list(
87 function(o) { return JSON2js(o.getAttribute('retrieve_id')); }
89 obj.error.sdump('D_TRACE','circ/record_buckets: selection list 2 = ' + js2JSON(obj.selection_list2) );
90 if (obj.selection_list2.length == 0) {
91 obj.controller.view.record_buckets_delete_item.disabled = true;
92 obj.controller.view.record_buckets_delete_item.setAttribute('disabled','true');
93 obj.controller.view.record_buckets_export.disabled = true;
94 obj.controller.view.record_buckets_export.setAttribute('disabled','true');
96 obj.controller.view.record_buckets_delete_item.disabled = false;
97 obj.controller.view.record_buckets_delete_item.setAttribute('disabled','false');
98 obj.controller.view.record_buckets_export.disabled = false;
99 obj.controller.view.record_buckets_export.setAttribute('disabled','false');
102 alert('FIXME: ' + E);
108 JSAN.use('util.controller'); obj.controller = new util.controller();
112 'record_buckets_menulist_placeholder' : [
116 JSAN.use('util.widgets'); JSAN.use('util.functional');
117 var buckets = obj.network.simple_request(
118 'BUCKET_RETRIEVE_VIA_USER',
119 [ ses(), obj.data.list.au[0].id() ]
121 if (typeof buckets.ilsevent != 'undefined') {
122 obj.error.standard_unexpected_error_alert('Could not retrieve your buckets.',buckets);
125 var items = [ ['Choose a bucket...',''] ].concat(
126 util.functional.map_list(
127 util.functional.filter_list(
130 return o.btype() == 'staff_client';
134 obj.bucket_id_name_map[ o.id() ] = o.name();
135 return [ o.name(), o.id() ];
139 g.error.sdump('D_TRACE','items = ' + js2JSON(items));
140 util.widgets.remove_children( e );
141 var ml = util.widgets.make_menulist(
145 ml.setAttribute('id','bucket_menulist');
146 ml.setAttribute('accesskey','');
148 function change_bucket(ev) {
149 var bucket_id = ev.target.value;
150 if (!bucket_id) return;
151 var bucket = obj.network.simple_request(
153 [ ses(), 'biblio', bucket_id ]
155 var items = bucket.items() || [];
157 for (var i = 0; i < items.length; i++) {
158 var item = obj.flesh_item_for_list(
159 items[i].target_biblio_record_entry(),
162 if (item) obj.list2.append( item );
166 ml.addEventListener( 'change_bucket', change_bucket , false);
167 ml.addEventListener( 'command', function() {
168 JSAN.use('util.widgets'); util.widgets.dispatch('change_bucket',ml);
170 obj.controller.view.bucket_menulist = ml;
171 JSAN.use('util.widgets'); util.widgets.dispatch('change_bucket',ml);
176 'record_buckets_add' : [
179 var bucket_id = obj.controller.view.bucket_menulist.value;
180 if (!bucket_id) return;
181 for (var i = 0; i < obj.record_ids.length; i++) {
182 var bucket_item = new cbrebi();
183 bucket_item.isnew('1');
184 bucket_item.bucket(bucket_id);
185 bucket_item.target_biblio_record_entry( obj.record_ids[i] );
187 var robj = obj.network.simple_request('BUCKET_ITEM_CREATE',
188 [ ses(), 'biblio', bucket_item ]);
190 if (typeof robj == 'object') throw robj;
192 var item = obj.flesh_item_for_list( obj.record_ids[i], robj );
195 obj.list2.append( item );
202 'record_buckets_sel_add' : [
205 var bucket_id = obj.controller.view.bucket_menulist.value;
206 if (!bucket_id) return;
207 for (var i = 0; i < obj.selection_list1.length; i++) {
208 var docid = obj.selection_list1[i].docid;
209 var bucket_item = new cbrebi();
210 bucket_item.isnew('1');
211 bucket_item.bucket(bucket_id);
212 bucket_item.target_biblio_record_entry( docid );
214 var robj = obj.network.simple_request('BUCKET_ITEM_CREATE',
215 [ ses(), 'biblio', bucket_item ]);
217 if (typeof robj == 'object') throw robj;
219 var item = obj.flesh_item_for_list( docid, robj );
222 obj.list2.append( item );
230 'record_buckets_export' : [
233 for (var i = 0; i < obj.selection_list2.length; i++) {
234 var docid = obj.selection_list2[i].docid;
235 var item = obj.flesh_item_for_list( docid );
237 obj.list1.append( item );
238 obj.record_ids.push( docid );
244 'record_buckets_delete_item' : [
247 for (var i = 0; i < obj.selection_list2.length; i++) {
249 var bucket_item_id = obj.selection_list2[i].bucket_item_id;
250 var robj = obj.network.simple_request('BUCKET_ITEM_DELETE',
251 [ ses(), 'biblio', bucket_item_id ]);
252 if (typeof robj == 'object') throw robj;
259 JSAN.use('util.widgets');
260 util.widgets.dispatch('change_bucket',obj.controller.view.bucket_menulist);
265 'record_buckets_delete_bucket' : [
269 var bucket = obj.controller.view.bucket_menulist.value;
270 var name = obj.bucket_id_name_map[ bucket ];
271 var conf = window.confirm('Delete the bucket named ' + name + '?');
274 var robj = obj.network.simple_request('BUCKET_DELETE',[ses(),'biblio',bucket]);
275 if (typeof robj == 'object') throw robj;
276 obj.controller.render('record_buckets_menulist_placeholder');
279 JSAN.use('util.widgets');
280 util.widgets.dispatch('change_bucket',obj.controller.view.bucket_menulist);
285 alert('FIXME -- ' + E);
289 'record_buckets_new_bucket' : [
293 var name = prompt('What would you like to name the bucket?','','Bucket Creation');
296 var bucket = new ccb();
297 bucket.btype('staff_client');
298 bucket.owner( obj.data.list.au[0].id() );
301 var robj = obj.network.simple_request('BUCKET_CREATE',[ses(),'biblio',bucket]);
303 if (typeof robj == 'object') throw robj;
305 obj.controller.render('record_buckets_menulist_placeholder');
306 obj.controller.view.bucket_menulist.value = robj;
309 JSAN.use('util.widgets');
310 util.widgets.dispatch('change_bucket',obj.controller.view.bucket_menulist);
319 'cmd_merge_records' : [
323 obj.data.stash_retrieve();
324 JSAN.use('util.functional');
326 var record_ids = util.functional.map_list(
327 obj.list2.dump_retrieve_ids(),
329 return JSON2js(o).docid; // docid
333 netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect UniversalBrowserWrite');
334 var top_xml = '<vbox xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul" flex="1" >';
335 top_xml += '<description>Merge these records? (Select the "lead" record first)</description>';
336 top_xml += '<hbox><button id="lead" disabled="true" label="Merge" name="fancy_submit"/><button label="Cancel" accesskey="C" name="fancy_cancel"/></hbox></vbox>';
338 var xml = '<form xmlns="http://www.w3.org/1999/xhtml">';
339 xml += '<table><tr valign="top">';
340 for (var i = 0; i < record_ids.length; i++) {
341 xml += '<td><input value="Lead" id="record_' + record_ids[i] + '" type="radio" name="lead"';
342 xml += ' onclick="' + "try { var x = document.getElementById('lead'); x.setAttribute('value',";
343 xml += record_ids[i] + '); x.disabled = false; } catch(E) { alert(E); }">';
344 xml += '</input>Lead Record? #' + record_ids[i] + '</td>';
346 xml += '</tr><tr valign="top">';
347 for (var i = 0; i < record_ids.length; i++) {
348 xml += '<td nowrap="nowrap"><iframe src="' + urls.XUL_BIB_BRIEF;
349 xml += '?docid=' + record_ids[i] + '"/></td>';
351 xml += '</tr><tr valign="top">';
352 for (var i = 0; i < record_ids.length; i++) {
353 html = obj.network.simple_request('MARC_HTML_RETRIEVE',[ record_ids[i] ]);
354 xml += '<td nowrap="nowrap"><iframe style="min-height: 1000px; min-width: 300px;" flex="1" src="data:text/html,' + window.escape(html) + '"/></td>';
356 xml += '</tr></table></form>';
357 obj.data.temp_merge_top = top_xml; obj.data.stash('temp_merge_top');
358 obj.data.temp_merge_mid = xml; obj.data.stash('temp_merge_mid');
360 urls.XUL_FANCY_PROMPT
361 + '?xml_in_stash=temp_merge_mid'
362 + '&top_xml_in_stash=temp_merge_top'
363 + '&title=' + window.escape('Record Merging'),
364 'fancy_prompt', 'chrome,resizable,modal,width=700,height=500'
366 obj.data.stash_retrieve();
367 if (obj.data.fancy_prompt_data == '') { alert('Merge Aborted'); return; }
368 var robj = obj.network.simple_request('MERGE_RECORDS',
371 obj.data.fancy_prompt_data.lead,
372 util.functional.filter_list( record_ids,
374 return o != obj.data.fancy_prompt_data.lead;
379 if (typeof robj.ilsevent != 'undefined') {
382 alert('Records were successfully merged.');
385 obj.render_pending_records(); // FIXME -- need a generic refresh for lists
388 JSAN.use('util.widgets');
389 util.widgets.dispatch('change_bucket',obj.controller.view.bucket_menulist);
393 obj.error.standard_unexpected_error_alert('Records were not likely merged.',E);
400 function() { alert('Not Yet Implemented'); }
402 'cmd_record_buckets_done' : [
412 JSAN.use('util.functional');
413 var docids = util.functional.map_list(
414 obj.list2.dump_retrieve_ids(),
416 return JSON2js(o).docid; // docid
419 for (var i = 0; i < docids.length; i++) {
420 var doc_id = docids[i];
421 var opac_url = xulG.url_prefix( urls.opac_rdetail ) + '?r=' + doc_id;
422 var content_params = {
424 'authtime' : ses('authtime'),
425 'opac_url' : opac_url,
428 xulG.url_prefix(urls.XUL_OPAC_WRAPPER),
429 {'tab_name':'Retrieving title...'},
434 obj.error.standard_unexpected_error_alert('Showing in OPAC',E);
442 this.controller.render();
444 if (typeof xulG == 'undefined') {
445 obj.controller.view.cmd_sel_opac.disabled = true;
446 obj.controller.view.cmd_sel_opac.setAttribute('disabled',true);
448 obj.controller.view.cmd_record_buckets_done.disabled = true;
449 obj.controller.view.cmd_record_buckets_done.setAttribute('disabled',true);
453 'flesh_item_for_list' : function(docid,bucket_item_id) {
456 var record = obj.network.simple_request( 'MODS_SLIM_RECORD_RETRIEVE', [ docid ]);
457 if (record == null || typeof(record.ilsevent) != 'undefined') {
461 'retrieve_id' : js2JSON( { 'docid' : docid, 'bucket_item_id' : bucket_item_id } ),
471 obj.error.standard_unexpected_error_alert('Could not retrieve this record: ' + docid,E);
479 dump('exiting cat.record_buckets.js\n');