2016-11-16 10:15:33 +00:00
|
|
|
import R from 'ramda'
|
|
|
|
|
2017-06-27 11:36:31 +00:00
|
|
|
// This array can't be generated, as the arguments to require.context must be literals :-|
|
|
|
|
let directoryLoaders =
|
|
|
|
[
|
|
|
|
require.context('../../règles/rémunération-travail/cdd',
|
|
|
|
true, /([A-Za-z\u00C0-\u017F]|\.|-|_)+.yaml$/),
|
|
|
|
require.context('../../règles/rémunération-travail/entités/ok',
|
|
|
|
true, /([A-Za-z\u00C0-\u017F]|\.|-|_)+.yaml$/),
|
|
|
|
require.context('../../règles/rémunération-travail/cotisations/ok',
|
|
|
|
true, /([A-Za-z\u00C0-\u017F]|\.|-|_)+.yaml$/),
|
|
|
|
]
|
2017-03-16 18:30:30 +00:00
|
|
|
|
2017-06-27 11:36:31 +00:00
|
|
|
// require.context returns an object which
|
|
|
|
// a) is a function behaving like 'requires', taking a filename and returning a module and
|
|
|
|
// b) has additional properties, some function-valued; keys() returns the files matched
|
|
|
|
// A "module" is simply the contents of a file according to a Webpack loader; this can be JS, JSON, etc.
|
|
|
|
// Thus, this weird loadAll returns an array, each item of which is the contents of each file in a directory
|
|
|
|
let loadAll = directoryLoaderFunction =>
|
|
|
|
directoryLoaderFunction.keys().map(directoryLoaderFunction)
|
2017-04-24 18:03:38 +00:00
|
|
|
|
2017-06-27 11:36:31 +00:00
|
|
|
let rules = R.pipe(
|
|
|
|
R.map(loadAll),
|
|
|
|
R.flatten,
|
2017-05-07 17:45:44 +00:00
|
|
|
R.reject(R.isNil)
|
2017-06-27 11:36:31 +00:00
|
|
|
)(directoryLoaders)
|
2017-05-07 17:45:44 +00:00
|
|
|
|
|
|
|
export default rules
|