1.0.1 • Published 3 months ago

@meta-ultra/app-router-cli v1.0.1

Weekly downloads
-
License
MIT
Repository
github
Last release
3 months ago

Welcome to @meta-ultra/app-router-cli

With @meta-ultra/app-router and @meta-ultra/app-router-auth, we can structure our project in Next.js App Router convention by setting up the router configuration manually. Are you looking for a more effective way to automate the configure processing. There we are! @meta-ultra/app-router-cli is exactly what you want.

Give a ⭐️ if this project helped you!

🌟 Features

  • Supports page, layout, not-found, error, global-error and template.
  • Supports group routes, including extended group route segment (...name).
  • Supports dynamic routes including catch-all and optional catch-all segments.
  • Supports parallel routes.
  • Supports intercepting routes.
  • Supports route handlers.
  • Generates root layout automatically if no root layout is found.
  • Allows to prefer browser router or hash router.
  • Be able to customize basename of the router.
  • Supports watch mode, easy to integrate to your building workflow.

:alien: Prerequisites

Due to the output of processing which is code snippet will depend on @meta-ultra/app-router, please run pnpm add @meta-ultra/app-router@latest to install it first.

🏠 Installation

Install @meta-ultra/app-router with your favorite package manager:

  • pnpm: pnpm add -D @meta-ultra/app-router-cli@latest
  • yarn: yarn add -D @meta-ultra/app-router-cli@latest
  • npm: npm install -D @meta-ultra/app-router-cli@latest

✨ Usage

  • Show the help text

    > app-router -h
    
    Usage:
    $ app-router <command> [options]
    
    Options:
      -h, --help                           Display this message
      -v, --version                        Display version number
      --hash                               Use hash instead of history API (default: false)
      --basename, -b [basename]            The URL basename(synonym for publicPath in Webpack) defaults to process.env.PUBLIC_URL (default: process.env.PUBLIC_URL)
      --watch, -w                          Enable watch mode (default: false)
      --watch-aggregate-timeout [timeout]  Add a delay(ms) before rebuilding once the first file added or removed (default: 700)
      --base-url [baseUrl]                 The baseUrl for route handlers, defaults to process.env.REACT_APP_BASE_URL (default: process.env.REACT_APP_BASE_URL)
      --mock-adapter [mockAdapter]         The import statement path of mock adapter, defaults to "./utils/mockAdapter" (default: ./utils/mockAdapter)
      --source, -s [folder]                The app folder path (default: ./src/app)
      --output, -o [file]                  The router file path (default: ./src/router.tsx)
  • Run in watch mode

    app-router -w -s ./src/app -o ./src/router.tsx

👶 Author

Hey, friends. I'm John Huang, a full stack developer majorly code with React, Next.js, GraphQL, TailwindCSS, Taro and SpringBoot. Feel free to contact with me 😃

🤝 Contributing

Contributions, issues and feature requests are welcome! Feel free to check issues page.

1.0.1

3 months ago

1.0.0

4 months ago

0.5.3

4 months ago

0.5.2

4 months ago

0.5.1

4 months ago

0.5.0

4 months ago

0.4.0

6 months ago

0.3.1

6 months ago

0.3.0

6 months ago

0.2.0

6 months ago

0.1.0

6 months ago