I've been watching youtube videos about Resources for most of the morning and I tried implementing them myself, but I just can't wrap my head around it. Basically I want to replace my current skill system with resources to clean things up.
My current structure uses way too many nodes. Skills can currently be KinematicBodies, RigidBodies, or Areas. I have a corresponding script for each of these called "KinematicInitialize" or "RigidBodyIntitalize" etc. that extend from their respective node. And then I have actual packed scene (with the sprite, animation, etc.) that extends from each of those scripts. The problem is that these 3 "initialize" scripts are all basically exactly the same. They're importing data from my skillsheet json file (which I want to replace with resources eventually but one step at a time). Additionally, the packed scenes that extend from the initialize scripts are also all almost the same (they all have sprite, animationplayer, etc.)
Here's an example of an initialize:
class_name SkillInit_Area2D extends Area2D
onready var signalBus = SignalBus
onready var skillSprite = $Sprite
onready var animationPlayer = $AnimationPlayer
onready var hitbox = $AbilityHitbox
var skillName: String
var skillElement: String
var skillType: String
var cooldownDuration: float
var skillDamage: int
skillElement = DataImport.skill_data[skillName].Element
skillType = DataImport.skill_data[skillName].SkillType
cooldownDuration = DataImport.skill_data[skillName].CooldownDuration
skillDamage = DataImport.skill_data[skillName].SkillDamage
+ a variety of functions like scaling the sprite, checking aoe timers and starting those, etc.
And then the Area2D that extends that, "extends SkillInit_Area2D", has the specific behaviors for Area2D skills. The actual skills inherit from this where I can change the sprite, etc. Same with Kinematic and Rigid.
This is all fine except that, again, all my packed scenes are the same, and the data import itself is all the same, so when I want to edit/add/remove one thing, I have to do it in 3 different places.
I feel like using resources would clean this up tremendously but I'm having issues implementing.
When the player uses an ability, it begins with an "AttackManager" node I have attached to the Player. It catches the Skill Name, adds the right skill as a child (which is only using KinematicBody script, Area script, etc.), and then sends the Skill Name to the Child which then checks the "Initialize" script to see how much damage it does, its cooldown, etc.
So what I did was make a resource called "playerabilitydata" that includes all of the variables and import data of the skills. I then have a KinematicBody2D node with a script that starts with:
onready var skillData = load("res://resources/abilities/player_ability_data.gd")
skillData.skillName = skillName
But then when I try to use this ability in game, I get the error: "Invalid set index 'skillName' (on base 'GDScript') with value type of 'String'" which makes it sound like I can't send the skill's name into the Player Ability Data so it can get the right cooldown, damage, etc.
When I instead use
export(Resource) var skillData
And then load the script through the editor, I don't seem to need to use "skillData.skillName = skillName", but I get error that it can't reach the "knockback_vector" variable.
var projectileRotation = Vector2.RIGHT.rotated(rotation)
skillData.knockback_vector = projectileRotation
Overall I am just super confused and can't figure out how to do this right. Sorry if my explanation is confusing, I just wanted to be thorough. Any help would be super appreciated. I am also willing to completely redo things from scratch. Thanks so much!
tldr: How do you use Resources for different types of Skills?