24 lines
653 B
JavaScript
24 lines
653 B
JavaScript
import fs from 'fs'
|
|
import path from 'path'
|
|
|
|
const pipe =
|
|
(...fns) =>
|
|
(x) =>
|
|
fns.reduce((v, f) => f(v), x)
|
|
|
|
const flattenArray = (input) =>
|
|
input.reduce((acc, item) => [...acc, ...(Array.isArray(item) ? item : [item])], [])
|
|
|
|
const map = (fn) => (input) => input.map(fn)
|
|
|
|
const walkDir = (fullPath) => {
|
|
return fs.statSync(fullPath).isFile() ? fullPath : getAllFilesRecursively(fullPath)
|
|
}
|
|
|
|
const pathJoinPrefix = (prefix) => (extraPath) => path.join(prefix, extraPath)
|
|
|
|
const getAllFilesRecursively = (folder) =>
|
|
pipe(fs.readdirSync, map(pipe(pathJoinPrefix(folder), walkDir)), flattenArray)(folder)
|
|
|
|
export default getAllFilesRecursively
|