blob: e7febd0b8ad043dc9c0b5afece2b157092fcab78 [file] [log] [blame]
Rohit Waghchaure8002d472016-07-13 16:03:05 +05301# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
2# License: GNU General Public License v3. See license.txt
3
4from __future__ import unicode_literals
5
6import frappe
Rohit Waghchaure7d439ec2016-07-21 14:50:59 +05307from frappe.utils import flt
Rohit Waghchaure8002d472016-07-13 16:03:05 +05308from frappe.utils.make_random import can_make
9from frappe.utils.make_random import how_many, get_random
10from erpnext.projects.doctype.timesheet.test_timesheet import make_timesheet
Rohit Waghchaure7d439ec2016-07-21 14:50:59 +053011from erpnext.demo.user.hr import make_sales_invoice_for_timesheet
Rohit Waghchaure8002d472016-07-13 16:03:05 +053012
13def run_projects(current_date):
14 frappe.set_user(frappe.db.get_global('demo_projects_user'))
15 if frappe.db.get_global('demo_projects_user'):
16 make_project(current_date)
17 make_timesheet_for_projects(current_date)
18 close_tasks(current_date)
19
20def make_timesheet_for_projects(current_date ):
21 for data in frappe.get_all("Task", ["name", "project"], {"status": "Open", "exp_end_date": ("<", current_date)}):
22 employee = get_random("Employee")
23 if frappe.db.get_value('Salary Structure', {'employee': employee}, 'salary_slip_based_on_timesheet'):
Rohit Waghchaure7d439ec2016-07-21 14:50:59 +053024 ts = make_timesheet(employee, simulate = True, billable = 1,
Rohit Waghchaure8002d472016-07-13 16:03:05 +053025 activity_type=get_random("Activity Type"), project=data.project, task =data.name)
26
Rohit Waghchaure7d439ec2016-07-21 14:50:59 +053027 if flt(ts.total_billing_amount) > 0.0:
28 make_sales_invoice_for_timesheet(ts.name)
29 frappe.db.commit()
30
Rohit Waghchaure8002d472016-07-13 16:03:05 +053031def close_tasks(current_date):
32 for task in frappe.get_all("Task", ["name"], {"status": "Open", "exp_end_date": ("<", current_date)}):
33 task = frappe.get_doc("Task", task.name)
34 task.status = "Closed"
35 task.save()
36
37def make_project(current_date):
38 if not frappe.db.exists('Project',
39 "New Product Development " + current_date.strftime("%Y-%m-%d")):
40 project = frappe.get_doc({
41 "doctype": "Project",
42 "project_name": "New Product Development " + current_date.strftime("%Y-%m-%d"),
43 })
44 project.set("tasks", [
45 {
46 "title": "Review Requirements",
47 "start_date": frappe.utils.add_days(current_date, 10),
48 "end_date": frappe.utils.add_days(current_date, 11)
49 },
50 {
51 "title": "Design Options",
52 "start_date": frappe.utils.add_days(current_date, 11),
53 "end_date": frappe.utils.add_days(current_date, 20)
54 },
55 {
56 "title": "Make Prototypes",
57 "start_date": frappe.utils.add_days(current_date, 20),
58 "end_date": frappe.utils.add_days(current_date, 30)
59 },
60 {
61 "title": "Customer Feedback on Prototypes",
62 "start_date": frappe.utils.add_days(current_date, 30),
63 "end_date": frappe.utils.add_days(current_date, 40)
64 },
65 {
66 "title": "Freeze Feature Set",
67 "start_date": frappe.utils.add_days(current_date, 40),
68 "end_date": frappe.utils.add_days(current_date, 45)
69 },
70 {
71 "title": "Testing",
72 "start_date": frappe.utils.add_days(current_date, 45),
73 "end_date": frappe.utils.add_days(current_date, 60)
74 },
75 {
76 "title": "Product Engineering",
77 "start_date": frappe.utils.add_days(current_date, 45),
78 "end_date": frappe.utils.add_days(current_date, 55)
79 },
80 {
81 "title": "Supplier Contracts",
82 "start_date": frappe.utils.add_days(current_date, 55),
83 "end_date": frappe.utils.add_days(current_date, 70)
84 },
85 {
86 "title": "Design and Build Fixtures",
87 "start_date": frappe.utils.add_days(current_date, 45),
88 "end_date": frappe.utils.add_days(current_date, 65)
89 },
90 {
91 "title": "Test Run",
92 "start_date": frappe.utils.add_days(current_date, 70),
93 "end_date": frappe.utils.add_days(current_date, 80)
94 },
95 {
96 "title": "Launch",
97 "start_date": frappe.utils.add_days(current_date, 80),
98 "end_date": frappe.utils.add_days(current_date, 90)
99 },
100 ])
101 project.insert()