UNPKG

one

Version:

One is a new React Framework that makes Vite serve both native and web.

44 lines (43 loc) 1.82 kB
import { matchGroupName } from "./matchers.mjs"; function sortDynamicConvention(a, b) { return a.deep && !b.deep ? 1 : !a.deep && b.deep ? -1 : 0; } function sortRoutes(a, b) { const aDynamicSegments = getDynamicSegments(a), bDynamicSegments = getDynamicSegments(b); if (aDynamicSegments.length && !bDynamicSegments.length) return 1; if (!aDynamicSegments.length && bDynamicSegments.length) return -1; if (aDynamicSegments.length && bDynamicSegments.length) { if (aDynamicSegments.length !== bDynamicSegments.length) return bDynamicSegments.length - aDynamicSegments.length; for (let i = 0; i < aDynamicSegments.length; i++) { const aDynamic = aDynamicSegments[i], bDynamic = bDynamicSegments[i]; if (aDynamic.notFound && bDynamic.notFound) { const s2 = sortDynamicConvention(aDynamic, bDynamic); if (s2) return s2; } if (aDynamic.notFound && !bDynamic.notFound) return 1; if (!aDynamic.notFound && bDynamic.notFound) return -1; const s = sortDynamicConvention(aDynamic, bDynamic); if (s) return s; } return 0; } const aIndex = a.route === "index" || matchGroupName(a.route) != null, bIndex = b.route === "index" || matchGroupName(b.route) != null; return aIndex && !bIndex ? -1 : !aIndex && bIndex ? 1 : a.route.length - b.route.length; } function getDynamicSegments(route) { return [...(route.dynamic || []), ...(route.layouts?.flatMap(layout => layout.dynamic || []) || [])]; } function sortRoutesWithInitial(initialRouteName) { return (a, b) => { if (initialRouteName) { if (a.route === initialRouteName) return -1; if (b.route === initialRouteName) return 1; } return sortRoutes(a, b); }; } export { sortRoutes, sortRoutesWithInitial }; //# sourceMappingURL=sortRoutes.mjs.map