I finally have working code to search an array of objects but it's really slow to populate/show the list results in a view. I've been looking into using ObservableObject and EnvironmentObject but I'm not sure how to implement them here. I'm importing a CSV and using the headers as keys and row items as values then displaying them in a List. When I try to search for something the list repopulates but takes a VERY long time. Any help would be greatly appreciated!!!
ListView.swift
import Foundation
import SwiftUI
var arrayOfData = [Container]()
struct ListView: View {
@State private var searchTerm: String = ""
@State private var array: [Container] = []
//@State var array: [Container] = newArray
func arrayFiller(){
if arrayOfData.count > 0 {
arrayOfData.removeAll()
}
for item in csvArray {
arrayOfData.append(Container(
barcode: item["Barcode"],
model: item["Model"],
description: item["ASDescription"],
serial: item["Asset Serial No"],
building: item["Building"],
floor: item["Floor"],
room: item["Room"]))
}
}
init() {
// UITableView.appearance().separatorColor = .clear
//Build list of headers using the top view.
arrayFiller()
}
var body: some View {
List {
SearchBar(text: $searchTerm, array: $array)
ForEach(array, id:\.self){item in
Text("\(item.barcode ?? "")")}
}
}
}
SearchBar.swift
struct SearchBar: UIViewRepresentable {
@Binding var text: String
@Binding var array: [Container]
class Coordinator: NSObject, UISearchBarDelegate, ObservableObject {
@Binding var text: String
@Binding var array: [Container]
init(text: Binding<String>, array: Binding<[Container]>) {
_text = text
_array = array
}
func searchBar(_ searchBar: UISearchBar, textDidChange searchText: String) {
text = searchText
array = [Container]()
DispatchQueue.main.asyncAfter(deadline: .now() + .milliseconds(100)) {
self.array = arrayOfData.filter {
self.text.isEmpty ? true : (($0.barcode?.localizedCaseInsensitiveContains(self.text))!)}
}
print(array)
}
}
func makeCoordinator() -> SearchBar.Coordinator {
return Coordinator(text: $text, array: $array)
}
func makeUIView(context: UIViewRepresentableContext<SearchBar>) -> UISearchBar {
let searchBar = UISearchBar(frame: .zero)
searchBar.delegate = context.coordinator
return searchBar
}
func updateUIView(_ uiView: UISearchBar, context: UIViewRepresentableContext<SearchBar>) {
uiView.text = text
}
}