UNPKG

ttk-app-core

Version:
75 lines (59 loc) 2.33 kB
import { Map, fromJS, toJS } 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, { path, value }) => { return this.metaReducer.sf(state, path, fromJS(value)) } updateArr = (state, arr) => { arr.forEach(item => { state = this.metaReducer.sf(state, item.path, fromJS(item.value)) }) return state } load = (state, value) => { state = this.metaReducer.sf(state, 'data.list', fromJS(value)) return state } tableLoading = (state, loading) => { return this.metaReducer.sf(state, 'data.loading', loading) } normalSearchChange = (state, { path, value }) => { return this.metaReducer.sf(state, path, fromJS(value)) } showOptionsChange = (state, { path, value }) => { return this.metaReducer.sf(state, path, value) } searchUpdate = (state, value) => { return this.metaReducer.sf(state, 'data.searchValue', fromJS(value)) } initOption = (state, { currencylist, accountlist, enableddate }) => { state = this.metaReducer.sf(state, 'data.other.currencylist', fromJS(currencylist)) state = this.metaReducer.sf(state, 'data.other.accountlist', fromJS(accountlist)) state = this.metaReducer.sf(state, 'data.other.enableddate', fromJS(enableddate)) return state } tableOnchange = (state, value) => { state = this.metaReducer.sf(state, 'data.list', fromJS(value)) return state } sortReduce = (state, key, value) => { state = this.metaReducer.sf(state, `data.sort.${key}`, fromJS(value)) state = this.metaReducer.sf(state, 'data.key', Math.random()) return state } } export default function creator(option) { const metaReducer = new MetaReducer(option), o = new reducer({ ...option, metaReducer }) return { ...metaReducer, ...o } }