2020-05-13 10:47:36 +05:30
|
|
|
# Copyright (c) 2020, Frappe Technologies Pvt. Ltd. and Contributors
|
|
|
|
# License: GNU General Public License v3. See license.txt
|
|
|
|
|
|
|
|
import frappe
|
|
|
|
import erpnext
|
|
|
|
import json
|
2020-05-20 12:05:03 +05:30
|
|
|
from frappe import _
|
2020-05-13 10:47:36 +05:30
|
|
|
|
|
|
|
def get_data():
|
|
|
|
return frappe._dict({
|
|
|
|
"dashboards": get_dashboards(),
|
|
|
|
"charts": get_charts(),
|
|
|
|
"number_cards": get_number_cards(),
|
|
|
|
})
|
|
|
|
|
|
|
|
def get_dashboards():
|
|
|
|
dashboards = []
|
|
|
|
dashboards.append(get_human_resource_dashboard())
|
|
|
|
return dashboards
|
|
|
|
|
|
|
|
def get_human_resource_dashboard():
|
|
|
|
return {
|
|
|
|
"name": "Human Resource",
|
|
|
|
"dashboard_name": "Human Resource",
|
|
|
|
"is_default": 1,
|
|
|
|
"charts": [
|
2020-05-20 12:05:03 +05:30
|
|
|
{ "chart": "Outgoing Salary", "width": "Full"},
|
2020-05-13 10:47:36 +05:30
|
|
|
{ "chart": "Gender Diversity Ratio", "width": "Half"},
|
2020-05-13 21:47:52 +05:30
|
|
|
{ "chart": "Job Application Status", "width": "Half"},
|
|
|
|
{ "chart": 'Designation Wise Employee Count', "width": "Half"},
|
|
|
|
{ "chart": 'Department Wise Employee Count', "width": "Half"},
|
|
|
|
{ "chart": 'Designation Wise Openings', "width": "Half"},
|
|
|
|
{ "chart": 'Department Wise Openings', "width": "Half"},
|
2020-05-13 10:47:36 +05:30
|
|
|
{ "chart": "Attendance Count", "width": "Full"}
|
|
|
|
],
|
|
|
|
"cards": [
|
|
|
|
{"card": "Total Employees"},
|
2020-05-20 12:05:03 +05:30
|
|
|
{"card": "New Joinees (Last year)"},
|
|
|
|
{'card': "Employees Left (Last year)"},
|
|
|
|
{'card': "Total Job Openings (Last month)"},
|
|
|
|
{'card': "Total Applicants (Last month)"},
|
|
|
|
{'card': "Shortlisted Candidates (Last month)"},
|
|
|
|
{'card': "Rejected Candidates (Last month)"},
|
|
|
|
{'card': "Total Job Offered (Last month)"},
|
2020-05-13 10:47:36 +05:30
|
|
|
]
|
|
|
|
}
|
|
|
|
|
|
|
|
def get_recruitment_dashboard():
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
def get_charts():
|
|
|
|
company = erpnext.get_default_company()
|
2020-05-13 21:47:52 +05:30
|
|
|
date = frappe.utils.get_datetime()
|
|
|
|
|
|
|
|
month_map = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov","Dec"]
|
|
|
|
|
2020-05-13 10:47:36 +05:30
|
|
|
|
|
|
|
if not company:
|
|
|
|
company = frappe.db.get_value("Company", {"is_group": 0}, "name")
|
|
|
|
|
|
|
|
dashboard_charts = [
|
2020-05-20 12:05:03 +05:30
|
|
|
get_dashboards_chart_doc('Gender Diversity Ratio', "Group By", "Pie",
|
|
|
|
document_type = "Employee", group_by_type="Count", group_by_based_on="gender",
|
|
|
|
filters_json = json.dumps([["Employee", "status", "=", "Active"]]))
|
2020-05-13 10:47:36 +05:30
|
|
|
]
|
|
|
|
|
|
|
|
dashboard_charts.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_dashboards_chart_doc('Job Application Status', "Group By", "Pie",
|
|
|
|
document_type = "Job Applicant", group_by_type="Count", group_by_based_on="status",
|
|
|
|
filters_json = json.dumps([["Job Applicant", "creation", "Previous", "1 month"]]))
|
2020-05-13 10:47:36 +05:30
|
|
|
)
|
|
|
|
|
|
|
|
dashboard_charts.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_dashboards_chart_doc('Outgoing Salary', "Sum", "Line",
|
|
|
|
document_type = "Salary Slip", based_on="end_date",
|
|
|
|
value_based_on = "rounded_total", time_interval = "Monthly", timeseries = 1,
|
|
|
|
filters_json = json.dumps([["Salary Slip", "docstatus", "=", 1]]))
|
2020-05-13 10:47:36 +05:30
|
|
|
)
|
2020-05-20 12:05:03 +05:30
|
|
|
|
|
|
|
custom_options = '''{
|
|
|
|
"type": "line",
|
|
|
|
"axisOptions": {
|
|
|
|
"shortenYAxisNumbers": 1
|
|
|
|
},
|
|
|
|
"tooltipOptions": {}
|
|
|
|
}'''
|
|
|
|
|
|
|
|
filters_json = json.dumps({
|
|
|
|
"month": month_map[date.month - 1],
|
|
|
|
"year": str(date.year),
|
|
|
|
"company":company
|
|
|
|
})
|
2020-05-13 10:47:36 +05:30
|
|
|
|
2020-05-13 21:47:52 +05:30
|
|
|
dashboard_charts.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_dashboards_chart_doc('Attendance Count', "Report", "Line",
|
|
|
|
report_name = "Monthly Attendance Sheet", is_custom =1, group_by_type="Count",
|
|
|
|
filters_json = filters_json, custom_options=custom_options)
|
2020-05-13 21:47:52 +05:30
|
|
|
)
|
2020-05-13 10:47:36 +05:30
|
|
|
|
|
|
|
dashboard_charts.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_dashboards_chart_doc('Department Wise Employee Count', "Group By", "Donut",
|
|
|
|
document_type = "Employee", group_by_type="Count", group_by_based_on="department",
|
|
|
|
filters_json = json.dumps([["Employee", "status", "=", "Active"]]))
|
2020-05-13 10:47:36 +05:30
|
|
|
)
|
|
|
|
|
2020-05-13 21:47:52 +05:30
|
|
|
dashboard_charts.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_dashboards_chart_doc('Designation Wise Employee Count', "Group By", "Donut",
|
|
|
|
document_type = "Employee", group_by_type="Count", group_by_based_on="designation",
|
|
|
|
filters_json = json.dumps([["Employee", "status", "=", "Active"]]))
|
2020-05-13 21:47:52 +05:30
|
|
|
)
|
2020-05-13 10:47:36 +05:30
|
|
|
|
2020-05-13 21:47:52 +05:30
|
|
|
dashboard_charts.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_dashboards_chart_doc('Designation Wise Openings', "Group By", "Bar",
|
|
|
|
document_type = "Job Opening", group_by_type="Sum", group_by_based_on="designation",
|
|
|
|
time_interval = "Monthly", aggregate_function_based_on = "planned_vacancies")
|
2020-05-13 21:47:52 +05:30
|
|
|
)
|
|
|
|
dashboard_charts.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_dashboards_chart_doc('Department Wise Openings', "Group By", "Bar",
|
|
|
|
document_type = "Job Opening", group_by_type="Sum", group_by_based_on="department",
|
|
|
|
time_interval = "Monthly", aggregate_function_based_on = "planned_vacancies")
|
2020-05-13 21:47:52 +05:30
|
|
|
)
|
|
|
|
return dashboard_charts
|
2020-05-13 10:47:36 +05:30
|
|
|
|
|
|
|
|
|
|
|
def get_number_cards():
|
|
|
|
number_cards = []
|
|
|
|
|
|
|
|
number_cards = [
|
|
|
|
get_number_cards_doc("Employee", "Total Employees", filters_json = json.dumps([
|
|
|
|
["Employee","status","=","Active"]
|
|
|
|
])
|
|
|
|
)
|
|
|
|
]
|
2020-05-13 21:47:52 +05:30
|
|
|
|
2020-05-13 10:47:36 +05:30
|
|
|
number_cards.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_number_cards_doc("Employee", "New Joinees (Last year)", filters_json = json.dumps([
|
2020-05-13 21:47:52 +05:30
|
|
|
["Employee","date_of_joining","Previous","1 year"],
|
2020-05-13 10:47:36 +05:30
|
|
|
["Employee","status","=","Active"]
|
2020-05-13 21:47:52 +05:30
|
|
|
])
|
2020-05-13 10:47:36 +05:30
|
|
|
)
|
2020-05-13 21:47:52 +05:30
|
|
|
)
|
|
|
|
|
2020-05-13 10:47:36 +05:30
|
|
|
number_cards.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_number_cards_doc("Employee", "Employees Left (Last year)", filters_json = json.dumps([
|
2020-05-29 10:19:33 +05:30
|
|
|
["Employee", "relieving_date", "Previous", "1 year"],
|
2020-05-20 12:05:03 +05:30
|
|
|
["Employee", "status", "=", "Left"]
|
2020-05-13 10:47:36 +05:30
|
|
|
])
|
|
|
|
)
|
|
|
|
)
|
2020-05-13 21:47:52 +05:30
|
|
|
|
2020-05-13 10:47:36 +05:30
|
|
|
number_cards.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_number_cards_doc("Job Applicant", "Total Applicants (Last month)", filters_json = json.dumps([
|
|
|
|
["Job Applicant", "creation", "Previous", "1 month"]
|
2020-05-13 10:47:36 +05:30
|
|
|
])
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
2020-05-13 21:47:52 +05:30
|
|
|
number_cards.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_number_cards_doc("Job Opening", "Total Job Openings (Last month)", func = "Sum",
|
|
|
|
aggregate_function_based_on = "planned_vacancies",
|
|
|
|
filters_json = json.dumps([["Job Opening", "creation", "Previous", "1 month"]])
|
2020-05-13 21:47:52 +05:30
|
|
|
)
|
|
|
|
)
|
|
|
|
number_cards.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_number_cards_doc("Job Applicant", "Shortlisted Candidates (Last month)", filters_json = json.dumps([
|
|
|
|
["Job Applicant", "status", "=", "Accepted"],
|
|
|
|
["Job Applicant", "creation", "Previous", "1 month"]
|
2020-05-13 21:47:52 +05:30
|
|
|
])
|
|
|
|
)
|
|
|
|
)
|
|
|
|
number_cards.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_number_cards_doc("Job Applicant", "Rejected Candidates (Last month)", filters_json = json.dumps([
|
|
|
|
["Job Applicant", "status", "=", "Rejected"],
|
|
|
|
["Job Applicant", "creation", "Previous", "1 month"]
|
2020-05-13 21:47:52 +05:30
|
|
|
])
|
|
|
|
)
|
|
|
|
)
|
|
|
|
number_cards.append(
|
2020-05-20 12:05:03 +05:30
|
|
|
get_number_cards_doc("Job Offer", "Total Job Offered (Last month)",
|
|
|
|
filters_json = json.dumps([["Job Offer", "creation", "Previous", "1 month"]])
|
2020-05-13 21:47:52 +05:30
|
|
|
)
|
|
|
|
)
|
|
|
|
|
2020-05-13 10:47:36 +05:30
|
|
|
return number_cards
|
|
|
|
|
|
|
|
|
|
|
|
def get_number_cards_doc(document_type, label, **args):
|
|
|
|
args = frappe._dict(args)
|
|
|
|
|
|
|
|
return {
|
|
|
|
"doctype": "Number Card",
|
|
|
|
"document_type": document_type,
|
|
|
|
"function": args.func or "Count",
|
|
|
|
"is_public": args.is_public or 1,
|
2020-05-20 12:05:03 +05:30
|
|
|
"label": _(label),
|
2020-05-13 10:47:36 +05:30
|
|
|
"name": args.name or label,
|
|
|
|
"show_percentage_stats": args.show_percentage_stats or 1,
|
|
|
|
"stats_time_interval": args.stats_time_interval or 'Monthly',
|
|
|
|
"filters_json": args.filters_json or '[]',
|
2020-05-13 21:47:52 +05:30
|
|
|
"aggregate_function_based_on": args.aggregate_function_based_on or None
|
2020-05-13 10:47:36 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
def get_dashboards_chart_doc(name, chart_type, graph_type, **args):
|
|
|
|
args = frappe._dict(args)
|
|
|
|
|
|
|
|
return {
|
|
|
|
"name": name,
|
2020-05-20 12:05:03 +05:30
|
|
|
"chart_name": _(args.chart_name or name),
|
2020-05-13 10:47:36 +05:30
|
|
|
"chart_type": chart_type,
|
|
|
|
"document_type": args.document_type or None,
|
|
|
|
"report_name": args.report_name or None,
|
|
|
|
"is_custom": args.is_custom or 0,
|
|
|
|
"group_by_type": args.group_by_type or None,
|
|
|
|
"group_by_based_on": args.group_by_based_on or None,
|
|
|
|
"based_on": args.based_on or None,
|
|
|
|
"value_based_on": args.value_based_on or None,
|
|
|
|
"number_of_groups": args.number_of_groups or 0,
|
|
|
|
"is_public": args.is_public or 1,
|
|
|
|
"timespan": args.timespan or "Last Year",
|
|
|
|
"time_interval": args.time_interval or "Yearly",
|
|
|
|
"timeseries": args.timeseries or 0,
|
|
|
|
"filters_json": args.filters_json or '[]',
|
|
|
|
"type": graph_type,
|
|
|
|
"custom_options": args.custom_options or '',
|
|
|
|
"doctype": "Dashboard Chart",
|
2020-05-13 21:47:52 +05:30
|
|
|
"aggregate_function_based_on": args.aggregate_function_based_on or None
|
2020-05-13 10:47:36 +05:30
|
|
|
}
|