summaryrefslogtreecommitdiffstats
path: root/js/teachers.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/teachers.js')
-rw-r--r--js/teachers.js152
1 files changed, 76 insertions, 76 deletions
diff --git a/js/teachers.js b/js/teachers.js
index aab7d74..5fc2baf 100644
--- a/js/teachers.js
+++ b/js/teachers.js
@@ -14,71 +14,71 @@ function setLoading(state) {
// Function, responsible for fetching and displaying data
async function loadTeachers(force_refresh = false) {
- setLoading(true);
- // Load required data
- let promises_to_run = [
- localforage.getItem("username").then((value) => {
- username = value;
- }),
- localforage.getItem("password").then((value) => {
- password = value;
- }),
- localforage.getItem("teachers").then((value) => {
- teachers = value;
- })
- ];
- await Promise.all(promises_to_run);
- // If we don't have a list of teachers, query it
- if (teachers === null || force_refresh) {
- try {
- let gsecInstance = new gsec();
- await gsecInstance.login(username, password);
- gsecInstance.fetchTeachers().then( (value) => {
- teachers = value;
- localforage.setItem("teachers", value).then((value) => {
- displayData();
- setLoading(false);
- });
- setLoading(false);
- }).catch( (err) => {
- gsecErrorHandlerUI(err);
- setLoading(false);
- });
- } catch (err) {
- gsecErrorHandlerUI(err);
- setLoading(false);
- }
- } else {
- displayData();
- setLoading(false);
- }
+ setLoading(true);
+ // Load required data
+ let promises_to_run = [
+ localforage.getItem("username").then((value) => {
+ username = value;
+ }),
+ localforage.getItem("password").then((value) => {
+ password = value;
+ }),
+ localforage.getItem("teachers").then((value) => {
+ teachers = value;
+ })
+ ];
+ await Promise.all(promises_to_run);
+ // If we don't have a list of teachers, query it
+ if (teachers === null || force_refresh) {
+ try {
+ let gsecInstance = new gsec();
+ await gsecInstance.login(username, password);
+ gsecInstance.fetchTeachers().then( (value) => {
+ teachers = value;
+ localforage.setItem("teachers", value).then(() => {
+ displayData();
+ setLoading(false);
+ });
+ setLoading(false);
+ }).catch( (err) => {
+ gsecErrorHandlerUI(err);
+ setLoading(false);
+ });
+ } catch (err) {
+ gsecErrorHandlerUI(err);
+ setLoading(false);
+ }
+ } else {
+ displayData();
+ setLoading(false);
+ }
}
// Function for displaying data
function displayData() {
- for(const teacher of Object.keys(teachers)) {
- // Create row
- let row = document.createElement("tr");
- // Create cell 1
- let cell_name = document.createElement("td");
- let cell_name_text = document.createTextNode(teacher);
- // Create cell 2
- let cell_subject = document.createElement("td");
- // Array ([0]) is useless, since every teacher is duplicated (for each subject) // <-- ne velja za gsec.js, velja pa za gimsisextclient, PHP varianta
- var subjectsString = "";
- for(const subject of Object.keys(teachers[teacher]["subjects"])) {
- subjectsString += subject;
- subjectsString += ", ";
- }
- let cell_subject_text = document.createTextNode(subjectsString.slice(0, -2)); // slajsnemo zadnji ", "
- cell_name.appendChild(cell_name_text);
- row.appendChild(cell_name);
- cell_subject.appendChild(cell_subject_text);
- row.appendChild(cell_subject);
- $("#teachers-body").append(row);
- };
- // Refresh handlers
- refreshTableClickHandlers();
+ for(const teacher of Object.keys(teachers)) {
+ // Create row
+ let row = document.createElement("tr");
+ // Create cell 1
+ let cell_name = document.createElement("td");
+ let cell_name_text = document.createTextNode(teacher);
+ // Create cell 2
+ let cell_subject = document.createElement("td");
+ // Array ([0]) is useless, since every teacher is duplicated (for each subject) // <-- ne velja za gsec.js, velja pa za gimsisextclient, PHP varianta
+ var subjectsString = "";
+ for(const subject of Object.keys(teachers[teacher]["subjects"])) {
+ subjectsString += subject;
+ subjectsString += ", ";
+ }
+ let cell_subject_text = document.createTextNode(subjectsString.slice(0, -2)); // slajsnemo zadnji ", "
+ cell_name.appendChild(cell_name_text);
+ row.appendChild(cell_name);
+ cell_subject.appendChild(cell_subject_text);
+ row.appendChild(cell_subject);
+ $("#teachers-body").append(row);
+ };
+ // Refresh handlers
+ refreshTableClickHandlers();
}
async function checkLogin() {
@@ -109,22 +109,22 @@ function refreshTableClickHandlers() {
}
function teacherInfo(teacher_id) {
- let name = Object.keys(teachers)[teacher_id];
- let teacher_object = teachers[name];
- var subjectsString = "";
- for(const subject of Object.keys(teacher_object["subjects"])) {
- subjectsString += subject;
- subjectsString += ", ";
- }
- let subject = subjectsString.slice(0, -2);
- let office_day = dateString.day(teacher_object["tpMeetings"]["day"]);
- let office_lesson = teacher_object["tpMeetings"]["period"];
- $("#teacher-name").text(name);
- $("#teacher-subject").text(`${S("schoolSubject")}: ${subject}`);
- $("#teacher-office").text(`${office_day}, ${S("lesson")} ${office_lesson}`);
+ let name = Object.keys(teachers)[teacher_id];
+ let teacher_object = teachers[name];
+ var subjectsString = "";
+ for(const subject of Object.keys(teacher_object["subjects"])) {
+ subjectsString += subject;
+ subjectsString += ", ";
+ }
+ let subject = subjectsString.slice(0, -2);
+ let office_day = dateString.day(teacher_object["tpMeetings"]["day"]);
+ let office_lesson = teacher_object["tpMeetings"]["period"];
+ $("#teacher-name").text(name);
+ $("#teacher-subject").text(`${S("schoolSubject")}: ${subject}`);
+ $("#teacher-office").text(`${office_day}, ${S("lesson")} ${office_lesson}`);
- const modal = document.querySelectorAll(".side-modal")[0];
- M.Sidenav.getInstance(modal).open();
+ const modal = document.querySelectorAll(".side-modal")[0];
+ M.Sidenav.getInstance(modal).open();
}
document.addEventListener("DOMContentLoaded", () => {