Merge pull request #4133 from saurabh6790/erp_support
Calendar view for holiday listing
This commit is contained in:
commit
8f3b360f83
@ -53,7 +53,7 @@ my_account_context = "erpnext.shopping_cart.utils.update_my_account_context"
|
|||||||
|
|
||||||
email_append_to = ["Job Applicant", "Opportunity", "Issue"]
|
email_append_to = ["Job Applicant", "Opportunity", "Issue"]
|
||||||
|
|
||||||
calendars = ["Task", "Production Order", "Time Log", "Leave Application", "Sales Order"]
|
calendars = ["Task", "Production Order", "Time Log", "Leave Application", "Sales Order", "Holiday List"]
|
||||||
|
|
||||||
website_generators = ["Item Group", "Item", "Sales Partner"]
|
website_generators = ["Item Group", "Item", "Sales Partner"]
|
||||||
|
|
||||||
|
@ -16,7 +16,8 @@ class HolidayList(Document):
|
|||||||
|
|
||||||
def get_weekly_off_dates(self):
|
def get_weekly_off_dates(self):
|
||||||
self.validate_values()
|
self.validate_values()
|
||||||
yr_start_date, yr_end_date = self.get_fy_start_end_dates()
|
self.validate_days()
|
||||||
|
yr_start_date, yr_end_date = get_fy_start_end_dates(self.fiscal_year)
|
||||||
date_list = self.get_weekly_off_date_list(yr_start_date, yr_end_date)
|
date_list = self.get_weekly_off_date_list(yr_start_date, yr_end_date)
|
||||||
last_idx = max([cint(d.idx) for d in self.get("holidays")] or [0,])
|
last_idx = max([cint(d.idx) for d in self.get("holidays")] or [0,])
|
||||||
for i, d in enumerate(date_list):
|
for i, d in enumerate(date_list):
|
||||||
@ -30,10 +31,11 @@ class HolidayList(Document):
|
|||||||
throw(_("Please select Fiscal Year"))
|
throw(_("Please select Fiscal Year"))
|
||||||
if not self.weekly_off:
|
if not self.weekly_off:
|
||||||
throw(_("Please select weekly off day"))
|
throw(_("Please select weekly off day"))
|
||||||
|
|
||||||
def get_fy_start_end_dates(self):
|
def validate_days(self):
|
||||||
return frappe.db.sql("""select year_start_date, year_end_date
|
for day in self.get("holidays"):
|
||||||
from `tabFiscal Year` where name=%s""", (self.fiscal_year,))[0]
|
if (self.weekly_off).upper() == (day.description).upper():
|
||||||
|
frappe.throw("Records alredy exist for mentioned weekly off")
|
||||||
|
|
||||||
def get_weekly_off_date_list(self, year_start_date, year_end_date):
|
def get_weekly_off_date_list(self, year_start_date, year_end_date):
|
||||||
from frappe.utils import getdate
|
from frappe.utils import getdate
|
||||||
@ -59,3 +61,39 @@ class HolidayList(Document):
|
|||||||
def update_default_holiday_list(self):
|
def update_default_holiday_list(self):
|
||||||
frappe.db.sql("""update `tabHoliday List` set is_default = 0
|
frappe.db.sql("""update `tabHoliday List` set is_default = 0
|
||||||
where ifnull(is_default, 0) = 1 and fiscal_year = %s""", (self.fiscal_year,))
|
where ifnull(is_default, 0) = 1 and fiscal_year = %s""", (self.fiscal_year,))
|
||||||
|
|
||||||
|
@frappe.whitelist()
|
||||||
|
def get_events(start, end, filters=None):
|
||||||
|
import json
|
||||||
|
"""Returns events for Gantt / Calendar view rendering.
|
||||||
|
|
||||||
|
:param start: Start date-time.
|
||||||
|
:param end: End date-time.
|
||||||
|
:param filters: Filters (JSON).
|
||||||
|
"""
|
||||||
|
from frappe.desk.calendar import get_event_conditions
|
||||||
|
conditions = get_event_conditions("Holiday List", filters)
|
||||||
|
|
||||||
|
fiscal_year = None
|
||||||
|
if filters:
|
||||||
|
fiscal_year = json.loads(filters).get("fiscal_year")
|
||||||
|
|
||||||
|
if not fiscal_year:
|
||||||
|
fiscal_year = frappe.db.get_value("Global Defaults", None, "current_fiscal_year")
|
||||||
|
|
||||||
|
yr_start_date, yr_end_date = get_fy_start_end_dates(fiscal_year)
|
||||||
|
|
||||||
|
data = frappe.db.sql("""select hl.name, hld.holiday_date, hld.description
|
||||||
|
from `tabHoliday List` hl, tabHoliday hld
|
||||||
|
where hld.parent = hl.name
|
||||||
|
and (ifnull(hld.holiday_date, "0000-00-00") != "0000-00-00"
|
||||||
|
and hld.holiday_date between %(start)s and %(end)s)
|
||||||
|
{conditions}""".format(conditions=conditions), {
|
||||||
|
"start": yr_start_date,
|
||||||
|
"end": yr_end_date
|
||||||
|
}, as_dict=True, update={"allDay": 1})
|
||||||
|
|
||||||
|
return data
|
||||||
|
|
||||||
|
def get_fy_start_end_dates(fiscal_year):
|
||||||
|
return frappe.db.get_value("Fiscal Year", fiscal_year, ["year_start_date", "year_end_date"])
|
21
erpnext/hr/doctype/holiday_list/holiday_list_calendar.js
Normal file
21
erpnext/hr/doctype/holiday_list/holiday_list_calendar.js
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
// Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
||||||
|
// License: GNU General Public License v3. See license.txt
|
||||||
|
|
||||||
|
frappe.views.calendar["Holiday List"] = {
|
||||||
|
field_map: {
|
||||||
|
"start": "holiday_date",
|
||||||
|
"end": "holiday_date",
|
||||||
|
"id": "name",
|
||||||
|
"title": "description",
|
||||||
|
"allDay": "allDay"
|
||||||
|
},
|
||||||
|
filters: [
|
||||||
|
{
|
||||||
|
"fieldtype": "Link",
|
||||||
|
"fieldname": "fiscal_year",
|
||||||
|
"options": "Fiscal Year",
|
||||||
|
"label": __("Fiscal Year")
|
||||||
|
}
|
||||||
|
],
|
||||||
|
get_events_method: "erpnext.hr.doctype.holiday_list.holiday_list.get_events"
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user