import path from 'path' import flat from 'flat' import { get, set } from 'lodash-es' import languages from './languages.js' import dataDirectory from './data-directory.js' import encodeBracketedParentheses from './encode-bracketed-parentheses.js' const loadSiteDataFromDir = (dir) => ({ site: { data: dataDirectory(path.join(dir, 'data'), { preprocess: (dataString) => encodeBracketedParentheses(dataString.trimEnd()), ignorePatterns: [/README\.md$/], }), }, }) export default function loadSiteData() { // load english site data const siteData = { en: loadSiteDataFromDir(languages.en.dir), } // load and add other language data to siteData where keys match english keys, // filling holes with english site data const englishKeys = Object.keys(flat(siteData.en)) for (const language of Object.values(languages)) { if (language.code === 'en') continue const data = loadSiteDataFromDir(language.dir) for (const key of englishKeys) { set(siteData, `${language.code}.${key}`, get(data, key) || get(siteData.en, key)) } } for (const language of Object.values(languages)) { // Add the English `slug` to each item, to link a consistent anchor siteData[language.code].site.data.glossaries.external.forEach((item, i) => { item.slug = siteData.en.site.data.glossaries.external[i].term }) // Sort glossary by language-specific function if (language.code !== 'en') { siteData[language.code].site.data.glossaries.external.sort((a, b) => a.term.localeCompare(b.term, language.code) ) } } return siteData }