mon-entreprise/site/vite.config.ts.timestamp-16...

349 lines
42 KiB
JavaScript

// vite.config.ts
import replace from "file:///home/johan/Projets/mon-entreprise/node_modules/@rollup/plugin-replace/dist/rollup-plugin-replace.cjs.js";
import yaml from "file:///home/johan/Projets/mon-entreprise/node_modules/@rollup/plugin-yaml/dist/index.js";
import legacy from "file:///home/johan/Projets/mon-entreprise/node_modules/@vitejs/plugin-legacy/dist/index.mjs";
import react from "file:///home/johan/Projets/mon-entreprise/node_modules/@vitejs/plugin-react/dist/index.mjs";
import fs from "fs/promises";
import path from "path";
import serveStatic from "file:///home/johan/Projets/mon-entreprise/node_modules/serve-static/index.js";
import { defineConfig, loadEnv } from "file:///home/johan/Projets/mon-entreprise/node_modules/vite/dist/node/index.js";
import { VitePWA } from "file:///home/johan/Projets/mon-entreprise/node_modules/vite-plugin-pwa/dist/index.mjs";
// scripts/runScriptOnFileChange/execOnFileChange.ts
import { getPackageDeps } from "file:///home/johan/Projets/mon-entreprise/node_modules/@rushstack/package-deps-hash/lib/index.js";
import { exec as originalExec } from "child_process";
import { existsSync, lstatSync, readFileSync, writeFileSync } from "fs";
import { relative, resolve } from "path";
import { promisify } from "util";
var exec = promisify(originalExec);
var execOnFileChange = async (config) => {
const path2 = resolve(config.basePath, config.depsPath);
const deps = Object.fromEntries(getPackageDeps(config.basePath));
const depsEntries = Object.entries(deps);
const existingDeps = existsSync(path2) ? JSON.parse(readFileSync(path2, { encoding: "utf8" })) : {};
const existingDepsEntries = Object.entries(existingDeps);
const promises = config.options.map(async (cfg) => {
let fileChanged = null;
const index = cfg.paths.map((val) => {
const isDir = lstatSync(resolve(config.basePath, val)).isDirectory();
const isFile = lstatSync(resolve(config.basePath, val)).isFile();
return {
isDir,
isFile,
absolute: resolve(config.basePath, val),
relative: relative(
resolve(config.basePath),
resolve(config.basePath, val)
)
};
}).findIndex(({ absolute, relative: relative2, isFile, isDir }) => {
if (isFile) {
if (deps[relative2] !== existingDeps[relative2]) {
fileChanged = relative2;
}
return deps[relative2] !== existingDeps[relative2];
} else if (isDir) {
const index2 = depsEntries.findIndex(
([a, b], i) => {
var _a, _b;
return (relative2.length ? a.startsWith(relative2 + "/") : true) && (((_a = existingDepsEntries == null ? void 0 : existingDepsEntries[i]) == null ? void 0 : _a[0]) !== a || ((_b = existingDepsEntries == null ? void 0 : existingDepsEntries[i]) == null ? void 0 : _b[1]) !== b);
}
);
if (index2 > -1) {
fileChanged = depsEntries[index2][0];
}
return index2 > -1;
}
throw new Error("Path is not a directory or a file: " + absolute);
});
if (index > -1) {
const result = await exec(cfg.run);
return {
path: cfg.paths[index],
fileChanged,
run: cfg.run,
result
};
}
return null;
});
const res = await Promise.all(promises);
writeFileSync(path2, JSON.stringify(deps, null, 2));
return res;
};
// scripts/runScriptOnFileChange/index.ts
var runScriptOnFileChange = async () => {
console.log("Search for changed file...");
const results = await execOnFileChange({
basePath: "./",
depsPath: ".deps.json",
options: [
{
paths: [
"./source/pages/Simulateurs/EconomieCollaborative/activit\xE9s.yaml",
"./source/pages/Simulateurs/EconomieCollaborative/activit\xE9s.en.yaml"
],
run: "yarn build:yaml-to-dts"
}
]
});
results.filter((x) => !!x).forEach(({ fileChanged, run, result }) => {
console.log("Changed file detected:", fileChanged);
console.log("Execute:", run, "\n");
if (result.stdout) {
console.log(result.stdout);
}
if (result.stderr) {
console.error(result.stderr);
}
});
};
// vite-pwa-options.ts
var pwaOptions = {
registerType: "prompt",
strategies: "injectManifest",
srcDir: "source",
filename: "sw.ts",
injectManifest: {
maximumFileSizeToCacheInBytes: 3e6,
manifestTransforms: [
(entries) => {
const manifest = entries.filter(
(entry) => !/assets\/.*(-legacy|lazy_)/.test(entry.url) && (entry.url.endsWith(".html") ? /(infrance|mon-entreprise)\.html/.test(entry.url) : true)
);
return { manifest };
}
]
},
includeAssets: ["logo-*.png"],
manifest: {
start_url: "/",
name: "Mon entreprise",
short_name: "Mon entreprise",
description: "L'assistant officiel du cr\xE9ateur d'entreprise",
lang: "fr",
orientation: "portrait-primary",
display: "minimal-ui",
theme_color: "#2975d1",
background_color: "#ffffff",
icons: [
{
src: "/favicon/android-chrome-192x192-shadow.png?v=2.0",
sizes: "192x192",
type: "image/png"
},
{
src: "/favicon/android-chrome-512x512-shadow.png?v=2.0",
sizes: "512x512",
type: "image/png"
}
]
}
};
// vite.config.ts
var __vite_injected_original_import_meta_url = "file:///home/johan/Projets/mon-entreprise/site/vite.config.ts";
var env = (mode) => loadEnv(mode, process.cwd(), "");
var vite_config_default = defineConfig(({ command, mode }) => ({
resolve: {
alias: { "@": path.resolve("./source") },
extensions: [".js", ".ts", ".jsx", ".tsx", ".json"]
},
publicDir: "source/public",
build: {
sourcemap: true,
rollupOptions: {
output: {
chunkFileNames: (chunkInfo) => {
if (chunkInfo.isDynamicEntry) {
return "assets/lazy_[name].[hash].js";
}
return "assets/[name].[hash].js";
}
}
}
},
define: {
BRANCH_NAME: JSON.stringify(getBranch(mode)),
IS_DEVELOPMENT: mode === "development",
IS_STAGING: mode === "production" && !isProductionBranch(mode),
IS_PRODUCTION: mode === "production" && isProductionBranch(mode)
},
plugins: [
{
name: "run-script-on-file-change",
apply: "serve",
buildStart() {
if (mode === "development") {
void runScriptOnFileChange();
}
}
},
command === "build" && replace({
__SENTRY_DEBUG__: false,
preventAssignment: false
}),
react({
babel: {
plugins: [["babel-plugin-styled-components", { pure: true }]]
}
}),
yaml(),
multipleSPA({
defaultSite: "mon-entreprise",
templatePath: "./source/template.html",
sites: {
"mon-entreprise": {
lang: "fr",
entry: "/source/entry-fr.tsx",
title: "mon-entreprise.urssaf.fr : L'assistant officiel du cr\xE9ateur d'entreprise",
description: "Du statut juridique \xE0 la premi\xE8re embauche, en passant par la simulation des cotisations, vous trouverez ici toutes les ressources pour d\xE9marrer votre activit\xE9.",
shareImage: "/source/images/logo-monentreprise.svg",
shareImageAlt: "Logo mon-entreprise, site Urssaf"
},
infrance: {
lang: "en",
entry: "/source/entry-en.tsx",
title: "My company in France: A step-by-step guide to start a business in France",
description: "Find the type of company that suits you and follow the steps to register your company. Discover the French social security system by simulating your hiring costs. Discover the procedures to hire in France and learn the basics of French labour law.",
shareImage: "/logo-mycompany-share.png",
shareImageAlt: "Logo My company in France by Urssaf"
}
}
}),
VitePWA(pwaOptions),
legacy({
targets: ["defaults", "not IE 11"]
})
],
server: {
port: 3e3,
hmr: {
clientPort: typeof env(mode).HMR_CLIENT_PORT !== "undefined" ? parseInt(env(mode).HMR_CLIENT_PORT) : void 0
},
watch: {
ignored: [
"!**/node_modules/publicodes/**",
"!**/node_modules/publicodes-react/**"
]
},
proxy: {
"/api": "http://localhost:3004",
"/twemoji": {
target: "https://twemoji.maxcdn.com",
changeOrigin: true,
rewrite: (path2) => path2.replace(/^\/twemoji/, ""),
timeout: 3 * 1e3
}
}
},
optimizeDeps: {
entries: ["./source/entry-fr.tsx", "./source/entry-en.tsx"],
exclude: ["publicodes-react", "publicodes"],
include: ["publicodes > moo", "publicodes > nearley"]
},
ssr: {
noExternal: [
/react-aria|react-stately|internationalized/,
/markdown-to-jsx/,
/styled-components|emotion/,
/publicodes-react/
]
}
}));
function multipleSPA(options) {
const fillTemplate = async (siteName) => {
const siteData = options.sites[siteName];
const template = await fs.readFile(options.templatePath, "utf-8");
const filledTemplate = template.toString().replace(/\{\{(.+)\}\}/g, (_match, p1) => siteData[p1.trim()]);
return filledTemplate;
};
return {
name: "multiple-spa",
enforce: "pre",
configureServer(vite) {
vite.middlewares.use(
"/simulateur-iframe-integration.js",
serveStatic(new URL("./dist", __vite_injected_original_import_meta_url).pathname, {
index: "simulateur-iframe-integration.js"
})
);
vite.middlewares.use(async (req, res, next) => {
var _a;
const url = (_a = req.originalUrl) == null ? void 0 : _a.replace(/^\/%2F/, "/");
const firstLevelDir = url == null ? void 0 : url.slice(1).split("/")[0];
if (url && /\?.*html-proxy/.test(url)) {
return next();
}
if (url && ["/", "/index.html"].includes(url)) {
res.writeHead(302, { Location: "/" + options.defaultSite }).end();
} else if (firstLevelDir && url && Object.keys(options.sites).map((site) => `/${site}.html`).includes(url)) {
const siteName = firstLevelDir.replace(".html", "");
const content = await vite.transformIndexHtml(
"/" + siteName,
await fillTemplate(siteName)
);
res.end(content);
} else if (firstLevelDir && Object.keys(options.sites).some((name) => firstLevelDir === name)) {
const siteName = firstLevelDir;
const content = await vite.transformIndexHtml(
url,
await fillTemplate(siteName)
);
res.end(content);
} else {
next();
}
});
},
config(config, { command }) {
var _a, _b;
if (command === "build" && !((_a = config.build) == null ? void 0 : _a.ssr)) {
config.build = {
...config.build,
rollupOptions: {
...(_b = config.build) == null ? void 0 : _b.rollupOptions,
input: Object.fromEntries(
Object.keys(options.sites).map((name) => [
name,
`virtual:${name}.html`
])
)
}
};
}
},
resolveId(id) {
const pathname = id.split("/").slice(-1)[0];
if (pathname == null ? void 0 : pathname.startsWith("virtual:")) {
return pathname.replace("virtual:", "");
}
return null;
},
async load(id) {
if (Object.keys(options.sites).some((name) => id.endsWith(name + ".html"))) {
return await fillTemplate(id.replace(/\.html$/, ""));
}
}
};
}
var getBranch = (mode) => {
var _a, _b, _c;
let branch = (_c = (_b = (_a = env(mode).VITE_GITHUB_REF) == null ? void 0 : _a.split("/")) == null ? void 0 : _b.slice(-1)) == null ? void 0 : _c[0];
if (branch === "merge") {
branch = env(mode).VITE_GITHUB_HEAD_REF;
}
return branch ?? "";
};
var isProductionBranch = (mode) => {
return ["master", "next"].includes(getBranch(mode));
};
export {
vite_config_default as default,
getBranch,
isProductionBranch
};
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.ts", "scripts/runScriptOnFileChange/execOnFileChange.ts", "scripts/runScriptOnFileChange/index.ts", "vite-pwa-options.ts"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"/home/johan/Projets/mon-entreprise/site\";const __vite_injected_original_filename = \"/home/johan/Projets/mon-entreprise/site/vite.config.ts\";const __vite_injected_original_import_meta_url = \"file:///home/johan/Projets/mon-entreprise/site/vite.config.ts\";/* eslint-disable no-console */\nimport replace from '@rollup/plugin-replace'\nimport yaml from '@rollup/plugin-yaml'\nimport legacy from '@vitejs/plugin-legacy'\nimport react from '@vitejs/plugin-react'\nimport fs from 'fs/promises'\nimport path from 'path'\nimport serveStatic from 'serve-static'\nimport { Plugin, defineConfig, loadEnv } from 'vite'\nimport { VitePWA } from 'vite-plugin-pwa'\n\nimport { runScriptOnFileChange } from './scripts/runScriptOnFileChange'\nimport { pwaOptions } from './vite-pwa-options'\n\nconst env = (mode: string) => loadEnv(mode, process.cwd(), '')\n\nexport default defineConfig(({ command, mode }) => ({\n\tresolve: {\n\t\talias: { '@': path.resolve('./source') },\n\t\textensions: ['.js', '.ts', '.jsx', '.tsx', '.json'],\n\t},\n\tpublicDir: 'source/public',\n\tbuild: {\n\t\tsourcemap: true,\n\t\trollupOptions: {\n\t\t\toutput: {\n\t\t\t\tchunkFileNames: (chunkInfo) => {\n\t\t\t\t\tif (chunkInfo.isDynamicEntry) {\n\t\t\t\t\t\treturn 'assets/lazy_[name].[hash].js'\n\t\t\t\t\t}\n\n\t\t\t\t\treturn 'assets/[name].[hash].js'\n\t\t\t\t},\n\t\t\t},\n\t\t},\n\t},\n\tdefine: {\n\t\tBRANCH_NAME: JSON.stringify(getBranch(mode)),\n\t\tIS_DEVELOPMENT: mode === 'development',\n\t\tIS_STAGING: mode === 'production' && !isProductionBranch(mode),\n\t\tIS_PRODUCTION: mode === 'production' && isProductionBranch(mode),\n\t},\n\tplugins: [\n\t\t{\n\t\t\tname: 'run-script-on-file-change',\n\t\t\tapply: 'serve',\n\t\t\tbuildStart() {\n\t\t\t\tif (mode === 'development') {\n\t\t\t\t\tvoid runScriptOnFileChange()\n\t\t\t\t}\n\t\t\t},\n\t\t},\n\t\tcommand === 'build' &&\n\t\t\treplace({\n\t\t\t\t__SENTRY_DEBUG__: false,\n\t\t\t\tpreventAssignment: false,\n\t\t\t}),\n\t\treact({\n\t\t\tbabel: {\n\t\t\t\tplugins: [['babel-plugin-styled-components', { pure: true }]],\n\t\t\t},\n\t\t}),\n\t\tyaml(),\n\t\tmultipleSPA({\n\t\t\tdefaultSite: 'mon-entreprise',\n\t\t\ttemplatePath: './source/template.html',\n\t\t\tsites: {\n\t\t\t\t'mon-entreprise': {\n\t\t\t\t\tlang: 'fr',\n\t\t\t\t\tentry: '/source/entry-fr.tsx',\n\t\t\t\t\ttitle:\n\t\t\t\t\t\t\"mon-entreprise.urssaf.fr : L'assistant officiel du cr\u00E9ateur d'entreprise\",\n\t\t\t\t\tdescription:\n\t\t\t\t\t\t'Du statut juridique \u00E0 la premi\u00E8re embauche, en passant par la simulation des cotisations, vous trouverez ici toutes les ressources pour d\u00E9marrer votre activit\u00E9.',\n\t\t\t\t\tshareImage: '/source/images/logo-monentreprise.svg',\n\t\t\t\t\tshareImageAlt: 'Logo mon-entreprise, site Urssaf',\n\t\t\t\t},\n\t\t\t\tinfrance: {\n\t\t\t\t\tlang: 'en',\n\t\t\t\t\tentry: '/source/entry-en.tsx',\n\t\t\t\t\ttitle:\n\t\t\t\t\t\t'My company in France: A step-by-step guide to start a business in France',\n\t\t\t\t\tdescription:\n\t\t\t\t\t\t'Find the type of company that suits you and follow the steps to register your company. Discover the French social security system by simulating your hiring costs. Discover the procedures to hire in France and learn the basics of French labour law.',\n\t\t\t\t\tshareImage: '/logo-mycompany-share.png',\n\t\t\t\t\tshareImageAlt: 'Logo My company in France by Urssaf',\n\t\t\t\t},\n\t\t\t},\n\t\t}),\n\t\tVitePWA(pwaOptions),\n\t\tlegacy({\n\t\t\ttargets: ['defaults', 'not IE 11'],\n\t\t}),\n\t],\n\tserver: {\n\t\tport: 3000,\n\t\thmr: {\n\t\t\tclientPort:\n\t\t\t\ttypeof env(mode).HMR_CLIENT_PORT !== 'undefined'\n\t\t\t\t\t? parseInt(env(mode).HMR_CLIENT_PORT)\n\t\t\t\t\t: undefined,\n\t\t},\n\t\t// Keep watching changes in the publicodes package to support live reload\n\t\t// when we iterate on publicodes logic.\n\t\t// https://vitejs.dev/config/#server-watch\n\t\twatch: {\n\t\t\tignored: [\n\t\t\t\t'!**/node_modules/publicodes/**',\n\t\t\t\t'!**/node_modules/publicodes-react/**',\n\t\t\t],\n\t\t},\n\t\tproxy: {\n\t\t\t'/api': 'http://localhost:3004',\n\t\t\t'/twemoji': {\n\t\t\t\ttarget: 'https://twemoji.maxcdn.com',\n\t\t\t\tchangeOrigin: true,\n\t\t\t\trewrite: (path) => path.replace(/^\\/twemoji/, ''),\n\t\t\t\ttimeout: 3 * 1000,\n\t\t\t},\n\t\t},\n\t},\n\toptimizeDeps: {\n\t\tentries: ['./source/entry-fr.tsx', './source/entry-en.tsx'],\n\t\texclude: ['publicodes-react', 'publicodes'],\n\t\t// Optimize cjs deps from publicodes\n\t\tinclude: ['publicodes > moo', 'publicodes > nearley'],\n\t},\n\tssr: {\n\t\t/**\n\t\t * Prevent listed dependencies from being externalized for SSR build cause some\n\t\t * packages are not esm ready or package.json setup seems wrong, wait this pr to be merge:\n\t\t * react-spectrum: https://github.com/adobe/react-spectrum/pull/3630\n\t\t * markdown-to-jsx: https://github.com/probablyup/markdown-to-jsx/pull/414\n\t\t * styled-components: https://github.com/styled-components/styled-components/issues/3601\n\t\t * publicodes-react: Add type module\n\t\t */\n\t\tnoExternal: [\n\t\t\t/react-aria|react-stately|internationalized/,\n\t\t\t/markdown-to-jsx/,\n\t\t\t/styled-components|emotion/,\n\t\t\t/publicodes-react/, // TODO remove this after publicodes-react upgrade\n\t\t],\n\t},\n}))\n\ntype MultipleSPAOptions = {\n\tdefaultSite: string\n\ttemplatePath: string\n\tsites: Record<string, Record<string, string>>\n}\n\n/**\n * A custom plugin to create multiple virtual html files from a template. Will\n * generate distinct entry points and single-page application outputs.\n */\nfunction multipleSPA(options: MultipleSPAOptions): Plugin {\n\tconst fillTemplate = async (siteName: string) => {\n\t\tconst siteData = options.sites[siteName]\n\t\tconst template = await fs.readFile(options.templatePath, 'utf-8')\n\t\tconst filledTemplate = template\n\t\t\t.toString()\n\t\t\t.replace(/\\{\\{(.+)\\}\\}/g, (_match, p1) => siteData[(p1 as string).trim()])\n\n\t\treturn filledTemplate\n\t}\n\n\treturn {\n\t\tname: 'multiple-spa',\n\t\tenforce: 'pre',\n\n\t\tconfigureServer(vite) {\n\t\t\t// TODO: this middleware is specific to the \"mon-entreprise\" app and\n\t\t\t// shouldn't be in the \"multipleSPA\" plugin\n\t\t\tvite.middlewares.use(\n\t\t\t\t'/simulateur-iframe-integration.js',\n\t\t\t\tserveStatic(new URL('./dist', import.meta.url).pathname, {\n\t\t\t\t\tindex: 'simulateur-iframe-integration.js',\n\t\t\t\t})\n\t\t\t)\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-misused-promises\n\t\t\tvite.middlewares.use(async (req, res, next) => {\n\t\t\t\tconst url = req.originalUrl?.replace(/^\\/%2F/, '/')\n\n\t\t\t\tconst firstLevelDir = url?.slice(1).split('/')[0]\n\n\t\t\t\tif (url && /\\?.*html-proxy/.test(url)) {\n\t\t\t\t\treturn next()\n\t\t\t\t}\n\n\t\t\t\tif (url && ['/', '/index.html'].includes(url)) {\n\t\t\t\t\tres.writeHead(302, { Location: '/' + options.defaultSite }).end()\n\t\t\t\t}\n\t\t\t\t// this condition is for the start:netlify script to match /mon-entreprise or /infrance\n\t\t\t\telse if (\n\t\t\t\t\tfirstLevelDir &&\n\t\t\t\t\turl &&\n\t\t\t\t\tObject.keys(options.sites)\n\t\t\t\t\t\t.map((site) => `/${site}.html`)\n\t\t\t\t\t\t.includes(url)\n\t\t\t\t) {\n\t\t\t\t\tconst siteName = firstLevelDir.replace('.html', '')\n\t\t\t\t\tconst content = await vite.transformIndexHtml(\n\t\t\t\t\t\t'/' + siteName,\n\t\t\t\t\t\tawait fillTemplate(siteName)\n\t\t\t\t\t)\n\t\t\t\t\tres.end(content)\n\t\t\t\t} else if (\n\t\t\t\t\tfirstLevelDir &&\n\t\t\t\t\tObject.keys(options.sites).some((name) => firstLevelDir === name)\n\t\t\t\t) {\n\t\t\t\t\tconst siteName = firstLevelDir\n\t\t\t\t\tconst content = await vite.transformIndexHtml(\n\t\t\t\t\t\turl,\n\t\t\t\t\t\tawait fillTemplate(siteName)\n\t\t\t\t\t)\n\t\t\t\t\tres.end(content)\n\t\t\t\t} else {\n\t\t\t\t\tnext()\n\t\t\t\t}\n\t\t\t})\n\t\t},\n\n\t\tconfig(config, { command }) {\n\t\t\tif (command === 'build' && !config.build?.ssr) {\n\t\t\t\tconfig.build = {\n\t\t\t\t\t...config.build,\n\t\t\t\t\trollupOptions: {\n\t\t\t\t\t\t...config.build?.rollupOptions,\n\t\t\t\t\t\tinput: Object.fromEntries(\n\t\t\t\t\t\t\tObject.keys(options.sites).map((name) => [\n\t\t\t\t\t\t\t\tname,\n\t\t\t\t\t\t\t\t`virtual:${name}.html`,\n\t\t\t\t\t\t\t])\n\t\t\t\t\t\t),\n\t\t\t\t\t},\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\tresolveId(id) {\n\t\t\tconst pathname = id.split('/').slice(-1)[0]\n\t\t\tif (pathname?.startsWith('virtual:')) {\n\t\t\t\treturn pathname.replace('virtual:', '')\n\t\t\t}\n\n\t\t\treturn null\n\t\t},\n\n\t\tasync load(id) {\n\t\t\tif (\n\t\t\t\tObject.keys(options.sites).some((name) => id.endsWith(name + '.html'))\n\t\t\t) {\n\t\t\t\treturn await fillTemplate(id.replace(/\\.html$/, ''))\n\t\t\t}\n\t\t},\n\t}\n}\n\n/**\n * Git branch name\n */\nexport const getBranch = (mode: string) => {\n\tlet branch: string | undefined = env(mode)\n\t\t.VITE_GITHUB_REF?.split('/')\n\t\t?.slice(-1)?.[0]\n\n\tif (branch === 'merge') {\n\t\tbranch = env(mode).VITE_GITHUB_HEAD_REF\n\t}\n\n\treturn branch ?? ''\n}\n\n/**\n * We use this function to hide some features in production while keeping them\n * in feature-branches. In case we do A/B testing with several branches served\n * in production, we should add the public faced branch names in the test below.\n * This is different from the import.meta.env.MODE in that a feature branch may\n * be build in production mode (with the NODE_ENV) but we may still want to show\n * or hide some features.\n */\nexport const isProductionBranch = (mode: string) => {\n\treturn ['master', 'next'].includes(getBranch(mode))\n}\n", "const __vite_injected_original_dirname = \"/home/johan/Projets/mon-entreprise/site/scripts/runScriptOnFileChange\";const __vite_injected_original_filename = \"/home/johan/Projets/mon-entreprise/site/scripts/runScriptOnFileChange/execOnFileChange.ts\";const __vite_injected_original_import_meta_url = \"file:///home/johan/Projets/mon-entreprise/site/scripts/runScriptOnFileChange/execOnFileChange.ts\";import { getPackageDeps } from '@rushstack/package-deps-hash'\nimport { exec as originalExec } from 'child_process'\nimport { existsSync, lstatSync, readFileSync, writeFileSync } from 'fs'\nimport { relative, resolve } from 'path'\nimport { promisify } from 'util'\n\nconst exec = promisify(originalExec)\n\ntype DirPath = string\ntype FilePath = string\n\ninterface Option {\n\tpaths: (DirPath | FilePath)[]\n\trun: string\n}\n\ninterface Config {\n\tbasePath: string\n\tdepsPath: string\n\toptions: Option[]\n}\n\ntype Deps = Record<string, string>\n\n/**\n * Execute a command when a file or a file in the directory changes\n */\nexport const execOnFileChange = async (config: Config) => {\n\tconst path = resolve(config.basePath, config.depsPath)\n\n\tconst deps: Deps = Object.fromEntries(getPackageDeps(config.basePath))\n\tconst depsEntries = Object.entries(deps)\n\n\tconst existingDeps = existsSync(path)\n\t\t? (JSON.parse(readFileSync(path, { encoding: 'utf8' })) as Deps)\n\t\t: {}\n\tconst existingDepsEntries = Object.entries(existingDeps)\n\n\tconst promises = config.options.map(async (cfg) => {\n\t\tlet fileChanged: null | string = null\n\t\tconst index = cfg.paths\n\t\t\t.map((val) => {\n\t\t\t\tconst isDir = lstatSync(resolve(config.basePath, val)).isDirectory()\n\t\t\t\tconst isFile = lstatSync(resolve(config.basePath, val)).isFile()\n\n\t\t\t\treturn {\n\t\t\t\t\tisDir,\n\t\t\t\t\tisFile,\n\t\t\t\t\tabsolute: resolve(config.basePath, val),\n\t\t\t\t\trelative: relative(\n\t\t\t\t\t\tresolve(config.basePath),\n\t\t\t\t\t\tresolve(config.basePath, val)\n\t\t\t\t\t),\n\t\t\t\t}\n\t\t\t})\n\t\t\t.findIndex(({ absolute, relative, isFile, isDir }) => {\n\t\t\t\tif (isFile) {\n\t\t\t\t\tif (deps[relative] !== existingDeps[relative]) {\n\t\t\t\t\t\tfileChanged = relative\n\t\t\t\t\t}\n\n\t\t\t\t\treturn deps[relative] !== existingDeps[relative]\n\t\t\t\t} else if (isDir) {\n\t\t\t\t\tconst index = depsEntries.findIndex(\n\t\t\t\t\t\t([a, b], i) =>\n\t\t\t\t\t\t\t(relative.length ? a.startsWith(relative + '/') : true) &&\n\t\t\t\t\t\t\t(existingDepsEntries?.[i]?.[0] !== a ||\n\t\t\t\t\t\t\t\texistingDepsEntries?.[i]?.[1] !== b)\n\t\t\t\t\t)\n\n\t\t\t\t\tif (index > -1) {\n\t\t\t\t\t\tfileChanged = depsEntries[index][0]\n\t\t\t\t\t}\n\n\t\t\t\t\treturn index > -1\n\t\t\t\t}\n\t\t\t\tthrow new Error('Path is not a directory or a file: ' + absolute)\n\t\t\t})\n\n\t\tif (index > -1) {\n\t\t\tconst result = await exec(cfg.run)\n\n\t\t\treturn {\n\t\t\t\tpath: cfg.paths[index],\n\t\t\t\tfileChanged,\n\t\t\t\trun: cfg.run,\n\t\t\t\tresult,\n\t\t\t}\n\t\t}\n\n\t\treturn null\n\t})\n\n\tconst res = await Promise.all(promises)\n\n\twriteFileSync(path, JSON.stringify(deps, null, 2))\n\n\treturn res\n}\n", "const __vite_injected_original_dirname = \"/home/johan/Projets/mon-entreprise/site/scripts/runScriptOnFileChange\";const __vite_injected_original_filename = \"/home/johan/Projets/mon-entreprise/site/scripts/runScriptOnFileChange/index.ts\";const __vite_injected_original_import_meta_url = \"file:///home/johan/Projets/mon-entreprise/site/scripts/runScriptOnFileChange/index.ts\";import { execOnFileChange } from './execOnFileChange.js'\n\nexport const runScriptOnFileChange = async () => {\n\tconsole.log('Search for changed file...')\n\n\tconst results = await execOnFileChange({\n\t\tbasePath: './',\n\t\tdepsPath: '.deps.json',\n\t\toptions: [\n\t\t\t{\n\t\t\t\tpaths: [\n\t\t\t\t\t'./source/pages/Simulateurs/EconomieCollaborative/activit\u00E9s.yaml',\n\t\t\t\t\t'./source/pages/Simulateurs/EconomieCollaborative/activit\u00E9s.en.yaml',\n\t\t\t\t],\n\t\t\t\trun: 'yarn build:yaml-to-dts',\n\t\t\t},\n\t\t],\n\t})\n\n\tresults\n\t\t.filter(<T>(x: null | T): x is T => !!x)\n\t\t.forEach(({ fileChanged, run, result }) => {\n\t\t\tconsole.log('Changed file detected:', fileChanged)\n\t\t\tconsole.log('Execute:', run, '\\n')\n\n\t\t\tif (result.stdout) {\n\t\t\t\tconsole.log(result.stdout)\n\t\t\t}\n\t\t\tif (result.stderr) {\n\t\t\t\tconsole.error(result.stderr)\n\t\t\t}\n\t\t})\n}\n", "const __vite_injected_original_dirname = \"/home/johan/Projets/mon-entreprise/site\";const __vite_injected_original_filename = \"/home/johan/Projets/mon-entreprise/site/vite-pwa-options.ts\";const __vite_injected_original_import_meta_url = \"file:///home/johan/Projets/mon-entreprise/site/vite-pwa-options.ts\";import { Options } from 'vite-plugin-pwa'\n\nexport const pwaOptions: Partial<Options> = {\n\t// selfDestroying: true, // Unregister PWA\n\tregisterType: 'prompt',\n\tstrategies: 'injectManifest',\n\tsrcDir: 'source',\n\tfilename: 'sw.ts',\n\tinjectManifest: {\n\t\tmaximumFileSizeToCacheInBytes: 3000000,\n\t\tmanifestTransforms: [\n\t\t\t(entries) => {\n\t\t\t\tconst manifest = entries.filter(\n\t\t\t\t\t(entry) =>\n\t\t\t\t\t\t!/assets\\/.*(-legacy|lazy_)/.test(entry.url) &&\n\t\t\t\t\t\t(entry.url.endsWith('.html')\n\t\t\t\t\t\t\t? /(infrance|mon-entreprise)\\.html/.test(entry.url)\n\t\t\t\t\t\t\t: true)\n\t\t\t\t)\n\n\t\t\t\treturn { manifest }\n\t\t\t},\n\t\t],\n\t},\n\tincludeAssets: ['logo-*.png'],\n\tmanifest: {\n\t\tstart_url: '/',\n\t\tname: 'Mon entreprise',\n\t\tshort_name: 'Mon entreprise',\n\t\tdescription: \"L'assistant officiel du cr\u00E9ateur d'entreprise\",\n\t\tlang: 'fr',\n\t\torientation: 'portrait-primary',\n\t\tdisplay: 'minimal-ui',\n\t\ttheme_color: '#2975d1',\n\t\tbackground_color: '#ffffff',\n\t\ticons: [\n\t\t\t{\n\t\t\t\tsrc: '/favicon/android-chrome-192x192-shadow.png?v=2.0',\n\t\t\t\tsizes: '192x192',\n\t\t\t\ttype: 'image/png',\n\t\t\t},\n\t\t\t{\n\t\t\t\tsrc: '/favicon/android-chrome-512x512-shadow.png?v=2.0',\n\t\t\t\tsizes: '512x512',\n\t\t\t\ttype: 'image/png',\n\t\t\t},\n\t\t],\n\t},\n}\n"],
  "mappings": ";AACA,OAAO,aAAa;AACpB,OAAO,UAAU;AACjB,OAAO,YAAY;AACnB,OAAO,WAAW;AAClB,OAAO,QAAQ;AACf,OAAO,UAAU;AACjB,OAAO,iBAAiB;AACxB,SAAiB,cAAc,eAAe;AAC9C,SAAS,eAAe;;;ACTmX,SAAS,sBAAsB;AAC1a,SAAS,QAAQ,oBAAoB;AACrC,SAAS,YAAY,WAAW,cAAc,qBAAqB;AACnE,SAAS,UAAU,eAAe;AAClC,SAAS,iBAAiB;AAE1B,IAAM,OAAO,UAAU,YAAY;AAqB5B,IAAM,mBAAmB,OAAO,WAAmB;AACzD,QAAMA,QAAO,QAAQ,OAAO,UAAU,OAAO,QAAQ;AAErD,QAAM,OAAa,OAAO,YAAY,eAAe,OAAO,QAAQ,CAAC;AACrE,QAAM,cAAc,OAAO,QAAQ,IAAI;AAEvC,QAAM,eAAe,WAAWA,KAAI,IAChC,KAAK,MAAM,aAAaA,OAAM,EAAE,UAAU,OAAO,CAAC,CAAC,IACpD,CAAC;AACJ,QAAM,sBAAsB,OAAO,QAAQ,YAAY;AAEvD,QAAM,WAAW,OAAO,QAAQ,IAAI,OAAO,QAAQ;AAClD,QAAI,cAA6B;AACjC,UAAM,QAAQ,IAAI,MAChB,IAAI,CAAC,QAAQ;AACb,YAAM,QAAQ,UAAU,QAAQ,OAAO,UAAU,GAAG,CAAC,EAAE,YAAY;AACnE,YAAM,SAAS,UAAU,QAAQ,OAAO,UAAU,GAAG,CAAC,EAAE,OAAO;AAE/D,aAAO;AAAA,QACN;AAAA,QACA;AAAA,QACA,UAAU,QAAQ,OAAO,UAAU,GAAG;AAAA,QACtC,UAAU;AAAA,UACT,QAAQ,OAAO,QAAQ;AAAA,UACvB,QAAQ,OAAO,UAAU,GAAG;AAAA,QAC7B;AAAA,MACD;AAAA,IACD,CAAC,EACA,UAAU,CAAC,EAAE,UAAU,UAAAC,WAAU,QAAQ,MAAM,MAAM;AACrD,UAAI,QAAQ;AACX,YAAI,KAAKA,eAAc,aAAaA,YAAW;AAC9C,wBAAcA;AAAA,QACf;AAEA,eAAO,KAAKA,eAAc,aAAaA;AAAA,MACxC,WAAW,OAAO;AACjB,cAAMC,SAAQ,YAAY;AAAA,UACzB,CAAC,CAAC,GAAG,CAAC,GAAG,MAAG;AAhElB;AAiEQ,oBAAAD,UAAS,SAAS,EAAE,WAAWA,YAAW,GAAG,IAAI,YACjD,gEAAsB,OAAtB,mBAA2B,QAAO,OAClC,gEAAsB,OAAtB,mBAA2B,QAAO;AAAA;AAAA,QACrC;AAEA,YAAIC,SAAQ,IAAI;AACf,wBAAc,YAAYA,QAAO;AAAA,QAClC;AAEA,eAAOA,SAAQ;AAAA,MAChB;AACA,YAAM,IAAI,MAAM,wCAAwC,QAAQ;AAAA,IACjE,CAAC;AAEF,QAAI,QAAQ,IAAI;AACf,YAAM,SAAS,MAAM,KAAK,IAAI,GAAG;AAEjC,aAAO;AAAA,QACN,MAAM,IAAI,MAAM;AAAA,QAChB;AAAA,QACA,KAAK,IAAI;AAAA,QACT;AAAA,MACD;AAAA,IACD;AAEA,WAAO;AAAA,EACR,CAAC;AAED,QAAM,MAAM,MAAM,QAAQ,IAAI,QAAQ;AAEtC,gBAAcF,OAAM,KAAK,UAAU,MAAM,MAAM,CAAC,CAAC;AAEjD,SAAO;AACR;;;AChGO,IAAM,wBAAwB,YAAY;AAChD,UAAQ,IAAI,4BAA4B;AAExC,QAAM,UAAU,MAAM,iBAAiB;AAAA,IACtC,UAAU;AAAA,IACV,UAAU;AAAA,IACV,SAAS;AAAA,MACR;AAAA,QACC,OAAO;AAAA,UACN;AAAA,UACA;AAAA,QACD;AAAA,QACA,KAAK;AAAA,MACN;AAAA,IACD;AAAA,EACD,CAAC;AAED,UACE,OAAO,CAAI,MAAwB,CAAC,CAAC,CAAC,EACtC,QAAQ,CAAC,EAAE,aAAa,KAAK,OAAO,MAAM;AAC1C,YAAQ,IAAI,0BAA0B,WAAW;AACjD,YAAQ,IAAI,YAAY,KAAK,IAAI;AAEjC,QAAI,OAAO,QAAQ;AAClB,cAAQ,IAAI,OAAO,MAAM;AAAA,IAC1B;AACA,QAAI,OAAO,QAAQ;AAClB,cAAQ,MAAM,OAAO,MAAM;AAAA,IAC5B;AAAA,EACD,CAAC;AACH;;;AC9BO,IAAM,aAA+B;AAAA,EAE3C,cAAc;AAAA,EACd,YAAY;AAAA,EACZ,QAAQ;AAAA,EACR,UAAU;AAAA,EACV,gBAAgB;AAAA,IACf,+BAA+B;AAAA,IAC/B,oBAAoB;AAAA,MACnB,CAAC,YAAY;AACZ,cAAM,WAAW,QAAQ;AAAA,UACxB,CAAC,UACA,CAAC,4BAA4B,KAAK,MAAM,GAAG,MAC1C,MAAM,IAAI,SAAS,OAAO,IACxB,kCAAkC,KAAK,MAAM,GAAG,IAChD;AAAA,QACL;AAEA,eAAO,EAAE,SAAS;AAAA,MACnB;AAAA,IACD;AAAA,EACD;AAAA,EACA,eAAe,CAAC,YAAY;AAAA,EAC5B,UAAU;AAAA,IACT,WAAW;AAAA,IACX,MAAM;AAAA,IACN,YAAY;AAAA,IACZ,aAAa;AAAA,IACb,MAAM;AAAA,IACN,aAAa;AAAA,IACb,SAAS;AAAA,IACT,aAAa;AAAA,IACb,kBAAkB;AAAA,IAClB,OAAO;AAAA,MACN;AAAA,QACC,KAAK;AAAA,QACL,OAAO;AAAA,QACP,MAAM;AAAA,MACP;AAAA,MACA;AAAA,QACC,KAAK;AAAA,QACL,OAAO;AAAA,QACP,MAAM;AAAA,MACP;AAAA,IACD;AAAA,EACD;AACD;;;AHhDsL,IAAM,2CAA2C;AAcvO,IAAM,MAAM,CAAC,SAAiB,QAAQ,MAAM,QAAQ,IAAI,GAAG,EAAE;AAE7D,IAAO,sBAAQ,aAAa,CAAC,EAAE,SAAS,KAAK,OAAO;AAAA,EACnD,SAAS;AAAA,IACR,OAAO,EAAE,KAAK,KAAK,QAAQ,UAAU,EAAE;AAAA,IACvC,YAAY,CAAC,OAAO,OAAO,QAAQ,QAAQ,OAAO;AAAA,EACnD;AAAA,EACA,WAAW;AAAA,EACX,OAAO;AAAA,IACN,WAAW;AAAA,IACX,eAAe;AAAA,MACd,QAAQ;AAAA,QACP,gBAAgB,CAAC,cAAc;AAC9B,cAAI,UAAU,gBAAgB;AAC7B,mBAAO;AAAA,UACR;AAEA,iBAAO;AAAA,QACR;AAAA,MACD;AAAA,IACD;AAAA,EACD;AAAA,EACA,QAAQ;AAAA,IACP,aAAa,KAAK,UAAU,UAAU,IAAI,CAAC;AAAA,IAC3C,gBAAgB,SAAS;AAAA,IACzB,YAAY,SAAS,gBAAgB,CAAC,mBAAmB,IAAI;AAAA,IAC7D,eAAe,SAAS,gBAAgB,mBAAmB,IAAI;AAAA,EAChE;AAAA,EACA,SAAS;AAAA,IACR;AAAA,MACC,MAAM;AAAA,MACN,OAAO;AAAA,MACP,aAAa;AACZ,YAAI,SAAS,eAAe;AAC3B,eAAK,sBAAsB;AAAA,QAC5B;AAAA,MACD;AAAA,IACD;AAAA,IACA,YAAY,WACX,QAAQ;AAAA,MACP,kBAAkB;AAAA,MAClB,mBAAmB;AAAA,IACpB,CAAC;AAAA,IACF,MAAM;AAAA,MACL,OAAO;AAAA,QACN,SAAS,CAAC,CAAC,kCAAkC,EAAE,MAAM,KAAK,CAAC,CAAC;AAAA,MAC7D;AAAA,IACD,CAAC;AAAA,IACD,KAAK;AAAA,IACL,YAAY;AAAA,MACX,aAAa;AAAA,MACb,cAAc;AAAA,MACd,OAAO;AAAA,QACN,kBAAkB;AAAA,UACjB,MAAM;AAAA,UACN,OAAO;AAAA,UACP,OACC;AAAA,UACD,aACC;AAAA,UACD,YAAY;AAAA,UACZ,eAAe;AAAA,QAChB;AAAA,QACA,UAAU;AAAA,UACT,MAAM;AAAA,UACN,OAAO;AAAA,UACP,OACC;AAAA,UACD,aACC;AAAA,UACD,YAAY;AAAA,UACZ,eAAe;AAAA,QAChB;AAAA,MACD;AAAA,IACD,CAAC;AAAA,IACD,QAAQ,UAAU;AAAA,IAClB,OAAO;AAAA,MACN,SAAS,CAAC,YAAY,WAAW;AAAA,IAClC,CAAC;AAAA,EACF;AAAA,EACA,QAAQ;AAAA,IACP,MAAM;AAAA,IACN,KAAK;AAAA,MACJ,YACC,OAAO,IAAI,IAAI,EAAE,oBAAoB,cAClC,SAAS,IAAI,IAAI,EAAE,eAAe,IAClC;AAAA,IACL;AAAA,IAIA,OAAO;AAAA,MACN,SAAS;AAAA,QACR;AAAA,QACA;AAAA,MACD;AAAA,IACD;AAAA,IACA,OAAO;AAAA,MACN,QAAQ;AAAA,MACR,YAAY;AAAA,QACX,QAAQ;AAAA,QACR,cAAc;AAAA,QACd,SAAS,CAACG,UAASA,MAAK,QAAQ,cAAc,EAAE;AAAA,QAChD,SAAS,IAAI;AAAA,MACd;AAAA,IACD;AAAA,EACD;AAAA,EACA,cAAc;AAAA,IACb,SAAS,CAAC,yBAAyB,uBAAuB;AAAA,IAC1D,SAAS,CAAC,oBAAoB,YAAY;AAAA,IAE1C,SAAS,CAAC,oBAAoB,sBAAsB;AAAA,EACrD;AAAA,EACA,KAAK;AAAA,IASJ,YAAY;AAAA,MACX;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACD;AAAA,EACD;AACD,EAAE;AAYF,SAAS,YAAY,SAAqC;AACzD,QAAM,eAAe,OAAO,aAAqB;AAChD,UAAM,WAAW,QAAQ,MAAM;AAC/B,UAAM,WAAW,MAAM,GAAG,SAAS,QAAQ,cAAc,OAAO;AAChE,UAAM,iBAAiB,SACrB,SAAS,EACT,QAAQ,iBAAiB,CAAC,QAAQ,OAAO,SAAU,GAAc,KAAK,EAAE;AAE1E,WAAO;AAAA,EACR;AAEA,SAAO;AAAA,IACN,MAAM;AAAA,IACN,SAAS;AAAA,IAET,gBAAgB,MAAM;AAGrB,WAAK,YAAY;AAAA,QAChB;AAAA,QACA,YAAY,IAAI,IAAI,UAAU,wCAAe,EAAE,UAAU;AAAA,UACxD,OAAO;AAAA,QACR,CAAC;AAAA,MACF;AAEA,WAAK,YAAY,IAAI,OAAO,KAAK,KAAK,SAAS;AApLlD;AAqLI,cAAM,OAAM,SAAI,gBAAJ,mBAAiB,QAAQ,UAAU;AAE/C,cAAM,gBAAgB,2BAAK,MAAM,GAAG,MAAM,KAAK;AAE/C,YAAI,OAAO,iBAAiB,KAAK,GAAG,GAAG;AACtC,iBAAO,KAAK;AAAA,QACb;AAEA,YAAI,OAAO,CAAC,KAAK,aAAa,EAAE,SAAS,GAAG,GAAG;AAC9C,cAAI,UAAU,KAAK,EAAE,UAAU,MAAM,QAAQ,YAAY,CAAC,EAAE,IAAI;AAAA,QACjE,WAGC,iBACA,OACA,OAAO,KAAK,QAAQ,KAAK,EACvB,IAAI,CAAC,SAAS,IAAI,WAAW,EAC7B,SAAS,GAAG,GACb;AACD,gBAAM,WAAW,cAAc,QAAQ,SAAS,EAAE;AAClD,gBAAM,UAAU,MAAM,KAAK;AAAA,YAC1B,MAAM;AAAA,YACN,MAAM,aAAa,QAAQ;AAAA,UAC5B;AACA,cAAI,IAAI,OAAO;AAAA,QAChB,WACC,iBACA,OAAO,KAAK,QAAQ,KAAK,EAAE,KAAK,CAAC,SAAS,kBAAkB,IAAI,GAC/D;AACD,gBAAM,WAAW;AACjB,gBAAM,UAAU,MAAM,KAAK;AAAA,YAC1B;AAAA,YACA,MAAM,aAAa,QAAQ;AAAA,UAC5B;AACA,cAAI,IAAI,OAAO;AAAA,QAChB,OAAO;AACN,eAAK;AAAA,QACN;AAAA,MACD,CAAC;AAAA,IACF;AAAA,IAEA,OAAO,QAAQ,EAAE,QAAQ,GAAG;AA9N9B;AA+NG,UAAI,YAAY,WAAW,GAAC,YAAO,UAAP,mBAAc,MAAK;AAC9C,eAAO,QAAQ;AAAA,UACd,GAAG,OAAO;AAAA,UACV,eAAe;AAAA,YACd,IAAG,YAAO,UAAP,mBAAc;AAAA,YACjB,OAAO,OAAO;AAAA,cACb,OAAO,KAAK,QAAQ,KAAK,EAAE,IAAI,CAAC,SAAS;AAAA,gBACxC;AAAA,gBACA,WAAW;AAAA,cACZ,CAAC;AAAA,YACF;AAAA,UACD;AAAA,QACD;AAAA,MACD;AAAA,IACD;AAAA,IAEA,UAAU,IAAI;AACb,YAAM,WAAW,GAAG,MAAM,GAAG,EAAE,MAAM,EAAE,EAAE;AACzC,UAAI,qCAAU,WAAW,aAAa;AACrC,eAAO,SAAS,QAAQ,YAAY,EAAE;AAAA,MACvC;AAEA,aAAO;AAAA,IACR;AAAA,IAEA,MAAM,KAAK,IAAI;AACd,UACC,OAAO,KAAK,QAAQ,KAAK,EAAE,KAAK,CAAC,SAAS,GAAG,SAAS,OAAO,OAAO,CAAC,GACpE;AACD,eAAO,MAAM,aAAa,GAAG,QAAQ,WAAW,EAAE,CAAC;AAAA,MACpD;AAAA,IACD;AAAA,EACD;AACD;AAKO,IAAM,YAAY,CAAC,SAAiB;AArQ3C;AAsQC,MAAI,UAA6B,qBAAI,IAAI,EACvC,oBAD+B,mBACd,MAAM,SADQ,mBAE9B,MAAM,QAFwB,mBAElB;AAEf,MAAI,WAAW,SAAS;AACvB,aAAS,IAAI,IAAI,EAAE;AAAA,EACpB;AAEA,SAAO,UAAU;AAClB;AAUO,IAAM,qBAAqB,CAAC,SAAiB;AACnD,SAAO,CAAC,UAAU,MAAM,EAAE,SAAS,UAAU,IAAI,CAAC;AACnD;",
  "names": ["path", "relative", "index", "path"]
}
