2015-07-17 09:33:18 +00:00
|
|
|
# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
|
|
|
# License: GNU General Public License v3. See license.txt
|
|
|
|
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
import frappe
|
2015-10-03 07:52:53 +00:00
|
|
|
from frappe.utils.make_random import add_random_children
|
2015-07-17 09:33:18 +00:00
|
|
|
import frappe.utils
|
2015-10-03 07:52:53 +00:00
|
|
|
import random
|
2015-07-17 09:33:18 +00:00
|
|
|
|
|
|
|
def make_sample_data():
|
|
|
|
"""Create a few opportunities, quotes, material requests, issues, todos, projects
|
|
|
|
to help the user get started"""
|
|
|
|
|
2015-07-24 09:46:25 +00:00
|
|
|
selling_items = frappe.get_all("Item", filters = {"is_sales_item": 1})
|
2015-08-24 08:53:55 +00:00
|
|
|
buying_items = frappe.get_all("Item", filters = {"is_purchase_item": 1})
|
2015-10-03 07:52:53 +00:00
|
|
|
customers = frappe.get_all("Customer")
|
2016-02-10 07:47:25 +00:00
|
|
|
|
2015-10-03 07:52:53 +00:00
|
|
|
if selling_items and customers:
|
2015-07-17 09:33:18 +00:00
|
|
|
for i in range(3):
|
2015-10-03 07:52:53 +00:00
|
|
|
customer = random.choice(customers).name
|
|
|
|
make_opportunity(selling_items, customer)
|
|
|
|
make_quote(selling_items, customer)
|
2015-07-17 09:33:18 +00:00
|
|
|
|
|
|
|
make_projects()
|
|
|
|
|
|
|
|
if buying_items:
|
|
|
|
make_material_request(buying_items)
|
|
|
|
|
|
|
|
frappe.db.commit()
|
|
|
|
|
2015-10-03 07:52:53 +00:00
|
|
|
def make_opportunity(selling_items, customer):
|
2015-07-17 09:33:18 +00:00
|
|
|
b = frappe.get_doc({
|
|
|
|
"doctype": "Opportunity",
|
|
|
|
"enquiry_from": "Customer",
|
2015-10-03 07:52:53 +00:00
|
|
|
"customer": customer,
|
2015-07-17 09:33:18 +00:00
|
|
|
"enquiry_type": "Sales",
|
|
|
|
"with_items": 1
|
|
|
|
})
|
|
|
|
|
|
|
|
add_random_children(b, "items", rows=len(selling_items), randomize = {
|
|
|
|
"qty": (1, 5),
|
2015-07-24 09:46:25 +00:00
|
|
|
"item_code": ("Item", {"is_sales_item": 1})
|
2015-07-17 09:33:18 +00:00
|
|
|
}, unique="item_code")
|
|
|
|
|
|
|
|
b.insert(ignore_permissions=True)
|
|
|
|
|
2016-02-10 07:47:25 +00:00
|
|
|
b.add_comment('Comment', text="This is a dummy record")
|
2015-07-17 09:33:18 +00:00
|
|
|
|
2015-10-03 07:52:53 +00:00
|
|
|
def make_quote(selling_items, customer):
|
2015-07-17 09:33:18 +00:00
|
|
|
qtn = frappe.get_doc({
|
|
|
|
"doctype": "Quotation",
|
|
|
|
"quotation_to": "Customer",
|
2015-10-03 07:52:53 +00:00
|
|
|
"customer": customer,
|
2015-07-17 09:33:18 +00:00
|
|
|
"order_type": "Sales"
|
|
|
|
})
|
|
|
|
|
|
|
|
add_random_children(qtn, "items", rows=len(selling_items), randomize = {
|
|
|
|
"qty": (1, 5),
|
2015-07-24 09:46:25 +00:00
|
|
|
"item_code": ("Item", {"is_sales_item": 1})
|
2015-07-17 09:33:18 +00:00
|
|
|
}, unique="item_code")
|
|
|
|
|
|
|
|
qtn.insert(ignore_permissions=True)
|
|
|
|
|
2016-02-10 07:47:25 +00:00
|
|
|
qtn.add_comment('Comment', text="This is a dummy record")
|
2015-07-17 09:33:18 +00:00
|
|
|
|
|
|
|
def make_material_request(buying_items):
|
|
|
|
for i in buying_items:
|
|
|
|
mr = frappe.get_doc({
|
|
|
|
"doctype": "Material Request",
|
|
|
|
"material_request_type": "Purchase",
|
|
|
|
"items": [{
|
|
|
|
"schedule_date": frappe.utils.add_days(frappe.utils.nowdate(), 7),
|
|
|
|
"item_code": i.name,
|
|
|
|
"qty": 10
|
|
|
|
}]
|
|
|
|
})
|
|
|
|
mr.insert()
|
|
|
|
mr.submit()
|
|
|
|
|
2016-02-10 07:47:25 +00:00
|
|
|
mr.add_comment('Comment', text="This is a dummy record")
|
2015-07-17 09:33:18 +00:00
|
|
|
|
|
|
|
|
|
|
|
def make_issue():
|
|
|
|
pass
|
|
|
|
|
|
|
|
def make_projects():
|
|
|
|
project = frappe.get_doc({
|
|
|
|
"doctype": "Project",
|
|
|
|
"project_name": "ERPNext Implementation",
|
|
|
|
})
|
|
|
|
current_date = frappe.utils.nowdate()
|
|
|
|
project.set("tasks", [
|
|
|
|
{
|
|
|
|
"title": "Explore ERPNext",
|
|
|
|
"start_date": frappe.utils.add_days(current_date, 1),
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 2)
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"title": "Run Sales Cycle",
|
|
|
|
"start_date": frappe.utils.add_days(current_date, 2),
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 3)
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"title": "Run Billing Cycle",
|
|
|
|
"start_date": frappe.utils.add_days(current_date, 3),
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 4)
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"title": "Run Purchase Cycle",
|
|
|
|
"start_date": frappe.utils.add_days(current_date, 4),
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 5)
|
|
|
|
},
|
|
|
|
{
|
2015-07-23 12:46:25 +00:00
|
|
|
"title": "Import Data",
|
2015-07-17 09:33:18 +00:00
|
|
|
"start_date": frappe.utils.add_days(current_date, 5),
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 6)
|
2015-07-23 12:46:25 +00:00
|
|
|
},
|
|
|
|
{
|
|
|
|
"title": "Go Live!",
|
|
|
|
"start_date": frappe.utils.add_days(current_date, 6),
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 7)
|
2015-07-17 09:33:18 +00:00
|
|
|
}])
|
|
|
|
|
|
|
|
project.insert(ignore_permissions=True)
|