one
Version:
One is a new React Framework that makes Vite serve both native and web.
56 lines (55 loc) • 1.88 kB
JavaScript
import { matchGroupName } from "./matchers";
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.js.map