1 function $(id) { return document.getElementById(id); }
4 JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.init({'via':'stash'});
6 case 'staff_id' : return data.list.au[0].id(); break;
7 case 'staff_usrname' : return data.list.au[0].usrname(); break;
9 return data.list.au[0].ws_ou();
12 return data.session.authtime;
16 return data.session.key;
21 function font_helper() {
23 JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.init({'via':'stash'});
24 removeCSSClass(document.documentElement,'ALL_FONTS_LARGER');
25 removeCSSClass(document.documentElement,'ALL_FONTS_SMALLER');
26 removeCSSClass(document.documentElement,'ALL_FONTS_XX_SMALL');
27 removeCSSClass(document.documentElement,'ALL_FONTS_X_SMALL');
28 removeCSSClass(document.documentElement,'ALL_FONTS_SMALL');
29 removeCSSClass(document.documentElement,'ALL_FONTS_MEDIUM');
30 removeCSSClass(document.documentElement,'ALL_FONTS_LARGE');
31 removeCSSClass(document.documentElement,'ALL_FONTS_X_LARGE');
32 removeCSSClass(document.documentElement,'ALL_FONTS_XX_LARGE');
33 addCSSClass(document.documentElement,data.global_font_adjust);
35 var Strings = $('offlineStrings') || $('commonStrings');
36 alert(Strings.getFormattedString('openils.global_util.font_size.error', [E]));
40 function persist_helper() {
42 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
43 var prefs = Components.classes['@mozilla.org/preferences-service;1'].getService(Components.interfaces['nsIPrefBranch']);
44 var nodes = document.getElementsByAttribute('oils_persist','*');
45 for (var i = 0; i < nodes.length; i++) {
46 var base_key = 'oils_persist_' + String(location.hostname + location.pathname + '_' + nodes[i].getAttribute('id')).replace('/','_','g') + '_';
47 var attribute_list = nodes[i].getAttribute('oils_persist').split(' ');
48 for (var j = 0; j < attribute_list.length; j++) {
49 var key = base_key + attribute_list[j];
50 var value = prefs.prefHasUserValue(key) ? prefs.getCharPref(key) : null;
51 dump('persist_helper: retrieving key = ' + key + ' value = ' + value + ' for ' + nodes[i].nodeName + '\n');
52 if (value) nodes[i].setAttribute( attribute_list[j], value );
54 if ( (nodes[i].nodeName == 'checkbox' || nodes[i].nodeName == 'menuitem') && attribute_list.indexOf('checked') > -1) {
55 if (nodes[i].disabled == false && nodes[i].hidden == false) {
56 var no_poke = nodes[i].getAttribute('oils_persist_no_poke');
57 if (no_poke && no_poke == 'true') {
58 // Timing issue for some checkboxes; don't poke them with an event
60 var evt = document.createEvent("Events");
61 evt.initEvent( 'command', true, true );
62 nodes[i].dispatchEvent(evt);
65 nodes[i].addEventListener(
70 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
71 var key = bk + 'checked';
73 if (ev.target.nodeName == 'checkbox') {
74 value = ev.target.checked;
76 value = ev.target.getAttribute('checked'); // menuitem with type="checkbox"
78 ev.target.setAttribute( 'checked', value );
79 prefs.setCharPref( key, value );
80 dump('persist_helper: setting key = ' + key + ' value = ' + value + ' for checkbox/menuitem\n');
82 alert('Error in persist_helper(), checkbox/menuitem command event listener: ' + E);
89 // TODO: Need to add event listeners for window resizing, splitter repositioning, grippy state, etc.
92 alert('Error in persist_helper(): ' + E);
98 for (var k in o) keys.push(k);
102 function get_contentWindow(frame) {
104 netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');
105 if (frame && frame.contentWindow) {
107 if (typeof frame.contentWindow.wrappedJSObject != 'undefined') {
108 return frame.contentWindow.wrappedJSObject;
111 var Strings = $('offlineStrings') || $('commonStrings');
112 alert(Strings.getFormattedString('openils.global_util.content_window_jsobject.error', [frame, E]));
114 return frame.contentWindow;
119 var Strings = $('offlineStrings') || $('commonStrings');
120 alert(Strings.getFormattedString('openils.global_util.content_window.error', [frame, E]));
124 function update_modal_xulG(v) {
126 JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.init({'via':'stash'});
127 var key = location.pathname + location.search + location.hash;
128 if (typeof data.modal_xulG_stack != 'undefined' && typeof data.modal_xulG_stack[key] != 'undefined') {
129 data.modal_xulG_stack[key][ data.modal_xulG_stack[key].length - 1 ] = v;
130 data.stash('modal_xulG_stack');
133 alert('FIXME: update_modal_xulG => ' + E);
137 function xul_param(param_name,_params) {
138 /* By default, this function looks for a CGI-style query param identified by param_name. If one isn't found, it then looks in xulG. If one still isn't found, and _params.stash_name is true, it looks in the global xpcom stash for the field identified by stash_name. If _params.concat is true, then it looks in all these places and concatenates the results. There are also options for converting JSON to javascript objects, and clearing the xpcom stash_name field after retrieval. Also added, ability to search a specific spot in the xpcom stash that implements a stack to hold xulG's for modal windows */
140 //dump('xul_param('+param_name+','+js2JSON(_params)+')\n');
141 var value = undefined; if (!_params) _params = {};
142 if (typeof _params.no_cgi == 'undefined') {
144 if (cgi.param(param_name)) {
145 var x = cgi.param(param_name);
146 //dump('\tfound via location.href = ' + x + '\n');
147 if (typeof _params.JSON2js_if_cgi != 'undefined') {
149 //dump('\tJSON2js = ' + x + '\n');
151 if (typeof _params.concat == 'undefined') {
152 //alert(param_name + ' x = ' + x);
156 if (value.constructor != Array) value = [ value ];
157 value = value.concat(x);
164 if (typeof _params.no_xulG == 'undefined') {
165 if (typeof _params.modal_xulG != 'undefined') {
166 JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.init({'via':'stash'});
167 var key = location.pathname + location.search + location.hash;
168 //dump('xul_param, considering modal key = ' + key + '\n');
169 if (typeof data.modal_xulG_stack != 'undefined' && typeof data.modal_xulG_stack[key] != 'undefined') {
170 xulG = data.modal_xulG_stack[key][ data.modal_xulG_stack[key].length - 1 ];
173 if (typeof xulG == 'object' && typeof xulG[ param_name ] != 'undefined') {
174 var x = xulG[ param_name ];
175 //dump('\tfound via xulG = ' + x + '\n');
176 if (typeof _params.JSON2js_if_xulG != 'undefined') {
178 //dump('\tJSON2js = ' + x + '\n');
180 if (typeof _params.concat == 'undefined') {
181 //alert(param_name + ' x = ' + x);
185 if (value.constructor != Array) value = [ value ];
186 value = value.concat(x);
193 if (typeof _params.no_xpcom == 'undefined') {
194 /* the field names used for temp variables in the global stash tend to be more unique than xuLG or CGI param names, to avoid collisions */
195 if (typeof _params.stash_name != 'undefined') {
196 JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.init({'via':'stash'});
197 if (typeof data[ _params.stash_name ] != 'undefined') {
198 var x = data[ _params.stash_name ];
199 //dump('\tfound via xpcom = ' + x + '\n');
200 if (typeof _params.JSON2js_if_xpcom != 'undefined') {
202 //dump('\tJSON2js = ' + x + '\n');
204 if (_params.clear_xpcom) {
205 data[ _params.stash_name ] = undefined; data.stash( _params.stash_name );
207 if (typeof _params.concat == 'undefined') {
208 //alert(param_name + ' x = ' + x);
212 if (value.constructor != Array) value = [ value ];
213 value = value.concat(x);
221 //alert(param_name + ' value = ' + value);
224 dump('xul_param error: ' + E + '\n');
228 function get_bool(a) {
229 // Normal javascript interpretation except 'f' == false, per postgres, and 'F' == false, and '0' == false (newer JSON is returning '0' instead of 0 in cases)
230 // So false includes 'f', '', '0', 0, null, and undefined
231 if (a == 'f') return false;
232 if (a == 'F') return false;
233 if (a == '0') return false;
234 if (a) return true; else return false;
237 function get_db_true() {
241 function get_db_false() {
245 function copy_to_clipboard(ev) {
247 netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');
249 if (typeof ev == 'object') {
250 if (typeof ev.target != 'undefined') {
251 if (typeof ev.target.textContent != 'undefined') if (ev.target.textContent) text = ev.target.textContent;
252 if (typeof ev.target.value != 'undefined') if (ev.target.value) text = ev.target.value;
254 } else if (typeof ev == 'string') {
257 const gClipboardHelper = Components.classes["@mozilla.org/widget/clipboardhelper;1"]
258 .getService(Components.interfaces.nsIClipboardHelper);
259 gClipboardHelper.copyString(text);
260 var Strings = $('offlineStrings') || $('commonStrings');
261 alert(Strings.getFormattedString('openils.global_util.clipboard', [text]));
263 var Strings = $('offlineStrings') || $('commonStrings');
264 alert(Strings.getFormattedString('openils.global_util.clipboard.error', [E]));
268 function clear_the_cache() {
270 netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');
271 var cacheClass = Components.classes["@mozilla.org/network/cache-service;1"];
272 var cacheService = cacheClass.getService(Components.interfaces.nsICacheService);
273 cacheService.evictEntries(Components.interfaces.nsICache.STORE_ON_DISK);
274 cacheService.evictEntries(Components.interfaces.nsICache.STORE_IN_MEMORY);
276 var Strings = $('offlineStrings') || $('commonStrings');
277 alert(Strings.getFormattedString('openils.global_util.clear_cache.error', [E]));
281 function toOpenWindowByType(inType, uri) {
282 var winopts = "chrome,extrachrome,menubar,resizable,scrollbars,status,toolbar";
283 window.open(uri, "_blank", winopts);
286 function url_prefix(url) {
287 if (url.match(/^\//)) url = urls.remote + url;
288 if (! url.match(/^(http|chrome):\/\//) && ! url.match(/^data:/) ) url = 'http://' + url;
289 dump('url_prefix = ' + url + '\n');