浏览代码

putting infobox data in gameList

lairaalmas 2 年之前
父节点
当前提交
792ab3f207

src/assets/img/characters/balloon/ballon_basket.png → src/assets/img/characters/balloon/balloon_basket.png


src/assets/img/icons_interactive/selection_box.png → src/assets/img/icons_interactive/select_input.png


src/assets/img/info_box/operation_equals.png → src/assets/img/info_box/op_eq.png


src/assets/img/info_box/operation_minus.png → src/assets/img/info_box/op_min.png


src/assets/img/info_box/operation_mixed.png → src/assets/img/info_box/op_mix.png


src/assets/img/info_box/operation_plus.png → src/assets/img/info_box/op_plus.png


+ 175 - 5
src/js/globals/globals_tokens.js

@@ -16,6 +16,61 @@ const gameList = [
       gameNameBtn: 'game_0',
       gameNameBtn: 'game_0',
       gameModeBtn: ['mode_0', 'mode_1'],
       gameModeBtn: ['mode_0', 'mode_1'],
       gameOperationBtn: ['operation_plus', 'operation_minus'],
       gameOperationBtn: ['operation_plus', 'operation_minus'],
+      menuInfoBox: () => ({
+        title:
+          '<strong>' + game.lang.game + ':</strong> ' + game.lang.square + ' I',
+        body: '<ul>' + game.lang.infoBox_squareOne + '</ul>',
+        img:
+          '<img class="mx-auto" width=60% src="' +
+          game.image['s1-A'].src +
+          '">',
+      }),
+      customMenuInfoBox: () => ({
+        gameMode: {
+          title: '<b>' + game.lang.game_modes + '</b>',
+          body: game.lang.infoBox_mode,
+          img:
+            '<table> <tr> <td> <b>a)</b> ' +
+            game.lang.infoBox_mode_s1_A +
+            ' </td> <td> <b>b)</b> ' +
+            game.lang.infoBox_mode_s1_B +
+            ' </td> </tr> <tr> <td> <img width=100% src="' +
+            game.image['s1-A-h'].src +
+            '"> ' +
+            ' </td> <td> <img width=100% src="' +
+            game.image['s1-B-h'].src +
+            '"> </td> </tr> <table>',
+        },
+        gameDifficulty: {
+          title: '<b>' + game.lang.difficulties + '</b>',
+          body: game.lang.infoBox_diff + ' ' + game.lang.infoBox_diff_obs,
+          img:
+            '<table> <tr> <td> <b>' +
+            game.lang.difficulty +
+            ':</b> 1' +
+            ' </td> <td> <b>' +
+            game.lang.difficulty +
+            ':</b> 3' +
+            ' </td> </tr> <tr> <td> <img width=100% src="' +
+            game.image['s1-diff-1'].src +
+            '"> ' +
+            ' </td> <td style="border-left: 4px solid white"> <img width=100% src="' +
+            game.image['s1-diff-3'].src +
+            '"> </td> </tr> </table> <br>' +
+            game.lang.infoBox_diff_aux +
+            '<center> <img width=50% src="' +
+            game.image['map-s1'].src +
+            '"> </center>',
+        },
+        gameMisc: {
+          title: '<b>' + game.lang.show + ' ' + self.auxText + '</b>',
+          body: game.lang.infoBox_misc_label,
+          img:
+            '<img class="mx-auto" width=80% src="' +
+            game.image['s1-label'].src +
+            '">',
+        },
+      }),
       mapCharacterAnimation: (operation) => {
       mapCharacterAnimation: (operation) => {
         return operation === 'plus'
         return operation === 'plus'
           ? ['green_tractor', [0, 1, 2, 3, 4], 3]
           ? ['green_tractor', [0, 1, 2, 3, 4], 3]
@@ -82,6 +137,62 @@ const gameList = [
         'operation_minus',
         'operation_minus',
         'operation_mixed',
         'operation_mixed',
       ],
       ],
+      menuInfoBox: () => ({
+        title:
+          '<strong>' + game.lang.game + ':</strong> ' + game.lang.circle + ' I',
+        body: '<ul>' + game.lang.infoBox_circleOne + '</ul>',
+        img:
+          '<img class="mx-auto" width=80% src="' +
+          game.image['c1-A'].src +
+          '">',
+      }),
+      customMenuInfoBox: () => ({
+        gameMode: {
+          title: '<b>' + game.lang.game_modes + '</b>',
+          body: game.lang.infoBox_mode,
+          img:
+            '<table> <tr style="border-bottom: 5px solid white"> <td width=70%> <img width=100% src="' +
+            game.image['c1-A-h'].src +
+            '">' +
+            ' </td> <td> &nbsp; <b>a)</b> ' +
+            game.lang.infoBox_mode_c1_A +
+            ' </td> </tr> </tr> <td> <img width=100% src="' +
+            game.image['c1-B-h'].src +
+            '"> ' +
+            ' </td> <td> &nbsp; <b>b)</b> ' +
+            game.lang.infoBox_mode_c1_B +
+            '</td> </tr> <table>',
+        },
+        gameDifficulty: {
+          title: '<b>' + game.lang.difficulties + '</b>',
+          body: game.lang.infoBox_diff + ' ' + game.lang.infoBox_diff_obs,
+          img:
+            '<table> <tr> <td style="border-right: 4px solid white"> <b>' +
+            game.lang.difficulty +
+            ':</b> 1' +
+            ' </td> <td> <b>' +
+            game.lang.difficulty +
+            ':</b> 5' +
+            ' </td> </tr> <tr> <td> <img width=100% src="' +
+            game.image['c1-diff-1'].src +
+            '"> ' +
+            ' </td> <td style="border-left: 4px solid white"> <img width=100% src="' +
+            game.image['c1-diff-5'].src +
+            '"> </td> </tr> </table> <center> <br>' +
+            game.lang.infoBox_diff_aux +
+            '<center> <img width=50% src="' +
+            game.image['map-c1s2'].src +
+            '"> </center>',
+        },
+        gameMisc: {
+          title: '<b>' + game.lang.show + ' ' + self.auxText + '</b>',
+          body: game.lang.infoBox_misc_label,
+          img:
+            '<img class="mx-auto" width=60% src="' +
+            game.image['c1-label'].src +
+            '">',
+        },
+      }),
       mapCharacterAnimation: (operation) => {
       mapCharacterAnimation: (operation) => {
         return ['kid', [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10], 3];
         return ['kid', [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10], 3];
       },
       },
@@ -128,6 +239,63 @@ const gameList = [
       gameNameBtn: 'game_2',
       gameNameBtn: 'game_2',
       gameModeBtn: ['mode_4', 'mode_5'],
       gameModeBtn: ['mode_4', 'mode_5'],
       gameOperationBtn: ['operation_equals'],
       gameOperationBtn: ['operation_equals'],
+      menuInfoBox: () => ({
+        title:
+          '<strong>' +
+          game.lang.game +
+          ':</strong> ' +
+          game.lang.square +
+          ' II',
+        body: '<ul>' + game.lang.infoBox_squareTwo + '</ul>',
+        img:
+          '<img class="mx-auto" width=80% src="' + game.image['s2'].src + '">',
+      }),
+      customMenuInfoBox: () => ({
+        gameMode: {
+          title: '<b>' + game.lang.game_modes + '</b>',
+          body: game.lang.infoBox_mode,
+          img:
+            '<table> <tr> <td> <b>a)</b> ' +
+            game.lang.infoBox_mode_s2_A +
+            ' </td> <td> <b>b)</b> ' +
+            game.lang.infoBox_mode_s2_B +
+            ' </td> </tr> <tr> <td> <img width=98% src="' +
+            game.image['s2-A-h'].src +
+            '"> ' +
+            ' </td> <td> <img width=98% src="' +
+            game.image['s2-B-h'].src +
+            '"> </td> </tr> <table>',
+        },
+        gameDifficulty: {
+          title: '<b>' + game.lang.difficulties + '</b>',
+          body: game.lang.infoBox_diff,
+          img:
+            '<table> <tr> <td> <b>' +
+            game.lang.difficulty +
+            ':</b> 1' +
+            ' </td> <td> <b>' +
+            game.lang.difficulty +
+            ':</b> 5' +
+            ' </td> </tr> <tr> <td> <img width=100% src="' +
+            game.image['s2-diff-1'].src +
+            '"> ' +
+            ' </td> <td style="border-left: 4px solid white"> <img width=100% src="' +
+            game.image['s2-diff-5'].src +
+            '"> </td> </tr> </table> <br>' +
+            game.lang.infoBox_diff_aux +
+            '<center> <img width=50% src="' +
+            game.image['map-c1s2'].src +
+            '"> </center>',
+        },
+        gameMisc: {
+          title: '<b>' + game.lang.show + ' ' + self.auxText + '</b>',
+          body: game.lang.infoBox_misc_rect,
+          img:
+            '<img class="mx-auto" width=100% src="' +
+            game.image['s2-label'].src +
+            '">',
+        },
+      }),
       mapCharacterAnimation: (operation) => {
       mapCharacterAnimation: (operation) => {
         return ['kid', [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10], 3];
         return ['kid', [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10], 3];
       },
       },
@@ -174,6 +342,8 @@ const gameList = [
       gameNameBtn: 'game_3',
       gameNameBtn: 'game_3',
       gameModeBtn: ['mode_6'],
       gameModeBtn: ['mode_6'],
       gameOperationBtn: ['operation_equals'],
       gameOperationBtn: ['operation_equals'],
+      // menuInfoBox: ()=>({}),
+      // customMenuInfoBox: ()=>({ gameMode: {}, gameDifficulty: {}, gameMisc: {} }),
       mapCharacterAnimation: (operation) => {
       mapCharacterAnimation: (operation) => {
         return operation === 'plus'
         return operation === 'plus'
           ? ['green_tractor', [0, 1, 2, 3, 4], 3]
           ? ['green_tractor', [0, 1, 2, 3, 4], 3]
@@ -483,10 +653,10 @@ const url = {
       ['s2-diff-1', baseUrl + 'info_box/s2-diff-1.png'],
       ['s2-diff-1', baseUrl + 'info_box/s2-diff-1.png'],
       ['s2-diff-5', baseUrl + 'info_box/s2-diff-5.png'],
       ['s2-diff-5', baseUrl + 'info_box/s2-diff-5.png'],
       ['s2-label', baseUrl + 'info_box/s2-label.png'],
       ['s2-label', baseUrl + 'info_box/s2-label.png'],
-      ['operation_plus', baseUrl + 'info_box/operation_plus.png'],
-      ['operation_minus', baseUrl + 'info_box/operation_minus.png'],
-      ['operation_mixed', baseUrl + 'info_box/operation_mixed.png'],
-      ['operation_equals', baseUrl + 'info_box/operation_equals.png'],
+      ['op_plus', baseUrl + 'info_box/op_plus.png'],
+      ['op_min', baseUrl + 'info_box/op_min.png'],
+      ['op_mix', baseUrl + 'info_box/op_mix.png'],
+      ['op_eq', baseUrl + 'info_box/op_eq.png'],
     ],
     ],
     sprite: [
     sprite: [
       // Game Sprites
       // Game Sprites
@@ -494,7 +664,7 @@ const url = {
       // Navigation icons on the top of the page
       // Navigation icons on the top of the page
       ['audio', baseUrl + 'icons_navigation/audio.png', 2],
       ['audio', baseUrl + 'icons_navigation/audio.png', 2],
       // Interactive icons
       // Interactive icons
-      ['select', baseUrl + 'icons_interactive/selection_box.png', 2],
+      ['select_input', baseUrl + 'icons_interactive/select_input.png', 2],
       ['btn_square', baseUrl + 'icons_interactive/btn_square.png', 2],
       ['btn_square', baseUrl + 'icons_interactive/btn_square.png', 2],
       // Menu icons - Game modes
       // Menu icons - Game modes
       ['mode_0', baseUrl + 'icons_menu/squareOne_1.png', 2], // Square I : A
       ['mode_0', baseUrl + 'icons_menu/squareOne_1.png', 2], // Square I : A

+ 48 - 194
src/js/menus/menu_custom.js

@@ -58,14 +58,14 @@ const customMenuState = {
       let x = gameFrame().x;
       let x = gameFrame().x;
       let y = gameFrame().y;
       let y = gameFrame().y;
 
 
-      const auxText = this.renderSectionTitles(x, y, offsetW, offsetH);
+      this.renderSectionTitles(x, y, offsetW, offsetH);
       this.renderCheckBox(x, y, offsetW, offsetH);
       this.renderCheckBox(x, y, offsetW, offsetH);
       this.renderModeSection(x, y, offsetW, offsetH, curGame);
       this.renderModeSection(x, y, offsetW, offsetH, curGame);
       this.renderOperationSection(x, y, offsetW, offsetH, curGame);
       this.renderOperationSection(x, y, offsetW, offsetH, curGame);
       this.renderDifficultySection(x, y, offsetW, offsetH, curGame);
       this.renderDifficultySection(x, y, offsetW, offsetH, curGame);
       this.renderEnterSection(x, y);
       this.renderEnterSection(x, y);
 
 
-      this.setInfoBoxes(auxText);
+      this.setInfoBoxes();
 
 
       // ------------- EVENTS
       // ------------- EVENTS
 
 
@@ -285,27 +285,25 @@ const customMenuState = {
       textStyles.h4_blue
       textStyles.h4_blue
     );
     );
 
 
-    let auxText;
+    self.auxText;
 
 
     if (gameName == 'squareTwo') {
     if (gameName == 'squareTwo') {
-      auxText = game.lang.aux_rectangle;
+      self.auxText = game.lang.aux_rectangle;
       game.add.text(
       game.add.text(
         x + 5 * offsetW + 10,
         x + 5 * offsetW + 10,
         y + offsetH + 80,
         y + offsetH + 80,
-        auxText,
+        self.auxText,
         textStyles.h4_blue
         textStyles.h4_blue
       );
       );
     } else {
     } else {
-      auxText = game.lang.title;
+      self.auxText = game.lang.title;
       game.add.text(
       game.add.text(
         x + 5 * offsetW,
         x + 5 * offsetW,
         y + offsetH + 80,
         y + offsetH + 80,
-        auxText,
+        self.auxText,
         textStyles.h2_blue
         textStyles.h2_blue
       );
       );
     }
     }
-
-    return auxText;
   },
   },
 
 
   renderCheckBox: function (x, y, offsetW, offsetH) {
   renderCheckBox: function (x, y, offsetW, offsetH) {
@@ -315,7 +313,7 @@ const customMenuState = {
     const selectionBox = game.add.sprite(
     const selectionBox = game.add.sprite(
       x + 5 * offsetW,
       x + 5 * offsetW,
       y + offsetH + 90,
       y + offsetH + 90,
-      'select',
+      'select_input',
       frame,
       frame,
       1.4
       1.4
     );
     );
@@ -439,7 +437,7 @@ const customMenuState = {
     }
     }
   },
   },
 
 
-  setInfoBoxes: function (auxText) {
+  setInfoBoxes: function () {
     // --------------------------- INFO BOX
     // --------------------------- INFO BOX
 
 
     self.infoBox = document.querySelector('.ifr-modal');
     self.infoBox = document.querySelector('.ifr-modal');
@@ -456,183 +454,39 @@ const customMenuState = {
       }
       }
     };
     };
 
 
-    self.infoBoxContent = {
-      gameMode: {
-        squareOne: {
-          title: '<b>' + game.lang.game_modes + '</b>',
-          body: game.lang.infoBox_mode,
-          img:
-            '<table> <tr> <td> <b>a)</b> ' +
-            game.lang.infoBox_mode_s1_A +
-            ' </td> <td> <b>b)</b> ' +
-            game.lang.infoBox_mode_s1_B +
-            ' </td> </tr> <tr> <td> <img width=100% src="' +
-            game.image['s1-A-h'].src +
-            '"> ' +
-            ' </td> <td> <img width=100% src="' +
-            game.image['s1-B-h'].src +
-            '"> </td> </tr> <table>',
-        },
-        circleOne: {
-          title: '<b>' + game.lang.game_modes + '</b>',
-          body: game.lang.infoBox_mode,
-          img:
-            '<table> <tr style="border-bottom: 5px solid white"> <td width=70%> <img width=100% src="' +
-            game.image['c1-A-h'].src +
-            '">' +
-            ' </td> <td> &nbsp; <b>a)</b> ' +
-            game.lang.infoBox_mode_c1_A +
-            ' </td> </tr> </tr> <td> <img width=100% src="' +
-            game.image['c1-B-h'].src +
-            '"> ' +
-            ' </td> <td> &nbsp; <b>b)</b> ' +
-            game.lang.infoBox_mode_c1_B +
-            '</td> </tr> <table>',
-        },
-        squareTwo: {
-          title: '<b>' + game.lang.game_modes + '</b>',
-          body: game.lang.infoBox_mode,
-          img:
-            '<table> <tr> <td> <b>a)</b> ' +
-            game.lang.infoBox_mode_s2_A +
-            ' </td> <td> <b>b)</b> ' +
-            game.lang.infoBox_mode_s2_B +
-            ' </td> </tr> <tr> <td> <img width=98% src="' +
-            game.image['s2-A-h'].src +
-            '"> ' +
-            ' </td> <td> <img width=98% src="' +
-            game.image['s2-B-h'].src +
-            '"> </td> </tr> <table>',
-        },
-      },
-
-      gameOperation: {
-        title: '<b>' + game.lang.operation_math + '</b>',
-        body: game.lang.infoBox_oper,
-        img:
-          '<table class="table">' +
-          '<tr>' +
-          '<td> <img width=50 src="' +
-          game.image['operation_plus'].src +
-          '"> </td>' +
-          '<td> <img width=50 src="' +
-          game.image['operation_mixed'].src +
-          '"> </td>' +
-          '<td> <img width=50 src="' +
-          game.image['operation_minus'].src +
-          '"> </td>' +
-          '<td> <img width=50 src="' +
-          game.image['operation_equals'].src +
-          '"> </td>' +
-          '</tr> <tr>' +
-          '<td class="text-center">' +
-          game.lang.plus +
-          '</td>' +
-          '<td class="text-center">' +
-          game.lang.mixed +
-          '</td>' +
-          '<td class="text-center">' +
-          game.lang.minus +
-          '</td>' +
-          '<td class="text-center">' +
-          game.lang.equals +
-          '</td>' +
-          '</tr>' +
-          '</table>',
-      },
-
-      gameDifficulty: {
-        squareOne: {
-          title: '<b>' + game.lang.difficulties + '</b>',
-          body: game.lang.infoBox_diff + ' ' + game.lang.infoBox_diff_obs,
-          img:
-            '<table> <tr> <td> <b>' +
-            game.lang.difficulty +
-            ':</b> 1' +
-            ' </td> <td> <b>' +
-            game.lang.difficulty +
-            ':</b> 3' +
-            ' </td> </tr> <tr> <td> <img width=100% src="' +
-            game.image['s1-diff-1'].src +
-            '"> ' +
-            ' </td> <td style="border-left: 4px solid white"> <img width=100% src="' +
-            game.image['s1-diff-3'].src +
-            '"> </td> </tr> </table> <br>' +
-            game.lang.infoBox_diff_aux +
-            '<center> <img width=50% src="' +
-            game.image['map-s1'].src +
-            '"> </center>',
-        },
-        circleOne: {
-          title: '<b>' + game.lang.difficulties + '</b>',
-          body: game.lang.infoBox_diff + ' ' + game.lang.infoBox_diff_obs,
-          img:
-            '<table> <tr> <td style="border-right: 4px solid white"> <b>' +
-            game.lang.difficulty +
-            ':</b> 1' +
-            ' </td> <td> <b>' +
-            game.lang.difficulty +
-            ':</b> 5' +
-            ' </td> </tr> <tr> <td> <img width=100% src="' +
-            game.image['c1-diff-1'].src +
-            '"> ' +
-            ' </td> <td style="border-left: 4px solid white"> <img width=100% src="' +
-            game.image['c1-diff-5'].src +
-            '"> </td> </tr> </table> <center> <br>' +
-            game.lang.infoBox_diff_aux +
-            '<center> <img width=50% src="' +
-            game.image['map-c1s2'].src +
-            '"> </center>',
-        },
-        squareTwo: {
-          title: '<b>' + game.lang.difficulties + '</b>',
-          body: game.lang.infoBox_diff,
-          img:
-            '<table> <tr> <td> <b>' +
-            game.lang.difficulty +
-            ':</b> 1' +
-            ' </td> <td> <b>' +
-            game.lang.difficulty +
-            ':</b> 5' +
-            ' </td> </tr> <tr> <td> <img width=100% src="' +
-            game.image['s2-diff-1'].src +
-            '"> ' +
-            ' </td> <td style="border-left: 4px solid white"> <img width=100% src="' +
-            game.image['s2-diff-5'].src +
-            '"> </td> </tr> </table> <br>' +
-            game.lang.infoBox_diff_aux +
-            '<center> <img width=50% src="' +
-            game.image['map-c1s2'].src +
-            '"> </center>',
-        },
-      },
-
-      gameMisc: {
-        squareOne: {
-          title: '<b>' + game.lang.show + ' ' + auxText + '</b>',
-          body: game.lang.infoBox_misc_label,
-          img:
-            '<img class="mx-auto" width=80% src="' +
-            game.image['s1-label'].src +
-            '">',
-        },
-        circleOne: {
-          title: '<b>' + game.lang.show + ' ' + auxText + '</b>',
-          body: game.lang.infoBox_misc_label,
-          img:
-            '<img class="mx-auto" width=60% src="' +
-            game.image['c1-label'].src +
-            '">',
-        },
-        squareTwo: {
-          title: '<b>' + game.lang.show + ' ' + auxText + '</b>',
-          body: game.lang.infoBox_misc_rect,
-          img:
-            '<img class="mx-auto" width=100% src="' +
-            game.image['s2-label'].src +
-            '">',
-        },
-      },
+    self.gameOperationContent = {
+      title: '<b>' + game.lang.operation_math + '</b>',
+      body: game.lang.infoBox_oper,
+      img:
+        '<table class="table">' +
+        '<tr>' +
+        '<td> <img width=50 src="' +
+        game.image['op_plus'].src +
+        '"> </td>' +
+        '<td> <img width=50 src="' +
+        game.image['op_mix'].src +
+        '"> </td>' +
+        '<td> <img width=50 src="' +
+        game.image['op_min'].src +
+        '"> </td>' +
+        '<td> <img width=50 src="' +
+        game.image['op_eq'].src +
+        '"> </td>' +
+        '</tr> <tr>' +
+        '<td class="text-center">' +
+        game.lang.plus +
+        '</td>' +
+        '<td class="text-center">' +
+        game.lang.mixed +
+        '</td>' +
+        '<td class="text-center">' +
+        game.lang.minus +
+        '</td>' +
+        '<td class="text-center">' +
+        game.lang.equals +
+        '</td>' +
+        '</tr>' +
+        '</table>',
     };
     };
   },
   },
 
 
@@ -642,19 +496,19 @@ const customMenuState = {
   showInfoBox: function (icon) {
   showInfoBox: function (icon) {
     self.infoBox.style.display = 'block';
     self.infoBox.style.display = 'block';
 
 
-    const element =
+    const info =
       icon.id == 'gameOperation'
       icon.id == 'gameOperation'
-        ? self.infoBoxContent[icon.id]
-        : self.infoBoxContent[icon.id][gameName];
+        ? self.gameOperationContent
+        : gameList[gameId].assets.customMenuInfoBox()[icon.id];
 
 
     let msg =
     let msg =
       '<h3>' +
       '<h3>' +
-      element.title +
+      info.title +
       '</h3>' +
       '</h3>' +
       '<p align=justify>' +
       '<p align=justify>' +
-      element.body +
+      info.body +
       '</p>' +
       '</p>' +
-      element.img;
+      info.img;
 
 
     document.querySelector('.ifr-modal__infobox').innerHTML = msg;
     document.querySelector('.ifr-modal__infobox').innerHTML = msg;
   },
   },

+ 18 - 54
src/js/menus/menu_main.js

@@ -79,7 +79,7 @@ const menuState = {
         );
         );
         infoIcon.anchor(0.5, 0.5);
         infoIcon.anchor(0.5, 0.5);
         infoIcon.iconType = 'infoIcon';
         infoIcon.iconType = 'infoIcon';
-        infoIcon.id = gameList[i].gameName;
+        infoIcon.id = i;
         this.menuIcons.push(infoIcon);
         this.menuIcons.push(infoIcon);
       }
       }
 
 
@@ -105,28 +105,6 @@ const menuState = {
     }
     }
   },
   },
 
 
