List Selection and JSON datasource

This commit is contained in:
Maximilian Roider
2025-11-14 10:57:06 +01:00
parent 3c6ed00379
commit d47326e984
9 changed files with 135 additions and 11 deletions

View File

@@ -22,18 +22,9 @@ import WebKit
@main @main
struct Clemens_PlaygroundApp: App { struct Clemens_PlaygroundApp: App {
private var url = "https://fressnapf-dev-gameassets.gamegame-server.de/"
var body: some Scene { var body: some Scene {
WindowGroup { WindowGroup {
VStack { GameSelection()
// Use this for >= Xcode 26 and remove commentary in "NewWebView.swift"
// NewWebView(url)
// Use this for < Xcode 26
OldWebView(url)
}
} }
} }
} }

View File

@@ -0,0 +1,14 @@
//
// Game.swift
// Clemens Playground
//
// Created by Maximilian Roider on 14.11.25.
//
import Foundation
struct Game: Hashable, Codable, Identifiable {
var id: Int
var name: String
var url: String
}

View File

@@ -0,0 +1,33 @@
//
// Loader.swift
// Clemens Playground
//
// Created by Maximilian Roider on 14.11.25.
//
import Foundation
var games: [Game] = load("games.json")
func load<T: Decodable>(_ filename: String) -> T {
let data: Data
guard let file = Bundle.main.url(forResource: filename, withExtension: nil)
else {
fatalError("Couldn't find \(filename) in main bundle.")
}
do {
data = try Data(contentsOf: file)
} catch {
fatalError("Couldn't load \(filename) from main bundle:\n\(error)")
}
do {
let decoder = JSONDecoder()
return try decoder.decode(T.self, from: data)
} catch {
fatalError("Couldn't parse \(filename) as \(T.self):\n\(error)")
}
}

View File

@@ -0,0 +1,25 @@
//
// GameSelection.swift
// Clemens Playground
//
// Created by Maximilian Roider on 14.11.25.
//
import SwiftUI
struct GameSelection: View {
var body: some View {
NavigationSplitView {
List(games) { game in
NavigationLink {
GameView(game)
} label: {
GameRow(game)
}
}
.navigationTitle("Games")
} detail: {
Text("Select a game")
}
}
}

View File

@@ -0,0 +1,24 @@
//
// GameView.swift
// Clemens Playground
//
// Created by Maximilian Roider on 14.11.25.
//
import SwiftUI
struct GameView: View {
private let game: Game
init(_ game: Game) {
self.game = game
}
var body: some View {
// Use this for >= Xcode 26 and remove commentary in "NewWebView.swift"
// NewWebView(game.url)
// Use this for < Xcode 26
OldWebView(game.url)
}
}

View File

@@ -0,0 +1,25 @@
//
// GameRow.swift
// Clemens Playground
//
// Created by Maximilian Roider on 14.11.25.
//
import SwiftUI
struct GameRow: View {
var game: Game
init(_ game: Game) {
self.game = game
}
var body: some View {
HStack {
Text(game.name)
Spacer()
Image(systemName: "chevron.forward")
}
}
}

View File

@@ -10,7 +10,7 @@ import SwiftUI
import WebKit import WebKit
struct OldWebView: UIViewRepresentable { struct OldWebView: UIViewRepresentable {
let url: String private let url: String
init(_ url: String) { init(_ url: String) {
self.url = url self.url = url

View File

@@ -0,0 +1,12 @@
[
{
"id": 1001,
"name": "Fressnapf",
"url": "https://fressnapf-dev-gameassets.gamegame-server.de/"
},
{
"id": 1002,
"name": "Projekt-Git",
"url": "https://git.roider.tech/darksider110/Clemens-Webview-Playground"
},
]