Add function to list divisions in submit form
parent
d561a34055
commit
9b7ec5f3d6
|
@ -14,4 +14,10 @@ export async function getGenders(sportID) {
|
||||||
const response = await fetch(`/data/genders?sport=${+sportID}`);
|
const response = await fetch(`/data/genders?sport=${+sportID}`);
|
||||||
const gendersList = await response.json();
|
const gendersList = await response.json();
|
||||||
return gendersList;
|
return gendersList;
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function getDivisions(sportID, gender) {
|
||||||
|
const response = await fetch(`/data/divisions?sport=${+sportID}&gender=${gender}`);
|
||||||
|
const divisionsList = await response.json();
|
||||||
|
return divisionsList;
|
||||||
}
|
}
|
|
@ -4,6 +4,7 @@ import * as Data from "./data.js";
|
||||||
const sportDropdown = document.getElementById('sport-dropdown');
|
const sportDropdown = document.getElementById('sport-dropdown');
|
||||||
const seasonDropdown = document.getElementById('year-dropdown');
|
const seasonDropdown = document.getElementById('year-dropdown');
|
||||||
const genderDropdown = document.getElementById('gender-dropdown');
|
const genderDropdown = document.getElementById('gender-dropdown');
|
||||||
|
const divisionDropdown = document.getElementById('division-dropdown');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -18,6 +19,8 @@ async function listSports() {
|
||||||
option.value = sport.id;
|
option.value = sport.id;
|
||||||
sportDropdown.appendChild(option);
|
sportDropdown.appendChild(option);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
listSeasons();
|
||||||
}
|
}
|
||||||
listSports();
|
listSports();
|
||||||
|
|
||||||
|
@ -45,10 +48,31 @@ async function listGenders() {
|
||||||
option.value = gender.name;
|
option.value = gender.name;
|
||||||
genderDropdown.appendChild(option);
|
genderDropdown.appendChild(option);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
listDivisions();
|
||||||
|
}
|
||||||
|
|
||||||
|
async function listDivisions() {
|
||||||
|
divisionDropdown.innerHTML = "";
|
||||||
|
|
||||||
|
const selectedSportID = sportDropdown.value;
|
||||||
|
const selectedGender = genderDropdown.value;
|
||||||
|
|
||||||
|
if(!selectedGender) return;
|
||||||
|
|
||||||
|
const divisionsList = await Data.getDivisions(selectedSportID, selectedGender);
|
||||||
|
|
||||||
|
divisionsList.forEach(division => {
|
||||||
|
const option = document.createElement('option');
|
||||||
|
option.text = division.name;
|
||||||
|
option.value = division.id;
|
||||||
|
divisionDropdown.appendChild(option);
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
sportDropdown.onchange = listGenders;
|
sportDropdown.onchange = listGenders;
|
||||||
|
genderDropdown.onchange = listDivisions;
|
|
@ -3,6 +3,7 @@ var router = express.Router();
|
||||||
var sports = require('../database/scores/sports');
|
var sports = require('../database/scores/sports');
|
||||||
var seasons = require('../database/scores/seasons');
|
var seasons = require('../database/scores/seasons');
|
||||||
var genders = require('../database/scores/genders');
|
var genders = require('../database/scores/genders');
|
||||||
|
var divisions = require('../database/scores/divisions');
|
||||||
|
|
||||||
|
|
||||||
router.get('/sports', function(req, res, next) {
|
router.get('/sports', function(req, res, next) {
|
||||||
|
@ -20,4 +21,11 @@ router.get('/genders', function(req, res, next) {
|
||||||
.then(data => res.json(data));
|
.then(data => res.json(data));
|
||||||
})
|
})
|
||||||
|
|
||||||
|
router.get('/divisions', function(req, res, next) {
|
||||||
|
const gender = req.body.gender == 'female' ? genders.FEMALE : genders.MALE;
|
||||||
|
|
||||||
|
divisions.retrieveBySportAndGender(req.query.sport, gender)
|
||||||
|
.then(data => res.json(data));
|
||||||
|
})
|
||||||
|
|
||||||
module.exports = router;
|
module.exports = router;
|
|
@ -16,9 +16,6 @@ block content
|
||||||
select#sport-dropdown(name="sport" class="main-dropdown")
|
select#sport-dropdown(name="sport" class="main-dropdown")
|
||||||
select#gender-dropdown(name="gender")
|
select#gender-dropdown(name="gender")
|
||||||
select#division-dropdown(name="division")
|
select#division-dropdown(name="division")
|
||||||
option(value="Varsity") Varsity
|
|
||||||
option(value="JV-A") JV-A
|
|
||||||
option(value="JV-B") JV-B
|
|
||||||
span(class='form-section')
|
span(class='form-section')
|
||||||
label Date of match
|
label Date of match
|
||||||
span(class='form-section-input')
|
span(class='form-section-input')
|
||||||
|
|
Reference in New Issue