Trying to implement what DTS Engineer posted
https://developer.apple.com/forums/thread/791837?login=true
But This time with REST API & DataModel , This is an Absolute Newbie SWIFTUI question,
Somehow my data model cannot get it working due to my lack of understanding !!, please help
Error "Candidate requires that 'SWIFT_DBG_Workflow_Trans_Datamodel_Data_ListViewModel' conform to 'Identifiable' (requirement specified as 'Data.Element' : 'Identifiable') (SwiftUICore.ForEach)"
Sorry for the long post, all of the source code listed below
//Datamodel -- scripts below
import Foundation
struct SWIFT_DBG_Workflow_Trans_Datamodel_Response: Decodable {
let SWIFT_DBG_Workflow_Trans_Datamodel_Rows: [SWIFT_DBG_Workflow_Trans_Datamodel_Data]
private enum CodingKeys: String, CodingKey {
case SWIFT_DBG_Workflow_Trans_Datamodel_Rows = "rows" // root tag: REST API
}
}
struct SWIFT_DBG_Workflow_Trans_Datamodel_Data: Decodable {
let mst_rec_id: Int32
let work_task:String
private enum CodingKeys: String, CodingKey {
case mst_rec_id = "mst_rec_id"
case work_task = "work_task"
}
}
// Script datamodel LIST
import Foundation
@MainActor
class SWIFT_DBG_Workflow_Trans_Datamode_List_Model: ObservableObject {
@Published var SWIFT_DBG_Workflow_Trans_Datamodel_Rows: [SWIFT_DBG_Workflow_Trans_Datamodel_Data_ListViewModel] = []
func search(mst_rec_id:Int32) async {
do {
let SWIFT_DBG_Workflow_Trans_Datamodel_Rows = try await Webservice_Workflow_Trans_Data().getWorkflow_Trans_DataList(mst_rec_id:mst_rec_id)
self.SWIFT_DBG_Workflow_Trans_Datamodel_Rows = SWIFT_DBG_Workflow_Trans_Datamodel_Rows.map(SWIFT_DBG_Workflow_Trans_Datamodel_Data_ListViewModel.init)
} catch {
print(error)
}
}
}
struct SWIFT_DBG_Workflow_Trans_Datamodel_Data_ListViewModel {
let SwiftDBGWorkflowTransDatamodelData: SWIFT_DBG_Workflow_Trans_Datamodel_Data
var mst_rec_id: Int32 {
SwiftDBGWorkflowTransDatamodelData.mst_rec_id
}
var work_task:String{
SwiftDBGWorkflowTransDatamodelData.work_task
}
}
// WEB SERVICE code
import Foundation
class Webservice_Workflow_Trans_Data {
func getWorkflow_Trans_DataList(mst_rec_id:Int32 ) async throws -> [SWIFT_DBG_Workflow_Trans_Datamodel_Data] {
var components = URLComponents()
components.scheme = "http"
components.host = "localhost" // To be pulled from Global Config.. Hot patch
components.path = "/GetWorkflowTransList"
components.port = 5555
components.queryItems = [
URLQueryItem(name: "mst_rec_id", value: String(mst_rec_id)), // VVI Need to pass eg:
]
guard let url = components.url else {
throw NetworkError.badURL
}
let (data, response) = try await URLSession.shared.data(from: url)
guard (response as? HTTPURLResponse)?.statusCode == 200 else {
throw NetworkError.badID
}
let SWIFT_DBG_Workflow_Trans_Datamodel_Response = try? JSONDecoder().decode(SWIFT_DBG_Workflow_Trans_Datamodel_Response.self, from: data)
print("WebservicePopulation_DataWorkflow_Trans_Data:URL:\(components.url)!")
print("API data: \(data)")
return SWIFT_DBG_Workflow_Trans_Datamodel_Response?.SWIFT_DBG_Workflow_Trans_Datamodel_Rows ?? []
}
}
// Main View code
import SwiftUI
struct SwiftUIView_Sheet_Test_Main_V2a: View {
@StateObject private var WorkflowTransListVM = SWIFT_DBG_Workflow_Trans_Datamode_List_Model()
@State private var selectedTransaction: SWIFT_DBG_Workflow_Trans_Datamode_List_Model? = nil
var body: some View {
NavigationStack{
List {
Section {
ForEach(WorkflowTransListVM.SWIFT_DBG_Workflow_Trans_Datamodel_Rows) { item in
WorkflowTransactionRow_V2(item: item) { selectedTransaction = $0 }
}
} header: {
ListHeaderRow_V2()
.textCase(nil)
}
}
.navigationTitle("Sheet Test Main View")
.navigationBarTitleDisplayMode(.inline)
.onAppear() {
async {
await WorkflowTransListVM.search(mst_rec_id:0)
}
}
}
}
}
//ROW View
struct WorkflowTransactionRow_V2: View {
let item: SWIFT_DBG_Workflow_Trans_Datamodel_Data
let onSelect: (SWIFT_DBG_Workflow_Trans_Datamodel_Data) -> Void
var body: some View {
HStack {
Text("\(item.mst_rec_id)")
.onTapGesture {
onSelect(item)
}
Spacer()
Text(item.work_task)
Spacer()
Button {
onSelect(item)
} label: {
Image(systemName: "ellipsis.circle.fill")
.foregroundColor(.blue)
}
}
}
}
struct ListHeaderRow_V2: View {
var body: some View {
HStack {
Text("Rec ID").font(.title3).frame(minWidth: 70)
Spacer()
Text("Work Task").font(.title3).frame(minWidth: 100)
Spacer()
Text("Status").font(.title3).frame(minWidth: 70)
Spacer()
}
}
}