2014-07-08 04:35:52 +00:00
|
|
|
'use strict';
|
|
|
|
|
2014-07-28 07:38:03 +00:00
|
|
|
var app = { };
|
|
|
|
|
2014-07-08 04:35:52 +00:00
|
|
|
function outputResults(results, maxResults) {
|
|
|
|
$('#results').empty();
|
|
|
|
$('#count').text(results.length);
|
|
|
|
|
|
|
|
results = results.splice(0, maxResults);
|
|
|
|
|
|
|
|
var template = Handlebars.compile($('#template').html());
|
|
|
|
$('#results').append(template({'results': results}));
|
|
|
|
}
|
|
|
|
|
|
|
|
function onAdjust(name, value) {
|
2014-07-28 07:38:03 +00:00
|
|
|
app.searchParams[name] = value;
|
|
|
|
console.log(app.searchParams);
|
2014-07-28 07:21:08 +00:00
|
|
|
|
|
|
|
var params = {
|
2014-07-28 07:38:03 +00:00
|
|
|
searchParams: app.searchParams,
|
|
|
|
searchRange: app.searchRange,
|
|
|
|
minScore: app.minScore,
|
|
|
|
hintSteps: app.hintSteps,
|
|
|
|
maxResults: app.maxResults
|
2014-07-28 07:21:08 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
$.getJSON('/node/search', params, function(results) {
|
|
|
|
var hintData = { };
|
|
|
|
for (var feature in results.columns) {
|
|
|
|
hintData[feature] = results.columns[feature].hints;
|
|
|
|
}
|
|
|
|
|
2014-07-28 07:38:03 +00:00
|
|
|
app.grapher.setColumnHints(hintData);
|
2014-07-28 07:21:08 +00:00
|
|
|
outputResults(results.items, params.maxResults);
|
|
|
|
});
|
2014-07-08 04:35:52 +00:00
|
|
|
}
|
|
|
|
|
2014-07-28 02:52:30 +00:00
|
|
|
function onSearch() {
|
|
|
|
var params = {
|
2014-07-28 07:38:03 +00:00
|
|
|
keyword: $('#keyword').val(),
|
|
|
|
searchRange: { min: -1.0, max: 1.0 },
|
|
|
|
minScore: parseInt($('#minScore').val()),
|
|
|
|
hintSteps: parseInt($('#hintSteps').val()),
|
|
|
|
maxResults: parseInt($('#maxResults').val())
|
2014-07-08 04:35:52 +00:00
|
|
|
};
|
|
|
|
|
2014-07-28 02:52:30 +00:00
|
|
|
$.getJSON('/node/search', params, function(results) {
|
2014-07-28 07:38:03 +00:00
|
|
|
app.searchParams = results.params;
|
|
|
|
app.searchRange = params.searchRange;
|
|
|
|
app.minScore = params.minScore;
|
|
|
|
app.hintSteps = params.hintSteps;
|
|
|
|
app.maxResults = params.maxResults;
|
|
|
|
|
|
|
|
app.grapher = new Grapher('grapher', new goog.math.Range(-1.0, 1.0), true, true);
|
|
|
|
app.grapher.setColumns(results.columns);
|
|
|
|
app.grapher.setValueChangedListener(onAdjust);
|
2014-07-28 06:41:14 +00:00
|
|
|
|
2014-07-28 06:51:48 +00:00
|
|
|
outputResults(results.items, params.maxResults);
|
2014-07-28 06:41:14 +00:00
|
|
|
|
|
|
|
$('#query').text(params.keyword);
|
2014-07-28 07:38:03 +00:00
|
|
|
|
2014-07-28 06:41:14 +00:00
|
|
|
$('#useLocalScale').click(function() {
|
|
|
|
var useLocalScale = $('#useLocalScale').is(':checked');
|
2014-07-28 07:38:03 +00:00
|
|
|
app.grapher.setUseLocalScale(useLocalScale);
|
2014-07-28 06:41:14 +00:00
|
|
|
});
|
|
|
|
$('#useRelativeScale').click(function() {
|
|
|
|
var useRelativeScale = $('#useRelativeScale').is(':checked');
|
2014-07-28 07:38:03 +00:00
|
|
|
app.grapher.setUseRelativeScale(useRelativeScale);
|
2014-07-28 06:41:14 +00:00
|
|
|
});
|
2014-07-28 07:38:03 +00:00
|
|
|
|
2014-07-28 06:41:14 +00:00
|
|
|
$('#input').fadeOut(function() {
|
|
|
|
$('#output').fadeIn();
|
|
|
|
});
|
2014-07-08 04:35:52 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
$(document).ready(function() {
|
2014-07-28 02:52:30 +00:00
|
|
|
$.getJSON('/node/keywords', function(keywords) {
|
2014-07-28 01:57:04 +00:00
|
|
|
for (var i = 0; i < keywords.length; ++i) {
|
2014-07-28 07:38:03 +00:00
|
|
|
var properties = { value: keywords[i], text: keywords[i] };
|
|
|
|
$('#keyword').append($('<option></option>', properties));
|
2014-07-26 06:29:55 +00:00
|
|
|
}
|
2014-07-28 01:57:04 +00:00
|
|
|
|
|
|
|
$('#search').prop('disabled', false);
|
2014-07-28 02:52:30 +00:00
|
|
|
$('#search').click(onSearch);
|
2014-07-26 06:02:42 +00:00
|
|
|
});
|
2014-07-08 04:35:52 +00:00
|
|
|
});
|