mirror of
https://github.com/vkaelin/LeagueStats.git
synced 2026-03-26 13:27:28 +00:00
42 lines
1.2 KiB
JavaScript
42 lines
1.2 KiB
JavaScript
|
|
import Vue from 'vue'
|
||
|
|
import { axios } from '@/plugins/axios'
|
||
|
|
import { createDetailedMatchData } from '@/helpers/summoner'
|
||
|
|
|
||
|
|
export const namespaced = true
|
||
|
|
|
||
|
|
export const state = {
|
||
|
|
matches: []
|
||
|
|
}
|
||
|
|
|
||
|
|
export const mutations = {
|
||
|
|
MATCHE_LOADING(state, gameId) {
|
||
|
|
const alreadyIn = state.matches.find(m => m.gameId === gameId)
|
||
|
|
if (!alreadyIn) {
|
||
|
|
state.matches.push({ gameId: gameId, status: 'loading' })
|
||
|
|
}
|
||
|
|
},
|
||
|
|
MATCHE_FOUND(state, matchDetails) {
|
||
|
|
matchDetails.status = 'loaded'
|
||
|
|
|
||
|
|
const index = state.matches.findIndex(m => m.gameId === matchDetails.gameId)
|
||
|
|
Vue.set(state.matches, index, matchDetails)
|
||
|
|
},
|
||
|
|
}
|
||
|
|
|
||
|
|
export const actions = {
|
||
|
|
async matchDetails({ commit, rootState }, gameId) {
|
||
|
|
commit('MATCHE_LOADING', gameId)
|
||
|
|
console.log('MATCH DETAILS STORE', gameId, rootState.currentRegion)
|
||
|
|
|
||
|
|
const resp = await axios(({ url: 'match-details', data: { gameId, region: rootState.currentRegion }, method: 'POST' })).catch(() => { })
|
||
|
|
console.log('--- DETAILS INFOS ---')
|
||
|
|
console.log(resp.data)
|
||
|
|
const detailedMatch = createDetailedMatchData(resp.data.matchDetails)
|
||
|
|
commit('MATCHE_FOUND', detailedMatch)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
export const getters = {
|
||
|
|
getMatchDetails: state => gameId => state.matches.find(m => m.gameId === gameId),
|
||
|
|
}
|