feat: class improvements

This commit is contained in:
Jannat Patel
2023-04-27 22:29:45 +05:30
parent e6621ad866
commit b5240f0eec
7 changed files with 223 additions and 79 deletions

View File

@@ -73,21 +73,8 @@ def remove_student(student, class_name):
@frappe.whitelist()
def update_course(class_name, course, value):
if cint(value):
doc = frappe.get_doc(
{
"doctype": "Class Course",
"parent": class_name,
"course": course,
"parenttype": "LMS Class",
"parentfield": "courses",
}
)
doc.save()
else:
frappe.db.delete("Class Course", {"parent": class_name, "course": course})
return True
def remove_course(course, parent):
frappe.db.delete("Class Course", {"name": course, "parent": parent})
@frappe.whitelist()

View File

@@ -1989,8 +1989,8 @@ select {
display: flex;
flex-direction: column;
border-radius: 0.75rem;
/* border: 1px solid var(--gray-200); */
box-shadow: var(--shadow-sm);
border: 1px solid var(--gray-300);
/* box-shadow: var(--shadow-sm); */
padding: 0.5rem;
height: 100%;
position: relative;

View File

@@ -112,26 +112,51 @@
{% macro CoursesSection(class_info, class_courses, published_courses) %}
<div class="class-course-list">
{% if published_courses | length %}
{% for course in published_courses %}
{% set checked = course.name in class_courses %}
<label class="class-course" data-course="{{ course.name }}">
<input type="checkbox" {% if checked %} checked {% endif %}
{% if not is_moderator %} disabled {% endif %}>
{{ course.title }}
</label>
{% endfor %}
{% endif %}
</div>
<article>
<header class="mb-5">
{% if is_moderator %}
<button class="btn btn-secondary btn-sm btn-add-course pull-right">
{{ _("Add Courses") }}
</button>
{% endif %}
<div class="bold-heading">
{{ _("Courses") }}
</div>
</header>
<div>
{% for course in class_courses %}
<div class="mb-4">
<div class="pull-right">
<svg class="icon icon-md pull-right btn-remove-course" data-course="{{ course.name }}">
<use href="#icon-delete"></use>
</svg>
</div>
<div>
{{ course.title }}
</div>
</div>
{% endfor %}
</div>
</article>
{% endmacro %}
{% macro StudentsSection(class_info, class_students) %}
<div class="">
{% if is_moderator %}
{{ AddStudents() }}
{% endif %}
<header>
<div class="pull-right">
<button class="btn btn-secondary btn-sm btn-add-student">
{{ _("Add Students") }}
</button>
</div>
<div class="bold-heading">
{{ _("Students") }}
</div>
</header>
{% if class_students | length %}
<table class="table">
@@ -171,23 +196,13 @@
</table>
{% else %}
<p class="text-muted mt-3 ml-5"> {{ _("No Students are added to this class.") }} </p>
<p class="text-muted mt-3"> {{ _("No Students are added to this class.") }} </p>
{% endif %}
</div>
{% endmacro %}
{% macro AddStudents() %}
<div class="mb-10">
<div class="add-students"></div>
<button class="btn btn-primary btn-sm ml-5" id="submit-student">
{{ _("Add") }}
</button>
</div>
{% endmacro %}
{% macro LiveClassSection(class_info, live_classes) %}
<div>
{{ CreateLiveClass(class_info) }}
@@ -304,3 +319,9 @@
{{ include_script('controls.bundle.js') }}
{% endblock %}
{% set classes = frappe.get_all("LMS Class", filters = {
"start_date": [">", frappe.utils.getdate()],
"title": ["like", "%ERPNext%"]
}, fields=["name", "title", "start_date", "end_date"])
%}

View File

@@ -1,24 +1,16 @@
frappe.ready(() => {
$("#submit-student").click((e) => {
submit_student(e);
$(".btn-add-student").click((e) => {
show_student_modal(e);
});
$(".remove-student").click((e) => {
remove_student(e);
});
$(".class-course").click((e) => {
update_course(e);
});
if ($("#live-class-form").length) {
make_live_class_form();
}
if ($(".add-students").length) {
make_add_students_section();
}
$("#open-class-modal").click((e) => {
e.preventDefault();
$("#live-class-modal").modal("show");
@@ -27,6 +19,14 @@ frappe.ready(() => {
$("#create-live-class").click((e) => {
create_live_class(e);
});
$(".btn-add-course").click((e) => {
show_course_modal(e);
});
$(".btn-remove-course").click((e) => {
remove_course(e);
});
});
const submit_student = (e) => {
@@ -77,17 +77,6 @@ const remove_student = (e) => {
);
};
const update_course = (e) => {
frappe.call({
method: "lms.lms.doctype.lms_class.lms_class.update_course",
args: {
course: $(e.currentTarget).data("course"),
value: $(e.currentTarget).children("input").prop("checked") ? 1 : 0,
class_name: $(".class-details").data("class"),
},
});
};
const create_live_class = (e) => {
let class_name = $(".class-details").data("class");
frappe.call({
@@ -353,3 +342,110 @@ const make_add_students_section = () => {
$(".add-students .form-section:last").removeClass("empty-section");
$(".add-students .frappe-control").removeClass("hide-control");
};
const show_course_modal = () => {
let course_modal = new frappe.ui.Dialog({
title: "Add Course",
fields: [
{
fieldtype: "Link",
options: "LMS Course",
label: __("Course"),
fieldname: "course",
reqd: 1,
},
],
primary_action_label: __("Add"),
primary_action(values) {
frappe.call({
method: "frappe.client.insert",
args: {
doc: {
doctype: "Class Course",
course: values.course,
parenttype: "LMS Class",
parentfield: "courses",
parent: $(".class-details").data("class"),
},
},
callback(r) {
frappe.show_alert(
{
message: __("Course Added"),
indicator: "green",
},
3
);
window.location.reload();
},
});
course_modal.hide();
},
});
course_modal.show();
};
const remove_course = (e) => {
frappe.call({
method: "lms.lms.doctype.lms_class.lms_class.remove_course",
args: {
course: $(e.target).data("course"),
parent: $(".class-details").data("class"),
},
callback(r) {
frappe.show_alert(
{
message: __("Course Removed"),
indicator: "green",
},
3
);
window.location.reload();
},
});
};
const show_student_modal = () => {
let student_modal = new frappe.ui.Dialog({
title: "Add Student",
fields: [
{
fieldtype: "Link",
options: "User",
label: __("Student"),
fieldname: "student",
reqd: 1,
filters: {
ignore_user_type: 1,
},
},
],
primary_action_label: __("Add"),
primary_action(values) {
frappe.call({
method: "frappe.client.insert",
args: {
doc: {
doctype: "Class Student",
student: values.student,
parenttype: "LMS Class",
parentfield: "students",
parent: $(".class-details").data("class"),
},
},
callback(r) {
frappe.show_alert(
{
message: __("Student Added"),
indicator: "green",
},
3
);
window.location.reload();
},
});
student_modal.hide();
},
});
student_modal.show();
};

View File

@@ -22,7 +22,7 @@ def get_context(context):
)
context.class_courses = frappe.get_all(
"Class Course", {"parent": class_name}, pluck="course"
"Class Course", {"parent": class_name}, ["name", "course", "title"]
)
class_students = frappe.get_all(

View File

@@ -12,8 +12,8 @@
</button>
{% endif %}
<div class="course-home-headings"> {{ _("All Classes") }} </div>
{% if classes %}
{{ ClassCards(classes) }}
{% if past_classes | length or upcoming_classes | length %}
{{ ClassTabs(past_classes, upcoming_classes) }}
{% else %}
<div class="empty-state">
<img class="icon icon-xl" src="/assets/lms/icons/comment.svg">
@@ -27,15 +27,38 @@
</div>
{% endblock %}
{%- block script %}
{{ super() }}
{{ include_script('controls.bundle.js') }}
{% if is_moderator %}
<script>
let class_info = null;
</script>
{% endif %}
{% endblock %}
{% macro ClassTabs(past_classes, upcoming_classes) %}
<article>
<ul class="nav lms-nav" id="courses-tab">
<li class="nav-item">
<a class="nav-link active" data-toggle="tab" href="#upcoming">
{{ _("Upcoming") }} ({{ upcoming_classes | length }})
</a>
</li>
<li class="nav-item">
<a class="nav-link" data-toggle="tab" href="#past">
{{ _("Past Classes") }} ({{ past_classes | length }})
</a>
</li>
</ul>
<div class="border-bottom mb-4"></div>
<div class="tab-content">
<div class="tab-pane active" id="upcoming" role="tabpanel" aria-labelledby="upcoming">
{{ ClassCards(upcoming_classes) }}
</div>
<div class="tab-pane" id="past" role="tabpanel" aria-labelledby="past">
{{ ClassCards(past_classes) }}
</div>
</div>
</article>
{% endmacro %}
{% macro ClassCards(classes) %}
<div class="lms-card-parent">
@@ -79,3 +102,13 @@
{% endfor %}
</div>
{% endmacro %}
{%- block script %}
{{ super() }}
{{ include_script('controls.bundle.js') }}
{% if is_moderator %}
<script>
let class_info = null;
</script>
{% endif %}
{% endblock %}

View File

@@ -6,8 +6,15 @@ from lms.lms.utils import has_course_moderator_role
def get_context(context):
context.no_cache = 1
context.is_moderator = has_course_moderator_role()
context.classes = frappe.get_all(
classes = frappe.get_all(
"LMS Class",
{"end_date": [">=", getdate()]},
["name", "title", "start_date", "end_date"],
fields=["name", "title", "start_date", "end_date"],
)
past_classes, upcoming_classes = [], []
for class_ in classes:
if getdate(class_.end_date) < getdate():
past_classes.append(class_)
else:
upcoming_classes.append(class_)
context.past_classes = past_classes
context.upcoming_classes = upcoming_classes