UNPKG

next

Version:

The React Framework

90 lines (89 loc) 2.96 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); 0 && (module.exports = { getParamProperties: null, getSegmentParam: null, isCatchAll: null }); function _export(target, all) { for(var name in all)Object.defineProperty(target, name, { enumerable: true, get: all[name] }); } _export(exports, { getParamProperties: function() { return getParamProperties; }, getSegmentParam: function() { return getSegmentParam; }, isCatchAll: function() { return isCatchAll; } }); const _interceptionroutes = require("./interception-routes"); function getSegmentParam(segment) { const interceptionMarker = _interceptionroutes.INTERCEPTION_ROUTE_MARKERS.find((marker)=>segment.startsWith(marker)); // if an interception marker is part of the path segment, we need to jump ahead // to the relevant portion for param parsing if (interceptionMarker) { segment = segment.slice(interceptionMarker.length); } if (segment.startsWith('[[...') && segment.endsWith(']]')) { return { // TODO-APP: Optional catchall does not currently work with parallel routes, // so for now aren't handling a potential interception marker. paramType: 'optional-catchall', paramName: segment.slice(5, -2) }; } if (segment.startsWith('[...') && segment.endsWith(']')) { return { paramType: interceptionMarker ? `catchall-intercepted-${interceptionMarker}` : 'catchall', paramName: segment.slice(4, -1) }; } if (segment.startsWith('[') && segment.endsWith(']')) { return { paramType: interceptionMarker ? `dynamic-intercepted-${interceptionMarker}` : 'dynamic', paramName: segment.slice(1, -1) }; } return null; } function isCatchAll(type) { return type === 'catchall' || type === 'catchall-intercepted-(..)(..)' || type === 'catchall-intercepted-(.)' || type === 'catchall-intercepted-(..)' || type === 'catchall-intercepted-(...)' || type === 'optional-catchall'; } function getParamProperties(paramType) { let repeat = false; let optional = false; switch(paramType){ case 'catchall': case 'catchall-intercepted-(..)(..)': case 'catchall-intercepted-(.)': case 'catchall-intercepted-(..)': case 'catchall-intercepted-(...)': repeat = true; break; case 'optional-catchall': repeat = true; optional = true; break; case 'dynamic': case 'dynamic-intercepted-(..)(..)': case 'dynamic-intercepted-(.)': case 'dynamic-intercepted-(..)': case 'dynamic-intercepted-(...)': break; default: paramType; } return { repeat, optional }; } //# sourceMappingURL=get-segment-param.js.map