This repository has been archived on 2025-01-01. You can view files and clone it, but cannot push or open issues or pull requests.
moodle-local_treestudyplan/amd/src/page-view-plan.js

275 lines
11 KiB
JavaScript
Raw Normal View History

/*eslint no-var: "error" */
/*eslint no-unused-vars: "off" */
/*eslint linebreak-style: "off" */
/*eslint no-trailing-spaces: "off" */
/*eslint-env es6*/
// 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';
import Vue from './vue/vue';
2023-08-19 17:54:40 +02:00
import Debugger from './util/debugger';
import {load_strings} from './util/string-helper';
2023-07-18 16:12:31 +02:00
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';
import RVComponents from './report-viewer-components';
Vue.use(RVComponents);
import TSComponents from './treestudyplan-components';
import ModalComponents from './modedit-modal';
Vue.use(ModalComponents);
2023-08-19 17:54:40 +02:00
import PortalVue from './portal-vue/portal-vue.esm';
Vue.use(PortalVue);
2023-08-31 07:40:55 +02:00
import BootstrapVue from './bootstrap-vue/bootstrap-vue';
Vue.use(BootstrapVue);
let debug = new Debugger("treestudyplanviewer");
let strings = load_strings({
studyplan: {
studyplan_select_placeholder: 'studyplan_select_placeholder',
},
});
/**
* Initialize the Page
* @param {int} contextid The context we should attempt to work in (1:1 related to the category)
* @param {int} categoryid The category we shoud attempt to work in (1:1 related to the context)
*/
2023-08-19 17:54:40 +02:00
export function init(contextid,categoryid) {
// Make sure the id's are numeric and integer
2023-09-08 12:47:29 +02:00
if(undefined === contextid || !Number.isInteger(Number(contextid)) || contextid < 1 ){ contextid = 1;}
else { contextid = Number(contextid);} // ensure a numeric value instead of string
if(undefined === categoryid || !Number.isInteger(Number(categoryid))){ categoryid = 0;}
else { categoryid = Number(categoryid);} // ensure a numeric value instead of string
const in_systemcontext = (contextid <= 1);
let app = new Vue({
el: '#root',
data: {
2024-06-02 17:21:30 +02:00
selected: {
planid: 0,
studentid: 0,
},
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',
args: {context_id: contextid}
2023-12-13 23:49:06 +01:00
}])[0].then(function(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);
const t = timingval[timinga] - timingval[timingb];
if(t == 0){
// sort by name if timing is equal
return a.name.localeCompare(b.name);
}
else {
return t;
}
});
app.studyplans = response;
// load studyplan from hash if applicable
const hash = window.location.hash.replace('#','');
const parts = hash.split("-");
2023-05-19 16:45:25 +02:00
2024-06-02 17:21:30 +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]);
break;
}
}
}
2023-12-13 23:49:06 +01:00
}).catch(notification.exception);
call([{
methodname: 'local_treestudyplan_list_available_categories',
2023-12-13 23:49:06 +01:00
args: { operation: 'view', refcontext_id: contextid}
}])[0].then(function(response){
const contexts = [];
for(const ix in response){
const cat = response[ix];
if(cat.studyplancount > 0 || cat.context_id == contextid){
contexts.push(cat);
}
}
app.usedcontexts = contexts;
2023-12-13 23:49:06 +01:00
}).catch(notification.exception);
2024-06-02 17:21:30 +02:00
addBrowserButtonEvent(this.navChanged, this.navChanged);
},
computed: {
dropdown_title(){
if(this.activestudyplan && this.activestudyplan.name){
return this.activestudyplan.name;
}
else{
return this.text.studyplan_select_placeholder;
}
},
contextid(){
return contextid;
}
},
methods: {
2024-06-02 17:21:30 +02:00
navChanged() {
const hash = window.location.hash.replace('#','');
const parts = hash.split("-");
debug.log("Navigation changed",hash,parts);
if(!!parts && parts.length > 0){
const planid = Number(parts[0]);
const studentid = (parts.length > 1)?Number(parts[1]):0;
debug.log("Selected ids",planid,studentid,this.selected.planid,this.selected.studentid);
if ( planid == 0) {
if (planid != this.selected.planid) {
this.closeStudyplan(false);
}
} 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){
const plan = this.studyplans[idx];
if(Number(plan.id) == planid){
this.selectStudyplan(plan,studentid,false);
break;
}
}
} else if (this.selected.studentid != studentid) {
for(const group of app.associatedstudents) {
for(const student of group.users){
if(Number(student.id) == studentid){
app.showStudentView(student,false);
break;
}
}
}
}
}
},
switchContext(ctxid){
const params = new URLSearchParams(location.search);
2023-12-12 23:44:02 +01:00
params.delete('categoryid');
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();
},50);
},
2024-06-02 17:21:30 +02:00
closeStudyplan(updatehash=true) {
app.selected.planid = 0;
app.selected.studentid = 0;
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-02 17:21:30 +02:00
selectStudyplan(studyplan,studentid,updatehash=true){
app.selected.planid = Number(studyplan.id);
app.selected.studentid = studentid?Number(studentid):0;
// fetch studyplan
app.loadingstudyplan = true;
app.associatedstudents = [];
app.selectedstudent = null;
app.studentstudyplan = null;
call([{
methodname: 'local_treestudyplan_get_studyplan_map',
args: { id: studyplan.id}
2023-12-13 23:49:06 +01:00
}])[0].then(function(response){
app.activestudyplan = ProcessStudyplan(response,true);
2024-06-02 17:21:30 +02:00
call([{
methodname: 'local_treestudyplan_all_associated_grouped',
args: { studyplan_id: studyplan.id}
2023-12-13 23:49:06 +01:00
}])[0].then(function(response){
app.associatedstudents = response;
2024-06-02 17:21:30 +02:00
let foundstudent = false;
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;
app.showStudentView(student,updatehash);
break;
}
}
}
}
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;
}
2023-12-13 23:49:06 +01:00
}).catch(notification.exception);
2023-12-13 23:49:06 +01:00
}).catch(function(error){
notification.exception(error);
app.loadingstudyplan = false;
});
},
2024-06-02 17:21:30 +02:00
showStudentView(student,updatehash=true){
app.selected.studentid = student?Number(student.id):0;
if (student) {
2024-06-02 17:21:30 +02:00
app.selectedstudent = student;
app.studentstudyplan = null;
app.loadingstudyplan = true;
call([{
methodname: 'local_treestudyplan_get_user_studyplan',
2024-06-02 17:21:30 +02:00
args: { userid: student.id, studyplanid: app.selected.planid}
}])[0].then(function(response){
app.studentstudyplan = ProcessStudyplan(response,false);
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;
}
}).catch(function(error){
notification.exception(error);
app.loadingstudyplan = false;
});
2024-06-02 17:21:30 +02:00
} else {
this.showOverview(updatehash);
}
},
2024-06-02 17:21:30 +02:00
showOverview(updatehash=true){
app.selected.studentid = 0;
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-19 16:45:25 +02:00
},
});
}