1 /* -----------------------------------------------------------------------
2 UI code for the user editor. Handles breaking up the components
3 into a wizard-like interface.
4 ----------------------------------------------------------------------- */
17 /* ID's of objects that should be focused when their page is made visible */
23 'ue_stat_cat_selector_1',
24 'ue_survey_selector_1',
29 function uEditNext() {
30 var i = _findActive();
31 if( i < (pages.length - 1)) uEditShowPage(pages[i+1]);
35 function uEditPrev() {
36 var i = _findActive();
37 if( i > 0 ) uEditShowPage(pages[i-1]);
40 function uEditCheckErrors() {
41 var errors = uEditGetErrorStrings();
42 if(errors) unHideMe($('ue_errors'));
43 else hideMe($('ue_errors'));
47 function uEditFetchError(id) { if($(id)) return $(id).innerHTML + "\n"; return "";}
50 function uEditShowPage(id) {
51 if( id == null ) return;
53 for( var p in pages ) {
56 removeCSSClass($(page+'_label'), 'label_active');
59 var idx = _findPageIdx(id);
62 addCSSClass($(id+'_label'), 'label_active');
63 var fpage = pageFocus[idx];
66 if( id == 'uedit_addresses' )
67 pnode = $n( $('ue_address_tbody').
68 getElementsByTagName('tr')[0], 'ue_addr_label');
72 try{pnode.select()}catch(e){}
75 unHideMe($('ue_back'));
76 unHideMe($('ue_fwd'));
78 if(idx == 0) hideMe($('ue_back'));
79 if(idx == (pages.length-1)) hideMe($('ue_fwd'));
82 function _findActive() {
83 for( var p in pages ) {
84 if(! $(pages[p]).className.match(/hide_me/) )
90 function _findPageIdx(name) {
91 for( var i in pages ) {
93 if( page == name ) return i;
98 /* ------------------------------------------------------------------------------ */
99 /* Below are the various UI components built from retrieved data */
100 /* ------------------------------------------------------------------------------ */
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());
113 for( var c in node.children() )
114 uEditBuildLibSelector(node.children()[c], depth, selector);
118 /* group tree selector */
119 function uEditDrawGroups(tree, depth, selector, drawme) {
121 selector = $('ue_profile');
124 groupsCache[tree.id()] = tree;
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 ) drawme = false;
133 var opt = insertSelectorVal( selector, -1, tree.name(), tree.id(), null, depth++ );
134 if(!isTrue(tree.usergroup())) opt.disabled = true;
137 for( var c in tree.children() )
138 uEditDrawGroups( tree.children()[c], depth, selector, drawme );
142 function uEditFindGroupPerm(group) {
143 if(!group) return null;
144 if( group.application_perm() )
145 return group.application_perm();
146 return uEditFindGroupPerm(groupsCache[group.parent()]);
150 /* user identification types */
151 function uEditDrawIDTypes(types) {
152 var pri_sel = $('ue_primary_ident_type');
153 //var sec_sel = $('ue_secondary_ident_type');
155 for( var t in types ) {
157 if(!type.name()) continue;
158 identTypesCache[type.id()] = type;
159 setSelectorVal( pri_sel, idx, type.name(), type.id() );
160 //setSelectorVal( sec_sel, idx++, type.name(), type.id() );
165 /* user statistical catagories */
166 function uEditDrawStatCats(cats) {
167 var tbody = $('ue_stat_cat_tbody');
168 var templ = tbody.removeChild($('ue_stat_cat_row'));
170 for( var c in cats ) {
171 var row = templ.cloneNode(true);
172 uEditInsertCat( row, cats[c], c );
173 tbody.appendChild(row);
178 function uEditInsertCat( row, cat, idx ) {
180 cat.entries().sort( /* sort the entries by value */
182 if( !a.value() ) return -1;
183 if( !b.value() ) return 1;
184 if( (a.value()+'').toLowerCase() > (b.value()+'').toLowerCase()) return 1;
185 if( (a.value()+'').toLowerCase() < (b.value()+'').toLowerCase()) return -1;
190 statCatsCache[cat.id()] = cat;
192 /* register the new map object */
193 uEditBuildSCMField(cat, row);
195 var newval = $n(row, 'ue_stat_cat_newval');
196 var selector = $n(row, 'ue_stat_cat_selector');
198 selector.onchange = function() {
199 newval.value = getSelectorVal(selector);
200 if(newval.onchange) newval.onchange();
203 if( idx == 0 ) selector.id = 'ue_stat_cat_selector_1';
205 $n(row, 'ue_stat_cat_name').appendChild(text(cat.name()));
206 $n(row, 'ue_stat_cat_owner').appendChild(
207 text(fetchOrgUnit(cat.owner()).shortname()));
209 for( var e in cat.entries() ) {
210 var entry = cat.entries()[e];
211 setSelectorVal( selector,
212 (parseInt(e)+1), entry.value(), entry.value() );
216 /* draw the surveys */
217 function uEditDrawSurveys(surveys) {
219 var div = $('uedit_surveys');
220 var table = div.removeChild($('ue_survey_table'));
221 if( surveys.length == 0 ) unHideMe($('uedit_no_surveys'));
223 for( var s in surveys ) {
224 var survey = surveys[s];
225 surveysCache[survey.id()] = survey;
226 var clone = table.cloneNode(true);
227 uEditInsertSurvey( div, clone, survey, s );
228 div.appendChild(clone);
232 /* insert the servey then insert each of that surveys questions */
233 function uEditInsertSurvey( div, table, survey, sidx ) {
235 $n(table, 'ue_survey_name').appendChild(text(survey.name()));
236 $n(table, 'ue_survey_desc').appendChild(text(survey.description()));
238 var tbody = $n(table, 'ue_survey_tbody');
239 var templ = tbody.removeChild($n(table, 'ue_survey_row'));
241 for( var q in survey.questions() ) {
242 var row = templ.cloneNode(true);
243 var quest = survey.questions()[q];
244 uEditInsertSurveyQuestion( row, survey, quest );
245 tbody.appendChild(row);
249 function uEditInsertSurveyQuestion( row, survey, question ) {
251 var selector = $n(row, 'ue_survey_answer');
252 row.setAttribute('question', question.id());
253 $n(row, 'ue_survey_question').appendChild(text(question.question()));
255 for( var a in question.answers() ) {
256 var answer = question.answers()[a];
257 surveyAnswersCache[answer.id()] = answer;
258 insertSelectorVal(selector, -1, answer.answer(), answer.id() );
261 surveyQuestionsCache[question.id()] = question;
263 if( patron.isnew() && isTrue(survey.required()) )
264 addCSSClass(selector, 'invalid_value');
266 selector.onchange = function() {
268 /* remove any existing responses for this survey */
269 patron.survey_responses(
270 grep( patron.survey_responses(),
272 return (item.survey() != survey.id());
278 if(!patron.survey_responses())
279 patron.survey_responses([]);
281 var val = getSelectorVal(selector);
283 if( patron.isnew() && isTrue(survey.required()) ) {
285 removeCSSClass(selector, 'invalid_value');
287 addCSSClass(selector, 'invalid_value');
293 var resp = new asvr();
295 resp.survey(survey.id());
296 resp.usr(patron.id());
297 resp.question(row.getAttribute('question'));
299 patron.survey_responses().push( resp );
307 /* -----------------------------------------------------------------------
308 Spit out the patron info to the summary display tables...
309 ----------------------------------------------------------------------- */
311 function uEditShowSummary() {
312 hideMe($('main_div_container'));
313 unHideMe($('summary_div_container'));
315 for( var f in dataFields ) {
317 var field = dataFields[f];
318 if( field.object == patron ) {
320 var val = uEditNodeVal(field);
322 if( field.key == 'profile' ||
323 field.key == 'home_ou' ||
324 field.key == 'ident_type' ||
325 field.key == 'ident_type2') {
327 val = getSelectorName($(field.widget.id));
330 var node = $('ue_summary_'+field.key);
331 if(node) appendClear(node, text(val));
334 if( field.object == patron.card() )
335 appendClear($('ue_summary_barcode'), text(uEditNodeVal(field)));
339 var table = $('ue_summary_table');
340 uEditFleshSummaryAddresses( table, patron );
341 uEditFleshSummaryStatCats( table, patron );
342 uEditFleshSummarySurveys( table, patron );
347 var uEditSummaryAddrRow;
348 function uEditFleshSummaryAddresses( table, patron ) {
350 var addrtbody = $n(table, 'ue_summary_addr_tbody');
351 if(!uEditSummaryAddrRow)
352 uEditSummaryAddrRow =
353 addrtbody.removeChild($n(addrtbody, 'ue_summary_addr_row'));
354 var rowtmpl = uEditSummaryAddrRow;
355 removeChildren(addrtbody);
357 for( var a in patron.addresses() ) {
358 var address = patron.addresses()[a];
359 var row = rowtmpl.cloneNode(true);
360 uEditFleshSummaryAddr( address, patron, row );
361 addrtbody.appendChild(row);
362 if(address.isdeleted()) addCSSClass(row, 'deleted');
367 function uEditFleshSummaryAddr( address, patron, row ) {
368 var yes = $('yes').innerHTML;
369 var no = $('no').innerHTML;
371 $n(row, 'label').appendChild(text(address.address_type()));
372 $n(row, 'street1').appendChild(text(address.street1()));
373 $n(row, 'street2').appendChild(text(address.street2()));
374 $n(row, 'city').appendChild(text(address.city()));
375 $n(row, 'county').appendChild(text(address.county()));
376 $n(row, 'state').appendChild(text(address.state()));
377 $n(row, 'country').appendChild(text(address.country()));
378 $n(row, 'zip').appendChild(text(address.post_code()));
379 $n(row, 'valid').appendChild(text( (isTrue(address.valid())) ? yes : no ));
380 $n(row, 'incorporated').appendChild(text( (isTrue(address.within_city_limits())) ? yes : no ));
382 var mid = patron.mailing_address();
383 if( typeof patron.mailing_address() == 'object' )
384 mid = patron.mailing_address().id();
385 $n(row, 'mailing').appendChild(text((mid == address.id()) ? yes : no ));
387 var bid = patron.billing_address();
388 if( typeof patron.billing_address() == 'object' )
389 bid = patron.billing_address().id();
390 $n(row, 'billing').appendChild(text((bid == address.id()) ? yes : no ));
395 var uEditSummaryStatCatRow;
396 function uEditFleshSummaryStatCats( table, patron ) {
397 var tbody = $n(table, 'ue_summary_stats_tbody');
399 if(!uEditSummaryStatCatRow)
400 uEditSummaryStatCatRow =
401 tbody.removeChild($n(tbody, 'ue_summary_stats_row'));
402 var rowtmpl = uEditSummaryStatCatRow;
403 removeChildren(tbody);
405 for( var s in patron.stat_cat_entries() ) {
406 row = rowtmpl.cloneNode(true);
407 var entry = patron.stat_cat_entries()[s];
408 var cat = statCatsCache[entry.stat_cat()];
409 $n(row, 'ue_summary_stat_name').appendChild(text(cat.name()));
410 $n(row, 'ue_summary_stat_value').appendChild(text(entry.stat_cat_entry()));
411 row.setAttribute('statcat', entry.stat_cat());
412 if( entry.isdeleted() ) addCSSClass(row, 'deleted');
413 tbody.appendChild(row);
416 if( ! getElementsByTagNameFlat( tbody, 'tr' )[0] )
417 hideMe(tbody.parentNode);
419 unHideMe(tbody.parentNode);
424 var uEditSummarySurveyRow;
425 function uEditFleshSummarySurveys( table, patron ) {
427 var tbody = $n(table, 'ue_summary_survey_tbody');
428 if(!uEditSummarySurveyRow)
429 uEditSummarySurveyRow =
430 tbody.removeChild($n(tbody, 'ue_summary_survey_row'));
431 var rowtmpl = uEditSummarySurveyRow;
433 removeChildren(tbody);
435 for( var r in patron.survey_responses() ) {
436 var row = rowtmpl.cloneNode(true);
437 var resp = patron.survey_responses()[r];
438 var survey = surveysCache[resp.survey()];
439 var quest = surveyQuestionsCache[resp.question()];
440 var answer = surveyAnswersCache[resp.answer()];
441 $n(row, 'ue_summary_survey_name').appendChild(text(survey.name()));
442 $n(row, 'ue_summary_survey_question').appendChild(text(quest.question()));
443 $n(row, 'ue_summary_survey_answer').appendChild(text(answer.answer()));
444 tbody.appendChild(row);
447 if( ! getElementsByTagNameFlat(tbody, 'tr')[0])
448 hideMe(tbody.parentNode);
450 unHideMe(tbody.parentNode);
454 function uEditDrawNetLevels(netLevels) {
455 var sel = $('ue_net_level');
458 insertSelectorVal( sel, -1, i.name(), i.id() );