import json import random import frappe from frappe.utils import add_days, nowdate from six import iteritems from erpnext.demo.domains import data from erpnext.demo.setup.setup_data import import_json def setup_data(): import_json("Location") import_json("Asset Category") setup_item() setup_workstation() setup_asset() import_json('Operation') setup_item_price() show_item_groups_in_website() import_json('BOM', submit=True) frappe.db.commit() frappe.clear_cache() def setup_workstation(): workstations = [u'Drilling Machine 1', u'Lathe 1', u'Assembly Station 1', u'Assembly Station 2', u'Packing and Testing Station'] for w in workstations: frappe.get_doc({ "doctype": "Workstation", "workstation_name": w, "holiday_list": frappe.get_all("Holiday List")[0].name, "hour_rate_consumable": int(random.random() * 20), "hour_rate_electricity": int(random.random() * 10), "hour_rate_labour": int(random.random() * 40), "hour_rate_rent": int(random.random() * 10), "working_hours": [ { "enabled": 1, "start_time": "8:00:00", "end_time": "15:00:00" } ] }).insert() def show_item_groups_in_website(): """set show_in_website=1 for Item Groups""" products = frappe.get_doc("Item Group", "Products") products.show_in_website = 1 products.route = 'products' products.save() def setup_asset(): assets = json.loads(open(frappe.get_app_path('erpnext', 'demo', 'data', 'asset.json')).read()) for d in assets: asset = frappe.new_doc('Asset') asset.update(d) asset.purchase_date = add_days(nowdate(), -random.randint(20, 1500)) asset.next_depreciation_date = add_days(asset.purchase_date, 30) asset.warehouse = "Stores - WPL" asset.set_missing_values() asset.make_depreciation_schedule() asset.flags.ignore_validate = True asset.flags.ignore_mandatory = True asset.save() asset.submit() def setup_item(): items = json.loads(open(frappe.get_app_path('erpnext', 'demo', 'data', 'item.json')).read()) for i in items: item = frappe.new_doc('Item') item.update(i) if hasattr(item, 'item_defaults') and item.item_defaults[0].default_warehouse: item.item_defaults[0].company = data.get("Manufacturing").get('company_name') warehouse = frappe.get_all('Warehouse', filters={'warehouse_name': item.item_defaults[0].default_warehouse}, limit=1) if warehouse: item.item_defaults[0].default_warehouse = warehouse[0].name item.insert() def setup_product_bundle(): frappe.get_doc({ 'doctype': 'Product Bundle', 'new_item_code': 'Wind Mill A Series with Spare Bearing', 'items': [ {'item_code': 'Wind Mill A Series', 'qty': 1}, {'item_code': 'Bearing Collar', 'qty': 1}, {'item_code': 'Bearing Assembly', 'qty': 1}, ] }).insert() def setup_item_price(): frappe.db.sql("delete from `tabItem Price`") standard_selling = { "Base Bearing Plate": 28, "Base Plate": 21, "Bearing Assembly": 300, "Bearing Block": 14, "Bearing Collar": 103.6, "Bearing Pipe": 63, "Blade Rib": 46.2, "Disc Collars": 42, "External Disc": 56, "Internal Disc": 70, "Shaft": 340, "Stand": 400, "Upper Bearing Plate": 300, "Wind Mill A Series": 320, "Wind Mill A Series with Spare Bearing": 750, "Wind MIll C Series": 400, "Wind Turbine": 400, "Wing Sheet": 30.8 } standard_buying = { "Base Bearing Plate": 20, "Base Plate": 28, "Base Plate Un Painted": 16, "Bearing Block": 13, "Bearing Collar": 96.4, "Bearing Pipe": 55, "Blade Rib": 38, "Disc Collars": 34, "External Disc": 50, "Internal Disc": 60, "Shaft": 250, "Stand": 300, "Upper Bearing Plate": 200, "Wing Sheet": 25 } for price_list in ("standard_buying", "standard_selling"): for item, rate in iteritems(locals().get(price_list)): frappe.get_doc({ "doctype": "Item Price", "price_list": price_list.replace("_", " ").title(), "item_code": item, "selling": 1 if price_list=="standard_selling" else 0, "buying": 1 if price_list=="standard_buying" else 0, "price_list_rate": rate, "currency": "USD" }).insert()