fix: attendance cannot be marked outside of Academic Year validation

This commit is contained in:
Rucha Mahabal 2020-10-23 18:32:33 +05:30
parent 8b4d33474e
commit b01334d2e1
3 changed files with 116 additions and 316 deletions

View File

@ -7,7 +7,7 @@ import frappe
import json import json
from frappe import _ from frappe import _
from frappe.model.mapper import get_mapped_doc from frappe.model.mapper import get_mapped_doc
from frappe.utils import flt, cstr from frappe.utils import flt, cstr, getdate
from frappe.email.doctype.email_group.email_group import add_subscribers from frappe.email.doctype.email_group.email_group import add_subscribers
def get_course(program): def get_course(program):
@ -67,6 +67,13 @@ def mark_attendance(students_present, students_absent, course_schedule=None, stu
:param date: Date. :param date: Date.
""" """
if student_group:
academic_year = frappe.db.get_value('Student Group', student_group, 'academic_year')
if academic_year:
year_start_date, year_end_date = frappe.db.get_value('Academic Year', academic_year, ['year_start_date', 'year_end_date'])
if getdate(date) < getdate(year_start_date) or getdate(date) > getdate(year_end_date):
frappe.throw(_('Attendance cannot be marked outside of Academic Year {0}').format(academic_year))
present = json.loads(students_present) present = json.loads(students_present)
absent = json.loads(students_absent) absent = json.loads(students_absent)

View File

@ -31,6 +31,14 @@ class StudentAttendance(Document):
if getdate(self.date) > getdate(): if getdate(self.date) > getdate():
frappe.throw(_('Attendance cannot be marked for future dates.')) frappe.throw(_('Attendance cannot be marked for future dates.'))
if self.student_group:
academic_year = frappe.db.get_value('Student Group', self.student_group, 'academic_year')
if academic_year:
year_start_date, year_end_date = frappe.db.get_value('Academic Year', academic_year, ['year_start_date', 'year_end_date'])
if year_start_date and year_end_date:
if getdate(self.date) < getdate(year_start_date) or getdate(self.date) > getdate(year_end_date):
frappe.throw(_('Attendance cannot be marked outside of Academic Year {0}').format(academic_year))
def set_student_group(self): def set_student_group(self):
if self.course_schedule: if self.course_schedule:
self.student_group = frappe.db.get_value('Course Schedule', self.course_schedule, 'student_group') self.student_group = frappe.db.get_value('Course Schedule', self.course_schedule, 'student_group')

View File

@ -1,333 +1,118 @@
{ {
"allow_copy": 1, "actions": [],
"allow_guest_to_view": 0, "allow_copy": 1,
"allow_import": 0, "creation": "2016-11-16 17:12:46.437539",
"allow_rename": 0, "doctype": "DocType",
"beta": 0, "editable_grid": 1,
"creation": "2016-11-16 17:12:46.437539", "engine": "InnoDB",
"custom": 0, "field_order": [
"docstatus": 0, "based_on",
"doctype": "DocType", "group_based_on",
"document_type": "", "column_break_2",
"editable_grid": 1, "student_group",
"engine": "InnoDB", "academic_year",
"academic_term",
"course_schedule",
"date",
"attendance",
"students_html"
],
"fields": [ "fields": [
{ {
"allow_bulk_edit": 0, "fieldname": "based_on",
"allow_on_submit": 0, "fieldtype": "Select",
"bold": 0, "label": "Based On",
"collapsible": 0, "options": "Student Group\nCourse Schedule"
"columns": 0, },
"default": "",
"fieldname": "based_on",
"fieldtype": "Select",
"hidden": 0,
"ignore_user_permissions": 0,
"ignore_xss_filter": 0,
"in_filter": 0,
"in_global_search": 0,
"in_list_view": 0,
"in_standard_filter": 0,
"label": "Based On",
"length": 0,
"no_copy": 0,
"options": "Student Group\nCourse Schedule",
"permlevel": 0,
"precision": "",
"print_hide": 0,
"print_hide_if_no_value": 0,
"read_only": 0,
"remember_last_selected_value": 0,
"report_hide": 0,
"reqd": 0,
"search_index": 0,
"set_only_once": 0,
"unique": 0
},
{ {
"allow_bulk_edit": 0, "default": "Batch",
"allow_on_submit": 0, "depends_on": "eval:doc.based_on == \"Student Group\"",
"bold": 0, "fieldname": "group_based_on",
"collapsible": 0, "fieldtype": "Select",
"columns": 0, "label": "Group Based On",
"default": "Batch", "options": "Batch\nCourse\nActivity"
"depends_on": "eval:doc.based_on == \"Student Group\"", },
"fieldname": "group_based_on",
"fieldtype": "Select",
"hidden": 0,
"ignore_user_permissions": 0,
"ignore_xss_filter": 0,
"in_filter": 0,
"in_global_search": 0,
"in_list_view": 0,
"in_standard_filter": 0,
"label": "Group Based On",
"length": 0,
"no_copy": 0,
"options": "Batch\nCourse\nActivity",
"permlevel": 0,
"precision": "",
"print_hide": 0,
"print_hide_if_no_value": 0,
"read_only": 0,
"remember_last_selected_value": 0,
"report_hide": 0,
"reqd": 0,
"search_index": 0,
"set_only_once": 0,
"unique": 0
},
{ {
"allow_bulk_edit": 0, "fieldname": "column_break_2",
"allow_on_submit": 0, "fieldtype": "Column Break"
"bold": 0, },
"collapsible": 0,
"columns": 0,
"fieldname": "column_break_2",
"fieldtype": "Column Break",
"hidden": 0,
"ignore_user_permissions": 0,
"ignore_xss_filter": 0,
"in_filter": 0,
"in_global_search": 0,
"in_list_view": 0,
"in_standard_filter": 0,
"length": 0,
"no_copy": 0,
"permlevel": 0,
"precision": "",
"print_hide": 0,
"print_hide_if_no_value": 0,
"read_only": 0,
"remember_last_selected_value": 0,
"report_hide": 0,
"reqd": 0,
"search_index": 0,
"set_only_once": 0,
"unique": 0
},
{ {
"allow_bulk_edit": 0, "depends_on": "eval:doc.based_on ==\"Student Group\"",
"allow_on_submit": 0, "fieldname": "student_group",
"bold": 0, "fieldtype": "Link",
"collapsible": 0, "in_list_view": 1,
"columns": 0, "label": "Student Group",
"depends_on": "eval:doc.based_on ==\"Student Group\"", "options": "Student Group",
"fieldname": "student_group", "reqd": 1
"fieldtype": "Link", },
"hidden": 0,
"ignore_user_permissions": 0,
"ignore_xss_filter": 0,
"in_filter": 0,
"in_global_search": 0,
"in_list_view": 1,
"in_standard_filter": 0,
"label": "Student Group",
"length": 0,
"no_copy": 0,
"options": "Student Group",
"permlevel": 0,
"precision": "",
"print_hide": 0,
"print_hide_if_no_value": 0,
"read_only": 0,
"remember_last_selected_value": 0,
"report_hide": 0,
"reqd": 1,
"search_index": 0,
"set_only_once": 0,
"unique": 0
},
{ {
"allow_bulk_edit": 0, "depends_on": "eval:doc.based_on ==\"Course Schedule\"",
"allow_on_submit": 0, "fieldname": "course_schedule",
"bold": 0, "fieldtype": "Link",
"collapsible": 0, "in_list_view": 1,
"columns": 0, "label": "Course Schedule",
"depends_on": "eval:doc.based_on ==\"Course Schedule\"", "options": "Course Schedule",
"fieldname": "course_schedule", "reqd": 1
"fieldtype": "Link", },
"hidden": 0,
"ignore_user_permissions": 0,
"ignore_xss_filter": 0,
"in_filter": 0,
"in_global_search": 0,
"in_list_view": 1,
"in_standard_filter": 0,
"label": "Course Schedule",
"length": 0,
"no_copy": 0,
"options": "Course Schedule",
"permlevel": 0,
"precision": "",
"print_hide": 0,
"print_hide_if_no_value": 0,
"read_only": 0,
"remember_last_selected_value": 0,
"report_hide": 0,
"reqd": 1,
"search_index": 0,
"set_only_once": 0,
"unique": 0
},
{ {
"allow_bulk_edit": 0, "depends_on": "eval:doc.based_on ==\"Student Group\"",
"allow_on_submit": 0, "fieldname": "date",
"bold": 0, "fieldtype": "Date",
"collapsible": 0, "in_list_view": 1,
"columns": 0, "label": "Date",
"depends_on": "eval:doc.based_on ==\"Student Group\"", "reqd": 1
"fieldname": "date", },
"fieldtype": "Date",
"hidden": 0,
"ignore_user_permissions": 0,
"ignore_xss_filter": 0,
"in_filter": 0,
"in_global_search": 0,
"in_list_view": 1,
"in_standard_filter": 0,
"label": "Date",
"length": 0,
"no_copy": 0,
"permlevel": 0,
"precision": "",
"print_hide": 0,
"print_hide_if_no_value": 0,
"read_only": 0,
"remember_last_selected_value": 0,
"report_hide": 0,
"reqd": 1,
"search_index": 0,
"set_only_once": 0,
"unique": 0
},
{ {
"allow_bulk_edit": 0, "depends_on": "eval: (doc.course_schedule \n|| (doc.student_group && doc.date))",
"allow_on_submit": 0, "fieldname": "attendance",
"bold": 0, "fieldtype": "Section Break",
"collapsible": 0, "label": "Attendance"
"columns": 0, },
"depends_on": "eval: (doc.course_schedule \n|| (doc.student_group && doc.date))",
"fieldname": "attendance",
"fieldtype": "Section Break",
"hidden": 0,
"ignore_user_permissions": 0,
"ignore_xss_filter": 0,
"in_filter": 0,
"in_global_search": 0,
"in_list_view": 0,
"in_standard_filter": 0,
"label": "Attendance",
"length": 0,
"no_copy": 0,
"permlevel": 0,
"precision": "",
"print_hide": 0,
"print_hide_if_no_value": 0,
"read_only": 0,
"remember_last_selected_value": 0,
"report_hide": 0,
"reqd": 0,
"search_index": 0,
"set_only_once": 0,
"unique": 0
},
{ {
"allow_bulk_edit": 0, "fieldname": "students_html",
"allow_on_submit": 0, "fieldtype": "HTML",
"bold": 0, "label": "Students HTML"
"collapsible": 0, },
"columns": 0, {
"fieldname": "students_html", "fetch_from": "student_group.academic_year",
"fieldtype": "HTML", "fieldname": "academic_year",
"hidden": 0, "fieldtype": "Link",
"ignore_user_permissions": 0, "label": "Academic Year",
"ignore_xss_filter": 0, "options": "Academic Year",
"in_filter": 0, "read_only": 1
"in_global_search": 0, },
"in_list_view": 0, {
"in_standard_filter": 0, "fetch_from": "student_group.academic_term",
"label": "Students HTML", "fieldname": "academic_term",
"length": 0, "fieldtype": "Link",
"no_copy": 0, "label": "Academic Term",
"permlevel": 0, "options": "Academic Term",
"precision": "", "read_only": 1
"print_hide": 0,
"print_hide_if_no_value": 0,
"read_only": 0,
"remember_last_selected_value": 0,
"report_hide": 0,
"reqd": 0,
"search_index": 0,
"set_only_once": 0,
"unique": 0
} }
], ],
"has_web_view": 0, "hide_toolbar": 1,
"hide_heading": 1, "issingle": 1,
"hide_toolbar": 1, "links": [],
"idx": 0, "modified": "2020-10-23 17:52:28.078971",
"image_view": 0, "modified_by": "Administrator",
"in_create": 0, "module": "Education",
"is_submittable": 0, "name": "Student Attendance Tool",
"issingle": 1, "owner": "Administrator",
"istable": 0,
"max_attachments": 0,
"modified": "2017-11-10 18:55:36.168044",
"modified_by": "Administrator",
"module": "Education",
"name": "Student Attendance Tool",
"name_case": "",
"owner": "Administrator",
"permissions": [ "permissions": [
{ {
"amend": 0, "create": 1,
"apply_user_permissions": 0, "read": 1,
"cancel": 0, "role": "Instructor",
"create": 1,
"delete": 0,
"email": 0,
"export": 0,
"if_owner": 0,
"import": 0,
"permlevel": 0,
"print": 0,
"read": 1,
"report": 0,
"role": "Instructor",
"set_user_permissions": 0,
"share": 0,
"submit": 0,
"write": 1 "write": 1
}, },
{ {
"amend": 0, "create": 1,
"apply_user_permissions": 0, "read": 1,
"cancel": 0, "role": "Academics User",
"create": 1,
"delete": 0,
"email": 0,
"export": 0,
"if_owner": 0,
"import": 0,
"permlevel": 0,
"print": 0,
"read": 1,
"report": 0,
"role": "Academics User",
"set_user_permissions": 0,
"share": 0,
"submit": 0,
"write": 1 "write": 1
} }
], ],
"quick_entry": 0, "restrict_to_domain": "Education",
"read_only": 0, "sort_field": "modified",
"read_only_onload": 0, "sort_order": "DESC"
"restrict_to_domain": "Education",
"show_name_in_global_search": 0,
"sort_field": "modified",
"sort_order": "DESC",
"track_changes": 0,
"track_seen": 0
} }