Adds legendary actions.
This commit is contained in:
		| @@ -62,6 +62,7 @@ class MonsterViewModel: ObservableObject { | |||||||
|     @Published var customProficiencyBonus: Int64 |     @Published var customProficiencyBonus: Int64 | ||||||
|     @Published var abilities: [AbilityViewModel] |     @Published var abilities: [AbilityViewModel] | ||||||
|     @Published var actions: [AbilityViewModel] |     @Published var actions: [AbilityViewModel] | ||||||
|  |     @Published var legendaryActions: [AbilityViewModel] | ||||||
|      |      | ||||||
|     init(_ rawMonster: Monster? = nil) { |     init(_ rawMonster: Monster? = nil) { | ||||||
|         self.name = "" |         self.name = "" | ||||||
| @@ -116,6 +117,7 @@ class MonsterViewModel: ObservableObject { | |||||||
|         self.customProficiencyBonus = 0 |         self.customProficiencyBonus = 0 | ||||||
|         self.abilities = [] |         self.abilities = [] | ||||||
|         self.actions = [] |         self.actions = [] | ||||||
|  |         self.legendaryActions = [] | ||||||
|  |  | ||||||
|         if (rawMonster != nil) { |         if (rawMonster != nil) { | ||||||
|             self.copyFromMonster(monster: rawMonster!) |             self.copyFromMonster(monster: rawMonster!) | ||||||
| @@ -199,6 +201,9 @@ class MonsterViewModel: ObservableObject { | |||||||
|          |          | ||||||
|         self.actions = (monster.actions ?? []) |         self.actions = (monster.actions ?? []) | ||||||
|             .map {AbilityViewModel($0.name, $0.abilityDescription)} |             .map {AbilityViewModel($0.name, $0.abilityDescription)} | ||||||
|  |          | ||||||
|  |         self.legendaryActions = (monster.legendaryActions ?? []) | ||||||
|  |             .map {AbilityViewModel($0.name, $0.abilityDescription)} | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     func copyToMonster(monster: Monster) { |     func copyToMonster(monster: Monster) { | ||||||
| @@ -278,5 +283,7 @@ class MonsterViewModel: ObservableObject { | |||||||
|         monster.abilities = abilities.map {AbilityViewModel($0.name, $0.abilityDescription)} |         monster.abilities = abilities.map {AbilityViewModel($0.name, $0.abilityDescription)} | ||||||
|          |          | ||||||
|         monster.actions = actions.map {AbilityViewModel($0.name, $0.abilityDescription)} |         monster.actions = actions.map {AbilityViewModel($0.name, $0.abilityDescription)} | ||||||
|  |          | ||||||
|  |         monster.legendaryActions = legendaryActions.map {AbilityViewModel($0.name, $0.abilityDescription)} | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -40,6 +40,7 @@ | |||||||
|         <attribute name="intelligenceScore" attributeType="Integer 64" defaultValueString="10" usesScalarValueType="YES"/> |         <attribute name="intelligenceScore" attributeType="Integer 64" defaultValueString="10" usesScalarValueType="YES"/> | ||||||
|         <attribute name="isBlind" attributeType="Boolean" defaultValueString="NO" usesScalarValueType="YES"/> |         <attribute name="isBlind" attributeType="Boolean" defaultValueString="NO" usesScalarValueType="YES"/> | ||||||
|         <attribute name="languages" optional="YES" attributeType="Transformable" valueTransformerName="LanguageViewModelValueTransformer" customClassName="[LanguageViewModel]"/> |         <attribute name="languages" optional="YES" attributeType="Transformable" valueTransformerName="LanguageViewModelValueTransformer" customClassName="[LanguageViewModel]"/> | ||||||
|  |         <attribute name="legendaryActions" optional="YES" attributeType="Transformable" valueTransformerName="AbilityViewModelValueTransformer" customClassName="[AbilityViewModel]"/> | ||||||
|         <attribute name="name" attributeType="String" defaultValueString="Unnamed Monster"/> |         <attribute name="name" attributeType="String" defaultValueString="Unnamed Monster"/> | ||||||
|         <attribute name="naturalArmorBonus" attributeType="Integer 64" defaultValueString="0" usesScalarValueType="YES"/> |         <attribute name="naturalArmorBonus" attributeType="Integer 64" defaultValueString="0" usesScalarValueType="YES"/> | ||||||
|         <attribute name="otherArmorDescription" attributeType="String" defaultValueString=""/> |         <attribute name="otherArmorDescription" attributeType="String" defaultValueString=""/> | ||||||
| @@ -69,7 +70,7 @@ | |||||||
|         <relationship name="monster" optional="YES" maxCount="1" deletionRule="Nullify" destinationEntity="Monster" inverseName="skills" inverseEntity="Monster"/> |         <relationship name="monster" optional="YES" maxCount="1" deletionRule="Nullify" destinationEntity="Monster" inverseName="skills" inverseEntity="Monster"/> | ||||||
|     </entity> |     </entity> | ||||||
|     <elements> |     <elements> | ||||||
|         <element name="Monster" positionX="-63" positionY="-18" width="128" height="914"/> |         <element name="Monster" positionX="-63" positionY="-18" width="128" height="929"/> | ||||||
|         <element name="Skill" positionX="-63" positionY="135" width="128" height="14"/> |         <element name="Skill" positionX="-63" positionY="135" width="128" height="14"/> | ||||||
|     </elements> |     </elements> | ||||||
| </model> | </model> | ||||||
| @@ -80,6 +80,10 @@ struct EditMonster: View { | |||||||
|                 NavigationLink( |                 NavigationLink( | ||||||
|                     "Actions", |                     "Actions", | ||||||
|                     destination: EditTraits(viewModel: monsterViewModel, path: \.actions, title: "Actions")) |                     destination: EditTraits(viewModel: monsterViewModel, path: \.actions, title: "Actions")) | ||||||
|  |                  | ||||||
|  |                 NavigationLink( | ||||||
|  |                     "Legendary Actions", | ||||||
|  |                     destination: EditTraits(viewModel: monsterViewModel, path: \.legendaryActions, title: "Legendary Actions")) | ||||||
|             } |             } | ||||||
|              |              | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -213,6 +213,7 @@ struct MonsterDetail: View { | |||||||
|                 let monsterChallengeRatingDescription = monster.challengeRatingDescription |                 let monsterChallengeRatingDescription = monster.challengeRatingDescription | ||||||
|                 let monsterAbilities: [AbilityViewModel] = monster.abilities ?? [] |                 let monsterAbilities: [AbilityViewModel] = monster.abilities ?? [] | ||||||
|                 let monsterActions: [AbilityViewModel] = monster.actions ?? [] |                 let monsterActions: [AbilityViewModel] = monster.actions ?? [] | ||||||
|  |                 let monsterLegendaryActions: [AbilityViewModel] = monster.legendaryActions ?? [] | ||||||
|                  |                  | ||||||
|                 BasicInfoView(monster: monster) |                 BasicInfoView(monster: monster) | ||||||
|                  |                  | ||||||
| @@ -270,6 +271,18 @@ struct MonsterDetail: View { | |||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 // Legendary Actions |                 // Legendary Actions | ||||||
|  |                 if (monsterLegendaryActions.count > 0) { | ||||||
|  |                     VStack(alignment: .leading) { | ||||||
|  |                         Text("Legendary Actions") | ||||||
|  |                             .fontWeight(.bold) | ||||||
|  |                         ForEach(monsterLegendaryActions) { action in | ||||||
|  |                             VStack { | ||||||
|  |                                 Markdown(Document(action.renderedText(monster))) | ||||||
|  |                                 Divider() | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|                  |                  | ||||||
|             } |             } | ||||||
|             .padding(.horizontal) |             .padding(.horizontal) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user