forked from MeloNX/MeloNX
UI enhancements
This commit is contained in:
parent
757fb1f6d1
commit
df2b17ddd6
@ -48,15 +48,7 @@ struct GameLibraryView: View {
|
|||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
iOSNav {
|
iOSNav {
|
||||||
ScrollView {
|
List {
|
||||||
LazyVStack(alignment: .leading, spacing: 20) {
|
|
||||||
if !isSearching {
|
|
||||||
Text("Games")
|
|
||||||
.font(.system(size: 34, weight: .bold))
|
|
||||||
.padding(.horizontal)
|
|
||||||
.padding(.top, 12)
|
|
||||||
}
|
|
||||||
|
|
||||||
if Ryujinx.shared.games.isEmpty {
|
if Ryujinx.shared.games.isEmpty {
|
||||||
VStack(spacing: 16) {
|
VStack(spacing: 16) {
|
||||||
Image(systemName: "gamecontroller.fill")
|
Image(systemName: "gamecontroller.fill")
|
||||||
@ -108,7 +100,6 @@ struct GameLibraryView: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
LazyVStack(spacing: 2) {
|
|
||||||
ForEach(filteredGames) { game in
|
ForEach(filteredGames) { game in
|
||||||
GameListRow(game: game, startemu: $startemu, games: games, isViewingGameInfo: $isViewingGameInfo, isSelectingGameUpdate: $isSelectingGameUpdate, gameInfo: $gameInfo)
|
GameListRow(game: game, startemu: $startemu, games: games, isViewingGameInfo: $isViewingGameInfo, isSelectingGameUpdate: $isSelectingGameUpdate, gameInfo: $gameInfo)
|
||||||
.onTapGesture {
|
.onTapGesture {
|
||||||
@ -118,7 +109,8 @@ struct GameLibraryView: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
.navigationTitle("Games")
|
||||||
|
.navigationBarTitleDisplayMode(.large)
|
||||||
.onAppear {
|
.onAppear {
|
||||||
loadRecentGames()
|
loadRecentGames()
|
||||||
|
|
||||||
@ -143,9 +135,8 @@ struct GameLibraryView: View {
|
|||||||
print(error)
|
print(error)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
.toolbar {
|
.toolbar {
|
||||||
ToolbarItem(placement: .topBarLeading) {
|
ToolbarItem(placement: .topBarTrailing) {
|
||||||
Button {
|
Button {
|
||||||
isSelectingGameFile.toggle()
|
isSelectingGameFile.toggle()
|
||||||
} label: {
|
} label: {
|
||||||
@ -215,7 +206,6 @@ struct GameLibraryView: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.background(Color(.systemGroupedBackground))
|
|
||||||
.searchable(text: $searchText)
|
.searchable(text: $searchText)
|
||||||
.onChange(of: searchText) { _ in
|
.onChange(of: searchText) { _ in
|
||||||
isSearching = !searchText.isEmpty
|
isSearching = !searchText.isEmpty
|
||||||
@ -296,7 +286,6 @@ struct GameLibraryView: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private func addToRecentGames(_ game: Game) {
|
private func addToRecentGames(_ game: Game) {
|
||||||
recentGames.removeAll { $0.id == game.id }
|
recentGames.removeAll { $0.id == game.id }
|
||||||
|
|
||||||
@ -329,7 +318,6 @@ struct GameLibraryView: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// MARK: - Delete Game Function
|
// MARK: - Delete Game Function
|
||||||
func deleteGame(game: Game) {
|
func deleteGame(game: Game) {
|
||||||
let fileManager = FileManager.default
|
let fileManager = FileManager.default
|
||||||
@ -474,9 +462,6 @@ struct GameListRow: View {
|
|||||||
.foregroundColor(.accentColor)
|
.foregroundColor(.accentColor)
|
||||||
.opacity(0.8)
|
.opacity(0.8)
|
||||||
}
|
}
|
||||||
.padding(.horizontal)
|
|
||||||
.padding(.vertical, 8)
|
|
||||||
.background(Color(.systemBackground))
|
|
||||||
.contextMenu {
|
.contextMenu {
|
||||||
Section {
|
Section {
|
||||||
Button {
|
Button {
|
||||||
@ -533,4 +518,3 @@ struct GameListRow: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -18,16 +18,22 @@ struct UpdateManagerSheet: View {
|
|||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
NavigationView {
|
NavigationView {
|
||||||
VStack {
|
List(paths, id: \..self, selection: $selectedItem) { item in
|
||||||
List(paths, id: \..self) { item in
|
|
||||||
Button(action: {
|
Button(action: {
|
||||||
selectItem(item.lastPathComponent)
|
selectItem(item.lastPathComponent)
|
||||||
}) {
|
}) {
|
||||||
HStack {
|
HStack {
|
||||||
Text(item.lastPathComponent)
|
Text(item.lastPathComponent)
|
||||||
if selectedItem == "\(game!.titleId)/\(item.lastPathComponent)" {
|
.foregroundStyle(Color(uiColor: .label))
|
||||||
Spacer()
|
Spacer()
|
||||||
Image(systemName: "checkmark")
|
if selectedItem == "\(game!.titleId)/\(item.lastPathComponent)" {
|
||||||
|
Image(systemName: "checkmark.circle.fill")
|
||||||
|
.foregroundStyle(Color.accentColor)
|
||||||
|
.font(.system(size: 24))
|
||||||
|
} else {
|
||||||
|
Image(systemName: "circle")
|
||||||
|
.foregroundStyle(Color(uiColor: .secondaryLabel))
|
||||||
|
.font(.system(size: 24))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -39,15 +45,15 @@ struct UpdateManagerSheet: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
.onAppear {
|
||||||
.onAppear() {
|
|
||||||
print(URL.documentsDirectory.appendingPathComponent("games").appendingPathComponent(game!.titleId).appendingPathComponent("updates.json"))
|
print(URL.documentsDirectory.appendingPathComponent("games").appendingPathComponent(game!.titleId).appendingPathComponent("updates.json"))
|
||||||
|
|
||||||
loadJSON(URL.documentsDirectory.appendingPathComponent("games").appendingPathComponent(game!.titleId).appendingPathComponent("updates.json"))
|
loadJSON(URL.documentsDirectory.appendingPathComponent("games").appendingPathComponent(game!.titleId).appendingPathComponent("updates.json"))
|
||||||
}
|
}
|
||||||
.navigationTitle("\(game!.titleName) Updates")
|
.navigationTitle("\(game!.titleName) Updates")
|
||||||
|
.navigationBarTitleDisplayMode(.inline)
|
||||||
.toolbar {
|
.toolbar {
|
||||||
Button("+") {
|
Button("Add", systemImage: "plus") {
|
||||||
isSelectingGameUpdate = true
|
isSelectingGameUpdate = true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -80,7 +86,8 @@ struct UpdateManagerSheet: View {
|
|||||||
let destinationURL = romUpdatedDirectory.appendingPathComponent(url.lastPathComponent)
|
let destinationURL = romUpdatedDirectory.appendingPathComponent(url.lastPathComponent)
|
||||||
try? fileManager.copyItem(at: url, to: destinationURL)
|
try? fileManager.copyItem(at: url, to: destinationURL)
|
||||||
|
|
||||||
Ryujinx.shared.setTitleUpdate(titleId: gameInfo.titleId, updatePath: "\(gameInfo.titleId)/" + url.lastPathComponent)
|
items.append(gameInfo.titleId + "/" + url.lastPathComponent)
|
||||||
|
selectItem(url.lastPathComponent)
|
||||||
Ryujinx.shared.games = Ryujinx.shared.loadGames()
|
Ryujinx.shared.games = Ryujinx.shared.loadGames()
|
||||||
loadJSON(jsonURL!)
|
loadJSON(jsonURL!)
|
||||||
} catch {
|
} catch {
|
||||||
@ -108,6 +115,7 @@ struct UpdateManagerSheet: View {
|
|||||||
}
|
}
|
||||||
|
|
||||||
saveJSON(selectedItem: selectedItem ?? "")
|
saveJSON(selectedItem: selectedItem ?? "")
|
||||||
|
Ryujinx.shared.games = Ryujinx.shared.loadGames()
|
||||||
}
|
}
|
||||||
|
|
||||||
func saveJSON(selectedItem: String) {
|
func saveJSON(selectedItem: String) {
|
||||||
@ -122,7 +130,6 @@ struct UpdateManagerSheet: View {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func loadJSON(_ json: URL) {
|
func loadJSON(_ json: URL) {
|
||||||
|
|
||||||
self.jsonURL = json
|
self.jsonURL = json
|
||||||
print("Failed to read JSO")
|
print("Failed to read JSO")
|
||||||
|
|
||||||
@ -132,16 +139,17 @@ struct UpdateManagerSheet: View {
|
|||||||
do {
|
do {
|
||||||
let data = try Data(contentsOf: jsonURL)
|
let data = try Data(contentsOf: jsonURL)
|
||||||
if let jsonDict = try JSONSerialization.jsonObject(with: data, options: []) as? [String: Any],
|
if let jsonDict = try JSONSerialization.jsonObject(with: data, options: []) as? [String: Any],
|
||||||
let list = jsonDict["paths"] as? [String] {
|
let list = jsonDict["paths"] as? [String]
|
||||||
|
{
|
||||||
var urls: [URL] = []
|
var urls: [URL] = []
|
||||||
|
|
||||||
for path in list {
|
for path in list {
|
||||||
urls.append(URL.documentsDirectory.appendingPathComponent("updates").appendingPathComponent(path))
|
urls.append(URL.documentsDirectory.appendingPathComponent("updates").appendingPathComponent(path))
|
||||||
}
|
}
|
||||||
|
|
||||||
self.items = list
|
items = list
|
||||||
self.paths = urls
|
paths = urls
|
||||||
self.selectedItem = jsonDict["selected"] as? String
|
selectedItem = jsonDict["selected"] as? String
|
||||||
}
|
}
|
||||||
} catch {
|
} catch {
|
||||||
print("Failed to read JSON: \(error)")
|
print("Failed to read JSON: \(error)")
|
||||||
@ -155,8 +163,8 @@ struct UpdateManagerSheet: View {
|
|||||||
do {
|
do {
|
||||||
let newData = try JSONSerialization.data(withJSONObject: defaultData, options: .prettyPrinted)
|
let newData = try JSONSerialization.data(withJSONObject: defaultData, options: .prettyPrinted)
|
||||||
try newData.write(to: jsonURL)
|
try newData.write(to: jsonURL)
|
||||||
self.items = []
|
items = []
|
||||||
self.selectedItem = ""
|
selectedItem = ""
|
||||||
} catch {
|
} catch {
|
||||||
print("Failed to create default JSON: \(error)")
|
print("Failed to create default JSON: \(error)")
|
||||||
}
|
}
|
||||||
@ -183,9 +191,9 @@ struct UpdateManagerSheet: View {
|
|||||||
|
|
||||||
let newData = try JSONSerialization.data(withJSONObject: jsonDict, options: .prettyPrinted)
|
let newData = try JSONSerialization.data(withJSONObject: jsonDict, options: .prettyPrinted)
|
||||||
try newData.write(to: jsonURL)
|
try newData.write(to: jsonURL)
|
||||||
|
Ryujinx.shared.games = Ryujinx.shared.loadGames()
|
||||||
} catch {
|
} catch {
|
||||||
print("Failed to update JSON: \(error)")
|
print("Failed to update JSON: \(error)")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user