server_src_client-server-shared_duel-controller.js.html 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8">
  5. <title>Source: server/src/client-server-shared/duel-controller.js | 12 Heroes</title>
  6. <script src="scripts/prettify/prettify.js"> </script>
  7. <script src="scripts/prettify/lang-css.js"> </script>
  8. <!--[if lt IE 9]>
  9. <script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
  10. <![endif]-->
  11. <link type="text/css" rel="stylesheet" href="styles/bootstrap.min.css">
  12. <link type="text/css" rel="stylesheet" href="styles/prettify-jsdoc.css">
  13. <link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
  14. <link type="text/css" rel="stylesheet" href="styles/tui-doc.css">
  15. </head>
  16. <body>
  17. <nav class="lnb" id="lnb">
  18. <div class="logo" style="">
  19. <img src="img/toast-ui.png" width="100%" height="100%">
  20. </div>
  21. <div class="title">
  22. <h1><a href="index.html" class="link">12 Heroes</a></h1>
  23. </div>
  24. <div class="search-container" id="search-container">
  25. <input type="text" placeholder="Search">
  26. <ul></ul>
  27. </div>
  28. <div class="lnb-api hidden"><h3>Namespaces</h3><ul><li><a href="Constants.html">Constants</a><button type="button" class="hidden toggle-subnav btn btn-link"> <span class="glyphicon glyphicon-plus"></span></button><div class="hidden" id="Constants_sub"></div></li><li><a href="Constants.HERO.html">Constants.HERO</a><button type="button" class="hidden toggle-subnav btn btn-link"> <span class="glyphicon glyphicon-plus"></span></button><div class="hidden" id="Constants.HERO_sub"><div class="member-type">Members</div><ul class="inner"><li><a href="Constants.HERO.html#.HERO_ABILITY">HERO_ABILITY</a></li><li><a href="Constants.HERO.html#.HERO_DEPLOY">HERO_DEPLOY</a></li><li><a href="Constants.HERO.html#.HERO_DISCARD">HERO_DISCARD</a></li><li><a href="Constants.HERO.html#.HERO_DISMISS">HERO_DISMISS</a></li><li><a href="Constants.HERO.html#.HERO_MOVE">HERO_MOVE</a></li><li><a href="Constants.HERO.html#.HERO_RECRUIT">HERO_RECRUIT</a></li><li><a href="Constants.HERO.html#.HERO_REPLACE">HERO_REPLACE</a></li></ul></div></li><li><a href="Constants.PLAYER.html">Constants.PLAYER</a><button type="button" class="hidden toggle-subnav btn btn-link"> <span class="glyphicon glyphicon-plus"></span></button><div class="hidden" id="Constants.PLAYER_sub"><div class="member-type">Members</div><ul class="inner"><li><a href="Constants.PLAYER.html#.PLAYER_PASS">PLAYER_PASS</a></li><li><a href="Constants.PLAYER.html#.PLAYER_SUPPLY">PLAYER_SUPPLY</a></li></ul></div></li><li><a href="Constants.POS.html">Constants.POS</a><button type="button" class="hidden toggle-subnav btn btn-link"> <span class="glyphicon glyphicon-plus"></span></button><div class="hidden" id="Constants.POS_sub"><div class="member-type">Members</div><ul class="inner"><li><a href="Constants.POS.html#.POS_BATTLE_CENTER">POS_BATTLE_CENTER</a></li><li><a href="Constants.POS.html#.POS_BATTLE_LEFT">POS_BATTLE_LEFT</a></li><li><a href="Constants.POS.html#.POS_BATTLE_RIGHT">POS_BATTLE_RIGHT</a></li><li><a href="Constants.POS.html#.POS_CAMP">POS_CAMP</a></li><li><a href="Constants.POS.html#.POS_DISCARD">POS_DISCARD</a></li><li><a href="Constants.POS.html#.POS_HAND">POS_HAND</a></li><li><a href="Constants.POS.html#.POS_PILE">POS_PILE</a></li></ul></div></li><li><a href="Constants.REQ.html">Constants.REQ</a><button type="button" class="hidden toggle-subnav btn btn-link"> <span class="glyphicon glyphicon-plus"></span></button><div class="hidden" id="Constants.REQ_sub"><div class="member-type">Members</div><ul class="inner"><li><a href="Constants.REQ.html#.REQ_ERROR">REQ_ERROR</a></li><li><a href="Constants.REQ.html#.REQ_IDLE">REQ_IDLE</a></li><li><a href="Constants.REQ.html#.REQ_REQUESTED">REQ_REQUESTED</a></li><li><a href="Constants.REQ.html#.REQ_SUCCESS">REQ_SUCCESS</a></li></ul></div></li></ul></div><div class="lnb-api hidden"><h3>Global</h3><ul><li><a href="global.html#getDraftSets">getDraftSets</a></li><li><a href="global.html#getHeroesIdsByFaction">getHeroesIdsByFaction</a></li><li><a href="global.html#shuffleHeroes">shuffleHeroes</a></li><li><a href="global.html#TH_Ability">TH_Ability</a></li><li><a href="global.html#TH_AbilityHook">TH_AbilityHook</a></li><li><a href="global.html#TH_AdvRule">TH_AdvRule</a></li><li><a href="global.html#TH_BattleTile">TH_BattleTile</a></li><li><a href="global.html#TH_Color">TH_Color</a></li><li><a href="global.html#TH_CommStatus">TH_CommStatus</a></li><li><a href="global.html#TH_DeckMode">TH_DeckMode</a></li><li><a href="global.html#TH_Faction">TH_Faction</a></li><li><a href="global.html#TH_GameDataStore">TH_GameDataStore</a></li><li><a href="global.html#TH_GameGlobalState">TH_GameGlobalState</a></li><li><a href="global.html#TH_GameStateEnum">TH_GameStateEnum</a></li><li><a href="global.html#TH_HeroAction">TH_HeroAction</a></li><li><a href="global.html#TH_HeroCard">TH_HeroCard</a></li><li><a href="global.html#TH_HeroInGame">TH_HeroInGame</a></li><li><a href="global.html#TH_HeroPosition">TH_HeroPosition</a></li><li><a href="global.html#TH_MessageChatFrom">TH_MessageChatFrom</a></li><li><a href="global.html#TH_MessageDraftStep">TH_MessageDraftStep</a></li><li><a href="global.html#TH_MessageFaction">TH_MessageFaction</a></li><li><a href="global.html#TH_MessageTournamentDeckStep">TH_MessageTournamentDeckStep</a></li><li><a href="global.html#TH_PlayerAction">TH_PlayerAction</a></li><li><a href="global.html#TH_PlayerGameState">TH_PlayerGameState</a></li><li><a href="global.html#TH_Popularity">TH_Popularity</a></li><li><a href="global.html#TH_ReqStatus">TH_ReqStatus</a></li></ul></div>
  29. </nav>
  30. <div id="resizer"></div>
  31. <div class="main" id="main">
  32. <section>
  33. <article>
  34. <pre class="prettyprint source linenums"><code>'use strict';
  35. /* This file will be used by server for online game, and by app for local game
  36. Therfore it should not have any dependency on any of those environments.
  37. It is a state machine that follows the game steps
  38. It receives a dataStore to get and share data but doesn't care what is
  39. behind (socket.io comm for online, direct call to vuex store for local)
  40. Is gives an interface in order to receive notifications
  41. Receiving interface :
  42. - dataStore : provides methods :
  43. - .load() : to get saved game data
  44. - .save(data) : to store game data and propagate (returns true if it succeeded, false otherwise)
  45. - .getHeroesJson() : to get JSON file with all heroes cards described
  46. Provides interface :
  47. - duelControllerProxy : provides methods :
  48. - endTurn(data) : notifies the controller that players ended current turn with attached data */
  49. import { initHeroesFromJson } from './heroesHelper';
  50. import gameStates from './gameStates/gameStates';
  51. let DuelController = function(dataStore) {
  52. let gameData = {
  53. game: {},
  54. bluePlayer: {},
  55. redPlayer: {}
  56. };
  57. let allHeroes = null;
  58. /** ***** STATE MACHINE internal methods ***** */
  59. // Holds current running state
  60. let currentGameState = null;
  61. // Set new current State
  62. let setCurrentState = stateName => {
  63. currentGameState = states[stateName];
  64. gameData.game.gameState = stateName;
  65. console.log('Set new state : ', stateName);
  66. };
  67. // get new State
  68. let getCurrentState = () => {
  69. return currentGameState;
  70. };
  71. // Start the current state
  72. let startCurrentState = (payload = null) => {
  73. currentGameState.start(payload);
  74. };
  75. // Update the current state
  76. let updateCurrentState = (payload = null) => {
  77. currentGameState.update(payload);
  78. };
  79. // End the current state
  80. let endCurrentState = (payload = null) => {
  81. currentGameState.end(payload);
  82. };
  83. let getGameData = () => gameData;
  84. // Interface to set data and store it
  85. let storeData = (data = null) => {
  86. if (data) {
  87. setData(data);
  88. }
  89. return dataStore.save(gameData);
  90. };
  91. // Interface to set data only
  92. let setData = data => {
  93. gameData = data;
  94. };
  95. // Interface to load data
  96. let loadData = () => {
  97. gameData = dataStore.load();
  98. };
  99. // Interface to get set of all heroes
  100. let getAllHeroes = () => {
  101. if (!allHeroes) {
  102. allHeroes = initHeroesFromJson(dataStore.getHeroesJson());
  103. }
  104. return allHeroes;
  105. };
  106. // Pass those state machine methods to each state
  107. let stateCtrl = {
  108. setCurrentState,
  109. getCurrentState,
  110. startCurrentState,
  111. updateCurrentState,
  112. endCurrentState,
  113. storeData,
  114. setData,
  115. getGameData,
  116. loadData,
  117. getAllHeroes
  118. };
  119. // declare all states
  120. // First state to be set after public APIs (start or resume game) are called
  121. let states = {
  122. '0_INIT': new gameStates.initState(stateCtrl),
  123. '1_SELECT_FACTION': new gameStates.selectFactionState(stateCtrl),
  124. '1_SELECT_DRAFT': new gameStates.selectDraftState(stateCtrl),
  125. '1_SELECT_TOURNAMENT': new gameStates.selectTournamentState(stateCtrl),
  126. '2_CHANGE_UP_TO_3_CARDS': new gameStates.changeUpTo3Cards(stateCtrl)
  127. };
  128. /** ***** Following are public methods ***** */
  129. // Method to create and start a new game (both players are there)
  130. let startNewGame = function(player1Name, player2Name, gameOptions) {
  131. // 1st state is init
  132. setCurrentState('0_INIT');
  133. //Start it
  134. startCurrentState({
  135. player1Name,
  136. player2Name,
  137. gameOptions
  138. });
  139. };
  140. // Method to resume existing game, gameData is passed already
  141. let resumeGame = function(data) {
  142. gameData = data;
  143. // Just set state per data in DB
  144. // This state will wait for update
  145. setCurrentState(gameData.game.gameState);
  146. };
  147. // Provide an interface so that players can notify the DuelController
  148. let DuelControllerProxy = () => {
  149. return {
  150. endTurn: data => {
  151. console.log('data from player :>> ', data);
  152. currentGameState.update(data);
  153. }
  154. };
  155. };
  156. // Return public methods
  157. return {
  158. startNewGame,
  159. resumeGame,
  160. duelControllerProxy: new DuelControllerProxy()
  161. };
  162. };
  163. export default DuelController;
  164. </code></pre>
  165. </article>
  166. </section>
  167. </div>
  168. <footer>
  169. <img class="logo" src="img/toast-ui.png" style="">
  170. <div class="footer-text">NHN Entertainment. Frontend Development Lab</div>
  171. </footer>
  172. <script>prettyPrint();</script>
  173. <script src="scripts/jquery.min.js"></script>
  174. <script src="scripts/tui-doc.js"></script>
  175. <script src="scripts/linenumber.js"></script>
  176. <script>
  177. var id = '_sub'.replace(/"/g, '_');
  178. var selectedApi = document.getElementById(id); // do not use jquery selector
  179. var $selectedApi = $(selectedApi);
  180. $selectedApi.removeClass('hidden');
  181. $selectedApi.parent().find('.glyphicon').removeClass('glyphicon-plus').addClass('glyphicon-minus');
  182. showLnbApi();
  183. </script>
  184. </body>
  185. </html>