2021-02-23 14:06:38 +05:30
|
|
|
import frappe
|
2022-02-01 00:39:14 +05:30
|
|
|
|
2021-02-23 14:06:38 +05:30
|
|
|
from erpnext.e_commerce.doctype.website_item.website_item import make_website_item
|
|
|
|
|
2022-02-01 00:39:14 +05:30
|
|
|
|
2021-02-23 14:06:38 +05:30
|
|
|
def execute():
|
|
|
|
frappe.reload_doc("e_commerce", "doctype", "website_item")
|
2021-09-09 09:47:18 +05:30
|
|
|
frappe.reload_doc("e_commerce", "doctype", "website_item_tabbed_section")
|
|
|
|
frappe.reload_doc("e_commerce", "doctype", "website_offer")
|
|
|
|
frappe.reload_doc("e_commerce", "doctype", "recommended_items")
|
|
|
|
frappe.reload_doc("e_commerce", "doctype", "e_commerce_settings")
|
2021-02-23 14:06:38 +05:30
|
|
|
frappe.reload_doc("stock", "doctype", "item")
|
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
item_fields = [
|
|
|
|
"item_code",
|
|
|
|
"item_name",
|
|
|
|
"item_group",
|
|
|
|
"stock_uom",
|
|
|
|
"brand",
|
|
|
|
"image",
|
|
|
|
"has_variants",
|
|
|
|
"variant_of",
|
|
|
|
"description",
|
|
|
|
"weightage",
|
|
|
|
]
|
|
|
|
web_fields_to_map = [
|
|
|
|
"route",
|
|
|
|
"slideshow",
|
|
|
|
"website_image_alt",
|
|
|
|
"website_warehouse",
|
|
|
|
"web_long_description",
|
|
|
|
"website_content",
|
|
|
|
"thumbnail",
|
|
|
|
]
|
2021-02-23 14:06:38 +05:30
|
|
|
|
2021-10-19 18:50:44 +05:30
|
|
|
# get all valid columns (fields) from Item master DB schema
|
2022-03-28 18:52:46 +05:30
|
|
|
item_table_fields = frappe.db.sql("desc `tabItem`", as_dict=1) # nosemgrep
|
|
|
|
item_table_fields = [d.get("Field") for d in item_table_fields]
|
2021-05-18 15:13:33 +05:30
|
|
|
|
2021-09-02 14:30:37 +05:30
|
|
|
# prepare fields to query from Item, check if the web field exists in Item master
|
2021-05-18 15:13:33 +05:30
|
|
|
web_query_fields = []
|
2021-09-02 14:30:37 +05:30
|
|
|
for web_field in web_fields_to_map:
|
|
|
|
if web_field in item_table_fields:
|
|
|
|
web_query_fields.append(web_field)
|
|
|
|
item_fields.append(web_field)
|
2021-05-18 15:13:33 +05:30
|
|
|
|
|
|
|
# check if the filter fields exist in Item master
|
|
|
|
or_filters = {}
|
|
|
|
for field in ["show_in_website", "show_variant_in_website"]:
|
|
|
|
if field in item_table_fields:
|
|
|
|
or_filters[field] = 1
|
|
|
|
|
|
|
|
if not web_query_fields or not or_filters:
|
|
|
|
# web fields to map are not present in Item master schema
|
|
|
|
# most likely a fresh installation that doesnt need this patch
|
|
|
|
return
|
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
items = frappe.db.get_all("Item", fields=item_fields, or_filters=or_filters)
|
2021-10-20 14:08:14 +05:30
|
|
|
total_count = len(items)
|
2021-02-23 14:06:38 +05:30
|
|
|
|
2021-10-20 14:08:14 +05:30
|
|
|
for count, item in enumerate(items, start=1):
|
|
|
|
if frappe.db.exists("Website Item", {"item_code": item.item_code}):
|
|
|
|
continue
|
2021-10-19 18:50:44 +05:30
|
|
|
|
2021-10-20 14:08:14 +05:30
|
|
|
# make new website item from item (publish item)
|
|
|
|
website_item = make_website_item(item, save=False)
|
|
|
|
website_item.ranking = item.get("weightage")
|
2021-10-19 17:31:55 +05:30
|
|
|
|
2021-10-20 14:08:14 +05:30
|
|
|
for field in web_fields_to_map:
|
|
|
|
website_item.update({field: item.get(field)})
|
2021-10-19 17:31:55 +05:30
|
|
|
|
2021-10-20 14:08:14 +05:30
|
|
|
website_item.save()
|
2021-10-19 17:31:55 +05:30
|
|
|
|
2021-10-20 14:08:14 +05:30
|
|
|
# move Website Item Group & Website Specification table to Website Item
|
|
|
|
for doctype in ("Website Item Group", "Item Website Specification"):
|
|
|
|
frappe.db.set_value(
|
|
|
|
doctype,
|
2022-03-28 18:52:46 +05:30
|
|
|
{"parenttype": "Item", "parent": item.item_code}, # filters
|
|
|
|
{"parenttype": "Website Item", "parent": website_item.name}, # value dict
|
2021-10-20 14:08:14 +05:30
|
|
|
)
|
2021-02-23 14:06:38 +05:30
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
if count % 20 == 0: # commit after every 20 items
|
2021-09-02 14:30:37 +05:30
|
|
|
frappe.db.commit()
|
2021-10-20 14:08:14 +05:30
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
frappe.utils.update_progress_bar("Creating Website Items", count, total_count)
|