From e25e37c871dc548cc2799c37235ec31ed19b79c9 Mon Sep 17 00:00:00 2001 From: Tom Hicks Date: Sun, 21 Mar 2021 14:47:15 -0700 Subject: [PATCH] Moves saving throws from EditMonster to a sub view. --- iOS/EditSavingThrows.swift | 79 ++++++++++++++++++++++ iOS/MonsterCards.xcodeproj/project.pbxproj | 4 ++ iOS/MonsterCards/Views/EditMonster.swift | 78 +++++---------------- 3 files changed, 100 insertions(+), 61 deletions(-) create mode 100644 iOS/EditSavingThrows.swift diff --git a/iOS/EditSavingThrows.swift b/iOS/EditSavingThrows.swift new file mode 100644 index 0000000..421d787 --- /dev/null +++ b/iOS/EditSavingThrows.swift @@ -0,0 +1,79 @@ +// +// EditSavingThrows.swift +// MonsterCards +// +// Created by Tom Hicks on 3/21/21. +// + +import SwiftUI + +struct EditSavingThrows: View { + @ObservedObject var monsterViewModel: MonsterViewModel + + var body: some View { + List { + VStack { + MCAdvantagePicker( + label: "Strength Advantage", + value: $monsterViewModel.strengthSavingThrowAdvantage) + + MCProficiencyPicker( + label: "Strength Proficiency", + value: $monsterViewModel.strengthSavingThrowProficiency) + } + VStack { + MCAdvantagePicker( + label: "Dexterity Advantage", + value: $monsterViewModel.dexteritySavingThrowAdvantage) + + MCProficiencyPicker( + label: "Dexterity Proficiency", + value: $monsterViewModel.dexteritySavingThrowProficiency) + } + VStack { + MCAdvantagePicker( + label: "Constitution Advantage", + value: $monsterViewModel.constitutionSavingThrowAdvantage) + + MCProficiencyPicker( + label: "Constitution Proficiency", + value: $monsterViewModel.constitutionSavingThrowProficiency) + } + VStack { + MCAdvantagePicker( + label: "Intelligence Advantage", + value: $monsterViewModel.intelligenceSavingThrowAdvantage) + + MCProficiencyPicker( + label: "Intelligence Proficiency", + value: $monsterViewModel.intelligenceSavingThrowProficiency) + } + VStack { + MCAdvantagePicker( + label: "Wisdom Advantage", + value: $monsterViewModel.wisdomSavingThrowAdvantage) + + MCProficiencyPicker( + label: "Wisdom Proficiency", + value: $monsterViewModel.wisdomSavingThrowProficiency) + } + VStack { + MCAdvantagePicker( + label: "Charisma Advantage", + value: $monsterViewModel.charismaSavingThrowAdvantage) + + MCProficiencyPicker( + label: "Charisma Proficiency", + value: $monsterViewModel.charismaSavingThrowProficiency) + } + } + .textCase(nil) + } +} + +struct EditSavingThrows_Previews: PreviewProvider { + static var previews: some View { + let viewModel = MonsterViewModel(nil) + EditSavingThrows(monsterViewModel: viewModel) + } +} diff --git a/iOS/MonsterCards.xcodeproj/project.pbxproj b/iOS/MonsterCards.xcodeproj/project.pbxproj index bffc655..9f2ade3 100644 --- a/iOS/MonsterCards.xcodeproj/project.pbxproj +++ b/iOS/MonsterCards.xcodeproj/project.pbxproj @@ -20,6 +20,7 @@ E24ACE562607EE94009BF703 /* EditArmor.swift in Sources */ = {isa = PBXBuildFile; fileRef = E24ACE552607EE94009BF703 /* EditArmor.swift */; }; E24ACE5B2607F0F2009BF703 /* EditSpeed.swift in Sources */ = {isa = PBXBuildFile; fileRef = E24ACE5A2607F0F2009BF703 /* EditSpeed.swift */; }; E24ACE602607F45E009BF703 /* EditAbilityScores.swift in Sources */ = {isa = PBXBuildFile; fileRef = E24ACE5F2607F45E009BF703 /* EditAbilityScores.swift */; }; + E24ACE652607F55D009BF703 /* EditSavingThrows.swift in Sources */ = {isa = PBXBuildFile; fileRef = E24ACE642607F55D009BF703 /* EditSavingThrows.swift */; }; E2570FB925B1AC520055B23B /* MonsterCardsApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = E2570FB825B1AC520055B23B /* MonsterCardsApp.swift */; }; E2570FBB25B1AC520055B23B /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E2570FBA25B1AC520055B23B /* ContentView.swift */; }; E2570FBD25B1AC550055B23B /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = E2570FBC25B1AC550055B23B /* Assets.xcassets */; }; @@ -72,6 +73,7 @@ E24ACE552607EE94009BF703 /* EditArmor.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = EditArmor.swift; sourceTree = ""; }; E24ACE5A2607F0F2009BF703 /* EditSpeed.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = EditSpeed.swift; sourceTree = ""; }; E24ACE5F2607F45E009BF703 /* EditAbilityScores.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = EditAbilityScores.swift; sourceTree = ""; }; + E24ACE642607F55D009BF703 /* EditSavingThrows.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = EditSavingThrows.swift; sourceTree = ""; }; E2570FB525B1AC520055B23B /* MonsterCards.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = MonsterCards.app; sourceTree = BUILT_PRODUCTS_DIR; }; E2570FB825B1AC520055B23B /* MonsterCardsApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MonsterCardsApp.swift; sourceTree = ""; }; E2570FBA25B1AC520055B23B /* ContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ContentView.swift; sourceTree = ""; }; @@ -137,6 +139,7 @@ E2570FAC25B1AC520055B23B = { isa = PBXGroup; children = ( + E24ACE642607F55D009BF703 /* EditSavingThrows.swift */, E24ACE5F2607F45E009BF703 /* EditAbilityScores.swift */, E24ACE552607EE94009BF703 /* EditArmor.swift */, E24ACE4F2607326E009BF703 /* EditBasicInfo.swift */, @@ -393,6 +396,7 @@ E24ACE5B2607F0F2009BF703 /* EditSpeed.swift in Sources */, E2570FB925B1AC520055B23B /* MonsterCardsApp.swift in Sources */, E20209D325D8DD9600EFE733 /* Skill+CoreDataClass.swift in Sources */, + E24ACE652607F55D009BF703 /* EditSavingThrows.swift in Sources */, E2BD702C25B3A8D70058ED69 /* MCTextField.swift in Sources */, E20209E825D8DEC100EFE733 /* AbilityScore.swift in Sources */, E210B83F25B42DAB0083EAC5 /* MCAdvantagePicker.swift in Sources */, diff --git a/iOS/MonsterCards/Views/EditMonster.swift b/iOS/MonsterCards/Views/EditMonster.swift index 1fbc9ff..ac9a634 100644 --- a/iOS/MonsterCards/Views/EditMonster.swift +++ b/iOS/MonsterCards/Views/EditMonster.swift @@ -20,69 +20,25 @@ struct EditMonster: View { var body: some View { List { - NavigationLink("Basic Info", destination: EditBasicInfo(monsterViewModel: monsterViewModel)) - NavigationLink("Armor", destination: EditArmor(monsterViewModel: monsterViewModel)) - NavigationLink("Speed", destination: EditSpeed(monsterViewModel: monsterViewModel)) - NavigationLink("Ability Scores", destination: EditAbilityScores(monsterViewModel: monsterViewModel)) + NavigationLink( + "Basic Info", + destination: EditBasicInfo(monsterViewModel: monsterViewModel)) - Section(header: Text("Saving Throws")) { - VStack { - MCAdvantagePicker( - label: "Strength Advantage", - value: $monsterViewModel.strengthSavingThrowAdvantage) - - MCProficiencyPicker( - label: "Strength Proficiency", - value: $monsterViewModel.strengthSavingThrowProficiency) - } - VStack { - MCAdvantagePicker( - label: "Dexterity Advantage", - value: $monsterViewModel.dexteritySavingThrowAdvantage) - - MCProficiencyPicker( - label: "Dexterity Proficiency", - value: $monsterViewModel.dexteritySavingThrowProficiency) - } - VStack { - MCAdvantagePicker( - label: "Constitution Advantage", - value: $monsterViewModel.constitutionSavingThrowAdvantage) - - MCProficiencyPicker( - label: "Constitution Proficiency", - value: $monsterViewModel.constitutionSavingThrowProficiency) - } - VStack { - MCAdvantagePicker( - label: "Intelligence Advantage", - value: $monsterViewModel.intelligenceSavingThrowAdvantage) - - MCProficiencyPicker( - label: "Intelligence Proficiency", - value: $monsterViewModel.intelligenceSavingThrowProficiency) - } - VStack { - MCAdvantagePicker( - label: "Wisdom Advantage", - value: $monsterViewModel.wisdomSavingThrowAdvantage) - - MCProficiencyPicker( - label: "Wisdom Proficiency", - value: $monsterViewModel.wisdomSavingThrowProficiency) - } - VStack { - MCAdvantagePicker( - label: "Charisma Advantage", - value: $monsterViewModel.charismaSavingThrowAdvantage) - - MCProficiencyPicker( - label: "Charisma Proficiency", - value: $monsterViewModel.charismaSavingThrowProficiency) - } - } - .textCase(nil) + NavigationLink( + "Armor", + destination: EditArmor(monsterViewModel: monsterViewModel)) + NavigationLink( + "Speed", + destination: EditSpeed(monsterViewModel: monsterViewModel)) + + NavigationLink( + "Ability Scores", + destination: EditAbilityScores(monsterViewModel: monsterViewModel)) + + NavigationLink( + "Saving Throws", + destination: EditSavingThrows(monsterViewModel: monsterViewModel)) } .onAppear(perform: copyMonsterToLocal) .toolbar(content: {