ttk-app-core
Version:
enterprise develop framework
36 lines (31 loc) • 1.3 kB
JavaScript
import { Map, fromJS } from 'immutable'
import { reducer as MetaReducer } from 'edf-meta-engine'
import config from './config'
import { getInitState } from './data'
class reducer {
constructor(option) {
this.metaReducer = option.metaReducer
this.config = config.current
}
init = (state, option) => {
const initState = getInitState()
return this.metaReducer.init(state, initState)
}
update = (state, { active, chart, project, quickNav, team }) => {
state = this.metaReducer.sf(state, 'data.active', fromJS(active))
state = this.metaReducer.sf(state, 'data.chart', fromJS(chart))
state = this.metaReducer.sf(state, 'data.project', fromJS(project))
state = this.metaReducer.sf(state, 'data.quickNav', fromJS(quickNav))
state = this.metaReducer.sf(state, 'data.team', fromJS(team))
return state
}
modifyContent = (state) => {
const content = this.metaReducer.gf(state, 'data.content')
return this.metaReducer.sf(state, 'data.content', content + '!')
}
}
export default function creator(option) {
const metaReducer = new MetaReducer(option),
o = new reducer({ ...option, metaReducer })
return { ...metaReducer, ...o }
}