import React, { useReducer } from 'react'
const CHANGE_LOCALE = 'CHANGE_LOCALE'

const mainContext = React.createContext()

const reducer = (state, action) => {
    switch (action.type) {
        case CHANGE_LOCALE:
            return { ...state, locale: action.locale || 'zh' }
        default:
            return state
    }
}

const ContextProvider = (props) => {
    const [state, dispatch] = useReducer(reducer, {
        locale: 'zh'
    })
    return (
        <mainContext.Provider value={{ state, dispatch }}>
            {props.children}
        </mainContext.Provider>
    )
}

export { reducer, mainContext, ContextProvider }