2015-07-17 15:03:18 +05:30
|
|
|
# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
|
|
|
# License: GNU General Public License v3. See license.txt
|
|
|
|
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
2017-03-09 18:11:11 +05:30
|
|
|
import json
|
2021-09-02 16:44:59 +05:30
|
|
|
import os
|
2017-03-09 18:11:11 +05:30
|
|
|
import random
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2015-07-17 15:03:18 +05:30
|
|
|
import frappe
|
|
|
|
import frappe.utils
|
2017-03-09 18:11:11 +05:30
|
|
|
from frappe import _
|
2015-10-03 13:22:53 +05:30
|
|
|
from frappe.utils.make_random import add_random_children
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2015-07-17 15:03:18 +05:30
|
|
|
|
2017-12-06 13:28:06 +05:30
|
|
|
def make_sample_data(domains, make_dependent = False):
|
2015-07-17 15:03:18 +05:30
|
|
|
"""Create a few opportunities, quotes, material requests, issues, todos, projects
|
|
|
|
to help the user get started"""
|
|
|
|
|
2017-09-04 11:14:04 +05:30
|
|
|
if make_dependent:
|
|
|
|
items = frappe.get_all("Item", {'is_sales_item': 1})
|
|
|
|
customers = frappe.get_all("Customer")
|
|
|
|
warehouses = frappe.get_all("Warehouse")
|
2016-02-10 13:17:25 +05:30
|
|
|
|
2017-09-04 11:14:04 +05:30
|
|
|
if items and customers:
|
|
|
|
for i in range(3):
|
|
|
|
customer = random.choice(customers).name
|
|
|
|
make_opportunity(items, customer)
|
|
|
|
make_quote(items, customer)
|
2015-07-17 15:03:18 +05:30
|
|
|
|
2017-09-04 11:14:04 +05:30
|
|
|
if items and warehouses:
|
|
|
|
make_material_request(frappe.get_all("Item"))
|
2015-07-17 15:03:18 +05:30
|
|
|
|
2017-12-06 13:28:06 +05:30
|
|
|
make_projects(domains)
|
2018-06-21 05:47:52 +02:00
|
|
|
import_notification()
|
2015-07-17 15:03:18 +05:30
|
|
|
|
2016-04-15 12:52:12 +05:30
|
|
|
def make_opportunity(items, customer):
|
2015-07-17 15:03:18 +05:30
|
|
|
b = frappe.get_doc({
|
|
|
|
"doctype": "Opportunity",
|
2019-07-03 10:34:31 +05:30
|
|
|
"opportunity_from": "Customer",
|
2015-10-03 13:22:53 +05:30
|
|
|
"customer": customer,
|
2017-11-16 17:03:52 +05:30
|
|
|
"opportunity_type": _("Sales"),
|
2015-07-17 15:03:18 +05:30
|
|
|
"with_items": 1
|
|
|
|
})
|
|
|
|
|
2016-04-15 12:52:12 +05:30
|
|
|
add_random_children(b, "items", rows=len(items), randomize = {
|
2015-07-17 15:03:18 +05:30
|
|
|
"qty": (1, 5),
|
2016-04-15 12:52:12 +05:30
|
|
|
"item_code": ["Item"]
|
2015-07-17 15:03:18 +05:30
|
|
|
}, unique="item_code")
|
|
|
|
|
|
|
|
b.insert(ignore_permissions=True)
|
|
|
|
|
2016-02-10 13:17:25 +05:30
|
|
|
b.add_comment('Comment', text="This is a dummy record")
|
2015-07-17 15:03:18 +05:30
|
|
|
|
2016-04-15 12:52:12 +05:30
|
|
|
def make_quote(items, customer):
|
2015-07-17 15:03:18 +05:30
|
|
|
qtn = frappe.get_doc({
|
|
|
|
"doctype": "Quotation",
|
|
|
|
"quotation_to": "Customer",
|
2019-07-03 10:34:31 +05:30
|
|
|
"party_name": customer,
|
2015-07-17 15:03:18 +05:30
|
|
|
"order_type": "Sales"
|
|
|
|
})
|
|
|
|
|
2016-04-15 12:52:12 +05:30
|
|
|
add_random_children(qtn, "items", rows=len(items), randomize = {
|
2015-07-17 15:03:18 +05:30
|
|
|
"qty": (1, 5),
|
2016-04-15 12:52:12 +05:30
|
|
|
"item_code": ["Item"]
|
2015-07-17 15:03:18 +05:30
|
|
|
}, unique="item_code")
|
|
|
|
|
|
|
|
qtn.insert(ignore_permissions=True)
|
|
|
|
|
2016-02-10 13:17:25 +05:30
|
|
|
qtn.add_comment('Comment', text="This is a dummy record")
|
2015-07-17 15:03:18 +05:30
|
|
|
|
2016-04-15 12:52:12 +05:30
|
|
|
def make_material_request(items):
|
|
|
|
for i in items:
|
2015-07-17 15:03:18 +05:30
|
|
|
mr = frappe.get_doc({
|
|
|
|
"doctype": "Material Request",
|
|
|
|
"material_request_type": "Purchase",
|
2017-09-26 10:56:31 +08:00
|
|
|
"schedule_date": frappe.utils.add_days(frappe.utils.nowdate(), 7),
|
2015-07-17 15:03:18 +05:30
|
|
|
"items": [{
|
|
|
|
"schedule_date": frappe.utils.add_days(frappe.utils.nowdate(), 7),
|
|
|
|
"item_code": i.name,
|
|
|
|
"qty": 10
|
|
|
|
}]
|
|
|
|
})
|
|
|
|
mr.insert()
|
|
|
|
mr.submit()
|
|
|
|
|
2016-02-10 13:17:25 +05:30
|
|
|
mr.add_comment('Comment', text="This is a dummy record")
|
2015-07-17 15:03:18 +05:30
|
|
|
|
|
|
|
|
|
|
|
def make_issue():
|
|
|
|
pass
|
|
|
|
|
2017-12-06 13:28:06 +05:30
|
|
|
def make_projects(domains):
|
2017-03-09 18:11:11 +05:30
|
|
|
current_date = frappe.utils.nowdate()
|
2015-07-17 15:03:18 +05:30
|
|
|
project = frappe.get_doc({
|
|
|
|
"doctype": "Project",
|
|
|
|
"project_name": "ERPNext Implementation",
|
|
|
|
})
|
2017-03-09 18:11:11 +05:30
|
|
|
|
|
|
|
tasks = [
|
|
|
|
{
|
|
|
|
"title": "Explore ERPNext",
|
|
|
|
"start_date": current_date,
|
|
|
|
"end_date": current_date,
|
|
|
|
"file": "explore.md"
|
|
|
|
}]
|
|
|
|
|
2017-12-06 13:28:06 +05:30
|
|
|
if 'Education' in domains:
|
2017-03-09 18:11:11 +05:30
|
|
|
tasks += [
|
|
|
|
{
|
2017-11-23 15:22:10 +05:30
|
|
|
"title": _("Setup your Institute in ERPNext"),
|
2017-03-09 18:11:11 +05:30
|
|
|
"start_date": current_date,
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 1),
|
2017-11-23 15:22:10 +05:30
|
|
|
"file": "education_masters.md"
|
2017-03-09 18:11:11 +05:30
|
|
|
},
|
|
|
|
{
|
2017-03-10 12:47:29 +05:30
|
|
|
"title": "Setup Master Data",
|
2017-03-09 18:11:11 +05:30
|
|
|
"start_date": current_date,
|
2017-03-10 12:47:29 +05:30
|
|
|
"end_date": frappe.utils.add_days(current_date, 1),
|
2017-11-23 15:22:10 +05:30
|
|
|
"file": "education_masters.md"
|
2017-03-09 18:11:11 +05:30
|
|
|
}]
|
|
|
|
|
|
|
|
else:
|
|
|
|
tasks += [
|
|
|
|
{
|
2017-03-10 12:47:29 +05:30
|
|
|
"title": "Setup Your Company",
|
2017-03-09 18:11:11 +05:30
|
|
|
"start_date": current_date,
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 1),
|
|
|
|
"file": "masters.md"
|
2015-07-17 15:03:18 +05:30
|
|
|
},
|
|
|
|
{
|
2017-03-10 12:47:29 +05:30
|
|
|
"title": "Start Tracking your Sales",
|
2017-03-09 18:11:11 +05:30
|
|
|
"start_date": current_date,
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 2),
|
|
|
|
"file": "sales.md"
|
2015-07-17 15:03:18 +05:30
|
|
|
},
|
|
|
|
{
|
2017-03-10 12:47:29 +05:30
|
|
|
"title": "Start Managing Purchases",
|
2017-03-09 18:11:11 +05:30
|
|
|
"start_date": current_date,
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 3),
|
|
|
|
"file": "purchase.md"
|
2015-07-17 15:03:18 +05:30
|
|
|
},
|
|
|
|
{
|
2015-07-23 18:16:25 +05:30
|
|
|
"title": "Import Data",
|
2017-03-09 18:11:11 +05:30
|
|
|
"start_date": current_date,
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 4),
|
|
|
|
"file": "import_data.md"
|
2015-07-23 18:16:25 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
"title": "Go Live!",
|
2017-03-09 18:11:11 +05:30
|
|
|
"start_date": current_date,
|
|
|
|
"end_date": frappe.utils.add_days(current_date, 5),
|
|
|
|
"file": "go_live.md"
|
|
|
|
}]
|
|
|
|
|
|
|
|
for t in tasks:
|
|
|
|
with open (os.path.join(os.path.dirname(__file__), "tasks", t['file'])) as f:
|
2018-08-07 11:53:36 +05:30
|
|
|
t['description'] = frappe.utils.md_to_html(f.read())
|
2017-03-09 18:11:11 +05:30
|
|
|
del t['file']
|
|
|
|
|
|
|
|
project.append('tasks', t)
|
2015-07-17 15:03:18 +05:30
|
|
|
|
|
|
|
project.insert(ignore_permissions=True)
|
2017-03-09 18:11:11 +05:30
|
|
|
|
2018-06-21 05:47:52 +02:00
|
|
|
def import_notification():
|
|
|
|
'''Import notification for task start'''
|
2017-03-09 18:11:11 +05:30
|
|
|
with open (os.path.join(os.path.dirname(__file__), "tasks/task_alert.json")) as f:
|
2018-06-21 05:47:52 +02:00
|
|
|
notification = frappe.get_doc(json.loads(f.read())[0])
|
|
|
|
notification.insert()
|
2017-03-09 18:11:11 +05:30
|
|
|
|
2017-03-10 12:47:29 +05:30
|
|
|
# trigger the first message!
|
2018-06-11 17:20:30 +05:30
|
|
|
from frappe.email.doctype.notification.notification import trigger_daily_alerts
|
2017-03-10 12:47:29 +05:30
|
|
|
trigger_daily_alerts()
|
|
|
|
|
2017-03-09 18:11:11 +05:30
|
|
|
def test_sample():
|
2018-06-11 17:20:30 +05:30
|
|
|
frappe.db.sql('delete from `tabNotification`')
|
2017-03-09 18:11:11 +05:30
|
|
|
frappe.db.sql('delete from tabProject')
|
|
|
|
frappe.db.sql('delete from tabTask')
|
|
|
|
make_projects('Education')
|
2018-06-21 05:47:52 +02:00
|
|
|
import_notification()
|