Update button + some bug fixes
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@@ -97,4 +97,4 @@ fastlane/test_output
|
|||||||
# https://github.com/johnno1962/injectionforxcode
|
# https://github.com/johnno1962/injectionforxcode
|
||||||
|
|
||||||
iOSInjectionProject/
|
iOSInjectionProject/
|
||||||
|
.DS_Store
|
||||||
|
|||||||
@@ -12,6 +12,7 @@
|
|||||||
9E6C730C2C3D796D0056ADDC /* DownloadButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E6C730B2C3D796D0056ADDC /* DownloadButton.swift */; };
|
9E6C730C2C3D796D0056ADDC /* DownloadButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E6C730B2C3D796D0056ADDC /* DownloadButton.swift */; };
|
||||||
9E6C730E2C3DB16F0056ADDC /* UninstallButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E6C730D2C3DB16F0056ADDC /* UninstallButton.swift */; };
|
9E6C730E2C3DB16F0056ADDC /* UninstallButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E6C730D2C3DB16F0056ADDC /* UninstallButton.swift */; };
|
||||||
9E6C73112C3DB5940056ADDC /* CaskDetailView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E6C73102C3DB5940056ADDC /* CaskDetailView.swift */; };
|
9E6C73112C3DB5940056ADDC /* CaskDetailView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E6C73102C3DB5940056ADDC /* CaskDetailView.swift */; };
|
||||||
|
9E6C73182C3E853E0056ADDC /* UpdateButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E6C73172C3E853E0056ADDC /* UpdateButton.swift */; };
|
||||||
9E8CE5362C3C545600A39146 /* BrewerApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E8CE5352C3C545600A39146 /* BrewerApp.swift */; };
|
9E8CE5362C3C545600A39146 /* BrewerApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E8CE5352C3C545600A39146 /* BrewerApp.swift */; };
|
||||||
9E8CE5382C3C545600A39146 /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E8CE5372C3C545600A39146 /* ContentView.swift */; };
|
9E8CE5382C3C545600A39146 /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E8CE5372C3C545600A39146 /* ContentView.swift */; };
|
||||||
9E8CE53A2C3C545700A39146 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 9E8CE5392C3C545700A39146 /* Assets.xcassets */; };
|
9E8CE53A2C3C545700A39146 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 9E8CE5392C3C545700A39146 /* Assets.xcassets */; };
|
||||||
@@ -45,6 +46,7 @@
|
|||||||
9E6C730B2C3D796D0056ADDC /* DownloadButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DownloadButton.swift; sourceTree = "<group>"; };
|
9E6C730B2C3D796D0056ADDC /* DownloadButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DownloadButton.swift; sourceTree = "<group>"; };
|
||||||
9E6C730D2C3DB16F0056ADDC /* UninstallButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UninstallButton.swift; sourceTree = "<group>"; };
|
9E6C730D2C3DB16F0056ADDC /* UninstallButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UninstallButton.swift; sourceTree = "<group>"; };
|
||||||
9E6C73102C3DB5940056ADDC /* CaskDetailView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CaskDetailView.swift; sourceTree = "<group>"; };
|
9E6C73102C3DB5940056ADDC /* CaskDetailView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CaskDetailView.swift; sourceTree = "<group>"; };
|
||||||
|
9E6C73172C3E853E0056ADDC /* UpdateButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UpdateButton.swift; sourceTree = "<group>"; };
|
||||||
9E8CE5322C3C545600A39146 /* Brewer.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Brewer.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
9E8CE5322C3C545600A39146 /* Brewer.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Brewer.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
9E8CE5352C3C545600A39146 /* BrewerApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BrewerApp.swift; sourceTree = "<group>"; };
|
9E8CE5352C3C545600A39146 /* BrewerApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BrewerApp.swift; sourceTree = "<group>"; };
|
||||||
9E8CE5372C3C545600A39146 /* ContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ContentView.swift; sourceTree = "<group>"; };
|
9E8CE5372C3C545600A39146 /* ContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ContentView.swift; sourceTree = "<group>"; };
|
||||||
@@ -88,6 +90,7 @@
|
|||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
9E6C730B2C3D796D0056ADDC /* DownloadButton.swift */,
|
9E6C730B2C3D796D0056ADDC /* DownloadButton.swift */,
|
||||||
|
9E6C73172C3E853E0056ADDC /* UpdateButton.swift */,
|
||||||
9E6C730D2C3DB16F0056ADDC /* UninstallButton.swift */,
|
9E6C730D2C3DB16F0056ADDC /* UninstallButton.swift */,
|
||||||
);
|
);
|
||||||
path = Components;
|
path = Components;
|
||||||
@@ -304,6 +307,7 @@
|
|||||||
9E6C73072C3D5E570056ADDC /* SearchView.swift in Sources */,
|
9E6C73072C3D5E570056ADDC /* SearchView.swift in Sources */,
|
||||||
9E6C730C2C3D796D0056ADDC /* DownloadButton.swift in Sources */,
|
9E6C730C2C3D796D0056ADDC /* DownloadButton.swift in Sources */,
|
||||||
9E8CE5382C3C545600A39146 /* ContentView.swift in Sources */,
|
9E8CE5382C3C545600A39146 /* ContentView.swift in Sources */,
|
||||||
|
9E6C73182C3E853E0056ADDC /* UpdateButton.swift in Sources */,
|
||||||
9E6C730E2C3DB16F0056ADDC /* UninstallButton.swift in Sources */,
|
9E6C730E2C3DB16F0056ADDC /* UninstallButton.swift in Sources */,
|
||||||
9E8CE5622C3C5A6A00A39146 /* Homebrew.swift in Sources */,
|
9E8CE5622C3C5A6A00A39146 /* Homebrew.swift in Sources */,
|
||||||
9E6C73092C3D5E950056ADDC /* InstalledView.swift in Sources */,
|
9E6C73092C3D5E950056ADDC /* InstalledView.swift in Sources */,
|
||||||
|
|||||||
@@ -17,6 +17,7 @@ struct BrewerApp: App {
|
|||||||
if let number = Int(
|
if let number = Int(
|
||||||
res.trimmingCharacters(in: .whitespacesAndNewlines)), number > 0
|
res.trimmingCharacters(in: .whitespacesAndNewlines)), number > 0
|
||||||
{
|
{
|
||||||
|
print(number)
|
||||||
isUpToDate = false
|
isUpToDate = false
|
||||||
}
|
}
|
||||||
} catch {
|
} catch {
|
||||||
|
|||||||
61
Brewer/Components/UpdateButton.swift
Normal file
61
Brewer/Components/UpdateButton.swift
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
//
|
||||||
|
// UpdateButton.swift
|
||||||
|
// Brewer
|
||||||
|
//
|
||||||
|
// Created by Cédric MAS on 10/07/2024.
|
||||||
|
//
|
||||||
|
|
||||||
|
import SwiftUI
|
||||||
|
|
||||||
|
struct UpdateButton: View {
|
||||||
|
let name: String
|
||||||
|
@State private var brew = Homebrew()
|
||||||
|
@State private var newInfo = Homebrew()
|
||||||
|
|
||||||
|
private var updated: String? {
|
||||||
|
if let cask = newInfo.data?.casks.first(where: { $0.fullToken == name }
|
||||||
|
), !cask.outdated {
|
||||||
|
return cask.version
|
||||||
|
}
|
||||||
|
if let formulae = newInfo.data?.formulae.first(where: {
|
||||||
|
$0.fullName == name
|
||||||
|
}), !formulae.outdated {
|
||||||
|
return formulae.versions.stable
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var body: some View {
|
||||||
|
if let newVersion = updated {
|
||||||
|
Text("Updated: \(newVersion)")
|
||||||
|
} else if brew.isLoading {
|
||||||
|
ProgressView()
|
||||||
|
.controlSize(.small)
|
||||||
|
} else if brew.errorMessage != nil {
|
||||||
|
Image(systemName: "x")
|
||||||
|
.symbolRenderingMode(.palette)
|
||||||
|
.symbolVariant(.circle)
|
||||||
|
.symbolVariant(.fill)
|
||||||
|
.foregroundStyle(.white, .red)
|
||||||
|
} else {
|
||||||
|
Button {
|
||||||
|
Task {
|
||||||
|
await brew.update(name)
|
||||||
|
newInfo.getInfo(on: name)
|
||||||
|
}
|
||||||
|
} label: {
|
||||||
|
Label(
|
||||||
|
"Update",
|
||||||
|
systemImage:
|
||||||
|
"arrow.counterclockwise"
|
||||||
|
)
|
||||||
|
.symbolRenderingMode(.palette)
|
||||||
|
.symbolVariant(.circle)
|
||||||
|
.symbolVariant(.fill)
|
||||||
|
.foregroundStyle(
|
||||||
|
.white, .orange)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -26,18 +26,7 @@ struct InstalledView: View {
|
|||||||
Text(cask.name.first ?? cask.fullToken)
|
Text(cask.name.first ?? cask.fullToken)
|
||||||
Spacer()
|
Spacer()
|
||||||
if cask.outdated {
|
if cask.outdated {
|
||||||
Button {
|
UpdateButton(name: cask.fullToken)
|
||||||
|
|
||||||
} label: {
|
|
||||||
Label(
|
|
||||||
"Update",
|
|
||||||
systemImage:
|
|
||||||
"arrow.counterclockwise.circle.fill"
|
|
||||||
)
|
|
||||||
.symbolRenderingMode(.palette)
|
|
||||||
.foregroundStyle(
|
|
||||||
.white, .orange)
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
Text(cask.version)
|
Text(cask.version)
|
||||||
}
|
}
|
||||||
@@ -65,17 +54,7 @@ struct InstalledView: View {
|
|||||||
Text(formulae.fullName)
|
Text(formulae.fullName)
|
||||||
Spacer()
|
Spacer()
|
||||||
if formulae.outdated {
|
if formulae.outdated {
|
||||||
Button {
|
UpdateButton(name: formulae.fullName)
|
||||||
|
|
||||||
} label: {
|
|
||||||
Label(
|
|
||||||
"Update",
|
|
||||||
systemImage:
|
|
||||||
"arrow.counterclockwise.circle.fill"
|
|
||||||
)
|
|
||||||
.symbolRenderingMode(.palette)
|
|
||||||
.foregroundStyle(.white, .orange)
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
Text(formulae.versions.stable)
|
Text(formulae.versions.stable)
|
||||||
}
|
}
|
||||||
@@ -97,8 +76,8 @@ struct InstalledView: View {
|
|||||||
}
|
}
|
||||||
.listStyle(.inset(alternatesRowBackgrounds: true))
|
.listStyle(.inset(alternatesRowBackgrounds: true))
|
||||||
let areOutdated =
|
let areOutdated =
|
||||||
data.casks.map(\.outdated).count
|
data.casks.filter(\.outdated).count
|
||||||
+ data.formulae.map(\.outdated).count
|
+ data.formulae.filter(\.outdated).count
|
||||||
let _ = UserDefaults.standard.set(
|
let _ = UserDefaults.standard.set(
|
||||||
!(areOutdated > 0), forKey: "isUpToDate")
|
!(areOutdated > 0), forKey: "isUpToDate")
|
||||||
if areOutdated > 0 {
|
if areOutdated > 0 {
|
||||||
|
|||||||
@@ -41,7 +41,7 @@ struct Cask: Codable {
|
|||||||
let url: String
|
let url: String
|
||||||
let version: String
|
let version: String
|
||||||
let installed: String?
|
let installed: String?
|
||||||
let outdated: Bool
|
var outdated: Bool
|
||||||
|
|
||||||
enum CodingKeys: String, CodingKey {
|
enum CodingKeys: String, CodingKey {
|
||||||
case token, tap, name, desc, homepage, url, version, installed, outdated
|
case token, tap, name, desc, homepage, url, version, installed, outdated
|
||||||
@@ -191,7 +191,7 @@ class Homebrew {
|
|||||||
return switch await task.result {
|
return switch await task.result {
|
||||||
case .success(let success):
|
case .success(let success):
|
||||||
success
|
success
|
||||||
case .failure(let fail):
|
case .failure:
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -201,11 +201,9 @@ class Homebrew {
|
|||||||
self.data = nil
|
self.data = nil
|
||||||
let task = Task { [weak self] in
|
let task = Task { [weak self] in
|
||||||
do {
|
do {
|
||||||
let res =
|
|
||||||
try shell(
|
try shell(
|
||||||
"/opt/homebrew/bin/brew uninstall \(fullToken); echo $?"
|
"/opt/homebrew/bin/brew uninstall \(fullToken)"
|
||||||
)
|
)
|
||||||
.trimmingCharacters(in: .whitespacesAndNewlines)
|
|
||||||
} catch {
|
} catch {
|
||||||
self?.errorMessage = error.localizedDescription
|
self?.errorMessage = error.localizedDescription
|
||||||
}
|
}
|
||||||
@@ -216,9 +214,35 @@ class Homebrew {
|
|||||||
return switch await task.result {
|
return switch await task.result {
|
||||||
case .success(let success):
|
case .success(let success):
|
||||||
success
|
success
|
||||||
case .failure(let failure):
|
case .failure:
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func update(_ name: String) async -> Bool {
|
||||||
|
self.isLoading = true
|
||||||
|
self.errorMessage = nil
|
||||||
|
self.data = nil
|
||||||
|
let task = Task { [weak self] in
|
||||||
|
do {
|
||||||
|
let res = try shell(
|
||||||
|
"/opt/homebrew/bin/brew upgrade \(name); echo $?"
|
||||||
|
)
|
||||||
|
.trimmingCharacters(in: .whitespacesAndNewlines)
|
||||||
|
self?.isLoading = false
|
||||||
|
return res == "0"
|
||||||
|
} catch {
|
||||||
|
self?.errorMessage = error.localizedDescription
|
||||||
|
}
|
||||||
|
self?.isLoading = false
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
return switch await task.result {
|
||||||
|
case .success(let success):
|
||||||
|
success
|
||||||
|
case .failure:
|
||||||
|
false
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user