fix: join batch, removed code revision, redirects for other pages if batch missing
This commit is contained in:
@@ -3,8 +3,9 @@
|
|||||||
# For license information, please see license.txt
|
# For license information, please see license.txt
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
# import frappe
|
import frappe
|
||||||
from frappe.model.document import Document
|
from frappe.model.document import Document
|
||||||
|
from frappe import _
|
||||||
|
|
||||||
class CommunityProjectMember(Document):
|
class CommunityProjectMember(Document):
|
||||||
def validate(self):
|
def validate(self):
|
||||||
|
|||||||
@@ -1,8 +0,0 @@
|
|||||||
// Copyright (c) 2021, FOSS United and contributors
|
|
||||||
// For license information, please see license.txt
|
|
||||||
|
|
||||||
frappe.ui.form.on('Code Revision', {
|
|
||||||
// refresh: function(frm) {
|
|
||||||
|
|
||||||
// }
|
|
||||||
});
|
|
||||||
@@ -1,58 +0,0 @@
|
|||||||
{
|
|
||||||
"actions": [],
|
|
||||||
"creation": "2021-04-07 00:26:28.806520",
|
|
||||||
"doctype": "DocType",
|
|
||||||
"editable_grid": 1,
|
|
||||||
"engine": "InnoDB",
|
|
||||||
"field_order": [
|
|
||||||
"section",
|
|
||||||
"code",
|
|
||||||
"author"
|
|
||||||
],
|
|
||||||
"fields": [
|
|
||||||
{
|
|
||||||
"fieldname": "section",
|
|
||||||
"fieldtype": "Link",
|
|
||||||
"in_list_view": 1,
|
|
||||||
"label": "Section",
|
|
||||||
"options": "LMS Section"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"fieldname": "code",
|
|
||||||
"fieldtype": "Code",
|
|
||||||
"label": "Code"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"fieldname": "author",
|
|
||||||
"fieldtype": "Link",
|
|
||||||
"in_list_view": 1,
|
|
||||||
"label": "Author",
|
|
||||||
"options": "User"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"index_web_pages_for_search": 1,
|
|
||||||
"links": [],
|
|
||||||
"modified": "2021-04-14 11:26:19.628317",
|
|
||||||
"modified_by": "Administrator",
|
|
||||||
"module": "LMS",
|
|
||||||
"name": "Code Revision",
|
|
||||||
"owner": "Administrator",
|
|
||||||
"permissions": [
|
|
||||||
{
|
|
||||||
"create": 1,
|
|
||||||
"delete": 1,
|
|
||||||
"email": 1,
|
|
||||||
"export": 1,
|
|
||||||
"print": 1,
|
|
||||||
"read": 1,
|
|
||||||
"report": 1,
|
|
||||||
"role": "System Manager",
|
|
||||||
"share": 1,
|
|
||||||
"write": 1
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"sort_field": "modified",
|
|
||||||
"sort_order": "DESC",
|
|
||||||
"title_field": "section",
|
|
||||||
"track_changes": 1
|
|
||||||
}
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
# -*- coding: utf-8 -*-
|
|
||||||
# Copyright (c) 2021, FOSS United and contributors
|
|
||||||
# For license information, please see license.txt
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
# import frappe
|
|
||||||
from frappe.model.document import Document
|
|
||||||
|
|
||||||
class CodeRevision(Document):
|
|
||||||
pass
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
# -*- coding: utf-8 -*-
|
|
||||||
# Copyright (c) 2021, FOSS United and Contributors
|
|
||||||
# See license.txt
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
|
|
||||||
# import frappe
|
|
||||||
import unittest
|
|
||||||
|
|
||||||
class TestCodeRevision(unittest.TestCase):
|
|
||||||
pass
|
|
||||||
@@ -92,7 +92,7 @@ def update_progress(lesson):
|
|||||||
course_progress.save(ignore_permissions=True)
|
course_progress.save(ignore_permissions=True)
|
||||||
|
|
||||||
def all_dynamic_content_submitted(lesson, user):
|
def all_dynamic_content_submitted(lesson, user):
|
||||||
exercise_names = frappe.get_list("Exercise", {"lesson": lesson}, pluck="name")
|
exercise_names = frappe.get_list("Exercise", {"lesson": lesson}, pluck="name", ignore_permissions=True)
|
||||||
all_exercises_submitted = False
|
all_exercises_submitted = False
|
||||||
query = {
|
query = {
|
||||||
"exercise": ["in", exercise_names],
|
"exercise": ["in", exercise_names],
|
||||||
|
|||||||
@@ -194,12 +194,16 @@ class LMSCourse(Document):
|
|||||||
|
|
||||||
def get_current_batch(self, member=frappe.session.user):
|
def get_current_batch(self, member=frappe.session.user):
|
||||||
current_membership = frappe.get_all("LMS Batch Membership", {"member": member, "course": self.name, "is_current": 1}, pluck="batch")
|
current_membership = frappe.get_all("LMS Batch Membership", {"member": member, "course": self.name, "is_current": 1}, pluck="batch")
|
||||||
|
print(current_membership, member, self.name)
|
||||||
if len(current_membership):
|
if len(current_membership):
|
||||||
return current_membership[0]
|
return current_membership[0]
|
||||||
|
print(frappe.db.get_value("LMS Batch Membership", {"member": member, "course": self.name}, "batch"))
|
||||||
return frappe.db.get_value("LMS Batch Membership", {"member": member, "course": self.name}, "batch")
|
return frappe.db.get_value("LMS Batch Membership", {"member": member, "course": self.name}, "batch")
|
||||||
|
|
||||||
def get_all_memberships(self, member=frappe.session.user):
|
def get_all_memberships(self, member=frappe.session.user):
|
||||||
|
print(member)
|
||||||
all_memberships = frappe.get_all("LMS Batch Membership", {"member": member, "course": self.name}, ["batch", "is_current"])
|
all_memberships = frappe.get_all("LMS Batch Membership", {"member": member, "course": self.name}, ["batch", "is_current"])
|
||||||
|
print(all_memberships)
|
||||||
for membership in all_memberships:
|
for membership in all_memberships:
|
||||||
membership.batch_title = frappe.db.get_value("LMS Batch", membership.batch, "title")
|
membership.batch_title = frappe.db.get_value("LMS Batch", membership.batch, "title")
|
||||||
return all_memberships
|
return all_memberships
|
||||||
|
|||||||
@@ -45,7 +45,9 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
window.checkout_upcoming_batches = () => {
|
window.checkout_upcoming_batches = () => {
|
||||||
|
if ($(".upcoming").length > 0) {
|
||||||
$('html,body').animate({ scrollTop: $(".upcoming").offset().top }, 300);
|
$('html,body').animate({ scrollTop: $(".upcoming").offset().top }, 300);
|
||||||
|
}
|
||||||
frappe.hide_msgprint();
|
frappe.hide_msgprint();
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -4,3 +4,5 @@ from . import utils
|
|||||||
def get_context(context):
|
def get_context(context):
|
||||||
utils.get_common_context(context)
|
utils.get_common_context(context)
|
||||||
context.messages = context.batch.get_messages()
|
context.messages = context.batch.get_messages()
|
||||||
|
if not context.batch:
|
||||||
|
utils.redirect_to_lesson(context.course)
|
||||||
|
|||||||
@@ -8,7 +8,7 @@
|
|||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
{% set invite_link = frappe.utils.get_url() + "/courses/" + course.name + "/" + batch.name + "/join" %}
|
{% set invite_link = frappe.utils.get_url() + "/courses/" + course.name + "/join?batch=" + batch.name %}
|
||||||
<div class="container mt-5">
|
<div class="container mt-5">
|
||||||
{{ widgets.BatchTabs(course=course, batch=batch) }}
|
{{ widgets.BatchTabs(course=course, batch=batch) }}
|
||||||
<!-- <div>
|
<!-- <div>
|
||||||
@@ -34,7 +34,7 @@
|
|||||||
<h3> Invite Members </h3>
|
<h3> Invite Members </h3>
|
||||||
<a href="" class="" id="invite-link" data-link="{{ invite_link }}">Get Batch Invitation
|
<a href="" class="" id="invite-link" data-link="{{ invite_link }}">Get Batch Invitation
|
||||||
Link</a>
|
Link</a>
|
||||||
<small id="copy-message" class="text-muted pull-right" style="display: none;">Copied to Clipboard.</small>
|
<small id="copy-message" class="text-muted" style="display: none;">Copied to Clipboard.</small>
|
||||||
</div>
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
@@ -54,7 +54,7 @@
|
|||||||
$("#copy-message").slideDown(function () {
|
$("#copy-message").slideDown(function () {
|
||||||
setTimeout(function () {
|
setTimeout(function () {
|
||||||
$("#copy-message").slideUp();
|
$("#copy-message").slideUp();
|
||||||
}, 5000);
|
}, 2000);
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -3,3 +3,5 @@ from . import utils
|
|||||||
|
|
||||||
def get_context(context):
|
def get_context(context):
|
||||||
utils.get_common_context(context)
|
utils.get_common_context(context)
|
||||||
|
if not context.batch:
|
||||||
|
utils.redirect_to_lesson(context.course)
|
||||||
|
|||||||
@@ -13,9 +13,9 @@
|
|||||||
<div class='page-card-head'>
|
<div class='page-card-head'>
|
||||||
<span class='indicator blue password-box'>Login Required</span>
|
<span class='indicator blue password-box'>Login Required</span>
|
||||||
</div>
|
</div>
|
||||||
<div class=''>Please log in to confirm to join the course {{ batch.course_title }}.</div>
|
<div class=''>Please log in to confirm joining the course {{ batch.course_title }}.</div>
|
||||||
<a type="submit" id="login" class="btn btn-primary w-100"
|
<a type="submit" id="login" class="btn btn-primary w-100"
|
||||||
href="/login?redirect-to=/courses/{{ batch.course }}/{{ batch.name }}/join">{{_("Login")}}</a>
|
href="/login?redirect-to=/courses/{{ batch.course }}/join?batch={{ batch.name }}">{{_("Login")}}</a>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% elif already_a_member %}
|
{% elif already_a_member %}
|
||||||
@@ -26,7 +26,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class=''>You are already a member of the batch {{ batch.title }} for the course {{ batch.course_title }}.
|
<div class=''>You are already a member of the batch {{ batch.title }} for the course {{ batch.course_title }}.
|
||||||
</div>
|
</div>
|
||||||
<a type="submit" id="batch-home" class="btn btn-primary w-100" href="/courses/{{batch.course}}/{{batch.name}}/home">{{_("Go to Batch Home")}}</a>
|
<a type="submit" id="batch-home" class="btn btn-primary w-100" href="">{{_("Go to Batch Home")}}</a>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% else %}
|
{% else %}
|
||||||
@@ -38,23 +38,20 @@
|
|||||||
<div>Please provide your confirmation to be a part of the batch {{ batch.title }} for the course
|
<div>Please provide your confirmation to be a part of the batch {{ batch.title }} for the course
|
||||||
{{ batch.course_title }}.
|
{{ batch.course_title }}.
|
||||||
</div>
|
</div>
|
||||||
<a type="submit" id="confirm" class="btn btn-primary w-100" data-batch="{{ batch.name | urlencode }}"
|
<a type="submit" id="confirm" class="btn btn-primary w-100">{{_("Confirm")}}</a>
|
||||||
data-course="{{ batch.course | urlencode }}">{{_("Confirm")}}</a>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block script %}
|
||||||
<script>
|
<script>
|
||||||
frappe.ready(() => {
|
frappe.ready(() => {
|
||||||
var confirm_element = $("#confirm");
|
$("#confirm").click((e) => {
|
||||||
var batch = decodeURIComponent(confirm_element.attr("data-batch"));
|
|
||||||
var course = decodeURIComponent(confirm_element.attr("data-course"));
|
|
||||||
|
|
||||||
confirm_element.click((e) => {
|
|
||||||
frappe.call({
|
frappe.call({
|
||||||
"method": "community.lms.doctype.lms_batch_membership.lms_batch_membership.create_membership",
|
"method": "community.lms.doctype.lms_batch_membership.lms_batch_membership.create_membership",
|
||||||
"args": {
|
"args": {
|
||||||
"batch": batch
|
"batch": "{{ batch.name }}"
|
||||||
},
|
},
|
||||||
"callback": (data) => {
|
"callback": (data) => {
|
||||||
if (data.message == "OK") {
|
if (data.message == "OK") {
|
||||||
@@ -63,12 +60,25 @@
|
|||||||
clear: true
|
clear: true
|
||||||
});
|
});
|
||||||
setTimeout(function () {
|
setTimeout(function () {
|
||||||
window.location.href = "/courses/" + course + "/" + batch + "/home";
|
window.location.href = "/courses/{{ batch.course }}/home";
|
||||||
}, 2000);
|
}, 2000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
$("#batch-home").click((e) => {
|
||||||
|
frappe.call({
|
||||||
|
method: "community.lms.doctype.lms_batch_membership.lms_batch_membership.update_current_membership",
|
||||||
|
args: {
|
||||||
|
"batch": "{{ batch.name }}",
|
||||||
|
"course": "{{ batch.course}}"
|
||||||
|
},
|
||||||
|
callback: (data) => {
|
||||||
|
window.location.href = "/courses/{{ batch.course }}/home"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|||||||
@@ -3,4 +3,5 @@ from . import utils
|
|||||||
|
|
||||||
def get_context(context):
|
def get_context(context):
|
||||||
utils.get_common_context(context)
|
utils.get_common_context(context)
|
||||||
print(context.members[0].bio)
|
if not context.batch:
|
||||||
|
utils.redirect_to_lesson(context.course)
|
||||||
|
|||||||
@@ -25,3 +25,6 @@ def get_common_context(context):
|
|||||||
def get_livecode_url():
|
def get_livecode_url():
|
||||||
return frappe.db.get_single_value("LMS Settings", "livecode_url")
|
return frappe.db.get_single_value("LMS Settings", "livecode_url")
|
||||||
|
|
||||||
|
def redirect_to_lesson(course, index_="1.1"):
|
||||||
|
frappe.local.flags.redirect_location = course.get_learn_url(index_)
|
||||||
|
raise frappe.Redirect
|
||||||
|
|||||||
@@ -96,6 +96,8 @@
|
|||||||
</div>
|
</div>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
|
{% else %}
|
||||||
|
<div class="mt-5 upcoming">There are no Upcoming Batches for this course currently.</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
{% endmacro %}
|
{% endmacro %}
|
||||||
|
|||||||
Reference in New Issue
Block a user