2024-06-03 23:24:16 +02:00
|
|
|
/* eslint no-unused-vars: "off" */
|
|
|
|
/* eslint no-trailing-spaces: "off" */
|
|
|
|
/* eslint max-depth: ["error", 5] */
|
2023-05-17 21:19:14 +02:00
|
|
|
// Put this file in path/to/plugin/amd/src
|
|
|
|
// You can call it anything you like
|
|
|
|
|
|
|
|
import {call} from 'core/ajax';
|
|
|
|
import notification from 'core/notification';
|
|
|
|
|
2023-08-22 23:12:33 +02:00
|
|
|
import Vue from './vue/vue';
|
2023-08-19 17:54:40 +02:00
|
|
|
|
|
|
|
import Debugger from './util/debugger';
|
2024-06-03 23:24:16 +02:00
|
|
|
import {loadStrings} from './util/string-helper';
|
|
|
|
import {processStudyplan} from './studyplan-processor';
|
2023-11-13 22:18:28 +01:00
|
|
|
import {studyplanTiming} from './util/date-helper';
|
2024-06-02 17:21:30 +02:00
|
|
|
import {addBrowserButtonEvent} from './util/browserbuttonevents';
|
2023-05-17 21:19:14 +02:00
|
|
|
|
|
|
|
import RVComponents from './report-viewer-components';
|
|
|
|
Vue.use(RVComponents);
|
|
|
|
import ModalComponents from './modedit-modal';
|
|
|
|
Vue.use(ModalComponents);
|
|
|
|
|
2023-08-19 17:54:40 +02:00
|
|
|
import PortalVue from './portal-vue/portal-vue.esm';
|
2023-05-17 21:19:14 +02:00
|
|
|
Vue.use(PortalVue);
|
2023-08-31 07:40:55 +02:00
|
|
|
import BootstrapVue from './bootstrap-vue/bootstrap-vue';
|
2023-05-17 21:19:14 +02:00
|
|
|
Vue.use(BootstrapVue);
|
|
|
|
|
|
|
|
|
|
|
|
let debug = new Debugger("treestudyplanviewer");
|
|
|
|
|
2024-06-03 23:24:16 +02:00
|
|
|
let strings = loadStrings({
|
2023-05-17 21:19:14 +02:00
|
|
|
studyplan: {
|
2024-06-03 23:24:16 +02:00
|
|
|
studyplanSelectPlaceholder: 'studyplan_select_placeholder',
|
2023-05-17 21:19:14 +02:00
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize the Page
|
2024-06-03 23:24:16 +02:00
|
|
|
* @param {number} contextid The context we should attempt to work in (1:1 related to the category)
|
|
|
|
* @param {number} categoryid The category we shoud attempt to work in (1:1 related to the context)
|
2023-05-17 21:19:14 +02:00
|
|
|
*/
|
2024-06-03 23:24:16 +02:00
|
|
|
export function init(contextid, categoryid) {
|
2023-05-17 21:19:14 +02:00
|
|
|
// Make sure the id's are numeric and integer
|
2024-06-03 23:24:16 +02:00
|
|
|
if (undefined === contextid || !Number.isInteger(Number(contextid)) || contextid < 1) {
|
|
|
|
contextid = 1;
|
|
|
|
} else { // Ensure a numeric value instead of string
|
|
|
|
contextid = Number(contextid);
|
|
|
|
}
|
|
|
|
if (undefined === categoryid || !Number.isInteger(Number(categoryid))) {
|
|
|
|
categoryid = 0;
|
|
|
|
} else { // Ensure a numeric value instead of string
|
|
|
|
categoryid = Number(categoryid);
|
|
|
|
}
|
2023-05-17 21:19:14 +02:00
|
|
|
|
|
|
|
let app = new Vue({
|
|
|
|
el: '#root',
|
|
|
|
data: {
|
2024-06-02 17:21:30 +02:00
|
|
|
selected: {
|
|
|
|
planid: 0,
|
|
|
|
studentid: 0,
|
|
|
|
},
|
2023-05-17 21:19:14 +02:00
|
|
|
displayedstudyplan: null,
|
|
|
|
activestudyplan: null,
|
|
|
|
associatedstudents: [],
|
|
|
|
selectedstudent: null,
|
|
|
|
studentstudyplan: null,
|
|
|
|
loadingstudyplan: false,
|
|
|
|
studyplans: [],
|
|
|
|
text: strings.studyplan,
|
|
|
|
toolbox: {
|
|
|
|
right: true,
|
|
|
|
},
|
|
|
|
usedcontexts: [],
|
|
|
|
},
|
|
|
|
async mounted() {
|
|
|
|
call([{
|
|
|
|
methodname: 'local_treestudyplan_list_studyplans',
|
2024-06-03 23:24:16 +02:00
|
|
|
args: {'context_id': contextid}
|
|
|
|
}])[0].then((response) => {
|
|
|
|
const timingval = {present: 0, past: 1, future: 2};
|
|
|
|
response.sort((a, b) => {
|
2023-11-13 22:18:28 +01:00
|
|
|
const timinga = studyplanTiming(a);
|
|
|
|
const timingb = studyplanTiming(b);
|
2023-05-17 21:19:14 +02:00
|
|
|
|
|
|
|
const t = timingval[timinga] - timingval[timingb];
|
2024-06-03 23:24:16 +02:00
|
|
|
if (t == 0) {
|
|
|
|
// Sort by name if timing is equal
|
2023-05-17 21:19:14 +02:00
|
|
|
return a.name.localeCompare(b.name);
|
2024-06-03 23:24:16 +02:00
|
|
|
} else {
|
2023-05-17 21:19:14 +02:00
|
|
|
return t;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
app.studyplans = response;
|
2024-06-03 23:24:16 +02:00
|
|
|
// Load studyplan from hash if applicable
|
|
|
|
const hash = window.location.hash.replace('#', '');
|
2023-05-17 21:19:14 +02:00
|
|
|
const parts = hash.split("-");
|
2023-05-19 16:45:25 +02:00
|
|
|
|
2024-06-03 23:24:16 +02:00
|
|
|
if (!!parts && parts.length > 0 && parts[0] != '') {
|
|
|
|
for (let idx in app.studyplans) {
|
|
|
|
if (app.studyplans[idx].id == parts[0]) {
|
|
|
|
app.selectStudyplan(app.studyplans[idx], parts[1]);
|
2023-05-17 21:19:14 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-06-03 23:24:16 +02:00
|
|
|
return;
|
2023-12-13 23:49:06 +01:00
|
|
|
}).catch(notification.exception);
|
2023-05-17 21:19:14 +02:00
|
|
|
call([{
|
2024-02-04 23:18:11 +01:00
|
|
|
methodname: 'local_treestudyplan_list_available_categories',
|
2024-06-03 23:24:16 +02:00
|
|
|
args: {operation: 'view', 'refcontext_id': contextid}
|
|
|
|
}])[0].then((response) => {
|
2023-05-17 21:19:14 +02:00
|
|
|
const contexts = [];
|
2024-06-03 23:24:16 +02:00
|
|
|
for (const ix in response) {
|
2024-02-04 23:18:11 +01:00
|
|
|
const cat = response[ix];
|
2024-06-03 23:24:16 +02:00
|
|
|
if (cat.studyplancount > 0 || cat.context_id == contextid) {
|
2024-02-04 23:18:11 +01:00
|
|
|
contexts.push(cat);
|
2023-05-17 21:19:14 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
app.usedcontexts = contexts;
|
2024-06-03 23:24:16 +02:00
|
|
|
return;
|
2023-12-13 23:49:06 +01:00
|
|
|
}).catch(notification.exception);
|
2024-06-02 17:21:30 +02:00
|
|
|
addBrowserButtonEvent(this.navChanged, this.navChanged);
|
2023-05-17 21:19:14 +02:00
|
|
|
},
|
|
|
|
computed: {
|
2024-06-03 23:24:16 +02:00
|
|
|
dropdownTitle() {
|
|
|
|
if (this.activestudyplan && this.activestudyplan.name) {
|
2023-05-17 21:19:14 +02:00
|
|
|
return this.activestudyplan.name;
|
2024-06-03 23:24:16 +02:00
|
|
|
} else {
|
|
|
|
return this.text.studyplanSelectPlaceholder;
|
2023-05-17 21:19:14 +02:00
|
|
|
}
|
|
|
|
},
|
2024-06-03 23:24:16 +02:00
|
|
|
contextid() {
|
2023-05-17 21:19:14 +02:00
|
|
|
return contextid;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
2024-06-02 17:21:30 +02:00
|
|
|
navChanged() {
|
2024-06-03 23:24:16 +02:00
|
|
|
const hash = window.location.hash.replace('#', '');
|
2024-06-02 17:21:30 +02:00
|
|
|
const parts = hash.split("-");
|
2024-06-03 23:24:16 +02:00
|
|
|
debug.log("Navigation changed", hash, parts);
|
2024-06-02 17:21:30 +02:00
|
|
|
|
2024-06-03 23:24:16 +02:00
|
|
|
if (!!parts && parts.length > 0) {
|
2024-06-02 17:21:30 +02:00
|
|
|
const planid = Number(parts[0]);
|
2024-06-03 23:24:16 +02:00
|
|
|
const studentid = (parts.length > 1) ? Number(parts[1]) : 0;
|
2024-06-02 17:21:30 +02:00
|
|
|
|
2024-06-03 23:24:16 +02:00
|
|
|
debug.log("Selected ids", planid, studentid, this.selected.planid, this.selected.studentid);
|
|
|
|
if (planid == 0) {
|
2024-06-02 17:21:30 +02:00
|
|
|
if (planid != this.selected.planid) {
|
|
|
|
this.closeStudyplan(false);
|
|
|
|
}
|
2024-06-03 23:24:16 +02:00
|
|
|
} else if (this.selected.planid != planid || (studentid == 0 && this.selected.studentid != 0)) {
|
|
|
|
debug.info("Requested plan changed - loading studyplan");
|
|
|
|
for (let idx in app.studyplans) {
|
2024-06-02 17:21:30 +02:00
|
|
|
const plan = this.studyplans[idx];
|
2024-06-03 23:24:16 +02:00
|
|
|
if (Number(plan.id) == planid) {
|
|
|
|
this.selectStudyplan(plan, studentid, false);
|
2024-06-02 17:21:30 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if (this.selected.studentid != studentid) {
|
2024-06-03 23:24:16 +02:00
|
|
|
for (const group of app.associatedstudents) {
|
|
|
|
for (const student of group.users) {
|
|
|
|
if (Number(student.id) == studentid) {
|
|
|
|
app.showStudentView(student, false);
|
2024-06-02 17:21:30 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2024-06-03 23:24:16 +02:00
|
|
|
switchContext(ctxid) {
|
2023-05-17 21:19:14 +02:00
|
|
|
const params = new URLSearchParams(location.search);
|
2023-12-12 23:44:02 +01:00
|
|
|
params.delete('categoryid');
|
2023-12-14 21:42:34 +01:00
|
|
|
params.set('contextid', ctxid);
|
|
|
|
setTimeout(() => {
|
|
|
|
// Reload page in a timeout to give other form javasccript the change to remove the beforeunload handler.
|
|
|
|
window.location.href = window.location.pathname + "?" + params.toString();
|
2024-06-03 23:24:16 +02:00
|
|
|
}, 50);
|
2023-05-17 21:19:14 +02:00
|
|
|
},
|
2024-06-03 23:24:16 +02:00
|
|
|
closeStudyplan(updatehash = true) {
|
2024-06-02 17:21:30 +02:00
|
|
|
app.selected.planid = 0;
|
|
|
|
app.selected.studentid = 0;
|
2023-05-17 21:19:14 +02:00
|
|
|
app.activestudyplan = null;
|
|
|
|
app.associatedstudents = [];
|
|
|
|
app.studentstudyplan = [];
|
|
|
|
app.displayedstudyplan = null;
|
2024-06-02 17:21:30 +02:00
|
|
|
if (updatehash) {
|
|
|
|
window.location.hash = '';
|
|
|
|
}
|
2023-05-19 16:45:25 +02:00
|
|
|
},
|
|
|
|
|
2024-06-03 23:24:16 +02:00
|
|
|
selectStudyplan(studyplan, studentid, updatehash = true) {
|
2024-06-02 17:21:30 +02:00
|
|
|
app.selected.planid = Number(studyplan.id);
|
2024-06-03 23:24:16 +02:00
|
|
|
app.selected.studentid = studentid ? Number(studentid) : 0;
|
|
|
|
// Fetch studyplan
|
2023-05-17 21:19:14 +02:00
|
|
|
app.loadingstudyplan = true;
|
|
|
|
app.associatedstudents = [];
|
|
|
|
app.selectedstudent = null;
|
|
|
|
app.studentstudyplan = null;
|
|
|
|
call([{
|
|
|
|
methodname: 'local_treestudyplan_get_studyplan_map',
|
2024-06-03 23:24:16 +02:00
|
|
|
args: {id: studyplan.id}
|
|
|
|
}])[0].then((response) => {
|
|
|
|
app.activestudyplan = processStudyplan(response, true);
|
2024-06-02 17:21:30 +02:00
|
|
|
|
2023-05-17 21:19:14 +02:00
|
|
|
call([{
|
2024-01-28 22:45:55 +01:00
|
|
|
methodname: 'local_treestudyplan_all_associated_grouped',
|
2024-06-03 23:24:16 +02:00
|
|
|
args: {'studyplan_id': studyplan.id}
|
|
|
|
}])[0].then((response) => {
|
2023-05-17 21:19:14 +02:00
|
|
|
app.associatedstudents = response;
|
2024-06-02 17:21:30 +02:00
|
|
|
let foundstudent = false;
|
2024-06-03 23:24:16 +02:00
|
|
|
if (studentid) {
|
|
|
|
for (const group of app.associatedstudents) {
|
|
|
|
for (const student of group.users) {
|
|
|
|
if (student.id == studentid) {
|
2024-06-02 17:21:30 +02:00
|
|
|
foundstudent = true;
|
2024-06-03 23:24:16 +02:00
|
|
|
app.showStudentView(student, updatehash);
|
2024-02-18 13:47:08 +01:00
|
|
|
break;
|
|
|
|
}
|
2023-05-17 21:19:14 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-06-02 17:21:30 +02:00
|
|
|
if (!foundstudent) {
|
|
|
|
app.selected.studentid = 0;
|
|
|
|
if (updatehash) {
|
|
|
|
window.location.hash = app.activestudyplan.id;
|
|
|
|
}
|
|
|
|
app.displayedstudyplan = app.activestudyplan;
|
|
|
|
app.loadingstudyplan = false;
|
|
|
|
}
|
2024-06-03 23:24:16 +02:00
|
|
|
return;
|
2023-12-13 23:49:06 +01:00
|
|
|
}).catch(notification.exception);
|
2024-06-03 23:24:16 +02:00
|
|
|
return;
|
|
|
|
}).catch(function(error) {
|
2023-05-17 21:19:14 +02:00
|
|
|
notification.exception(error);
|
|
|
|
app.loadingstudyplan = false;
|
|
|
|
});
|
|
|
|
},
|
2024-06-03 23:24:16 +02:00
|
|
|
showStudentView(student, updatehash = true) {
|
|
|
|
app.selected.studentid = student ? Number(student.id) : 0;
|
2024-01-28 14:41:35 +01:00
|
|
|
if (student) {
|
2024-06-02 17:21:30 +02:00
|
|
|
app.selectedstudent = student;
|
|
|
|
app.studentstudyplan = null;
|
2024-01-28 14:41:35 +01:00
|
|
|
app.loadingstudyplan = true;
|
|
|
|
call([{
|
|
|
|
methodname: 'local_treestudyplan_get_user_studyplan',
|
2024-06-03 23:24:16 +02:00
|
|
|
args: {userid: student.id, studyplanid: app.selected.planid}
|
|
|
|
}])[0].then((response) => {
|
|
|
|
app.studentstudyplan = processStudyplan(response, false);
|
2024-01-28 14:41:35 +01:00
|
|
|
app.displayedstudyplan = app.studentstudyplan;
|
|
|
|
app.loadingstudyplan = false;
|
2024-06-02 17:21:30 +02:00
|
|
|
if (updatehash) {
|
|
|
|
window.location.hash = app.activestudyplan.id + "-" + student.id;
|
|
|
|
}
|
2024-06-03 23:24:16 +02:00
|
|
|
return;
|
|
|
|
}).catch((error) => {
|
2024-01-28 14:41:35 +01:00
|
|
|
notification.exception(error);
|
|
|
|
app.loadingstudyplan = false;
|
|
|
|
});
|
2024-06-02 17:21:30 +02:00
|
|
|
} else {
|
|
|
|
this.showOverview(updatehash);
|
2024-01-28 14:41:35 +01:00
|
|
|
}
|
2023-05-17 21:19:14 +02:00
|
|
|
},
|
2024-06-03 23:24:16 +02:00
|
|
|
showOverview(updatehash = true) {
|
2024-06-02 17:21:30 +02:00
|
|
|
app.selected.studentid = 0;
|
2023-05-17 21:19:14 +02:00
|
|
|
app.selectedstudent = null;
|
|
|
|
app.studentstudyplan = null;
|
|
|
|
app.displayedstudyplan = app.activestudyplan;
|
2024-06-02 17:21:30 +02:00
|
|
|
if (updatehash) {
|
|
|
|
window.location.hash = app.activestudyplan.id;
|
|
|
|
}
|
2023-05-17 21:19:14 +02:00
|
|
|
}
|
2023-05-19 16:45:25 +02:00
|
|
|
|
2023-05-17 21:19:14 +02:00
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|