Mercurial > public > simoleon
view Simoleon/Helpers/FavouriteButton.swift @ 21:c3dda63f50ed v1.1
Added Core Data and UI changes
- Implement Watchlist
- Change conversion design
- Improve UX
author | Dennis Concepción Martín <dennisconcepcionmartin@gmail.com> |
---|---|
date | Mon, 19 Jul 2021 19:27:12 +0100 |
parents | |
children | 3596690dda73 |
line wrap: on
line source
// // FavouriteButton.swift // Simoleon // // Created by Dennis Concepción Martín on 19/07/2021. // import SwiftUI struct FavouriteButton: View { var currencyPair: String @Environment(\.managedObjectContext) private var viewContext @FetchRequest(sortDescriptors: []) private var favourite: FetchedResults<Favourite> var body: some View { Button(action: { if isFavourite() { removeFromFavourites() } else { addToFavourites() } }) { RoundedRectangle(cornerRadius: 25) .foregroundColor(Color(.secondarySystemBackground)) .frame(width: 75, height: 75) .overlay( Image(systemName: generateStar()) .font(.system(size: 28)) .foregroundColor(Color(.systemYellow)) ) } } private func isFavourite() -> Bool { let favouriteCurrencyPairs = favourite.map { $0.currencyPair } if favouriteCurrencyPairs.contains(currencyPair) { return true } else { return false } } private func generateStar() -> String { if isFavourite() { return "star.fill" } else { return "star" } } private func removeFromFavourites() { withAnimation { let favouriteObject = favourite.first(where: { $0.currencyPair == currencyPair }) viewContext.delete(favouriteObject ?? Favourite()) do { try viewContext.save() } catch { let nsError = error as NSError fatalError("Unresolved error \(nsError), \(nsError.userInfo)") } } } private func addToFavourites() { withAnimation { let favourite = Favourite(context: viewContext) favourite.currencyPair = currencyPair do { try viewContext.save() } catch { let nsError = error as NSError fatalError("Unresolved error \(nsError), \(nsError.userInfo)") } } } } struct FavouriteButton_Previews: PreviewProvider { static var previews: some View { FavouriteButton(currencyPair: "USD/GBP") } }