Move the AuthorityControlSet module into openils -- it loads data from the server
authorMike Rylander <mrylander@gmail.com>
Mon, 9 May 2011 19:17:41 +0000 (15:17 -0400)
committerMike Rylander <mrylander@gmail.com>
Mon, 9 May 2011 19:20:50 +0000 (15:20 -0400)
Open-ILS/web/js/dojo/openils/AuthorityControlSet.js [moved from Open-ILS/web/js/dojo/MARC/AuthorityControlSet.js with 88% similarity]
Open-ILS/xul/staff_client/server/cat/marcedit.js

  * ---------------------------------------------------------------------------
  */
 
-if(!dojo._hasResource["MARC.AuthorityControlSet"]) {
+if(!dojo._hasResource["openils.AuthorityControlSet"]) {
 
     dojo.require('openils.PermaCrud');
     dojo.require('MARC.FixedFields');
 
-    dojo._hasResource["MARC.AuthorityControlSet"] = true;
-    dojo.provide("MARC.AuthorityControlSet");
-    dojo.declare('MARC.AuthorityControlSet', null, {
+    dojo._hasResource["openils.AuthorityControlSet"] = true;
+    dojo.provide("openils.AuthorityControlSet");
+    dojo.declare('openils.AuthorityControlSet', null, {
 
         _controlset : null,
 
         constructor : function(kwargs) {
 
-            if (!MARC.AuthorityControlSet._remote_loaded) {
+            if (!openils.AuthorityControlSet._remote_loaded) {
 
                 // TODO -- push the raw tree into the oils cache for later reuse
 
@@ -37,7 +37,7 @@ if(!dojo._hasResource["MARC.AuthorityControlSet"]) {
 
                 // loop over each acs
                 dojo.forEach( acs_list, function (cs) {
-                    MARC.AuthorityControlSet._controlsets[''+cs.id()] = {
+                    openils.AuthorityControlSet._controlsets[''+cs.id()] = {
                         id : cs.id(),
                         name : cs.name(),
                         description : cs.description(),
@@ -50,8 +50,8 @@ if(!dojo._hasResource["MARC.AuthorityControlSet"]) {
                     // grab the authority fields
                     var acsaf_list = pcrud.search('acsaf', {control_set : cs.id()});
                     var at_list = pcrud.search('at', {control_set : cs.id()});
-                    MARC.AuthorityControlSet._controlsets[''+cs.id()].raw.authority_fields( acsaf_list );
-                    MARC.AuthorityControlSet._controlsets[''+cs.id()].raw.thesauri( at_list );
+                    openils.AuthorityControlSet._controlsets[''+cs.id()].raw.authority_fields( acsaf_list );
+                    openils.AuthorityControlSet._controlsets[''+cs.id()].raw.thesauri( at_list );
 
                     // and loop over each
                     dojo.forEach( acsaf_list, function (csaf) {
@@ -75,8 +75,8 @@ if(!dojo._hasResource["MARC.AuthorityControlSet"]) {
                         var acsbf_list = pcrud.search('acsbf', {authority_field : csaf.id()});
                         csaf.bib_fields( acsbf_list );
 
-                        MARC.AuthorityControlSet._controlsets[''+cs.id()].bib_fields = [].concat(
-                            MARC.AuthorityControlSet._controlsets[''+cs.id()].bib_fields
+                        openils.AuthorityControlSet._controlsets[''+cs.id()].bib_fields = [].concat(
+                            openils.AuthorityControlSet._controlsets[''+cs.id()].bib_fields
                             acsbf_list
                         );
 
@@ -94,19 +94,19 @@ if(!dojo._hasResource["MARC.AuthorityControlSet"]) {
                     });
 
                     // build the authority_tag_map
-                    dojo.forEach( MARC.AuthorityControlSet._controlsets[''+cs.id()].bib_fields, function (bf) {
-                        MARC.AuthorityControlSet._controlsets[''+cs.id()].control_map[bf.tag()] = {};
+                    dojo.forEach( openils.AuthorityControlSet._controlsets[''+cs.id()].bib_fields, function (bf) {
+                        openils.AuthorityControlSet._controlsets[''+cs.id()].control_map[bf.tag()] = {};
                         dojo.forEach( bf.authority_field().sf_list().split(''), function (sf_code) {
-                            MARC.AuthorityControlSet._controlsets[''+cs.id()].control_map[bf.tag()][sf_code] = { bf.authority_field().tag() : sf_code };
+                            openils.AuthorityControlSet._controlsets[''+cs.id()].control_map[bf.tag()][sf_code] = { bf.authority_field().tag() : sf_code };
                         });
                     });
                 });
 
                 
                 if (this.controlSetList().length > 0)
-                    delete MARC.AuthorityControlSet._controlsets['-1'];
+                    delete openils.AuthorityControlSet._controlsets['-1'];
 
-                MARC.AuthorityControlSet._remote_loaded = true;
+                openils.AuthorityControlSet._remote_loaded = true;
             }
 
             if (kwargs.controlSet) {
@@ -122,20 +122,20 @@ if(!dojo._hasResource["MARC.AuthorityControlSet"]) {
         },
 
         controlSet: function (x) {
-            return MARC.AuthorityControlSet._controlsets[''+this.controlSetId(x)];
+            return openils.AuthorityControlSet._controlsets[''+this.controlSetId(x)];
         },
 
         authorityFields: function (x) {
-            return MARC.AuthorityControlSet._controlsets[''+this.controlSetId(x)].raw.authority_fields();
+            return openils.AuthorityControlSet._controlsets[''+this.controlSetId(x)].raw.authority_fields();
         },
 
         thesauri: function (x) {
-            return MARC.AuthorityControlSet._controlsets[''+this.controlSetId(x)].raw.thesauri();
+            return openils.AuthorityControlSet._controlsets[''+this.controlSetId(x)].raw.thesauri();
         },
 
         controlSetList : function () {
             var l = [];
-            for (var i in MARC.AuthorityControlSet._controlsets) {
+            for (var i in openils.AuthorityControlSet._controlsets) {
                 l.push(i);
             }
             return l;
@@ -153,9 +153,9 @@ if(!dojo._hasResource["MARC.AuthorityControlSet"]) {
 
     });
 
-    MARC.AuthorityControlSet._remote_loaded = false;
+    openils.AuthorityControlSet._remote_loaded = false;
 
-    MARC.AuthorityControlSet._controlsets = {
+    openils.AuthorityControlSet._controlsets = {
         // static sorta-LoC setup ... to be overwritten with server data 
         -1 : {
             id : -1,
index b8b3460..19a582d 100644 (file)
@@ -42,6 +42,8 @@ var show_auth_menu = false;
 
 function $(id) { return document.getElementById(id); }
 
+var acs = new openils.AuthorityControlSet ();
+
 function mangle_005() {
     var now = new Date();
     var y = now.getUTCFullYear();
@@ -1243,116 +1245,6 @@ function getContextMenu (target, type) {
     return true;
 }
 
-var authority_tag_map = {
-    100 : ['[100,500,700]',100],
-    700 : ['[100,500,700]',100],
-    800 : ['[100,500,700]',100],
-    110 : ['[110,510,710]',110],
-    610 : ['[110,510,710]',110],
-    710 : ['[110,510,710]',110],
-    810 : ['[110,510,710]',110],
-    111 : ['[111,511,711]',111],
-    611 : ['[111,511,711]',111],
-    711 : ['[111,511,711]',111],
-    811 : ['[111,511,711]',111],
-    240 : ['[130,530,730]',130],
-    130 : ['[130,530,730]',130],
-    730 : ['[130,530,730]',130],
-    830 : ['[130,530,730]',130],
-    600 : ['[100,500,580,581,582,585,700,780,781,782,785]',100],
-    630 : ['[130,530,730]',130],
-    648 : ['[148,548]',148],
-    650 : ['[150,550,580,581,582,585,750,780,781,782,785]',150],
-    651 : ['[151,551,580,581,582,585,751,780,781,782,785]',151],
-    655 : ['[155,555,580,581,582,585,755,780,781,782,785]',155]
-};
-
-function getAuthorityContextMenu (target, sf) {
-    var menu_id = sf.parent().@tag + ':' + sf.@code + '-authority-context-' + sf;
-
-    var page = 0;
-    var old = dojo.byId( menu_id );
-    if (old) {
-        page = auth_pages[menu_id];
-        old.parentNode.removeChild(old);
-    } else {
-        auth_pages[menu_id] = 0;
-    }
-
-    var sf_popup = createPopup({ id : menu_id, flex : 1 });
-
-    sf_popup.addEventListener("popuphiding", function(event) {
-        if (show_auth_menu) {
-            show_auth_menu = false;
-            getAuthorityContextMenu(target, sf);
-            dojo.byId(menu_id).openPopup();
-        }  
-    }, false);
-
-    context_menus.appendChild( sf_popup );
-
-    if (!authority_tag_map[sf.parent().@tag]) {
-        sf_popup.appendChild(createLabel( { value : $('catStrings').getString('staff.cat.marcedit.not_authority_field.label') } ) );
-        target.setAttribute('context', 'clipboard');
-        return false;
-    }
-
-    if (sf.toString().replace(/\s*/, '')) {
-        browseAuthority(sf_popup, menu_id, target, sf, 20, page);
-    }
-
-    return true;
-}
-
-/* Apply the complete 1xx */
-function applyFullAuthority ( target, ui_sf, e4x_sf ) {
-    var new_vals = dojo.query('*[tag^="1"]', target);
-    return applyAuthority( target, ui_sf, e4x_sf, new_vals );
-}
-
-function applySelectedAuthority ( target, ui_sf, e4x_sf ) {
-    var new_vals = target.getElementsByAttribute('checked','true');
-    return applyAuthority( target, ui_sf, e4x_sf, new_vals );
-}
-
-function applyAuthority ( target, ui_sf, e4x_sf, new_vals ) {
-    var field = e4x_sf.parent();
-
-    for (var i = 0; i < new_vals.length; i++) {
-
-        var sf_list = field.subfield;
-        for (var j in sf_list) {
-
-            if (sf_list[j].@code == new_vals[i].getAttribute('subfield')) {
-                sf_list[j] = new_vals[i].getAttribute('value');
-                new_vals[i].setAttribute('subfield','');
-                break;
-            }
-        }
-    }
-
-    for (var i = 0; i < new_vals.length; i++) {
-        if (!new_vals[i].getAttribute('subfield')) continue;
-
-        var val = new_vals[i].getAttribute('value');
-
-        var sf = <subfield code="" xmlns="http://www.loc.gov/MARC21/slim">{val}</subfield>;
-        sf.@code = new_vals[i].getAttribute('subfield');
-
-        field.insertChildAfter(field.subfield[field.subfield.length() - 1], sf);
-    }
-
-    var row = marcDatafield( field );
-
-    var node = ui_sf;
-    while (node.nodeName != 'row') {
-        node = node.parentNode;
-    }
-
-    node.parentNode.replaceChild( row, node );
-    return true;
-}
-
 var control_map = {
     100 : {
         'a' : { 100 : 'a' },
@@ -1611,6 +1503,97 @@ var control_map = {
     }
 };
 
+function getAuthorityContextMenu (target, sf) {
+    var menu_id = sf.parent().@tag + ':' + sf.@code + '-authority-context-' + sf;
+
+    var page = 0;
+    var old = dojo.byId( menu_id );
+    if (old) {
+        page = auth_pages[menu_id];
+        old.parentNode.removeChild(old);
+    } else {
+        auth_pages[menu_id] = 0;
+    }
+
+    var sf_popup = createPopup({ id : menu_id, flex : 1 });
+
+    sf_popup.addEventListener("popuphiding", function(event) {
+        if (show_auth_menu) {
+            show_auth_menu = false;
+            getAuthorityContextMenu(target, sf);
+            dojo.byId(menu_id).openPopup();
+        }  
+    }, false);
+
+    context_menus.appendChild( sf_popup );
+
+    var found_acs = [];
+    dojo.forEach( acs.controlSetList(), function (acs_id) {
+        if (ac.controlSet(acs_id).control_map[sf.parent().@tag]) found_acs.push(acs_id);
+    });
+
+    if (!found_acs.length) {
+        sf_popup.appendChild(createLabel( { value : $('catStrings').getString('staff.cat.marcedit.not_authority_field.label') } ) );
+        target.setAttribute('context', 'clipboard');
+        return false;
+    }
+
+    if (sf.toString().replace(/\s*/, '')) {
+        browseAuthority(sf_popup, menu_id, target, sf, 20, page);
+    }
+
+    return true;
+}
+
+/* Apply the complete 1xx */
+function applyFullAuthority ( target, ui_sf, e4x_sf ) {
+    var new_vals = dojo.query('*[tag^="1"]', target);
+    return applyAuthority( target, ui_sf, e4x_sf, new_vals );
+}
+
+function applySelectedAuthority ( target, ui_sf, e4x_sf ) {
+    var new_vals = target.getElementsByAttribute('checked','true');
+    return applyAuthority( target, ui_sf, e4x_sf, new_vals );
+}
+
+function applyAuthority ( target, ui_sf, e4x_sf, new_vals ) {
+    var field = e4x_sf.parent();
+
+    for (var i = 0; i < new_vals.length; i++) {
+
+        var sf_list = field.subfield;
+        for (var j in sf_list) {
+
+            if (sf_list[j].@code == new_vals[i].getAttribute('subfield')) {
+                sf_list[j] = new_vals[i].getAttribute('value');
+                new_vals[i].setAttribute('subfield','');
+                break;
+            }
+        }
+    }
+
+    for (var i = 0; i < new_vals.length; i++) {
+        if (!new_vals[i].getAttribute('subfield')) continue;
+
+        var val = new_vals[i].getAttribute('value');
+
+        var sf = <subfield code="" xmlns="http://www.loc.gov/MARC21/slim">{val}</subfield>;
+        sf.@code = new_vals[i].getAttribute('subfield');
+
+        field.insertChildAfter(field.subfield[field.subfield.length() - 1], sf);
+    }
+
+    var row = marcDatafield( field );
+
+    var node = ui_sf;
+    while (node.nodeName != 'row') {
+        node = node.parentNode;
+    }
+
+    node.parentNode.replaceChild( row, node );
+    return true;
+}
+
 function validateAuthority (button) {
     var grid = document.getElementById('recGrid');
     var label = button.getAttribute('label');
@@ -1621,48 +1604,54 @@ function validateAuthority (button) {
         var row = rows[i];
         var tag = row.firstChild;
 
-        if (!control_map[tag.value]) continue
-        button.setAttribute('label', label + ' - ' + tag.value);
-
-        var ind1 = tag.nextSibling;
-        var ind2 = ind1.nextSibling;
-        var subfields = ind2.nextSibling.childNodes;
-
-        var tags = {};
-
-        for (var j = 0; j < subfields.length; j++) {
-            var sf = subfields[j];
-            var sf_code = sf.childNodes[1].value;
-            var sf_value = sf.childNodes[2].value;
-
-            if (!control_map[tag.value][sf_code]) continue;
-
-            var found = 0;
-            for (var a_tag in control_map[tag.value][sf_code]) {
-                if (!tags[a_tag]) tags[a_tag] = [];
-                tags[a_tag].push({ term : sf_value, subfield : sf_code });
+        for (var acs_id in acs.controlSetList()) {
+            var control_map = acs.controlSet(acs_id).control_map;
+    
+            if (!control_map[tag.value]) continue
+            button.setAttribute('label', label + ' - ' + tag.value);
+    
+            var ind1 = tag.nextSibling;
+            var ind2 = ind1.nextSibling;
+            var subfields = ind2.nextSibling.childNodes;
+    
+            var tags = {};
+    
+            for (var j = 0; j < subfields.length; j++) {
+                var sf = subfields[j];
+                var sf_code = sf.childNodes[1].value;
+                var sf_value = sf.childNodes[2].value;
+    
+                if (!control_map[tag.value][sf_code]) continue;
+    
+                var found = 0;
+                for (var a_tag in control_map[tag.value][sf_code]) {
+                    if (!tags[a_tag]) tags[a_tag] = [];
+                    tags[a_tag].push({ term : sf_value, subfield : sf_code });
+                }
+    
+            }
+    
+            for (var val_tag in tags) {
+                var auth_data = validateBibField( acs_id, [val_tag], tags[val_tag]);
+                var res = new XML( auth_data.responseText );
+                found = parseInt(res.gw::payload.gw::string.toString());
+                if (found) break;
+            }
+    
+            // XXX If adt, etc should be validated separately from vxz, etc then move this up into the above for loop
+            for (var j = 0; j < subfields.length; j++) {
+                var sf = subfields[j];
+                if (!found) {
+                    dojo.removeClass(sf.childNodes[2], 'marcValidated');
+                    dojo.addClass(sf.childNodes[2], 'marcUnvalidated');
+                } else {
+                    dojo.removeClass(sf.childNodes[2], 'marcUnvalidated');
+                    dojo.addClass(sf.childNodes[2], 'marcValidated');
+                }
             }
 
-        }
-
-        for (var val_tag in tags) {
-            var auth_data = validateBibField( [val_tag], tags[val_tag]);
-            var res = new XML( auth_data.responseText );
-            found = parseInt(res.gw::payload.gw::string.toString());
             if (found) break;
         }
-
-        // XXX If adt, etc should be validated separately from vxz, etc then move this up into the above for loop
-        for (var j = 0; j < subfields.length; j++) {
-            var sf = subfields[j];
-            if (!found) {
-                dojo.removeClass(sf.childNodes[2], 'marcValidated');
-                dojo.addClass(sf.childNodes[2], 'marcUnvalidated');
-            } else {
-                dojo.removeClass(sf.childNodes[2], 'marcUnvalidated');
-                dojo.addClass(sf.childNodes[2], 'marcValidated');
-            }
-        }
     }
 
     button.setAttribute('label', label);