refactor: add guard clause for readability

Both functions only execute based on a condition. In such cases
condition should immediately exit the function, this is called "guard
clause" and helps in readability (less indent, and easy to "exit" when
reading the code.
This commit is contained in:
Ankush Menat 2021-05-22 23:15:32 +05:30
parent 4b484d741d
commit c229ac9322
No known key found for this signature in database
GPG Key ID: 8EA82E09BBD13AAF

View File

@ -359,47 +359,49 @@ class Item(WebsiteGenerator):
context.update(get_slideshow(self)) context.update(get_slideshow(self))
def set_attribute_context(self, context): def set_attribute_context(self, context):
if self.has_variants: if not self.has_variants:
attribute_values_available = {} return
context.attribute_values = {}
context.selected_attributes = {}
# load attributes attribute_values_available = {}
for v in context.variants: context.attribute_values = {}
v.attributes = frappe.get_all("Item Variant Attribute", context.selected_attributes = {}
fields=["attribute", "attribute_value"],
filters={"parent": v.name})
# make a map for easier access in templates
v.attribute_map = frappe._dict({})
for attr in v.attributes:
v.attribute_map[attr.attribute] = attr.attribute_value
for attr in v.attributes: # load attributes
values = attribute_values_available.setdefault(attr.attribute, []) for v in context.variants:
if attr.attribute_value not in values: v.attributes = frappe.get_all("Item Variant Attribute",
values.append(attr.attribute_value) fields=["attribute", "attribute_value"],
filters={"parent": v.name})
# make a map for easier access in templates
v.attribute_map = frappe._dict({})
for attr in v.attributes:
v.attribute_map[attr.attribute] = attr.attribute_value
if v.name == context.variant.name: for attr in v.attributes:
context.selected_attributes[attr.attribute] = attr.attribute_value values = attribute_values_available.setdefault(attr.attribute, [])
if attr.attribute_value not in values:
values.append(attr.attribute_value)
# filter attributes, order based on attribute table if v.name == context.variant.name:
for attr in self.attributes: context.selected_attributes[attr.attribute] = attr.attribute_value
values = context.attribute_values.setdefault(attr.attribute, [])
if cint(frappe.db.get_value("Item Attribute", attr.attribute, "numeric_values")): # filter attributes, order based on attribute table
for val in sorted(attribute_values_available.get(attr.attribute, []), key=flt): for attr in self.attributes:
values.append(val) values = context.attribute_values.setdefault(attr.attribute, [])
else: if cint(frappe.db.get_value("Item Attribute", attr.attribute, "numeric_values")):
# get list of values defined (for sequence) for val in sorted(attribute_values_available.get(attr.attribute, []), key=flt):
for attr_value in frappe.db.get_all("Item Attribute Value", values.append(val)
fields=["attribute_value"],
filters={"parent": attr.attribute}, order_by="idx asc"):
if attr_value.attribute_value in attribute_values_available.get(attr.attribute, []): else:
values.append(attr_value.attribute_value) # get list of values defined (for sequence)
for attr_value in frappe.db.get_all("Item Attribute Value",
fields=["attribute_value"],
filters={"parent": attr.attribute}, order_by="idx asc"):
context.variant_info = json.dumps(context.variants) if attr_value.attribute_value in attribute_values_available.get(attr.attribute, []):
values.append(attr_value.attribute_value)
context.variant_info = json.dumps(context.variants)
def set_disabled_attributes(self, context): def set_disabled_attributes(self, context):
"""Disable selection options of attribute combinations that do not result in a variant""" """Disable selection options of attribute combinations that do not result in a variant"""
@ -736,20 +738,22 @@ class Item(WebsiteGenerator):
def update_template_item(self): def update_template_item(self):
"""Set Show in Website for Template Item if True for its Variant""" """Set Show in Website for Template Item if True for its Variant"""
if self.variant_of: if not self.variant_of:
if self.show_in_website: return
self.show_variant_in_website = 1
self.show_in_website = 0
if self.show_variant_in_website: if self.show_in_website:
# show template self.show_variant_in_website = 1
template_item = frappe.get_doc("Item", self.variant_of) self.show_in_website = 0
if not template_item.show_in_website: if self.show_variant_in_website:
template_item.show_in_website = 1 # show template
template_item.flags.dont_update_variants = True template_item = frappe.get_doc("Item", self.variant_of)
template_item.flags.ignore_permissions = True
template_item.save() if not template_item.show_in_website:
template_item.show_in_website = 1
template_item.flags.dont_update_variants = True
template_item.flags.ignore_permissions = True
template_item.save()
def validate_item_defaults(self): def validate_item_defaults(self):
companies = {row.company for row in self.item_defaults} companies = {row.company for row in self.item_defaults}