2 use strict; use warnings;
4 # ------------------------------------------------------------
5 # turns the orgTree and orgTypes into js files
6 # ------------------------------------------------------------
9 use OpenILS::Utils::Fieldmapper;
10 use OpenSRF::Utils::SettingsClient;
11 use OpenSRF::Utils::Cache;
13 die "usage: perl org_tree_js.pl <bootstrap_config>" unless $ARGV[0];
14 OpenSRF::System->bootstrap_client(config_file => $ARGV[0]);
16 Fieldmapper->import(IDL => OpenSRF::Utils::SettingsClient->new->config_value("IDL"));
18 # must be loaded after the IDL is parsed
19 require OpenILS::Utils::CStoreEditor;
21 warn "removing OrgTree from the cache...\n";
22 my $cache = OpenSRF::Utils::Cache->new;
23 $cache->delete_cache('orgtree');
25 # fetch the org_unit's and org_unit_type's
26 my $e = OpenILS::Utils::CStoreEditor->new;
27 my $tree = $e->retrieve_all_actor_org_unit;
28 my $types = $e->retrieve_all_actor_org_unit_type;
33 return 'null' unless defined $v;
35 # required for JS code this is checking truthness
36 # without using isTrue() (1/0 vs. t/f)
37 return 1 if $v eq 't';
38 return 0 if $v eq 'f';
43 my $pile = "var _l = [";
47 my ($i,$t,$p,$n,$v) = ($o->id,$o->ou_type,val($o->parent_ou),$o->name,val($o->opac_visible));
49 push @array, "[$i,$t,$p,\"$n\",$v]";
52 $pile .= join ',', @array;
56 $pile .= 'globalOrgTypes = [';
58 $pile .= 'new aout([null,null,null,null,'.
59 val($t->can_have_users).','.
60 val($t->can_have_vols).','.
64 val($t->opac_label).','.
65 val($t->parent).']), ';
67 $pile =~ s/, $//; # remove trailing comma