-  /**
-   * Displays game menu information boxes.
-   */
-  showInfoBox: function (icon) {
-    if (self.infoBoxContent[icon.id]) {
-      self.infoBox.style.display = 'block';
-
-      let msg =
-        '<h3>' +
-        self.infoBoxContent[icon.id].title +
-        '</h3>' +
-        '<p>' +
-        self.infoBoxContent[icon.id].body +
-        '</p>' +
-        self.infoBoxContent[icon.id].img;
-
-      document.querySelector('.ifr-modal__infobox').innerHTML = msg;
-    } else {
-      console.error('Error: no info box was setup for this game.');
-    }
-  },
-
   setInfoBoxes: function () {
   setInfoBoxes: function () {
     self.infoBox = document.querySelector('.ifr-modal');
     self.infoBox = document.querySelector('.ifr-modal');
 
 
@@ -141,38 +119,24 @@ const menuState = {
         self.infoBox.style.display = 'none';
         self.infoBox.style.display = 'none';
       }
       }
     };
     };
+  },
 
 
-    self.infoBoxContent = {
-      squareOne: {
-        title:
-          '<strong>' + game.lang.game + ':</strong> ' + game.lang.square + ' I',
-        body: '<ul>' + game.lang.infoBox_squareOne + '</ul>',
-        img:
-          '<img class="mx-auto" width=60% src="' +
-          game.image['s1-A'].src +
-          '">',
-      },
-      circleOne: {
-        title:
-          '<strong>' + game.lang.game + ':</strong> ' + game.lang.circle + ' I',
-        body: '<ul>' + game.lang.infoBox_circleOne + '</ul>',
-        img:
-          '<img class="mx-auto" width=80% src="' +
-          game.image['c1-A'].src +
-          '">',
-      },
-      squareTwo: {
-        title:
-          '<strong>' +
-          game.lang.game +
-          ':</strong> ' +
-          game.lang.square +
-          ' II',
-        body: '<ul>' + game.lang.infoBox_squareTwo + '</ul>',
-        img:
-          '<img class="mx-auto" width=80% src="' + game.image['s2'].src + '">',
-      },
-    };
+  /**
+   * Displays game menu information boxes.
+   */
+  showInfoBox: function (icon) {
+    if (gameList?.[icon.id]?.assets?.menuInfoBox) {
+      const info = gameList[icon.id].assets.menuInfoBox();
+
+      self.infoBox.style.display = 'block';
+
+      let msg =
+        '<h3>' + info.title + '</h3>' + '<p>' + info.body + '</p>' + info.img;
+
+      document.querySelector('.ifr-modal__infobox').innerHTML = msg;
+    } else {
+      console.error('Error: no info box was setup for this game.');
+    }
   },
   },
 
 
   /**
   /**