« get me outta code hell

csb-game - Pixelly spin-off of the Command Synergy Battle system used in Final Fantasy XIII
summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--index.js45
1 files changed, 35 insertions, 10 deletions
diff --git a/index.js b/index.js
index 8bf7ee5..6e339d3 100644
--- a/index.js
+++ b/index.js
@@ -350,12 +350,16 @@ class BaseBattleMenu {
 
 class ActionMenu extends BaseBattleMenu {
   constructor(battle) {
-    super({options: Object.values(actionDatabase)
-      .map(chain => ({chain, levelTexts: chain.map(action => action.label)}))
-    })
+    super({options: []})
 
     this.battle = battle
-    this.uiLevel = 3 // 1-3 -- which of "fire", "fira", "firaga" is selected.
+    this.uiLevel = 2 // 1-3 -- which of "fire", "fira", "firaga" is selected.
+  }
+
+  buildOptions(targetType) {
+    this.options = Object.values(actionDatabase)
+      .filter(chain => chain[0].target === targetType) // Assume all actions have the same target type
+      .map(chain => ({chain, levelTexts: chain.map(action => action.label)}))
   }
 
   drawOption(option, ctx) {
@@ -426,8 +430,8 @@ class TargetMenu extends BaseBattleMenu {
     this.battle = battle
   }
 
-  buildOptions(action) {
-    this.options = this.battle.playerCharacter.getValidTargets(action)
+  buildOptions(targetType) {
+    this.options = this.battle.playerCharacter.getValidTargets(targetType)
       .map(char => ({label: char.name, battleCharacter: char}))
   }
 }
@@ -569,6 +573,11 @@ class Battle {
     this.actionMenu = new ActionMenu(this)
     this.targetMenu = new TargetMenu(this)
 
+    this.targetTypeMenu = new BaseBattleMenu({options: [
+      {label: 'Aggression', targetType: 'enemy'},
+      {label: 'Reinforcement', targetType: 'ally'}
+    ]})
+
     this.backdrop = new Backdrop()
 
     this.camera = new Camera()
@@ -582,7 +591,7 @@ class Battle {
 
     this.gameState = 'battle' // battle, pre-win, win
 
-    this.currentMenu = this.actionMenu
+    this.currentMenu = this.targetTypeMenu
     this.changeMenuAnim = {time: 1, direction: 1, old: null}
     this.preWinAnim = null
   }
@@ -708,10 +717,16 @@ class Battle {
     }
   }
 
+  showActionMenu({direction}) {
+    this.changeMenuAnim = {old: this.currentMenu, direction, time: 1}
+    this.currentMenu = this.actionMenu
+    this.actionMenu.buildOptions(this.playerCharacter.targetType)
+  }
+
   showTargetMenu() {
     this.changeMenuAnim = {old: this.currentMenu, direction: 1, time: 1}
     this.currentMenu = this.targetMenu
-    this.targetMenu.buildOptions(last(this.playerCharacter.atbBar.queuedActions).target) // TODO: Target type stored on the player
+    this.targetMenu.buildOptions(this.playerCharacter.targetType)
   }
 
   hideCurrentMenu() {
@@ -852,13 +867,18 @@ function drawLoop() {
 }
 
 canvas.addEventListener('keypress', evt => {
-  const { actionMenu, targetMenu, currentMenu } = battle
+  const { targetTypeMenu, actionMenu, targetMenu, currentMenu } = battle
   const { atbBar } = battle.playerCharacter
   if (!battle.playerCharacter.isExecutingChain && battle.currentMenu) {
     if (evt.keyCode === 38) {
       currentMenu.upOption()
     } else if (evt.keyCode === 40) {
       currentMenu.downOption()
+    } else if (currentMenu === targetTypeMenu) {
+      if (evt.keyCode === 13 || evt.which === 32) {
+        battle.playerCharacter.targetType = targetTypeMenu.getCurrentOption().targetType
+        battle.showActionMenu({direction: 1})
+      }
     } else if (currentMenu === actionMenu) {
       if (evt.keyCode === 37) {
         currentMenu.decreaseLevel()
@@ -867,7 +887,12 @@ canvas.addEventListener('keypress', evt => {
       } else if (evt.which === 32) {
         currentMenu.queueTo(atbBar)
       } else if (evt.keyCode === 8) {
-        atbBar.dequeue()
+        if (atbBar.queuedActions.length) {
+          atbBar.dequeue()
+        } else {
+          battle.currentMenu = targetTypeMenu
+          battle.changeMenuAnim = {old: actionMenu, direction: -1, time: 1}
+        }
       } else if (evt.keyCode === 13 || evt.key.toLowerCase() === 'e') {
         if (battle.playerCharacter.atbBar.queuedActions.length) {
           battle.showTargetMenu()