]> git.evergreen-ils.org Git - Evergreen.git/blob - Open-ILS/xul/staff_client/server/patron/ue_ui.js
added sanity check
[Evergreen.git] / Open-ILS / xul / staff_client / server / patron / ue_ui.js
1 /* -----------------------------------------------------------------------
2         UI code for the user editor.  Handles breaking up the components
3         into a wizard-like interface.
4         ----------------------------------------------------------------------- */
5
6
7 var pages = [ 
8         'uedit_userid', 
9         'uedit_contact_info', 
10         'uedit_addresses', 
11         'uedit_groups', 
12         'uedit_stat_cats', 
13         'uedit_surveys',
14         'uedit_finalize',
15         ];
16
17 /* ID's of objects that should be focused when their page is made visible */
18 var pageFocus = [
19         'ue_barcode',
20         'ue_email',
21         'ue_addr_label_1',
22         'ue_profile',
23         'ue_stat_cat_selector_1',
24         'ue_survey_selector_1',
25         'ue_view_summary'
26 ];
27
28
29 function uEditNext() {
30         var i = _findActive();
31         if( i < (pages.length - 1)) uEditShowPage(pages[i+1]);
32 }
33
34
35 function uEditPrev() {
36         var i = _findActive();
37         if( i > 0 ) uEditShowPage(pages[i-1]);
38 }
39
40 function uEditCheckErrors() {
41         var errors = uEditGetErrorStrings();
42         if(errors) unHideMe($('ue_errors'));
43         else hideMe($('ue_errors'));
44 }
45
46 /*
47 function uEditFetchError(id) { if($(id)) return $(id).innerHTML + "\n"; return "";}
48 */
49
50 function uEditShowPage(id) {
51         if( id == null ) return;
52
53         for( var p in pages ) {
54                 var page = pages[p];
55                 hideMe($(page));
56                 removeCSSClass($(page+'_label'), 'label_active');
57         }
58
59         var idx = _findPageIdx(id);
60
61         unHideMe($(id));
62         addCSSClass($(id+'_label'), 'label_active');
63         var fpage = pageFocus[idx];
64
65         var pnode = $(fpage);
66         if( id == 'uedit_addresses' ) 
67                 pnode = $n( $('ue_address_tbody').
68                         getElementsByTagName('tr')[0], 'ue_addr_label');
69
70         if(pnode) { 
71                 pnode.focus(); 
72                 try{pnode.select()}catch(e){} 
73         }
74
75         unHideMe($('ue_back'));
76         unHideMe($('ue_fwd'));
77
78         if(idx == 0) hideMe($('ue_back'));
79         if(idx == (pages.length-1)) hideMe($('ue_fwd'));
80 }
81
82 function _findActive() {
83         for( var p in pages ) {
84                 if(! $(pages[p]).className.match(/hide_me/) )
85                         return parseInt(p);
86         }
87         return null;
88 }
89
90 function _findPageIdx(name) {
91         for( var i in pages ) {
92                 var page = pages[i];
93                 if( page == name ) return i;
94         }
95         return -1;
96 }
97
98 /* ------------------------------------------------------------------------------ */
99 /* Below are the various UI components built from retrieved data */
100 /* ------------------------------------------------------------------------------ */
101
102
103 /* org selector */
104 function uEditBuildLibSelector( node, depth, selector ) {
105         if(!selector) selector = $('ue_org_selector');
106         if(!node) { depth = 0; node = globalOrgTree; }
107         var opt = insertSelectorVal( 
108                 selector, -1, node.name(), node.id(), null, depth++ );
109         if(!findOrgType(node.ou_type()).can_have_users()) opt.disabled = true; 
110         if( node.id() == USER.ws_ou() ) 
111                 setSelector(selector, node.id());
112
113         for( var c in node.children() ) 
114                 uEditBuildLibSelector(node.children()[c], depth, selector);
115 }
116
117
118 /* group tree selector */
119 function uEditDrawGroups(tree, depth, selector) {
120         if(!selector) {
121                 selector = $('ue_profile');
122                 depth = 0;
123         }
124         groupsCache[tree.id()] = tree;
125
126         /* if the staff does not have perms to access this group, 
127                 remove it from the tree and don't add it's children */
128         var perm = uEditFindGroupPerm(tree);
129         var org = PERMS[perm];
130         if( org == -1 ) return;
131
132         var opt = insertSelectorVal( selector, -1, tree.name(), tree.id(), null, depth++ );     
133
134         for( var c in tree.children() ) 
135                 uEditDrawGroups( tree.children()[c], depth, selector );
136 }
137
138
139 function uEditFindGroupPerm(group) {
140         if(!group) return null;
141         if( group.application_perm() ) 
142                 return group.application_perm();
143         return uEditFindGroupPerm(groupsCache[group.parent()]);
144 }
145
146
147 /* user identification types */
148 function uEditDrawIDTypes(types) {
149         var pri_sel = $('ue_primary_ident_type');
150         var sec_sel = $('ue_secondary_ident_type');
151         var idx = 1;
152         for( var t in types ) {
153                 var type = types[t];
154                 if(!type.name()) continue;
155                 identTypesCache[type.id()] = type;
156                 setSelectorVal( pri_sel, idx, type.name(), type.id() );
157                 setSelectorVal( sec_sel, idx++, type.name(), type.id() );
158         }
159 }
160
161 /* user statistical catagories */
162 function uEditDrawStatCats(cats) {
163         var tbody = $('ue_stat_cat_tbody');
164         var templ = tbody.removeChild($('ue_stat_cat_row'));
165
166         for( var c in cats ) {
167                 var row = templ.cloneNode(true);
168                 uEditInsertCat( row, cats[c], c );
169                 tbody.appendChild(row);
170         }
171 }
172
173
174 function uEditInsertCat( row, cat, idx ) {
175
176         cat.entries().sort(  /* sort the entries by value */
177                 function( a, b ) { 
178                         if( !a.value() ) return -1;
179                         if( !b.value() ) return 1;
180                         if( (a.value()+'').toLowerCase() > (b.value()+'').toLowerCase()) return 1;
181                         if( (a.value()+'').toLowerCase() < (b.value()+'').toLowerCase()) return -1;
182                         return 0;
183                 }
184         );
185
186         statCatsCache[cat.id()] = cat;
187
188         /* register the new map object */
189         uEditBuildSCMField(cat, row);
190
191         var newval = $n(row, 'ue_stat_cat_newval');
192         var selector = $n(row, 'ue_stat_cat_selector');
193
194         selector.onchange = function() { 
195                 newval.value = getSelectorVal(selector);
196                 if(newval.onchange) newval.onchange();
197         }
198
199         if( idx == 0 ) selector.id = 'ue_stat_cat_selector_1'; 
200
201         $n(row, 'ue_stat_cat_name').appendChild(text(cat.name()));
202         $n(row, 'ue_stat_cat_owner').appendChild(
203                 text(fetchOrgUnit(cat.owner()).shortname()));
204
205         for( var e in cat.entries() ) {
206                 var entry = cat.entries()[e];
207                 setSelectorVal( selector, 
208                         (parseInt(e)+1), entry.value(), entry.value() );
209         }
210 }
211
212 /* draw the surveys */
213 function uEditDrawSurveys(surveys) {
214
215         var div = $('uedit_surveys');
216         var table = div.removeChild($('ue_survey_table'));
217         if( surveys.length == 0 ) unHideMe($('uedit_no_surveys'));
218
219         for( var s in surveys ) {
220                 var survey = surveys[s];
221                 surveysCache[survey.id()] = survey;
222                 var clone = table.cloneNode(true);
223                 uEditInsertSurvey( div, clone, survey, s );
224                 div.appendChild(clone);
225         }
226 }
227
228 /* insert the servey then insert each of that surveys questions */
229 function uEditInsertSurvey( div, table, survey, sidx ) {
230
231         $n(table, 'ue_survey_name').appendChild(text(survey.name()));
232         $n(table, 'ue_survey_desc').appendChild(text(survey.description()));
233
234         var tbody = $n(table, 'ue_survey_tbody');
235         var templ = tbody.removeChild($n(table, 'ue_survey_row'));
236
237         for( var q in survey.questions() ) {
238                 var row = templ.cloneNode(true);
239                 var quest = survey.questions()[q];
240                 uEditInsertSurveyQuestion( row, survey, quest );
241                 tbody.appendChild(row);
242         }
243 }
244
245 function uEditInsertSurveyQuestion( row, survey, question ) {
246
247         var selector = $n(row, 'ue_survey_answer');
248         row.setAttribute('question', question.id());
249         $n(row, 'ue_survey_question').appendChild(text(question.question()));
250
251         for( var a in question.answers() ) {
252                 var answer = question.answers()[a];
253                 surveyAnswersCache[answer.id()] = answer;
254                 insertSelectorVal(selector, -1, answer.answer(), answer.id() );
255         }
256
257         surveyQuestionsCache[question.id()] = question;
258
259         if( patron.isnew() && isTrue(survey.required()) ) 
260                 addCSSClass(selector, 'invalid_value');
261
262         selector.onchange = function() {
263
264                 /* remove any existing responses for this survey */
265                 patron.survey_responses(
266                         grep( patron.survey_responses(),
267                                 function(item) {
268                                         return (item.survey() != survey.id());
269                                 }
270                         )
271                 );
272
273
274                 if(!patron.survey_responses())
275                         patron.survey_responses([]);
276
277                 var val = getSelectorVal(selector);
278
279                 if( patron.isnew() && isTrue(survey.required()) ) {
280                         if(val)
281                                 removeCSSClass(selector, 'invalid_value');
282                         else 
283                                 addCSSClass(selector, 'invalid_value');
284                 }
285
286                 if(!val) return;
287
288                 var resp        = new asvr();
289                 resp.isnew(1);
290                 resp.survey(survey.id());
291                 resp.usr(patron.id());
292                 resp.question(row.getAttribute('question'));
293                 resp.answer(val);
294                 patron.survey_responses().push( resp );
295         }
296 }
297
298
299
300
301
302 /* -----------------------------------------------------------------------
303         Spit out the patron info to the summary display tables...
304         ----------------------------------------------------------------------- */
305
306 function uEditShowSummary() {
307         hideMe($('main_div_container'));
308         unHideMe($('summary_div_container'));
309
310         for( var f in dataFields ) {
311
312                 var field = dataFields[f];
313                 if( field.object == patron ) {
314
315                         var val = uEditNodeVal(field);
316
317                         if(     field.key == 'profile'          ||
318                                         field.key == 'home_ou'          ||
319                                         field.key == 'ident_type'       ||
320                                         field.key == 'ident_type2') {
321
322                                 val = getSelectorName($(field.widget.id));
323                         }
324
325                         var node = $('ue_summary_'+field.key);
326                         if(node) appendClear(node, text(val));
327                 }
328
329                 if( field.object == patron.card() )
330                         appendClear($('ue_summary_barcode'), text(uEditNodeVal(field)));
331
332         }
333
334         var table = $('ue_summary_table');
335         uEditFleshSummaryAddresses( table, patron );
336         uEditFleshSummaryStatCats( table, patron );
337         uEditFleshSummarySurveys( table, patron );
338 }
339
340
341
342 var uEditSummaryAddrRow;
343 function uEditFleshSummaryAddresses( table, patron ) {
344
345         var addrtbody = $n(table, 'ue_summary_addr_tbody');
346         if(!uEditSummaryAddrRow)
347                 uEditSummaryAddrRow = 
348                         addrtbody.removeChild($n(addrtbody, 'ue_summary_addr_row'));
349         var rowtmpl = uEditSummaryAddrRow;
350         removeChildren(addrtbody);
351
352         for( var a in patron.addresses() ) {
353                 var address = patron.addresses()[a];
354                 var row = rowtmpl.cloneNode(true);
355                 uEditFleshSummaryAddr( address, patron, row );
356                 addrtbody.appendChild(row);
357                 if(address.isdeleted()) addCSSClass(row, 'deleted');
358         }
359 }
360
361
362 function uEditFleshSummaryAddr( address, patron, row ) {
363         var yes = $('yes').innerHTML;
364         var no = $('no').innerHTML;
365
366         $n(row, 'label').appendChild(text(address.address_type()));
367         $n(row, 'street1').appendChild(text(address.street1()));
368         $n(row, 'street2').appendChild(text(address.street2()));
369         $n(row, 'city').appendChild(text(address.city()));
370         $n(row, 'county').appendChild(text(address.county()));
371         $n(row, 'state').appendChild(text(address.state()));
372         $n(row, 'country').appendChild(text(address.country()));
373         $n(row, 'zip').appendChild(text(address.post_code()));
374         $n(row, 'valid').appendChild(text( (isTrue(address.valid())) ? yes : no ));
375         $n(row, 'incorporated').appendChild(text( (isTrue(address.within_city_limits())) ? yes : no ));
376
377         var mid = patron.mailing_address();
378         if( typeof patron.mailing_address() == 'object' ) 
379                 mid = patron.mailing_address().id();
380         $n(row, 'mailing').appendChild(text((mid == address.id()) ? yes : no ));
381
382         var bid = patron.billing_address();
383         if( typeof patron.billing_address() == 'object' ) 
384                 bid = patron.billing_address().id();
385         $n(row, 'billing').appendChild(text((bid == address.id()) ? yes : no ));
386 }
387
388
389
390 var uEditSummaryStatCatRow;
391 function uEditFleshSummaryStatCats( table, patron ) {
392         var tbody = $n(table, 'ue_summary_stats_tbody');
393
394         if(!uEditSummaryStatCatRow)
395                 uEditSummaryStatCatRow = 
396                         tbody.removeChild($n(tbody, 'ue_summary_stats_row'));
397         var rowtmpl = uEditSummaryStatCatRow;
398         removeChildren(tbody);
399
400         for( var s in patron.stat_cat_entries() ) {
401                 row = rowtmpl.cloneNode(true);
402                 var entry = patron.stat_cat_entries()[s];
403                 var cat = statCatsCache[entry.stat_cat()];
404                 $n(row, 'ue_summary_stat_name').appendChild(text(cat.name()));
405                 $n(row, 'ue_summary_stat_value').appendChild(text(entry.stat_cat_entry()));
406                 row.setAttribute('statcat', entry.stat_cat());
407                 if( entry.isdeleted() ) addCSSClass(row, 'deleted'); 
408                 tbody.appendChild(row);
409         }
410
411         if( ! getElementsByTagNameFlat( tbody, 'tr' )[0] )
412                 hideMe(tbody.parentNode);
413         else
414                 unHideMe(tbody.parentNode);
415 }
416
417
418
419 var uEditSummarySurveyRow;
420 function uEditFleshSummarySurveys( table, patron ) {
421
422         var tbody       = $n(table, 'ue_summary_survey_tbody');
423         if(!uEditSummarySurveyRow)
424                 uEditSummarySurveyRow = 
425                         tbody.removeChild($n(tbody, 'ue_summary_survey_row'));
426         var rowtmpl = uEditSummarySurveyRow;
427
428         removeChildren(tbody);
429
430         for( var r in patron.survey_responses() ) {
431                 var row         = rowtmpl.cloneNode(true);
432                 var resp                = patron.survey_responses()[r];
433                 var survey      = surveysCache[resp.survey()];
434                 var quest       = surveyQuestionsCache[resp.question()];
435                 var answer      = surveyAnswersCache[resp.answer()];
436                 $n(row, 'ue_summary_survey_name').appendChild(text(survey.name()));
437                 $n(row, 'ue_summary_survey_question').appendChild(text(quest.question()));
438                 $n(row, 'ue_summary_survey_answer').appendChild(text(answer.answer()));
439                 tbody.appendChild(row);
440         }
441
442         if( ! getElementsByTagNameFlat(tbody, 'tr')[0])
443                 hideMe(tbody.parentNode);
444         else
445                 unHideMe(tbody.parentNode);
446 }
447
448
449 function uEditDrawNetLevels(netLevels) {
450         var sel = $('ue_net_level');
451         iterate( netLevels, 
452                 function(i) {
453                         insertSelectorVal( sel, -1, i.name(), i.id() );
454                 }
455         );
456 }
457
458
459
460