src_store_menu_menu.js.html 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8">
  5. <title>Source: src/store/menu/menu.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>import { socketService } from '../../main';
  35. import { Constants } from 'const/constants';
  36. const state = {
  37. joinableGames: [],
  38. /** @type {import('type/comm').CommStatus} */
  39. loadGamesStatus: { status: Constants.REQ_IDLE, text: 'Not connected' },
  40. connectionStatus: { status: Constants.REQ_IDLE, text: 'Not connected' },
  41. createGameStatus: { status: Constants.REQ_IDLE, text: 'Not connected' },
  42. joinGameStatus: { status: Constants.REQ_IDLE, text: 'Not connected' }
  43. };
  44. const getters = {
  45. joinableGames(state) {
  46. return state.joinableGames;
  47. },
  48. connectionStatus(state) {
  49. return state.connectionStatus;
  50. },
  51. loadGamesStatus(state) {
  52. return state.loadGamesStatus;
  53. },
  54. createGameStatus(state) {
  55. return state.createGameStatus;
  56. },
  57. joinGameStatus(state) {
  58. return state.joinGameStatus;
  59. }
  60. };
  61. const mutations = {
  62. SET_JOINABLE_GAMES: (state, payload) => {
  63. state.joinableGames = payload;
  64. },
  65. SET_CONNECTION_STATUS: (state, payload) => {
  66. state.connectionStatus = payload;
  67. },
  68. SET_LOAD_GAMES_STATUS: (state, payload) => {
  69. state.loadGamesStatus = payload;
  70. },
  71. SET_CREATE_GAME_STATUS: (state, payload) => {
  72. state.createGameStatus = payload;
  73. },
  74. SET_JOIN_GAME_STATUS: (state, payload) => {
  75. state.joinGameStatus = payload;
  76. },
  77. RESET_ALL_STATUS: state => {
  78. let status = { status: Constants.REQ_IDLE, text: 'Not connected' };
  79. state.connectionStatus = status;
  80. state.loadGamesStatus = status;
  81. state.createGameStatus = status;
  82. state.joinGameStatus = status;
  83. }
  84. };
  85. const actions = {
  86. fetchJoinableGames: ({ commit, rootState }) => {
  87. let loadGamesStatus = {
  88. status: Constants.REQ_REQUESTED,
  89. text: 'Loading Games'
  90. };
  91. commit('SET_LOAD_GAMES_STATUS', loadGamesStatus);
  92. socketService
  93. .getGamesList(rootState.username)
  94. .then(games => {
  95. loadGamesStatus.status = Constants.REQ_SUCCESS;
  96. if (games.length === 0) {
  97. loadGamesStatus.text =
  98. 'No games found, wait for a new or create one !';
  99. } else {
  100. loadGamesStatus.text = 'Online games loaded';
  101. }
  102. commit('SET_JOINABLE_GAMES', games);
  103. commit('SET_LOAD_GAMES_STATUS', loadGamesStatus);
  104. })
  105. .catch(() => {
  106. loadGamesStatus = {
  107. status: Constants.REQ_ERROR,
  108. text: 'Error reaching server'
  109. };
  110. commit('SET_LOAD_GAMES_STATUS', loadGamesStatus);
  111. });
  112. },
  113. connect: ({ commit }, payload) => {
  114. return new Promise((resolve, reject) => {
  115. let connectionStatus = {};
  116. if (payload === '') {
  117. connectionStatus = {
  118. status: Constants.REQ_ERROR,
  119. text: 'Enter a valid username'
  120. };
  121. commit('SET_CONNECTION_STATUS', connectionStatus);
  122. reject();
  123. } else {
  124. commit('SET_USERNAME', payload, { root: true });
  125. connectionStatus = {
  126. status: Constants.REQ_REQUESTED,
  127. text: 'Connecting...'
  128. };
  129. commit('SET_CONNECTION_STATUS', connectionStatus);
  130. socketService
  131. .connect(payload)
  132. .then(() => {
  133. connectionStatus = {
  134. status: Constants.REQ_SUCCESS,
  135. text: 'Connected as ' + payload
  136. };
  137. commit('SET_CONNECTION_STATUS', connectionStatus);
  138. commit('SET_IS_CONNECTED', true, { root: true });
  139. localStorage.setItem('username', payload);
  140. resolve();
  141. })
  142. .catch(err => {
  143. connectionStatus = {
  144. status: Constants.REQ_ERROR,
  145. text: 'Could not connect as ' + payload + ' (' + err + ')'
  146. };
  147. commit('SET_CONNECTION_STATUS', connectionStatus);
  148. commit('SET_USERNAME', '', { root: true });
  149. reject();
  150. });
  151. }
  152. });
  153. },
  154. createOnlineGame: ({ commit, rootState }, payload) => {
  155. let createGameStatus = {
  156. status: Constants.REQ_REQUESTED,
  157. text: 'Creating Game'
  158. };
  159. let game = {
  160. player1: rootState.username,
  161. player2: '',
  162. deck: payload.deckMode,
  163. advRules: payload.advRules,
  164. status: 'CREATED',
  165. data: '{}'
  166. };
  167. commit('SET_CREATE_GAME_STATUS', createGameStatus);
  168. socketService
  169. .createGame(game)
  170. .then(id => {
  171. createGameStatus.status = Constants.REQ_SUCCESS;
  172. createGameStatus.text = 'Success creating online game ' + id;
  173. commit('SET_CREATE_GAME_STATUS', createGameStatus);
  174. commit('SET_GAME_ID', id, { root: true });
  175. commit('SET_IS_GAME_RUNNING', true, { root: true });
  176. })
  177. .catch(() => {
  178. createGameStatus = {
  179. status: Constants.REQ_ERROR,
  180. text: 'Error reaching server'
  181. };
  182. commit('SET_CREATE_GAME_STATUS', createGameStatus);
  183. });
  184. },
  185. joinOnlineGame: ({ commit, rootState }, payload) => {
  186. let joinGameStatus = {
  187. status: Constants.REQ_REQUESTED,
  188. text: 'Joining Game'
  189. };
  190. commit('SET_JOIN_GAME_STATUS', joinGameStatus);
  191. socketService
  192. .joinGame(rootState.username, payload.id, payload.isNew)
  193. .then(() => {
  194. joinGameStatus.status = Constants.REQ_SUCCESS;
  195. joinGameStatus.text = 'Success joining online game ' + payload.id;
  196. commit('SET_JOIN_GAME_STATUS', joinGameStatus);
  197. commit('SET_GAME_ID', payload.id, { root: true });
  198. commit('SET_IS_GAME_RUNNING', true, { root: true });
  199. if (!payload.isNew) {
  200. localStorage.setItem('gameId', payload.id);
  201. }
  202. })
  203. .catch(() => {
  204. joinGameStatus.status = Constants.REQ_ERROR;
  205. joinGameStatus.text = 'Error +-reaching server';
  206. commit('SET_JOIN_GAME_STATUS', joinGameStatus);
  207. });
  208. }
  209. };
  210. export default {
  211. namespaced: true,
  212. state,
  213. getters,
  214. mutations,
  215. actions
  216. };
  217. </code></pre>
  218. </article>
  219. </section>
  220. </div>
  221. <footer>
  222. <img class="logo" src="img/toast-ui.png" style="">
  223. <div class="footer-text">NHN Entertainment. Frontend Development Lab</div>
  224. </footer>
  225. <script>prettyPrint();</script>
  226. <script src="scripts/jquery.min.js"></script>
  227. <script src="scripts/tui-doc.js"></script>
  228. <script src="scripts/linenumber.js"></script>
  229. <script>
  230. var id = '_sub'.replace(/"/g, '_');
  231. var selectedApi = document.getElementById(id); // do not use jquery selector
  232. var $selectedApi = $(selectedApi);
  233. $selectedApi.removeClass('hidden');
  234. $selectedApi.parent().find('.glyphicon').removeClass('glyphicon-plus').addClass('glyphicon-minus');
  235. showLnbApi();
  236. </script>
  237. </body>
  238. </html>