Skip to content

Latest commit

 

History

History
77 lines (59 loc) · 3.53 KB

README.md

File metadata and controls

77 lines (59 loc) · 3.53 KB

Collecting Missions

The site is an HTML/CSS/JavaScript website without any server or backend. It can be hosted on static repositories such as GitHub or on an Apache HTTPD server. The js/query.js contains all the logic for contacting Google Fusion tables servers and retrieving the data.

Database

Google Fusion tables is used to store/retrieve the missions information. Fusion tables also takes care of rendering the map.

The data, coming from the MS Access database, is split into CSV files - one for each table. Each file is then uploaded to Fusion Tables and a unique identifier is obtained for each table. For example the MISSIONS_SAMPLES_SITES table was uploaded by Hannes here: https://www.google.com/fusiontables/DataSource?docid=1sfPdnErQ8ZubgZaHEa7FrYmsp63VELha6JERUj8 and has an identifier of 1sfPdnErQ8ZubgZaHEa7FrYmsp63VELha6JERUj8.

Once the CSV file is uploaded and the coordinates columns have been identified on Fusion Tables, the points are georeferenced and rendered automatically on Fusion Tables.

JavaScript is used on the site to filter and retrieve data through AJAX call using the REST HTTP API documented on the Fusion Table site: https://developers.google.com/fusiontables/

Code structure

Inside index.html there's a section that initializes all the various components used on the site:

$(function() {
    map.init()
    slide.init()
    query.init()
    dropdown.init()
    traits.init()
    $('.dropdown-toggle').dropdown()
    $('input, textarea').placeholder();
    query.checkParameter();
})

Each of those components such as map, slice, etc. has its own file such as js/map.js and js/slide.js. By looking at the init() methods within each module one can understand the functionality of a given module. For example the method that takes care of submitting the left-side information is the query.buildQuery() method:

    buildQuery: function() {
        var selectedGroup = $('.control-group .dropdown-toggle').text()

        if(selectedGroup == 'Collecting Missions') {
            missions.submit()
        } else if(selectedGroup == 'Collected Samples') {
            samples.submit()
        } else if(selectedGroup == 'Linked Accessions') {
            accessions.submit()
        } else if(selectedGroup == 'Traits') {
            traits.submit()
        }

    }

As can be seen, based on the left-side selection on the site, the specific module .submit() method is called. If we look at the samples.submit() method, which is contained within the samples.js file, we can see how the SQL query is build and then sent to Fusion Tables using their HTTP API, specifically using this code:

    submit: function() {
        var filters = []
        if(slide.filter) filters.push(slide.filter)
        $('div[groupName=samples] input').each(function() {
            var $this = $(this)
            var key, value, operator;
            key = $this.attr('placeholder')
            value = $this.val()
            operator = '=' // defaulting to = (not using < or >)
        
            if(value) {
                filters.push("'" + key + "' " + operator + " '" + value + "'")
            }
        })
        var where = filters.join(' AND ')
        if(where) {
            //console.log(where)
            query.setWhere(where)
        }
    }

As can be seen, this function simply takes care of building the SQL query and then calls the query.setWhere() method with the built query. query.setWhere() then takes care of calling Fusion Tables APIs.