2 # Extract MARC fields from XML
3 # get_marc_attrs( { marc_xml => doc } )
6 args.isbn = xml.findnodes('//*[@tag="020"]/*[@code="a"]').shift.textContent;
7 args.upc = xml.findnodes('//*[@tag="024"]/*[@code="a"]').textContent;
8 args.issn = xml.findnodes('//*[@tag="022"]/*[@code="a"]').textContent;
9 args.title = xml.findnodes('//*[@tag="245"]/*[@code="a"]').textContent;
10 args.author = xml.findnodes('//*[@tag="100"]/*[@code="a"]').textContent;
11 args.publisher = xml.findnodes('//*[@tag="260"]/*[@code="b"]').textContent;
12 args.pubdate = xml.findnodes('//*[@tag="260"]/*[@code="c"]').textContent;
13 args.edition = xml.findnodes('//*[@tag="250"]/*[@code="a"]').textContent ||
14 xml.findnodes('//*[@tag="534"]/*[@code="b"]').textContent ||
15 xml.findnodes('//*[@tag="775"]/*[@code="b"]').textContent;
17 '//*[@tag="300"]/*[@code="a" or @code="b" or @code="c" or @code="e"]'
20 FOR p IN phys; phys_content.push(p.textContent); END;
21 args.phys_desc = phys_content.join("");
24 args.isbn_clean = args.isbn.replace('\ .*', '');
26 # KCLS-specific stuff; needs to change
27 args.mattype = xml.findnodes('//*[@tag="998"]/*[@code="d"]').textContent;
28 args.kcls_cn = xml.findnodes('//*[@tag="092" or @tag="099"]/*').textContent;
29 mattype = args.mattype;
30 args.format = ctx.find_citm(mattype).value;
31 args.format_icon = icon_by_format.$mattype;
34 BLOCK get_hold_status;
35 IF hold.hold.status == 4;
37 IF ahr.shelf_expire_time;
38 l('<br/>Expires [_1]',
39 date.format(ctx.parse_datetime(ahr.shelf_expire_time), DATE_FORMAT));
41 ELSIF hold.hold.estimated_wait AND hold.hold.estimated_wait > 0;
42 # estimated wait is delivered as seconds.
43 SET hwait = POSIX.ceil(hold.hold.estimated_wait / 86400);
44 l("Estimated wait: [quant,_1,day,days]", hwait);
45 ELSIF hold.hold.status == 3;
47 ELSIF hold.hold.status < 3;
48 l("Waiting for copy");