blob: 8e67b1cd3468f294b64857c98393175c74e15f54 [file] [log] [blame]
Rucha Mahabal3cc85e12021-07-14 23:50:54 +05301import frappe
2from frappe import _
3from frappe.utils import getdate
4
5@frappe.whitelist()
6def create_employee_records():
7 company = create_company()
8 create_missing_designation()
9
10 emp1 = create_employee('Test Employee 1', 'CEO')
11 emp2 = create_employee('Test Employee 2', 'CTO')
12 emp3 = create_employee('Test Employee 3', 'Head of Marketing and Sales', emp1)
13 emp4 = create_employee('Test Employee 4', 'Project Manager', emp2)
14 emp5 = create_employee('Test Employee 5', 'Analyst', emp3)
15 emp6 = create_employee('Test Employee 6', 'Software Developer', emp4)
16
17 employees = [emp1, emp2, emp3, emp4, emp5, emp6]
18 return employees
19
20def create_company():
21 company = frappe.db.exists('Company', 'Test Org Chart')
22 if not company:
23 company = frappe.get_doc({
24 'doctype': 'Company',
25 'company_name': 'Test Org Chart',
26 'country': 'India',
27 'default_currency': 'INR'
28 }).insert().name
29
30 return company
31
32def create_employee(first_name, designation, reports_to=None):
33 employee = frappe.db.exists('Employee', {'first_name': first_name, 'designation': designation})
34 if not employee:
35 employee = frappe.get_doc({
36 'doctype': 'Employee',
37 'first_name': first_name,
38 'company': 'Test Org Chart',
39 'gender': 'Female',
40 'date_of_birth': getdate('08-12-1998'),
41 'date_of_joining': getdate('01-01-2021'),
42 'designation': designation,
43 'reports_to': reports_to
44 }).insert().name
45
46 return employee
47
48def create_missing_designation():
49 if not frappe.db.exists('Designation', 'CTO'):
50 frappe.get_doc({
51 'doctype': 'Designation',
52 'designation_name': 'CTO'
53 }).insert()