summaryrefslogtreecommitdiff
path: root/animism-align/frontend/site/store.js
blob: 262241262bd0c21171407d9a598b036df39dd852 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
import { crudState, crudReducer } from 'app/api/crud.reducer'
import { applyMiddleware, compose, combineReducers, createStore } from 'redux'
import { connectRouter, routerMiddleware } from 'connected-react-router'
import { createBrowserHistory } from 'history'
import thunk from 'redux-thunk'

import audioReducer from 'app/views/audio/audio.reducer'
import siteReducer from 'site/site/site.reducer'

import alignReducer from 'app/views/editor/align/align.reducer'
import paragraphReducer from 'app/views/editor/paragraph/paragraph.reducer'
import viewerReducer from 'app/views/viewer/viewer.reducer'

// document.querySelector("#plain_content").remove()
const siteData = JSON.parse(document.querySelector("#site_data").innerText)

const createRootReducer = history => (
  combineReducers([
    "media",
    "annotation",
    "paragraph",
    "episode",
    "venue",
  ].reduce((a, type) => {
    a[type] = (() => {
      const initialState = {
        ...crudState(),
        index: siteData[type],
      }
      if (type === 'paragraph') {
        return (state=initialState, action) => paragraphReducer(state, action)
      } else {
        const typeReducer = crudReducer(type)
        return (state=initialState, action) => typeReducer(state, action)
      }
    })()
    return a
  }, {
    // auth: (state = {}) => state,
    router: connectRouter(history),
    site: siteReducer,
    audio: audioReducer,
    align: alignReducer,
    viewer: viewerReducer,
  }))
)

const configureStore = (initialState = {}, history) => {
  const composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose

  const store = createStore(
    createRootReducer(history),
    initialState,
    composeEnhancers(
      applyMiddleware(
        thunk,
        routerMiddleware(history)
      ),
    ),
  )

  return store
}

const history = createBrowserHistory()
const store = configureStore({}, history)
const { dispatch } = store

export { store, history, dispatch }