Find Cheaper University Textbooks
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

71 lines
2.1 KiB

<search>
<form class="form-horizontal search-form" onsubmit={ submit } type="submit" method="get">
<div class="form-group">
<div class="container">
<div class="columns">
<div class="col-xs-12 col-sm-12 col-md-12 col-lg-12">
<input onfocus={ showhelp }
class="form-input search"
placeholder="Course Description"
type="text"
ref="title">
</input>
</div>
</div>
<div class="columns">
<div class="col-sm-6 col-md-6 col-lg-6">
<select class="semester form-select float-right" aria-labelledby="dLabel" ref="sem">
<option value="Fall" selected>Fall</option>
<option value="Winter">Winter</option>
<option value="Spring/Summer">Spring/Summer</option>
</select>
</div>
<div class="col-sm-6 col-md-6 col-lg-6">
<button
class="search-btn btn btn-primary float-left tooltip tooltip-bottom"
data-tooltip="Search by keywords"
type="submit">
Search
</button>
</div>
</div>
</div>
</div>
</form>
<div if={ opts.booksLoading } class="search-load">
</div>
<script>
import {filterCourses, groupsof} from './helpers.js';
import 'whatwg-fetch'
var self = this;
submit(ev) {
ev.preventDefault();
self.opts.booksLoading = true;
self.update();
self.opts.resultsEv.trigger("loading");
console.log(ev);
fetch("/search/fc?title="+self.refs.title.value+"&sem="+self.refs.sem.value).then(
function(response) {
if (response.ok) {
response.json().then(
function(courses) {
var fcourses = filterCourses(courses);
var cgroups = groupsof(3, fcourses);
self.opts.resultsEv.trigger("newResults", cgroups);
self.opts.booksLoading = false;
self.update();
});
}
});
}
</script>
</search>