Merge remote-tracking branch 'upstream/master' into bom-import-export

This commit is contained in:
Oliver Walters 2020-08-18 11:50:40 +10:00
commit 7349b396ca
3 changed files with 39 additions and 3 deletions

View File

@ -1357,7 +1357,7 @@ class PartParameter(models.Model):
class BomItem(models.Model): class BomItem(models.Model):
""" A BomItem links a part to its component items. """ A BomItem links a part to its component items.
A part can have a BOM (bill of materials) which defines A part can have a BOM (bill of materials) which defines
which parts are required (and in what quatity) to make it. which parts are required (and in what quantity) to make it.
Attributes: Attributes:
part: Link to the parent part (the part that will be produced) part: Link to the parent part (the part that will be produced)

View File

@ -62,6 +62,11 @@
</button> </button>
<select class='select bomselect' id='select_part_{{ row.index }}' name='part_{{ row.index }}'> <select class='select bomselect' id='select_part_{{ row.index }}' name='part_{{ row.index }}'>
{% if row.part_match %}
{% with row.part_match as part %}
<option value='{{ part.id }}'{% if part.id == row.part.id %} selected='selected'{% endif %}>{{ part.full_name }} - {{ part.description }}</option>
{% endwith %}
{% endif %}
<option value=''>---------</option> <option value=''>---------</option>
{% for part in row.part_options %} {% for part in row.part_options %}
<option value='{{ part.id }}'{% if part.id == row.part.id %} selected='selected'{% endif %}>{{ part.full_name }} - {{ part.description }}</option> <option value='{{ part.id }}'{% if part.id == row.part.id %} selected='selected'{% endif %}>{{ part.full_name }} - {{ part.description }}</option>

View File

@ -847,6 +847,7 @@ class BomUpload(FormView):
rows.append({ rows.append({
'index': row.get('index', -1), 'index': row.get('index', -1),
'data': data, 'data': data,
'part_match': row.get('part_match', None),
'part_options': row.get('part_options', self.allowed_parts), 'part_options': row.get('part_options', self.allowed_parts),
# User-input (passed between client and server) # User-input (passed between client and server)
@ -949,6 +950,7 @@ class BomUpload(FormView):
q_idx = self.getColumnIndex('Quantity') q_idx = self.getColumnIndex('Quantity')
p_idx = self.getColumnIndex('Part') p_idx = self.getColumnIndex('Part')
i_idx = self.getColumnIndex('IPN')
d_idx = self.getColumnIndex('Description') d_idx = self.getColumnIndex('Description')
r_idx = self.getColumnIndex('Reference') r_idx = self.getColumnIndex('Reference')
n_idx = self.getColumnIndex('Notes') n_idx = self.getColumnIndex('Notes')
@ -971,7 +973,7 @@ class BomUpload(FormView):
row['part_name'] = part_name row['part_name'] = part_name
# Fuzzy match the values and see what happends # Fuzzy match the values and see what happens
matches = [] matches = []
for part in self.allowed_parts: for part in self.allowed_parts:
@ -981,6 +983,9 @@ class BomUpload(FormView):
if len(matches) > 0: if len(matches) > 0:
matches = sorted(matches, key=lambda item: item['match'], reverse=True) matches = sorted(matches, key=lambda item: item['match'], reverse=True)
if i_idx >= 0:
row['part_ipn'] = row['data'][i_idx]
if d_idx >= 0: if d_idx >= 0:
row['description'] = row['data'][d_idx] row['description'] = row['data'][d_idx]
@ -991,6 +996,32 @@ class BomUpload(FormView):
row['notes'] = row['data'][n_idx] row['notes'] = row['data'][n_idx]
row['quantity'] = quantity row['quantity'] = quantity
# Part selection using IPN
try:
if row['part_ipn']:
part_matches = [part for part in self.allowed_parts if row['part_ipn'] == part.IPN]
part_options = [part for part in self.allowed_parts if part not in part_matches]
# Check for single match
if len(part_matches) == 1:
row['part_match'] = part_matches[0]
row['part_options'] = part_options
continue
except KeyError:
pass
# Part selection using Part Name
match_limit = 100
part_matches = [m['part'] for m in matches if m['match'] >= match_limit]
# Check for single match
if len(part_matches) == 1:
row['part_match'] = part_matches[0]
row['part_options'] = [m['part'] for m in matches if m['match'] < match_limit]
else:
row['part_options'] = [m['part'] for m in matches] row['part_options'] = [m['part'] for m in matches]
def extractDataFromFile(self, bom): def extractDataFromFile(self, bom):