import { createStore, combineReducers, applyMiddleware } from 'redux';
import thunk from 'redux-thunk';
import { createReducer } from 'redux-su';
import { composeWithDevTools } from 'redux-devtools-extension';
import { Portal, Link, Field } from '../Api/types';
const reducers = {
'auth': createReducer({
'authSet': (store: any, action: { v: string, csrf: string, user: any }) => ({ v: action.v, csrf: action.csrf, user: action.user, loading: false }),
'authLoad': (store: any, action: { loading: boolean }) => ({ ...store, loading: action.loading })
}, { v: "", csrf: "", user: null, loading: false }),
'entities': createReducer({
'portalSet': (store: any, action: { guid: string, portal: Portal }) =>
({ ...store, portals: { ...store.portals, [action.guid]: { ...action.portal } } }),
'linkSet': (store: any, action: { guid: string, link: Link }) =>
({ ...store, links: { ...store.links, [action.guid]: action.link } }),
'fieldSet': (store: any, action: { guid: string, field: Field }) =>
({ ...store, fields: { ...store.fields, [action.guid]: action.field } }),
'portalsSet': (store: any, action: { portals: Portal }) => {
const portals = store.portals
Object.keys(action.portals).forEach(guid => {
if (portals[guid]) {
portals[guid] = { ...portals[guid], fraction: action.portals[guid].fraction, level: action.portals[guid].level }
} else {
portals[guid] = action.portals[guid]
}
})
return { ...store, portals }
},
'linksSet': (store: any, action: { links: { [guid: string]: Link } }) =>
({ ...store, links: { ...store.links, ...action.links } }),
'fieldsSet': (store: any, action: { fields: { [guid: string]: Field } }) =>
({ ...store, fields: { ...store.fields, ...action.fields } }),
'setLoad': (store: any, action: { queue: string[][] }) =>
({ ...store, loadQueue: [...action.queue] }),
'linksGC': (store: any, action: { links: { [tile: string]: string[] } }) => {
let linksCache = store.linksCache
let links = store.links
Object.keys(action.links).forEach(tileId => {
const oldLinks = linksCache[tileId]
if (oldLinks != undefined) {
oldLinks.forEach((guid: string) => {
delete links[guid]
})
}
linksCache[tileId] = action.links[tileId]
})
return ({ ...store, links: { ...links }, linksCache })
},
'fieldsGC': (store: any, action: { fields: { [tile: string]: string[] } }) => {
let fieldsCache = store.fieldsCache
let fields = store.fields
Object.keys(action.fields).forEach(tileId => {
const oldFields = fieldsCache[tileId]
if (oldFields != undefined) {
oldFields.forEach((guid: string) => {
delete fields[guid]
})
}
fieldsCache[tileId] = action.fields[tileId]
})
return ({ ...store, fields: { ...fields }, fieldsCache })
},
}, { portals: {}, fields: {}, links: {}, loadQueue: [], linksCache: {}, fieldsCache: {} }),
'settings': createReducer({
'setLevelFrom': (store: any, action: { level: number }) => ({
...store, filterLevel: [action.level, store.filterLevel[1]]
}),
'setLevelTo': (store: any, action: { level: number }) => ({
...store, filterLevel: [store.filterLevel[0], action.level]
})
}, { filterLevel: [0, 8] })
}
function extend(obj: any, src: any) {
for (var key in src) {
if (src.hasOwnProperty(key) && !!src[key]) {
obj[key] = src[key];
}
}
return obj;
}
const store = createStore(
combineReducers(reducers),
composeWithDevTools(applyMiddleware(thunk))
)
export default store