diff options
author | Daniel Weipert <code@drogueronin.de> | 2023-08-18 23:19:13 +0200 |
---|---|---|
committer | Daniel Weipert <code@drogueronin.de> | 2023-08-18 23:19:13 +0200 |
commit | 91d048ef0f994446aaee91e3afcbd99788e439d7 (patch) | |
tree | 30063656343d7c3c0f9ebd37b2eb1896bfa76820 /resources/js/classes/utility | |
parent | f9b00e47e04eac414d892a08136a90833abeefd6 (diff) |
item effects,conditions
Diffstat (limited to 'resources/js/classes/utility')
-rw-r--r-- | resources/js/classes/utility/ItemCondition.js | 18 | ||||
-rw-r--r-- | resources/js/classes/utility/ItemEffect.js | 51 | ||||
-rw-r--r-- | resources/js/classes/utility/TechniqueEffect.js | 72 |
3 files changed, 141 insertions, 0 deletions
diff --git a/resources/js/classes/utility/ItemCondition.js b/resources/js/classes/utility/ItemCondition.js new file mode 100644 index 0000000..c8c1fe2 --- /dev/null +++ b/resources/js/classes/utility/ItemCondition.js @@ -0,0 +1,18 @@ +class ItemCondition { + /** + * @param {string} conditionCode + */ + constructor (conditionCode) { + this.is = conditionCode.split(' ')[0]; + this.what = conditionCode.split(' ')[1]; + + if (conditionCode.includes(',')) { + this.comparator = conditionCode.split(' ')[2].split(',')[0]; + this.value = conditionCode.split(' ')[2].split(',')[1]; + } + + else { + this.value = conditionCode.split(' ')[2]; + } + } +} diff --git a/resources/js/classes/utility/ItemEffect.js b/resources/js/classes/utility/ItemEffect.js new file mode 100644 index 0000000..aa1c1df --- /dev/null +++ b/resources/js/classes/utility/ItemEffect.js @@ -0,0 +1,51 @@ +class ItemEffect { + /** + * @type {string} + */ + type = ''; + + /** + * @type {('increase')} + */ + application = ''; + + /** + * @type {number} + */ + amount = 0; + + /** + * @param {string} effectCode + */ + constructor (effectCode) { + if (effectCode.startsWith('heal')) { + this.type = 'heal'; + + this.amount = parseInt(effectCode.split(' ')[1]); + } + + else if (effectCode.startsWith('revive')) { + this.type = 'revive'; + + this.amount = effectCode.split(' ')[1]; + } + + else if (effectCode.startsWith('learn_')) { + this.type = effectCode.split(' ')[0]; + + this.what = effectCode.split(' ')[1]; + } + + else if (Object.values(StatType).includes(effectCode.split(' ')[1] || '')) { + this.type = 'stat'; + + this.application = effectCode.split(' ')[0]; + this.what = effectCode.split(' ')[1].split(',')[0]; + this.amount = effectCode.split(' ')[1].split(',')[1]; + } + + else { + this.type = effectCode; + } + } +} diff --git a/resources/js/classes/utility/TechniqueEffect.js b/resources/js/classes/utility/TechniqueEffect.js new file mode 100644 index 0000000..10e9399 --- /dev/null +++ b/resources/js/classes/utility/TechniqueEffect.js @@ -0,0 +1,72 @@ +class TechniqueEffect { + /** + * @type {string} + */ + type = ''; + + /** + * @type {(('user' | 'target')|Monster)} + */ + recipient = null; + + /** + * @type {('give' | 'remove')} + */ + application = ''; + + /** + * @type {StatusEffectType} + */ + statusEffect = null; + + /** + * @type {Monster} + */ + user = null; + + /** + * @type {Monster} + */ + target = null; + + /** + * @param {string} effectCode + */ + constructor (effectCode) { + if (effectCode.includes('status_')) { + this.type = 'status'; + + this.recipient = effectCode.split(',')[1]; + this.application = effectCode.split(' ')[0]; + this.statusEffect = effectCode.split(',')[0].split(' ')[1].split('_')[1]; + } + + else if (effectCode.includes('healing')) { + this.type = 'healing'; + + this.recipient = effectCode.split(' ')[1]; + } + + else { + this.type = effectCode; + } + } + + /** + * @type {Monster} + */ + setUser (user) { + if (this.recipient === 'user') { + this.recipient = user; + } + } + + /** + * @type {Monster} + */ + setTarget (target) { + if (this.recipient === 'target') { + this.recipient = target; + } + } +} |