From: Galen Charlton Date: Mon, 11 Jul 2011 19:09:34 +0000 (-0400) Subject: append line items to table in specified order X-Git-Url: https://old-git.evergreen-ils.org/?a=commitdiff_plain;h=5f5d7abb92d2f09f6e2a9ae71911918623215853;p=evergreen%2Ftadl.git append line items to table in specified order Prior to this patch, the order that line items were displayed in (e.g.) a purchase order view was effetively randomized based on the amount of time it would take for async calls to fetch additional line item details to return. Signed-off-by: Galen Charlton Signed-off-by: Lebbeous Fogle-Weekley --- diff --git a/Open-ILS/web/js/ui/default/acq/common/li_table.js b/Open-ILS/web/js/ui/default/acq/common/li_table.js index 15679ba192..4068294535 100644 --- a/Open-ILS/web/js/ui/default/acq/common/li_table.js +++ b/Open-ILS/web/js/ui/default/acq/common/li_table.js @@ -253,11 +253,19 @@ function AcqLiTable() { this.addLineitem = function(li, skip_final_placement) { this.liCache[li.id()] = li; + // insert the row right away so that final order isn't + // dependent on how long subsequent async request take + // for a given line item + var row = self.rowTemplate.cloneNode(true); + if (!skip_final_placement) { + self.tbody.appendChild(row); + self.selectors.push(dojo.query('[name=selectbox]', row)[0]); + } + // sort the lineitem notes on edit_time if(!li.lineitem_notes()) li.lineitem_notes([]); var liWrapper = new openils.acq.Lineitem({lineitem:li}); - var row = self.rowTemplate.cloneNode(true); row.setAttribute('li', li.id()); var tds = dojo.query('[attr]', row); dojo.forEach(tds, function(td) {self.setRowAttr(td, liWrapper, td.getAttribute('attr'), td.getAttribute('attr_type'));}); @@ -360,10 +368,7 @@ function AcqLiTable() { // show either "mark received" or "unreceive" as appropriate this.updateLiState(li, row); - if (!skip_final_placement) { - self.tbody.appendChild(row); - self.selectors.push(dojo.query('[name=selectbox]', row)[0]); - } else { + if (skip_final_placement) { return row; } };