From 02f6ec921cbf5693ca8a714c577a676f4a997ef2 Mon Sep 17 00:00:00 2001 From: 1hitsong <3330318+1hitsong@users.noreply.github.com> Date: Fri, 10 Nov 2023 23:34:19 -0500 Subject: [PATCH] Fix Home Refresh Crash Fixes #1484 --- components/home/HomeRows.bs | 50 ++++++++++++++++++++++++++++++------- 1 file changed, 41 insertions(+), 9 deletions(-) diff --git a/components/home/HomeRows.bs b/components/home/HomeRows.bs index 9d5fcba3c..3e40f8243 100644 --- a/components/home/HomeRows.bs +++ b/components/home/HomeRows.bs @@ -109,7 +109,6 @@ sub removeHomeSection(sectionType as string) end for m.homeSectionIndexes.Delete(sectionName) - m.homeSectionIndexes.AddReplace("count", m.homeSectionIndexes.count - 1) m.top.content.removeChildIndex(removedSectionIndex) end sub @@ -408,10 +407,12 @@ sub updateLatestInRows() loadLatest.itemsToLoad = "latest" loadLatest.itemId = lib.id - metadata = { "title": lib.name } - metadata.Append({ "contentType": lib.json.CollectionType }) - loadLatest.metadata = metadata + metadata = { + "title": lib.name, + "contentType": lib.json.CollectionType + } + loadLatest.metadata = metadata loadLatest.observeField("content", "updateLatestItems") loadLatest.control = "RUN" end if @@ -429,8 +430,6 @@ sub updateLatestItems(msg) sectionName = "latestin" + LCase(node.metadata.title).Replace(" ", "") - rowIndex = m.homeSectionIndexes[sectionName] - if itemData.count() < 1 removeHomeSection(sectionName) return @@ -457,9 +456,42 @@ sub updateLatestItems(msg) row.appendChild(item) end for - ' replace the old row - updateSizeArray(itemSize, rowIndex, "replace") - m.top.content.replaceChild(row, rowIndex) + rowIndex = m.homeSectionIndexes[sectionName] + + ' Replace the old row + if isValid(rowIndex) + updateSizeArray(itemSize, rowIndex, "replace") + m.top.content.replaceChild(row, rowIndex) + return + end if + + ' Determine highest index of a Lastest In section so we can append the new section after it + highestLatestHomeSectionIndex = 0 + + for each section in m.homeSectionIndexes + if LCase(Left(section, 6)) = "latest" + if m.homeSectionIndexes[section] > highestLatestHomeSectionIndex + highestLatestHomeSectionIndex = m.homeSectionIndexes[section] + end if + end if + end for + + ' We have data for a section that doesn't currently exist + rowIndex = highestLatestHomeSectionIndex + 1 + + ' Advance all the indexes greater than or equal than our new row + for each section in m.homeSectionIndexes + if m.homeSectionIndexes[section] >= rowIndex + m.homeSectionIndexes[section]++ + end if + end for + + m.homeSectionIndexes.AddReplace(sectionName, rowIndex) + + m.top.content.insertChild(row, rowIndex) + updateSizeArray(itemSize, rowIndex) + + return end if end sub