diff --git a/Sources/Secretive/Views/CreateSecretView.swift b/Sources/Secretive/Views/CreateSecretView.swift index 74cca74..345da43 100644 --- a/Sources/Secretive/Views/CreateSecretView.swift +++ b/Sources/Secretive/Views/CreateSecretView.swift @@ -2,14 +2,14 @@ import SwiftUI import SecretKit struct CreateSecretView: View { - + @ObservedObject var store: StoreType @Binding var showing: Bool - + @State private var name = "" @State private var requiresAuthentication = true - @State private var test: ThumbnailPickerView.Item = ThumbnailPickerView.Item(name: "Test", thumbnail: Text("Hello")) - + @State private var test: ThumbnailPickerView.Item = ThumbnailPickerView.Item(name: "Test", description: "Hello", thumbnail: Text("Hello")) + var body: some View { VStack { HStack { @@ -24,20 +24,25 @@ struct CreateSecretView: View { TextField("Shhhhh", text: $name) .focusable() } - ThumbnailPickerView(items: [ - ThumbnailPickerView.Item(name: "Requires Authentication Before Use", thumbnail: Text("")), - ThumbnailPickerView.Item(name: "Notify on Use", thumbnail: Text("")) - ], selection: $test) - // HStack { - // VStack(spacing: 20) { - // Picker("", selection: $requiresAuthentication) { - // Text("Requires Authentication (Biometrics or Password) before each use").tag(true) - // Text("Authentication not required when Mac is unlocked").tag(false) - // } - // .pickerStyle(SegmentedPickerStyle()) - // } - // Spacer() - // } + if #available(macOS 12.0, *) { + ThumbnailPickerView(items: [ + ThumbnailPickerView.Item(name: "Requires Authentication Before Use", description: "You will be required to authenticate using Touch ID, Apple Watch, or password before each use.", thumbnail: AuthenticationView()), + ThumbnailPickerView.Item(name: "Notify on Use", + description: "No authentication is required while your Mac is unlocked.", + thumbnail: NotificationView()) + ], selection: $test) + } else { + // HStack { + // VStack(spacing: 20) { + // Picker("", selection: $requiresAuthentication) { + // Text("Requires Authentication (Biometrics or Password) before each use").tag(true) + // Text("Authentication not required when Mac is unlocked").tag(false) + // } + // .pickerStyle(SegmentedPickerStyle()) + // } + // Spacer() + // } + } } } HStack { @@ -52,7 +57,7 @@ struct CreateSecretView: View { } }.padding() } - + func save() { try! store.create(name: name, requiresAuthentication: requiresAuthentication) showing = false @@ -60,60 +65,85 @@ struct CreateSecretView: View { } struct ThumbnailPickerView: View { - + let items: [Item] - let selection: Binding - + @Binding var selection: Item + var body: some View { HStack { ForEach(items) { item in - Text(item.name) + VStack { + item.thumbnail + .clipShape(RoundedRectangle(cornerRadius: 10)) + .overlay(RoundedRectangle(cornerRadius: 10) + .stroke(lineWidth: item.id == selection.id ? 5 : 0)) + .foregroundColor(.accentColor) + Text(item.name) + .bold() + Text(item.description) + }.onTapGesture { + selection = item + } } + }.onAppear { + selection = items.first! } } - + } extension ThumbnailPickerView { - + struct Item: Identifiable { let id = UUID() let name: String + let description: String let thumbnail: AnyView - - init(name: String, thumbnail: ViewType) { + + init(name: String, description: String, thumbnail: ViewType) { self.name = name + self.description = description self.thumbnail = AnyView(thumbnail) } } - + +} + +@available(macOS 12.0, *) +struct SystemBackgroundView: View { + + let anchor: UnitPoint + + var body: some View { + if let mainScreen = NSScreen.main, let imageURL = NSWorkspace.shared.desktopImageURL(for: mainScreen) { + AsyncImage(url: imageURL) { phase in + switch phase { + case .empty, .failure: + Rectangle() + .foregroundColor(Color(.systemPurple)) + case .success(let image): + image + .resizable() + .scaleEffect(3, anchor: anchor) + .clipped() + @unknown default: + Rectangle() + .foregroundColor(Color(.systemPurple)) + } + } + } else { + Rectangle() + .foregroundColor(Color(.systemPurple)) + } + } } @available(macOS 12.0, *) struct AuthenticationView: View { - + var body: some View { ZStack { - if let mainScreen = NSScreen.main, let imageURL = NSWorkspace.shared.desktopImageURL(for: mainScreen) { - AsyncImage(url: imageURL) { phase in - switch phase { - case .empty, .failure: - Rectangle() - .foregroundColor(Color(.systemPurple)) - case .success(let image): - image - .resizable() - .scaleEffect(3) - @unknown default: - Rectangle() - .foregroundColor(Color(.systemPurple)) - } - } - } - RoundedRectangle(cornerRadius: 15) - .aspectRatio(0.8, contentMode: .fit) - .foregroundColor(Color(.windowBackgroundColor)) - .padding() + SystemBackgroundView(anchor: .center) VStack { Spacer() Image(systemName: "touchid") @@ -124,38 +154,97 @@ struct AuthenticationView: View { Spacer() Text("Touch ID Prompt") .font(.largeTitle) + .foregroundColor(.primary) .redacted(reason: .placeholder) Spacer() VStack { Text("Touch ID Detail prompt.Detail two.") .font(.title3) + .foregroundColor(.primary) Text("Touch ID Detail prompt.Detail two.") .font(.title3) + .foregroundColor(.primary) } .redacted(reason: .placeholder) Spacer() RoundedRectangle(cornerRadius: 10) .frame(width: 275, height: 40, alignment: .center) - .foregroundColor(Color(.controlAccentColor)) + .foregroundColor(.accentColor) RoundedRectangle(cornerRadius: 10) .frame(width: 275, height: 40, alignment: .center) .foregroundColor(Color(.unemphasizedSelectedContentBackgroundColor)) - }.padding().padding() + } + .padding() + .background( + RoundedRectangle(cornerRadius: 15) + .foregroundStyle(.ultraThickMaterial) + ) + .padding() } } - + +} + +@available(macOS 12.0, *) +struct NotificationView: View { + + var body: some View { + ZStack { + SystemBackgroundView(anchor: .topTrailing) + VStack { + Rectangle() + .background(Color.clear) + .foregroundStyle(.thinMaterial) + .frame(height: 35) + VStack { + HStack { + Spacer() + HStack { + Image(nsImage: NSApplication.shared.applicationIconImage) + .resizable() + .frame(width: 64, height: 64) + .foregroundColor(.primary) + .padding() + VStack(alignment: .leading) { + Text("Secretive") + .font(.largeTitle) + .foregroundColor(.primary) + Text("Secretive wants to sign some request") + .font(.title3) + .foregroundColor(.primary) + Text("Secretive wants to sign some request") + .font(.title3) + .foregroundColor(.primary) + } + .padding() + } + .redacted(reason: .placeholder) + .background( + RoundedRectangle(cornerRadius: 15) + .foregroundStyle(.ultraThickMaterial) + ) + } + Spacer() + } + .padding() + } + } + } + } #if DEBUG struct CreateSecretView_Previews: PreviewProvider { - + static var previews: some View { Group { CreateSecretView(store: Preview.StoreModifiable(), showing: .constant(true)) if #available(macOS 12.0, *) { AuthenticationView().environment(\.colorScheme, .dark) AuthenticationView().environment(\.colorScheme, .light) + NotificationView().environment(\.colorScheme, .dark) + NotificationView().environment(\.colorScheme, .light) } else { // Fallback on earlier versions }