summaryrefslogtreecommitdiff
path: root/animism-align/frontend/app/views/viewer/viewer.reducer.js
blob: daf9bba404ca10faed75e3bd8c9d64c81b493ba0 (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
70
71
72
73
74
75
76
77
78
79
80
81
import * as types from 'app/types'

const initialState = {
  transcript: false,
  checklist: false,
  nav: false,
  sections: { loading: true },
  fullscreenTimeline: [],
  currentSection: null,
  nextSection: null,
  navStyle: 'white',
  vitrineModal: {
    open: false,
    media: null,
    index: null,
  },
  options: {
  }
}

export default function viewerReducer(state = initialState, action) {
  // console.log(action.type, action)
  switch (action.type) {
    case types.viewer.toggle_component:
      return {
        ...state,
        [action.key]: action.value,
      }

    case types.viewer.load_sections:
      return {
        ...state,
        sections: action.sections,
        fullscreenTimeline: action.fullscreenTimeline,
      }

    case types.viewer.set_current_section:
      return {
        ...state,
        currentSection: action.currentSection,
        nextSection: action.nextSection,
      }

    case types.viewer.set_nav_style:
      return {
        ...state,
        navStyle: action.color,
      }

    case types.viewer.open_vitrine_modal:
      return {
        ...state,
        vitrineModal: {
          open: true,
          media: action.media,
          index: action.index,
        }
      }

    case types.viewer.close_vitrine_modal:
      return {
        ...state,
        vitrineModal: {
          ...state.vitrineModal,
          open: false,
        }
      }

    case types.viewer.set_vitrine_index:
      return {
        ...state,
        vitrineModal: {
          ...state.vitrineModal,
          index: action.index,        
        }
      }

    default:
      return state
  }
}