2018-03-07 15:44:35 -05:00
|
|
|
import {map, reduce, filter} from './utils'
|
2018-01-30 17:21:21 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Curried function for creating the formState
|
|
|
|
* @param {Object} options
|
|
|
|
*/
|
|
|
|
export const formulateState = (options = {}) => () => Object.assign({
|
|
|
|
values: {},
|
|
|
|
errors: {},
|
2018-02-01 12:14:19 -05:00
|
|
|
validationErrors: {},
|
|
|
|
meta: {}
|
2018-01-30 17:21:21 -05:00
|
|
|
}, options)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function for creating the formGetters
|
|
|
|
* @param {string} module
|
|
|
|
* @param {Object} getters
|
|
|
|
*/
|
|
|
|
export const formulateGetters = (moduleName = '', getters = {}) => Object.assign({
|
|
|
|
formValues (state) {
|
|
|
|
return state.values
|
|
|
|
},
|
|
|
|
formErrors (state) {
|
|
|
|
return state.errors
|
|
|
|
},
|
|
|
|
formValidationErrors (state) {
|
|
|
|
return state.validationErrors
|
|
|
|
},
|
2018-02-01 12:14:19 -05:00
|
|
|
formMeta (state) {
|
2018-02-02 12:07:51 -05:00
|
|
|
return reduce(state.meta, (forms, form, fields) => {
|
|
|
|
forms[form] = reduce(fields, (arr, field, data) => arr.concat(data), [])
|
|
|
|
return forms
|
|
|
|
}, {})
|
2018-02-01 12:14:19 -05:00
|
|
|
},
|
2018-01-30 17:21:21 -05:00
|
|
|
hasErrors (state) {
|
|
|
|
return map(state.errors, (form, errors) => {
|
|
|
|
return reduce(errors, (hasErrors, field, errors) => hasErrors || !!errors.length, false)
|
|
|
|
})
|
2018-02-15 23:21:29 -05:00
|
|
|
},
|
|
|
|
hasValidationErrors (state) {
|
|
|
|
return map(state.validationErrors, (form, errors) => {
|
|
|
|
return reduce(errors, (hasErrors, field, errors) => hasErrors || !!errors.length, false)
|
|
|
|
})
|
2018-01-30 17:21:21 -05:00
|
|
|
}
|
|
|
|
}, getters)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function for creating the formActions
|
|
|
|
* @param {string} moduleName
|
|
|
|
* @param {Object} actions
|
|
|
|
*/
|
|
|
|
export const formulateActions = (moduleName = '', actions = {}) => Object.assign({
|
|
|
|
}, actions)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function for creating the formMutations
|
|
|
|
* @param {Object} mutations
|
|
|
|
*/
|
|
|
|
export const formulateMutations = (mutations = {}) => Object.assign({
|
|
|
|
setFieldValue (state, {form, field, value}) {
|
|
|
|
state.values = Object.assign({}, state.values, {
|
|
|
|
[form]: Object.assign({}, state.values[form] || {}, {[field]: value})
|
|
|
|
})
|
|
|
|
},
|
|
|
|
setFieldErrors (state, {form, field, errors}) {
|
|
|
|
state.errors = Object.assign({}, state.errors, {
|
|
|
|
[form]: Object.assign({}, state.errors[form] || {}, {[field]: errors})
|
|
|
|
})
|
|
|
|
},
|
|
|
|
setFieldValidationErrors (state, {form, field, errors}) {
|
|
|
|
state.validationErrors = Object.assign({}, state.validationErrors, {
|
|
|
|
[form]: Object.assign({}, state.validationErrors[form] || {}, {[field]: errors})
|
|
|
|
})
|
2018-02-01 12:14:19 -05:00
|
|
|
},
|
|
|
|
setFieldMeta (state, {form, field, data}) {
|
|
|
|
state.meta = Object.assign({}, state.meta, {
|
|
|
|
[form]: Object.assign({}, state.meta[form] || {}, {[field]: data})
|
|
|
|
})
|
2018-03-02 15:14:47 -05:00
|
|
|
},
|
|
|
|
resetForm (state, form) {
|
|
|
|
if (state.values[form]) {
|
|
|
|
state.values = Object.assign({}, state.values, {
|
|
|
|
[form]: map(state.values[form], (key, value) => undefined)
|
|
|
|
})
|
|
|
|
}
|
2018-03-07 15:44:35 -05:00
|
|
|
},
|
|
|
|
removeField (state, {form, field}) {
|
|
|
|
for (let group in state) {
|
|
|
|
if (state[group][form] && state[group][form].hasOwnProperty(field)) {
|
|
|
|
state[group][form] = filter(state[group][form], (key, value) => key !== field)
|
|
|
|
}
|
|
|
|
}
|
2018-11-01 17:03:05 -04:00
|
|
|
},
|
|
|
|
removeFieldValidationErrors (state, {form, field}) {
|
|
|
|
state.validationErrors = Object.assign({}, state.validationErrors, {
|
|
|
|
[form]: filter(state.validationErrors[form] || {}, key => key !== field)
|
|
|
|
})
|
2018-01-30 17:21:21 -05:00
|
|
|
}
|
|
|
|
}, mutations)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function for exposing a full vuex module.
|
|
|
|
* @param {string} moduleName
|
|
|
|
* @param {Object} validation
|
|
|
|
*/
|
|
|
|
export const formulateModule = (moduleName) => ({
|
|
|
|
state: formulateState(),
|
|
|
|
getters: formulateGetters(moduleName),
|
|
|
|
actions: formulateActions(moduleName),
|
2018-01-31 21:52:10 -05:00
|
|
|
mutations: formulateMutations(),
|
|
|
|
namespaced: true
|
2018-01-30 17:21:21 -05:00
|
|
|
})
|