Added course filter
This commit is contained in:
parent
383c07becd
commit
0163471a92
4 changed files with 74 additions and 6 deletions
2
amd/build/studyplan-editor-components.min.js
vendored
2
amd/build/studyplan-editor-components.min.js
vendored
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -627,7 +627,7 @@ export default {
|
||||||
for(let i = 0; i < periods; i++){
|
for(let i = 0; i < periods; i++){
|
||||||
if(line.slots[index-i] && line.slots[index-i].courses){
|
if(line.slots[index-i] && line.slots[index-i].courses){
|
||||||
const list = line.slots[index-i].courses;
|
const list = line.slots[index-i].courses;
|
||||||
for(const ix in list){ // Really wish that 'for of' would work with the minifier moodle uses
|
for(const ix in list){ s
|
||||||
const item = list[ix];
|
const item = list[ix];
|
||||||
if(item.layer == layeridx){
|
if(item.layer == layeridx){
|
||||||
if(forGradable){
|
if(forGradable){
|
||||||
|
|
|
@ -4074,8 +4074,8 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
canLoadMore() {
|
canLoadMore() {
|
||||||
return (this.value.haschildren && (!this.value.children || this.value.children.length == 0)) ||
|
return (this.value.haschildren && (!this.value.children )) ||
|
||||||
(this.value.hascourses && (!this.value.courses || this.value.courses.length == 0));
|
(this.value.hascourses && (!this.value.courses ));
|
||||||
},
|
},
|
||||||
onShowDetails(){
|
onShowDetails(){
|
||||||
const self = this;
|
const self = this;
|
||||||
|
@ -4180,10 +4180,12 @@ export default {
|
||||||
systembadges: [],
|
systembadges: [],
|
||||||
courses: [],
|
courses: [],
|
||||||
filters: {
|
filters: {
|
||||||
|
courses: "",
|
||||||
systembadges: "",
|
systembadges: "",
|
||||||
relatedbadges: "",
|
relatedbadges: "",
|
||||||
},
|
},
|
||||||
loadingcourses: false,
|
loadingcourses: false,
|
||||||
|
loadingcategories: [],
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
|
@ -4204,8 +4206,68 @@ export default {
|
||||||
type: 'filter',
|
type: 'filter',
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
filteredCourses() {
|
||||||
|
const self=this;
|
||||||
|
if (self.filters.courses) {
|
||||||
|
return self.filterCategories(self.courses);
|
||||||
|
} else {
|
||||||
|
return self.courses;
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
// TODO: Filtering like this doesn't work, since the courses are lazyloaded on opening
|
||||||
|
filterCategories(catlist) {
|
||||||
|
const self = this;
|
||||||
|
const list = [];
|
||||||
|
const search = new RegExp(`.*?${self.filters.courses}.*?`,"ig");
|
||||||
|
for (const cat of catlist) {
|
||||||
|
const clone = Object.assign({},cat);
|
||||||
|
clone.courses = [];
|
||||||
|
|
||||||
|
if (cat.courses) {
|
||||||
|
for (const course of cat.courses) {
|
||||||
|
if ( search.test(course.shortname) || search.test(course.fullname)) {
|
||||||
|
clone.courses.push(course);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (cat.hascourses && !(self.loadingcategories.includes(cat.id))) {
|
||||||
|
self.loadingcategories.push(cat.id);
|
||||||
|
debug.info(`Loading from category ${cat.category.name}`,cat);
|
||||||
|
call([{
|
||||||
|
methodname: 'local_treestudyplan_get_category',
|
||||||
|
args: { "id": cat.id}
|
||||||
|
}])[0].then(function(response){
|
||||||
|
// Add reactive array 'children' to cat
|
||||||
|
self.$set(cat,"children",response.children);
|
||||||
|
self.$set(cat,"courses",response.courses);
|
||||||
|
self.loadingcategories.splice(self.loadingcategories.indexOf(cat.id),1);
|
||||||
|
}).catch(notification.exception);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cat.children) {
|
||||||
|
clone.children = self.filterCategories(cat.children);
|
||||||
|
} else if (cat.haschildren && !(self.loadingcategories.includes(cat.id))) {
|
||||||
|
self.loadingcategories.push(cat.id);
|
||||||
|
debug.info(`Loading from category ${cat.category.name}`,cat);
|
||||||
|
call([{
|
||||||
|
methodname: 'local_treestudyplan_get_category',
|
||||||
|
args: { "id": cat.id}
|
||||||
|
}])[0].then(function(response){
|
||||||
|
// Add reactive array 'children' to cat
|
||||||
|
self.$set(cat,"children",response.children);
|
||||||
|
self.loadingcategories.splice(self.loadingcategories.indexOf(cat.id),1);
|
||||||
|
}).catch(notification.exception);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((clone.children && clone.children.length) || clone.courses.length) {
|
||||||
|
list.push(clone);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return list;
|
||||||
|
},
|
||||||
|
|
||||||
initialize() {
|
initialize() {
|
||||||
const self = this;
|
const self = this;
|
||||||
self.loadingcourses = true;
|
self.loadingcourses = true;
|
||||||
|
@ -4271,7 +4333,13 @@ export default {
|
||||||
<div v-if="loadingcourses"
|
<div v-if="loadingcourses"
|
||||||
><div class="spinner-border text-primary" role="status"></div
|
><div class="spinner-border text-primary" role="status"></div
|
||||||
></div>
|
></div>
|
||||||
<t-coursecat-list v-model="courses"></t-coursecat-list>
|
<div v-else class="ml-4">
|
||||||
|
<input v-model="filters.courses" :placeholder="text.filter"></input>
|
||||||
|
<a @click="filters.courses = ''" v-if="filters.courses" href='#'
|
||||||
|
><i class='fa fa-times'></i></a
|
||||||
|
><b-spinner small v-if="loadingcategories.length > 0" variant="primary"></b-spinner>
|
||||||
|
</div>
|
||||||
|
<t-coursecat-list v-model="filteredCourses"></t-coursecat-list>
|
||||||
</b-tab>
|
</b-tab>
|
||||||
<b-tab :title="text.flow">
|
<b-tab :title="text.flow">
|
||||||
<ul class="t-toolbox">
|
<ul class="t-toolbox">
|
||||||
|
|
Reference in a new issue