This commit is contained in:
@@ -50,18 +50,3 @@ class CommunityCourseMember(WebsiteGenerator):
|
|||||||
send_priority=0,
|
send_priority=0,
|
||||||
queue_separately=True,
|
queue_separately=True,
|
||||||
args=args)
|
args=args)
|
||||||
|
|
||||||
def create_user(self):
|
|
||||||
user = frappe.get_doc({
|
|
||||||
"doctype": "User",
|
|
||||||
"email": self.email,
|
|
||||||
"first_name": self.full_name.split(" ")[0],
|
|
||||||
"full_name": self.full_name,
|
|
||||||
"username": self.user_name,
|
|
||||||
"send_welcome_email": 0,
|
|
||||||
"user_type": 'Website User',
|
|
||||||
"redirect_url": self.name
|
|
||||||
})
|
|
||||||
user.save(ignore_permissions=True)
|
|
||||||
update_password_link = user.reset_password()
|
|
||||||
return user, update_password_link
|
|
||||||
|
|||||||
@@ -136,7 +136,6 @@ primary_rules = [
|
|||||||
{"from_route": "/sketches/<sketch>", "to_route": "sketches/sketch"},
|
{"from_route": "/sketches/<sketch>", "to_route": "sketches/sketch"},
|
||||||
{"from_route": "/courses/<course>", "to_route": "courses/course"},
|
{"from_route": "/courses/<course>", "to_route": "courses/course"},
|
||||||
{"from_route": "/courses/<course>/<topic>", "to_route": "courses/topic"},
|
{"from_route": "/courses/<course>/<topic>", "to_route": "courses/topic"},
|
||||||
{"from_route": "/hackathons", "to_route": "hackathons"},
|
|
||||||
{"from_route": "/hackathons/<hackathon>", "to_route": "hackathons/hackathon"},
|
{"from_route": "/hackathons/<hackathon>", "to_route": "hackathons/hackathon"},
|
||||||
{"from_route": "/hackathons/<hackathon>/<project>", "to_route": "hackathons/project"},
|
{"from_route": "/hackathons/<hackathon>/<project>", "to_route": "hackathons/project"},
|
||||||
{"from_route": "/dashboard", "to_route": ""},
|
{"from_route": "/dashboard", "to_route": ""},
|
||||||
@@ -163,7 +162,8 @@ whitelist = [
|
|||||||
"/hackathons",
|
"/hackathons",
|
||||||
"/dashboard",
|
"/dashboard",
|
||||||
"/join-request"
|
"/join-request"
|
||||||
"/add-a-new-batch"
|
"/add-a-new-batch",
|
||||||
|
"/new-sign-up"
|
||||||
]
|
]
|
||||||
whitelist_rules = [{"from_route": p, "to_route": p[1:]} for p in whitelist]
|
whitelist_rules = [{"from_route": p, "to_route": p[1:]} for p in whitelist]
|
||||||
|
|
||||||
|
|||||||
0
community/lms/doctype/invite_request/__init__.py
Normal file
0
community/lms/doctype/invite_request/__init__.py
Normal file
8
community/lms/doctype/invite_request/invite_request.js
Normal file
8
community/lms/doctype/invite_request/invite_request.js
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
// Copyright (c) 2021, FOSS United and contributors
|
||||||
|
// For license information, please see license.txt
|
||||||
|
|
||||||
|
frappe.ui.form.on('Invite Request', {
|
||||||
|
// refresh: function(frm) {
|
||||||
|
|
||||||
|
// }
|
||||||
|
});
|
||||||
100
community/lms/doctype/invite_request/invite_request.json
Normal file
100
community/lms/doctype/invite_request/invite_request.json
Normal file
@@ -0,0 +1,100 @@
|
|||||||
|
{
|
||||||
|
"actions": [],
|
||||||
|
"creation": "2021-04-29 16:29:56.857914",
|
||||||
|
"doctype": "DocType",
|
||||||
|
"editable_grid": 1,
|
||||||
|
"engine": "InnoDB",
|
||||||
|
"field_order": [
|
||||||
|
"invite_email",
|
||||||
|
"signup_email",
|
||||||
|
"column_break_4",
|
||||||
|
"status",
|
||||||
|
"full_name",
|
||||||
|
"username",
|
||||||
|
"invite_code"
|
||||||
|
],
|
||||||
|
"fields": [
|
||||||
|
{
|
||||||
|
"allow_in_quick_entry": 1,
|
||||||
|
"fieldname": "invite_email",
|
||||||
|
"fieldtype": "Data",
|
||||||
|
"in_list_view": 1,
|
||||||
|
"label": "Invite Email",
|
||||||
|
"options": "Email",
|
||||||
|
"unique": 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fieldname": "full_name",
|
||||||
|
"fieldtype": "Data",
|
||||||
|
"label": "Full Name"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fieldname": "column_break_4",
|
||||||
|
"fieldtype": "Column Break"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fieldname": "signup_email",
|
||||||
|
"fieldtype": "Data",
|
||||||
|
"label": "Signup Email",
|
||||||
|
"options": "Email"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fieldname": "username",
|
||||||
|
"fieldtype": "Data",
|
||||||
|
"label": "Username"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fieldname": "invite_code",
|
||||||
|
"fieldtype": "Data",
|
||||||
|
"label": "Invite Code"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"default": "Pending",
|
||||||
|
"fieldname": "status",
|
||||||
|
"fieldtype": "Select",
|
||||||
|
"in_list_view": 1,
|
||||||
|
"in_standard_filter": 1,
|
||||||
|
"label": "Status",
|
||||||
|
"options": "Pending\nApproved\nRejected\nRegistered"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"index_web_pages_for_search": 1,
|
||||||
|
"links": [],
|
||||||
|
"modified": "2021-05-01 13:59:27.624814",
|
||||||
|
"modified_by": "Administrator",
|
||||||
|
"module": "LMS",
|
||||||
|
"name": "Invite Request",
|
||||||
|
"owner": "Administrator",
|
||||||
|
"permissions": [
|
||||||
|
{
|
||||||
|
"create": 1,
|
||||||
|
"delete": 1,
|
||||||
|
"email": 1,
|
||||||
|
"export": 1,
|
||||||
|
"print": 1,
|
||||||
|
"read": 1,
|
||||||
|
"report": 1,
|
||||||
|
"role": "System Manager",
|
||||||
|
"share": 1,
|
||||||
|
"write": 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"create": 1,
|
||||||
|
"delete": 1,
|
||||||
|
"email": 1,
|
||||||
|
"export": 1,
|
||||||
|
"print": 1,
|
||||||
|
"read": 1,
|
||||||
|
"report": 1,
|
||||||
|
"role": "Guest",
|
||||||
|
"share": 1,
|
||||||
|
"write": 1
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"quick_entry": 1,
|
||||||
|
"search_fields": "invite_email, signup_email",
|
||||||
|
"sort_field": "modified",
|
||||||
|
"sort_order": "DESC",
|
||||||
|
"title_field": "invite_email",
|
||||||
|
"track_changes": 1
|
||||||
|
}
|
||||||
73
community/lms/doctype/invite_request/invite_request.py
Normal file
73
community/lms/doctype/invite_request/invite_request.py
Normal file
@@ -0,0 +1,73 @@
|
|||||||
|
# -*- 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 import _
|
||||||
|
from frappe.model.document import Document
|
||||||
|
import json
|
||||||
|
from frappe.utils.password import get_decrypted_password
|
||||||
|
|
||||||
|
class InviteRequest(Document):
|
||||||
|
def on_update(self):
|
||||||
|
if self.has_value_changed('status') and self.status == "Approved":
|
||||||
|
self.send_email()
|
||||||
|
|
||||||
|
def create_user(self, password):
|
||||||
|
user = frappe.get_doc({
|
||||||
|
"doctype": "User",
|
||||||
|
"email": self.signup_email,
|
||||||
|
"first_name": self.full_name.split(" ")[0],
|
||||||
|
"full_name": self.full_name,
|
||||||
|
"username": self.username,
|
||||||
|
"send_welcome_email": 0,
|
||||||
|
"user_type": 'Website User',
|
||||||
|
"new_password": password
|
||||||
|
})
|
||||||
|
user.save(ignore_permissions=True)
|
||||||
|
return user
|
||||||
|
|
||||||
|
def send_email(self):
|
||||||
|
subject = _("Your request has been approved.")
|
||||||
|
args = {
|
||||||
|
"full_name": self.full_name,
|
||||||
|
"signup_form_link": "/new-sign-up?invite_code={0}".format(self.name),
|
||||||
|
"site_url": frappe.utils.get_url()
|
||||||
|
}
|
||||||
|
frappe.sendmail(
|
||||||
|
recipients=self.invite_email,
|
||||||
|
sender=frappe.db.get_single_value("LMS Settings", "email_sender"),
|
||||||
|
subject=subject,
|
||||||
|
header=[subject, "green"],
|
||||||
|
template = "lms_invite_request_approved",
|
||||||
|
args=args)
|
||||||
|
|
||||||
|
@frappe.whitelist(allow_guest=True)
|
||||||
|
def create_invite_request(email):
|
||||||
|
frappe.get_doc({
|
||||||
|
"doctype": "Invite Request",
|
||||||
|
"invite_email": email
|
||||||
|
}).save(ignore_permissions=True)
|
||||||
|
|
||||||
|
@frappe.whitelist(allow_guest=True)
|
||||||
|
def update_invite(data):
|
||||||
|
data = frappe._dict(json.loads(data))
|
||||||
|
|
||||||
|
try:
|
||||||
|
doc = frappe.get_doc("Invite Request", data.invite_code)
|
||||||
|
except frappe.DoesNotExistError:
|
||||||
|
frappe.throw(_("Invalid Invite Code."))
|
||||||
|
|
||||||
|
doc.signup_email = data.signup_email
|
||||||
|
doc.username = data.username
|
||||||
|
doc.full_name = data.full_name
|
||||||
|
doc.invite_code = data.invite_code
|
||||||
|
doc.save(ignore_permissions=True)
|
||||||
|
|
||||||
|
user = doc.create_user(data.password)
|
||||||
|
if user:
|
||||||
|
doc.status = "Registered"
|
||||||
|
doc.save(ignore_permissions=True)
|
||||||
|
|
||||||
|
return "OK"
|
||||||
10
community/lms/doctype/invite_request/test_invite_request.py
Normal file
10
community/lms/doctype/invite_request/test_invite_request.py
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Copyright (c) 2021, FOSS United and Contributors
|
||||||
|
# See license.txt
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
# import frappe
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
class TestInviteRequest(unittest.TestCase):
|
||||||
|
pass
|
||||||
@@ -27,6 +27,8 @@
|
|||||||
{
|
{
|
||||||
"fieldname": "course",
|
"fieldname": "course",
|
||||||
"fieldtype": "Link",
|
"fieldtype": "Link",
|
||||||
|
"in_list_view": 1,
|
||||||
|
"in_standard_filter": 1,
|
||||||
"label": "Course",
|
"label": "Course",
|
||||||
"options": "LMS Course"
|
"options": "LMS Course"
|
||||||
},
|
},
|
||||||
@@ -91,11 +93,13 @@
|
|||||||
{
|
{
|
||||||
"fieldname": "start_date",
|
"fieldname": "start_date",
|
||||||
"fieldtype": "Date",
|
"fieldtype": "Date",
|
||||||
|
"in_list_view": 1,
|
||||||
"label": "Start Date"
|
"label": "Start Date"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"fieldname": "start_time",
|
"fieldname": "start_time",
|
||||||
"fieldtype": "Time",
|
"fieldtype": "Time",
|
||||||
|
"in_list_view": 1,
|
||||||
"label": "Start Time"
|
"label": "Start Time"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -106,6 +110,7 @@
|
|||||||
{
|
{
|
||||||
"fieldname": "end_time",
|
"fieldname": "end_time",
|
||||||
"fieldtype": "Time",
|
"fieldtype": "Time",
|
||||||
|
"in_list_view": 1,
|
||||||
"label": "End Time"
|
"label": "End Time"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
@@ -117,7 +122,7 @@
|
|||||||
"link_fieldname": "batch"
|
"link_fieldname": "batch"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"modified": "2021-04-21 12:45:21.144972",
|
"modified": "2021-04-30 09:52:18.941276",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"module": "LMS",
|
"module": "LMS",
|
||||||
"name": "LMS Batch",
|
"name": "LMS Batch",
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ class LMSBatchMembership(Document):
|
|||||||
self.validate_membership_in_different_batch_same_course()
|
self.validate_membership_in_different_batch_same_course()
|
||||||
|
|
||||||
def validate_membership_in_same_batch(self):
|
def validate_membership_in_same_batch(self):
|
||||||
previous_membership = frappe.db.get_value("LMS Batch Membership", {"member": self.member, "batch": self.batch}, ["member_type","member"], as_dict=1)
|
previous_membership = frappe.db.get_value("LMS Batch Membership", {"member": self.member, "batch": self.batch, "name": ["!=", self.name]}, ["member_type","member"], as_dict=1)
|
||||||
if previous_membership:
|
if previous_membership:
|
||||||
member_name = frappe.db.get_value("Community Member", self.member, "full_name")
|
member_name = frappe.db.get_value("Community Member", self.member, "full_name")
|
||||||
frappe.throw(_("{0} is already a {1} of {2}").format(member_name, previous_membership.member_type, self.batch))
|
frappe.throw(_("{0} is already a {1} of {2}").format(member_name, previous_membership.member_type, self.batch))
|
||||||
@@ -29,7 +29,7 @@ class LMSBatchMembership(Document):
|
|||||||
frappe.throw(_("{0} is already a {1} of {2} course through {3} batch").format(member_name, membership.member_type, course, membership.batch))
|
frappe.throw(_("{0} is already a {1} of {2} course through {3} batch").format(member_name, membership.member_type, course, membership.batch))
|
||||||
|
|
||||||
@frappe.whitelist()
|
@frappe.whitelist()
|
||||||
def create_membership(batch, member=None, member_type="Student", role="Member"):
|
def create_membership(batch, course, member=None, member_type="Student", role="Member"):
|
||||||
if not member:
|
if not member:
|
||||||
member = frappe.db.get_value("Community Member", {"email": frappe.session.user}, "name")
|
member = frappe.db.get_value("Community Member", {"email": frappe.session.user}, "name")
|
||||||
frappe.get_doc({
|
frappe.get_doc({
|
||||||
@@ -39,4 +39,5 @@ def create_membership(batch, member=None, member_type="Student", role="Member"):
|
|||||||
"member_type": member_type,
|
"member_type": member_type,
|
||||||
"member": member
|
"member": member
|
||||||
}).save(ignore_permissions=True)
|
}).save(ignore_permissions=True)
|
||||||
return "OK"
|
course_slug = frappe.db.get_value("LMS Course", {"title": course}, ["slug"])
|
||||||
|
return course_slug
|
||||||
@@ -79,7 +79,7 @@ def send_creation_email(course, member):
|
|||||||
subject = _('Request for Mentorship')
|
subject = _('Request for Mentorship')
|
||||||
send_email([frappe.session.user, get_course_author(course)], None, subject, message)
|
send_email([frappe.session.user, get_course_author(course)], None, subject, message)
|
||||||
|
|
||||||
def send_email(recipients, cc, subject, message):
|
def send_email(recipients, cc=None, subject=None, message=None, template=None, args=None):
|
||||||
frappe.sendmail(
|
frappe.sendmail(
|
||||||
recipients = recipients,
|
recipients = recipients,
|
||||||
cc = cc,
|
cc = cc,
|
||||||
@@ -87,5 +87,7 @@ def send_email(recipients, cc, subject, message):
|
|||||||
subject = subject,
|
subject = subject,
|
||||||
send_priority = 0,
|
send_priority = 0,
|
||||||
queue_separately = True,
|
queue_separately = True,
|
||||||
message = message
|
message = message,
|
||||||
|
template=template,
|
||||||
|
args=args
|
||||||
)
|
)
|
||||||
@@ -6,10 +6,11 @@
|
|||||||
"engine": "InnoDB",
|
"engine": "InnoDB",
|
||||||
"field_order": [
|
"field_order": [
|
||||||
"livecode_url",
|
"livecode_url",
|
||||||
|
"column_break_2",
|
||||||
|
"email_sender",
|
||||||
"mentor_request_section",
|
"mentor_request_section",
|
||||||
"mentor_request_creation",
|
"mentor_request_creation",
|
||||||
"mentor_request_status_update",
|
"mentor_request_status_update"
|
||||||
"email_sender"
|
|
||||||
],
|
],
|
||||||
"fields": [
|
"fields": [
|
||||||
{
|
{
|
||||||
@@ -40,12 +41,16 @@
|
|||||||
"fieldname": "mentor_request_section",
|
"fieldname": "mentor_request_section",
|
||||||
"fieldtype": "Section Break",
|
"fieldtype": "Section Break",
|
||||||
"label": "Mentor Request"
|
"label": "Mentor Request"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fieldname": "column_break_2",
|
||||||
|
"fieldtype": "Column Break"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"index_web_pages_for_search": 1,
|
"index_web_pages_for_search": 1,
|
||||||
"issingle": 1,
|
"issingle": 1,
|
||||||
"links": [],
|
"links": [],
|
||||||
"modified": "2021-04-21 13:28:35.783395",
|
"modified": "2021-04-29 17:14:43.589700",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"module": "LMS",
|
"module": "LMS",
|
||||||
"name": "LMS Settings",
|
"name": "LMS Settings",
|
||||||
|
|||||||
@@ -5,27 +5,35 @@ frappe.ready(function () {
|
|||||||
"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": data.title,
|
"batch": data.title,
|
||||||
"member_type": "Mentor"
|
"member_type": "Mentor",
|
||||||
|
"course": data.course
|
||||||
},
|
},
|
||||||
"callback": (data) => {
|
"callback": (data) => {
|
||||||
if (data.message == "OK") {
|
if (data.message) {
|
||||||
window.location.href = "/courses"
|
window.location.href = `courses/${data.message}`
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
frappe.web_form.validate = () => {
|
frappe.web_form.validate = () => {
|
||||||
|
let sysdefaults = frappe.boot.sysdefaults;
|
||||||
|
let time_format = sysdefaults && sysdefaults.time_format ? sysdefaults.time_format : 'HH:mm:ss';
|
||||||
let data = frappe.web_form.get_values();
|
let data = frappe.web_form.get_values();
|
||||||
|
|
||||||
|
data.start_time = moment(data.start_time,time_format).format(time_format)
|
||||||
|
data.end_time = moment(data.end_time,time_format).format(time_format)
|
||||||
|
|
||||||
if (!frappe.datetime.validate(data.start_time) || !frappe.datetime.validate(data.end_time)) {
|
if (!frappe.datetime.validate(data.start_time) || !frappe.datetime.validate(data.end_time)) {
|
||||||
frappe.msgprint(__('Invalid Start or End Time.'));
|
frappe.msgprint(__('Invalid Start or End Time.'));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (data.start_time > data.end_time) {
|
if (data.start_time > data.end_time) {
|
||||||
frappe.msgprint(__('Start Time should be less than End Time.'));
|
frappe.msgprint(__('Start Time should be less than End Time.'));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
console.log(data.start_date, date.nowdate())
|
|
||||||
if (data.start_date < date.nowdate()) {
|
if (data.start_date < date.nowdate()) {
|
||||||
frappe.msgprint(__('Start date cannot be a past date.'))
|
frappe.msgprint(__('Start date cannot be a past date.'))
|
||||||
return false;
|
return false;
|
||||||
|
|||||||
@@ -11,6 +11,7 @@
|
|||||||
"apply_document_permissions": 0,
|
"apply_document_permissions": 0,
|
||||||
"button_label": "Save",
|
"button_label": "Save",
|
||||||
"creation": "2021-04-20 11:37:49.135114",
|
"creation": "2021-04-20 11:37:49.135114",
|
||||||
|
"custom_css": ".datepicker.active {\n background-color: white;\n}",
|
||||||
"doc_type": "LMS Batch",
|
"doc_type": "LMS Batch",
|
||||||
"docstatus": 0,
|
"docstatus": 0,
|
||||||
"doctype": "Web Form",
|
"doctype": "Web Form",
|
||||||
@@ -18,7 +19,7 @@
|
|||||||
"is_standard": 1,
|
"is_standard": 1,
|
||||||
"login_required": 1,
|
"login_required": 1,
|
||||||
"max_attachment_size": 0,
|
"max_attachment_size": 0,
|
||||||
"modified": "2021-04-26 11:08:00.026388",
|
"modified": "2021-04-30 11:22:18.188712",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"module": "LMS",
|
"module": "LMS",
|
||||||
"name": "add-a-new-batch",
|
"name": "add-a-new-batch",
|
||||||
@@ -37,13 +38,13 @@
|
|||||||
{
|
{
|
||||||
"allow_read_on_all_link_options": 0,
|
"allow_read_on_all_link_options": 0,
|
||||||
"fieldname": "course",
|
"fieldname": "course",
|
||||||
"fieldtype": "Link",
|
"fieldtype": "Data",
|
||||||
"hidden": 0,
|
"hidden": 0,
|
||||||
"label": "Course",
|
"label": "Course",
|
||||||
"max_length": 0,
|
"max_length": 0,
|
||||||
"max_value": 0,
|
"max_value": 0,
|
||||||
"options": "LMS Course",
|
"options": "",
|
||||||
"read_only": 0,
|
"read_only": 1,
|
||||||
"reqd": 0,
|
"reqd": 0,
|
||||||
"show_in_filter": 0
|
"show_in_filter": 0
|
||||||
},
|
},
|
||||||
@@ -90,7 +91,7 @@
|
|||||||
"fieldname": "start_time",
|
"fieldname": "start_time",
|
||||||
"fieldtype": "Data",
|
"fieldtype": "Data",
|
||||||
"hidden": 0,
|
"hidden": 0,
|
||||||
"label": "Start Time (HH:MM:SS)",
|
"label": "Start Time",
|
||||||
"max_length": 0,
|
"max_length": 0,
|
||||||
"max_value": 0,
|
"max_value": 0,
|
||||||
"read_only": 0,
|
"read_only": 0,
|
||||||
@@ -102,7 +103,7 @@
|
|||||||
"fieldname": "end_time",
|
"fieldname": "end_time",
|
||||||
"fieldtype": "Data",
|
"fieldtype": "Data",
|
||||||
"hidden": 0,
|
"hidden": 0,
|
||||||
"label": "End Time (HH:MM:SS)",
|
"label": "End Time",
|
||||||
"max_length": 0,
|
"max_length": 0,
|
||||||
"max_value": 0,
|
"max_value": 0,
|
||||||
"read_only": 0,
|
"read_only": 0,
|
||||||
|
|||||||
18
community/templates/emails/lms_invite_request_approved.html
Normal file
18
community/templates/emails/lms_invite_request_approved.html
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
<div>
|
||||||
|
{% set site_link = "<a href='" + site_url + "'>" + site_url + "</a>" %}
|
||||||
|
<p>{{_("Dear Community Member,")}}</p>
|
||||||
|
<p>{{_("Your Invite Request to be a part of {0} has
|
||||||
|
been approved.").format(site_link)}}</p>
|
||||||
|
<p>Click on the link below to complete your Sign up and set a new password</p>
|
||||||
|
<p style="margin: 15px 0px;">
|
||||||
|
<a href="{{ signup_form_link }}" rel="nofollow" class="btn btn-primary">{{ _("Complete Sign Up") }}</a>
|
||||||
|
</p>
|
||||||
|
<br>
|
||||||
|
<p>
|
||||||
|
{{_("You can also copy-paste following link in your browser")}}<br>
|
||||||
|
<a href="{{ signup_form_link }}">{{ site_url }}{{ signup_form_link }}</a>
|
||||||
|
</p>
|
||||||
|
<br>
|
||||||
|
<p>Thanks and Regards,</p>
|
||||||
|
<p>Your Community.</p>
|
||||||
|
</div>
|
||||||
@@ -111,11 +111,11 @@
|
|||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<a class="btn btn-primary add-batch margin-bottom" href="/add-a-new-batch?new=1&course={{course.name}}">Add a new batch</a>
|
<a class="btn btn-primary add-batch margin-bottom" href="/add-a-new-batch?new=1&course={{course.title}}">Add a new batch</a>
|
||||||
{% else %}
|
{% else %}
|
||||||
<div class="mentor_message">
|
<div class="mentor_message">
|
||||||
<p> You are a mentor for this course. </p>
|
<p> You are a mentor for this course. </p>
|
||||||
<a class="btn btn-primary" href="/add-a-new-batch?new=1&course={{course.name}}" >Create your first batch</a>
|
<a class="btn btn-primary" href="/add-a-new-batch?new=1&course={{course.title}}" >Create your first batch</a>
|
||||||
</div>
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% endmacro %}
|
{% endmacro %}
|
||||||
|
|||||||
65
community/www/new-sign-up.html
Normal file
65
community/www/new-sign-up.html
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
{% extends "templates/web.html" %}
|
||||||
|
|
||||||
|
{% block title %} {{_("New Sign Up")}} {% endblock %}
|
||||||
|
|
||||||
|
{% block page_content %}
|
||||||
|
|
||||||
|
<form id="reset-password">
|
||||||
|
<div class="form-group">
|
||||||
|
<input id="full_name" type="text" class="form-control" placeholder="{{ _('Full Name') }}" required>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<input id="signup_email" type="email" class="form-control" placeholder="{{ _('Email') }}" required>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<input id="username" type="text" class="form-control" placeholder="{{ _('Username') }}" required>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<input id="password" type="password" class="form-control" placeholder="{{ _('Password') }}" required>
|
||||||
|
<span class="password-strength-indicator indicator"></span>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<p class='password-strength-message text-muted small hidden'></p>
|
||||||
|
<div class="form-group">
|
||||||
|
<input id="invite_code" type="text" class="form-control" placeholder="{{ _('Invite Code') }}" readonly required
|
||||||
|
value="{{ frappe.form_dict['invite_code'] }}">
|
||||||
|
</div>
|
||||||
|
<button type="submit" id="submit" class="btn btn-primary">{{_("Submit")}}</button>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
frappe.ready(() => {
|
||||||
|
$("#submit").click(function () {
|
||||||
|
var data = {
|
||||||
|
full_name: $("#full_name").val(),
|
||||||
|
signup_email: $("#signup_email").val(),
|
||||||
|
username: $("#username").val(),
|
||||||
|
password: $("#password").val(),
|
||||||
|
invite_code: $("#invite_code").val(),
|
||||||
|
};
|
||||||
|
|
||||||
|
frappe.call({
|
||||||
|
type: "POST",
|
||||||
|
method: "community.lms.doctype.invite_request.invite_request.update_invite",
|
||||||
|
args: {
|
||||||
|
"data": data
|
||||||
|
},
|
||||||
|
callback: (data) => {
|
||||||
|
$("input").val("");
|
||||||
|
if (data.message == "OK") {
|
||||||
|
frappe.msgprint({
|
||||||
|
message: __("Your Account has been successfully created!"),
|
||||||
|
clear: true
|
||||||
|
});
|
||||||
|
setTimeout(function() {
|
||||||
|
window.location.href = "/login";
|
||||||
|
}, 2000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
})
|
||||||
|
</script>
|
||||||
|
|
||||||
|
{% endblock %}
|
||||||
@@ -1,14 +1,16 @@
|
|||||||
import frappe
|
import frappe
|
||||||
from ...lms.doctype.lms_sketch.lms_sketch import get_recent_sketches
|
from community.lms.models import Sketch
|
||||||
|
|
||||||
def get_context(context):
|
def get_context(context):
|
||||||
context.no_cache = 1
|
context.no_cache = 1
|
||||||
context.username = frappe.form_dict["username"]
|
context.username = frappe.form_dict["username"]
|
||||||
|
print(frappe.form_dict["username"])
|
||||||
context.member = get_member(context.username)
|
context.member = get_member(context.username)
|
||||||
|
print(context.member)
|
||||||
if not context.member:
|
if not context.member:
|
||||||
context.template = "www/404.html"
|
context.template = "www/404.html"
|
||||||
else:
|
else:
|
||||||
context.sketches = list(filter(lambda x: x.owner == context.member.email, get_recent_sketches()))
|
context.sketches = list(filter(lambda x: x.owner == context.member.email, Sketch.get_recent_sketches()))
|
||||||
|
|
||||||
def get_member(username):
|
def get_member(username):
|
||||||
try:
|
try:
|
||||||
|
|||||||
Reference in New Issue
Block a user