Moves saving throws from EditMonster to a sub view.
This commit is contained in:
		
							
								
								
									
										79
									
								
								iOS/EditSavingThrows.swift
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								iOS/EditSavingThrows.swift
									
									
									
									
									
										Normal file
									
								
							| @@ -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) | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -20,6 +20,7 @@ | |||||||
| 		E24ACE562607EE94009BF703 /* EditArmor.swift in Sources */ = {isa = PBXBuildFile; fileRef = E24ACE552607EE94009BF703 /* EditArmor.swift */; }; | 		E24ACE562607EE94009BF703 /* EditArmor.swift in Sources */ = {isa = PBXBuildFile; fileRef = E24ACE552607EE94009BF703 /* EditArmor.swift */; }; | ||||||
| 		E24ACE5B2607F0F2009BF703 /* EditSpeed.swift in Sources */ = {isa = PBXBuildFile; fileRef = E24ACE5A2607F0F2009BF703 /* EditSpeed.swift */; }; | 		E24ACE5B2607F0F2009BF703 /* EditSpeed.swift in Sources */ = {isa = PBXBuildFile; fileRef = E24ACE5A2607F0F2009BF703 /* EditSpeed.swift */; }; | ||||||
| 		E24ACE602607F45E009BF703 /* EditAbilityScores.swift in Sources */ = {isa = PBXBuildFile; fileRef = E24ACE5F2607F45E009BF703 /* EditAbilityScores.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 */; }; | 		E2570FB925B1AC520055B23B /* MonsterCardsApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = E2570FB825B1AC520055B23B /* MonsterCardsApp.swift */; }; | ||||||
| 		E2570FBB25B1AC520055B23B /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E2570FBA25B1AC520055B23B /* ContentView.swift */; }; | 		E2570FBB25B1AC520055B23B /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E2570FBA25B1AC520055B23B /* ContentView.swift */; }; | ||||||
| 		E2570FBD25B1AC550055B23B /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = E2570FBC25B1AC550055B23B /* Assets.xcassets */; }; | 		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 = "<group>"; }; | 		E24ACE552607EE94009BF703 /* EditArmor.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = EditArmor.swift; sourceTree = "<group>"; }; | ||||||
| 		E24ACE5A2607F0F2009BF703 /* EditSpeed.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = EditSpeed.swift; sourceTree = "<group>"; }; | 		E24ACE5A2607F0F2009BF703 /* EditSpeed.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = EditSpeed.swift; sourceTree = "<group>"; }; | ||||||
| 		E24ACE5F2607F45E009BF703 /* EditAbilityScores.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = EditAbilityScores.swift; sourceTree = "<group>"; }; | 		E24ACE5F2607F45E009BF703 /* EditAbilityScores.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = EditAbilityScores.swift; sourceTree = "<group>"; }; | ||||||
|  | 		E24ACE642607F55D009BF703 /* EditSavingThrows.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = EditSavingThrows.swift; sourceTree = "<group>"; }; | ||||||
| 		E2570FB525B1AC520055B23B /* MonsterCards.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = MonsterCards.app; sourceTree = BUILT_PRODUCTS_DIR; }; | 		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 = "<group>"; }; | 		E2570FB825B1AC520055B23B /* MonsterCardsApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MonsterCardsApp.swift; sourceTree = "<group>"; }; | ||||||
| 		E2570FBA25B1AC520055B23B /* ContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ContentView.swift; sourceTree = "<group>"; }; | 		E2570FBA25B1AC520055B23B /* ContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ContentView.swift; sourceTree = "<group>"; }; | ||||||
| @@ -137,6 +139,7 @@ | |||||||
| 		E2570FAC25B1AC520055B23B = { | 		E2570FAC25B1AC520055B23B = { | ||||||
| 			isa = PBXGroup; | 			isa = PBXGroup; | ||||||
| 			children = ( | 			children = ( | ||||||
|  | 				E24ACE642607F55D009BF703 /* EditSavingThrows.swift */, | ||||||
| 				E24ACE5F2607F45E009BF703 /* EditAbilityScores.swift */, | 				E24ACE5F2607F45E009BF703 /* EditAbilityScores.swift */, | ||||||
| 				E24ACE552607EE94009BF703 /* EditArmor.swift */, | 				E24ACE552607EE94009BF703 /* EditArmor.swift */, | ||||||
| 				E24ACE4F2607326E009BF703 /* EditBasicInfo.swift */, | 				E24ACE4F2607326E009BF703 /* EditBasicInfo.swift */, | ||||||
| @@ -393,6 +396,7 @@ | |||||||
| 				E24ACE5B2607F0F2009BF703 /* EditSpeed.swift in Sources */, | 				E24ACE5B2607F0F2009BF703 /* EditSpeed.swift in Sources */, | ||||||
| 				E2570FB925B1AC520055B23B /* MonsterCardsApp.swift in Sources */, | 				E2570FB925B1AC520055B23B /* MonsterCardsApp.swift in Sources */, | ||||||
| 				E20209D325D8DD9600EFE733 /* Skill+CoreDataClass.swift in Sources */, | 				E20209D325D8DD9600EFE733 /* Skill+CoreDataClass.swift in Sources */, | ||||||
|  | 				E24ACE652607F55D009BF703 /* EditSavingThrows.swift in Sources */, | ||||||
| 				E2BD702C25B3A8D70058ED69 /* MCTextField.swift in Sources */, | 				E2BD702C25B3A8D70058ED69 /* MCTextField.swift in Sources */, | ||||||
| 				E20209E825D8DEC100EFE733 /* AbilityScore.swift in Sources */, | 				E20209E825D8DEC100EFE733 /* AbilityScore.swift in Sources */, | ||||||
| 				E210B83F25B42DAB0083EAC5 /* MCAdvantagePicker.swift in Sources */, | 				E210B83F25B42DAB0083EAC5 /* MCAdvantagePicker.swift in Sources */, | ||||||
|   | |||||||
| @@ -20,69 +20,25 @@ struct EditMonster: View { | |||||||
|          |          | ||||||
|     var body: some View { |     var body: some View { | ||||||
|         List { |         List { | ||||||
|             NavigationLink("Basic Info", destination: EditBasicInfo(monsterViewModel: monsterViewModel)) |             NavigationLink( | ||||||
|             NavigationLink("Armor", destination: EditArmor(monsterViewModel: monsterViewModel)) |                 "Basic Info", | ||||||
|             NavigationLink("Speed", destination: EditSpeed(monsterViewModel: monsterViewModel)) |                 destination: EditBasicInfo(monsterViewModel: monsterViewModel)) | ||||||
|             NavigationLink("Ability Scores", destination: EditAbilityScores(monsterViewModel: monsterViewModel)) |  | ||||||
|              |              | ||||||
|             Section(header: Text("Saving Throws")) { |             NavigationLink( | ||||||
|                 VStack { |                 "Armor", | ||||||
|                     MCAdvantagePicker( |                 destination: EditArmor(monsterViewModel: monsterViewModel)) | ||||||
|                         label: "Strength Advantage", |  | ||||||
|                         value: $monsterViewModel.strengthSavingThrowAdvantage) |  | ||||||
|              |              | ||||||
|                     MCProficiencyPicker( |             NavigationLink( | ||||||
|                         label: "Strength Proficiency", |                 "Speed", | ||||||
|                         value: $monsterViewModel.strengthSavingThrowProficiency) |                 destination: EditSpeed(monsterViewModel: monsterViewModel)) | ||||||
|                 } |  | ||||||
|                 VStack { |  | ||||||
|                     MCAdvantagePicker( |  | ||||||
|                         label: "Dexterity Advantage", |  | ||||||
|                         value: $monsterViewModel.dexteritySavingThrowAdvantage) |  | ||||||
|              |              | ||||||
|                     MCProficiencyPicker( |             NavigationLink( | ||||||
|                         label: "Dexterity Proficiency", |                 "Ability Scores", | ||||||
|                         value: $monsterViewModel.dexteritySavingThrowProficiency) |                 destination: EditAbilityScores(monsterViewModel: monsterViewModel)) | ||||||
|                 } |  | ||||||
|                 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( | ||||||
|  |                 "Saving Throws", | ||||||
|  |                 destination: EditSavingThrows(monsterViewModel: monsterViewModel)) | ||||||
|         } |         } | ||||||
|         .onAppear(perform: copyMonsterToLocal) |         .onAppear(perform: copyMonsterToLocal) | ||||||
|         .toolbar(content: { |         .toolbar(content: { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user