Spell
Importing the class
It might be required for you to import the package if you encounter any issues (like casting an Array), so better be safe than sorry and add the import at the very top of the file.
import mods.rootsclassic.Spell;Implemented Interfaces
Spell implements the following interfaces. That means all methods defined in these interfaces are also available in Spell
Methods
Spell.addJsonRecipe(name as string, mapData as MapData)| Parameter | Type | 
|---|---|
| Parametername | Typestring | 
| ParametermapData | TypeMapData | 
Adds a new Mortar recipe.
// Spell.addMortarCrafting(uniqueName as string, items as IItemStack[], output as IItemStack)
<recipetype:rootsclassic:component>.addMortarCrafting("gunpowder_to_gold", [<item:minecraft:gunpowder>, <item:minecraft:coal>], <item:minecraft:gold_ingot>);| Parameter | Type | Description | 
|---|---|---|
| ParameteruniqueName | Typestring | DescriptionThe unique name of the recipe | 
| Parameteritems | TypeIItemStack[] | DescriptionThe inputs of the recipe | 
| Parameteroutput | TypeIItemStack | DescriptionThe output of the recipe | 
Return Type: stdlib.List<T>
// Spell.getAllRecipes() as stdlib.List<T>
<recipetype:rootsclassic:component>.getAllRecipes();Return Type: T
Spell.getRecipeByName(name as string) as T| Parameter | Type | 
|---|---|
| Parametername | Typestring | 
Return Type: T[ResourceLocation]
// Spell.getRecipeMap() as T[ResourceLocation]
<recipetype:rootsclassic:component>.getRecipeMap();Return Type: stdlib.List<T>
Spell.getRecipesByOutput(output as IIngredient) as stdlib.List<T>| Parameter | Type | 
|---|---|
| Parameteroutput | TypeIIngredient | 
Spell.remove(output as IIngredient)| Parameter | Type | 
|---|---|
| Parameteroutput | TypeIIngredient | 
// Spell.removeAll()
<recipetype:rootsclassic:component>.removeAll();Spell.removeByInput(input as IItemStack)| Parameter | Type | 
|---|---|
| Parameterinput | TypeIItemStack | 
Spell.removeByModid(modid as string, exclude as Predicate<string>)| Parameter | Type | Optional | Default Value | 
|---|---|---|---|
| Parametermodid | Typestring | Optionalfalse | Default Value | 
| Parameterexclude | TypePredicate<string> | Optionaltrue | Default Value(name as string) as bool => false | 
Spell.removeByName(names as string[])| Parameter | Type | 
|---|---|
| Parameternames | Typestring[] | 
Spell.removeByRegex(regex as string, exclude as Predicate<string>)| Parameter | Type | Optional | Default Value | 
|---|---|---|---|
| Parameterregex | Typestring | Optionalfalse | Default Value | 
| Parameterexclude | TypePredicate<string> | Optionaltrue | Default Value(name as string) as bool => false | 
Modify the ingredients of an existing Spell Recipe, in order to keep the Spell Powder with the right type. Names must be one of:
- rose_bush,
- dandelion,
- chorus,
- nether_wart,
- peony,
- sunflower,
- azure_bluet,
- allium,
- lilac,
- white_tulip,
- red_tulip,
- blue_orchid,
- poppy,
- poisonous_potato,
- orange_tulip,
- pink_tulip,
- oxeye_daisy,
- lily_pad,
- apple,
- midnight_bloom,
- flare_orchid,
- radiant_daisy
// Spell.setSpellIngredients(name as ResourceLocation, ingredients as IItemStack[])
<recipetype:rootsclassic:component>.setSpellIngredients(<resource:rootsclassic:rose_bush>, [<item:minecraft:tnt>, <item:minecraft:apple>]);| Parameter | Type | Description | 
|---|---|---|
| Parametername | TypeResourceLocation | DescriptionThe resourcelocation to target | 
| Parameteringredients | TypeIItemStack[] | DescriptionThe new ingredients of the recipe. | 
Properties
| Name | Type | Has Getter | Has Setter | 
|---|---|---|---|
| NameallRecipes | Typestdlib.List<T> | Has Gettertrue | Has Setterfalse | 
| NamerecipeMap | TypeT[ResourceLocation] | Has Gettertrue | Has Setterfalse |