ContactTrickDetailView.swift 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. import SwiftUI
  2. struct ContactTrickDetailView: View {
  3. @Environment(\.dismiss) var dismiss
  4. @ObservedObject var state: ContactTrick.StateModel
  5. @State private var contactTrickEntry: ContactTrickEntry
  6. init(entry: ContactTrickEntry, state: ContactTrick.StateModel) {
  7. self.state = state
  8. _contactTrickEntry = State(initialValue: entry)
  9. }
  10. var body: some View {
  11. Form {
  12. Section {
  13. HStack {
  14. // TODO: - make this beautiful @Dan
  15. Spacer()
  16. Image(uiImage: ContactPicture.getImage(contact: contactTrickEntry, state: state.previewState))
  17. .resizable()
  18. .frame(width: 100, height: 100)
  19. .clipShape(Circle())
  20. .overlay(Circle().stroke(Color.gray, lineWidth: 1))
  21. Spacer()
  22. }
  23. }
  24. TextField("Name", text: $contactTrickEntry.name)
  25. Section(header: Text("Layout")) {
  26. Toggle("Dark Mode", isOn: $contactTrickEntry.darkMode)
  27. Picker("Layout", selection: $contactTrickEntry.layout) {
  28. ForEach(ContactTrickLayout.allCases, id: \.id) { layout in
  29. Text(layout.displayName).tag(layout)
  30. }
  31. }
  32. .pickerStyle(SegmentedPickerStyle())
  33. }
  34. Section(header: Text("Primary Value")) {
  35. Picker("Primary", selection: $contactTrickEntry.primary) {
  36. ForEach(ContactTrickValue.allCases, id: \.id) { value in
  37. Text(value.displayName).tag(value)
  38. }
  39. }
  40. }
  41. Section(header: Text("Additional Values")) {
  42. Picker("Top Value", selection: $contactTrickEntry.top) {
  43. ForEach(ContactTrickValue.allCases, id: \.id) { value in
  44. Text(value.displayName).tag(value)
  45. }
  46. }
  47. Picker("Bottom Value", selection: $contactTrickEntry.bottom) {
  48. ForEach(ContactTrickValue.allCases, id: \.id) { value in
  49. Text(value.displayName).tag(value)
  50. }
  51. }
  52. }
  53. Section(header: Text("Ring Settings")) {
  54. Picker("Ring Width", selection: $contactTrickEntry.ringWidth) {
  55. ForEach(ContactTrickEntry.RingWidth.allCases, id: \.self) { width in
  56. Text(width.displayName)
  57. .tag(width)
  58. }
  59. }
  60. Picker("Ring Gap", selection: $contactTrickEntry.ringGap) {
  61. ForEach(ContactTrickEntry.RingGap.allCases, id: \.self) { gap in
  62. Text(gap.displayName)
  63. .tag(gap)
  64. }
  65. }
  66. }
  67. }
  68. .navigationBarTitle("Edit Contact Trick", displayMode: .inline)
  69. .navigationBarItems(
  70. trailing: Button("Save") {
  71. saveChanges()
  72. }
  73. )
  74. }
  75. private func saveChanges() {
  76. Task {
  77. await state.updateContact(with: contactTrickEntry)
  78. dismiss()
  79. }
  80. }
  81. }