@sect/use-placeholder-path
v1.4.1
Published
A custom React hook to retrieve placeholder path in Next.js App Router.
Downloads
265
Maintainers
Readme
@sect/use-placeholder-path
A custom React hook to retrieve placeholder paths in Next.js App Router.
Why Use This Hook?
Next.js 13+ App Router doesn't provide a built-in method to return the path of placeholder values, unlike router.pathname
in Pages Router. This hook fills that gap, allowing you to get the placeholder path in the App Router, similar to how you would in the Pages Router.
Easing the Transition from Pages Router
For developers migrating from Pages Router to App Router, this hook can significantly reduce the pain points associated with the transition. It provides a familiar way to access placeholder paths, making it easier to port existing code and maintain consistency in your application's routing logic. By offering functionality similar to router.pathname
, usePlaceholderPath
helps bridge the gap between the two routing systems, allowing for a smoother migration process and reducing the need for extensive refactoring of route-dependent code.
Installation
npm install @sect/use-placeholder-path
# or
yarn add @sect/use-placeholder-path
# or
pnpm add @sect/use-placeholder-path
Usage
'use client';
import usePlaceholderPath from '@sect/use-placeholder-path';
const MyComponent = () => {
const placeholderPath = usePlaceholderPath();
return (
<div>
<p>Current placeholder path: {placeholderPath}</p>
</div>
);
}
export default MyComponent;
API
usePlaceholderPath(options?: UsePlaceholderPathOptions): string
interface UsePlaceholderPathOptions {
optionalCatchAllSegments?: string;
}
optionalCatchAllSegments
: (optional) The name of the optional catch-all segment. If provided, enables handling of top-level optional catch-all segments.
Examples
- Route:
/users/123/posts/456
- Result:
/users/[userId]/posts/[postId]
- Result:
- Catch-all Segments Route:
/blog/2024/08/15
- Result:
/blog/[...slug]
- Result:
- Optional Catch-all Segments Route:
/shop/a/b/c
- Result:
/shop/[[...slug]]
- Result:
[!NOTE] For Top-Level Optional Catch-all Segments, special handling may be required. See the "Known Issues" section for more details.
Notes
usePlaceholderPath
requires the use of a Client Component.
Known Issues
Detecting Top-Level Optional Catch-all Segments
Top-Level Optional Catch-all Segments are expected to return /folderName/[[...segmentName]]
, but currently /folderName
is returned.
- Expected:
/shop/[[...slug]]
- Actual:
/shop
This is due to the technical limitations in detecting Top-Level Optional Catch-all Segments in the Next.js App Router.
To address this limitation, we've introduced an optional configuration:
const placeholderPath = usePlaceholderPath({
optionalCatchAllSegments: 'slug'
});
Changelog
See CHANGELOG.