Skip to content

Getting started

Installation

bash
npm install mobx-route
bash
yarn add mobx-route
bash
pnpm add mobx-route

Integration with React

tsx
import { Route } from "mobx-route";
import { RouteView, Link } from "mobx-route/react";

const route = new Route('/foo/bar/:baz');

...
<RouteView route={route} view={() => <div>Hello!</div>} />
...
<Link route={route} params={{ baz: 1 }} />

Writing first routes

ts
import { Route, RouteGroup } from "mobx-route";

const feed = new Route("/");
const users = new Route("/users");
const userDetails = users.extend("/:userId");

export const routes = {
  feed,
  users,
  userDetails,
  memes: new RouteGroup({
    list: new Route("/memes", { index: true }),
    details: new Route("/memes/:memeId"),
  }),
};

Attach routes to views in React

tsx
import { observer } from "mobx-react-lite";
import { routes } from "@/shared/config/routing";
import { RouteView, Link } from "mobx-route/react";

const AllUsersPage = () => {
  return (
    <div>
      <Link route={routes.userDetails} params={{ userId: 1 }}>
        Open user with id 1
      </Link>
    </div>
  );
};

const UserDetailsPage = observer(() => {
  const { params } = routes.userDetails.data!;

  return <div>{`User id: ${params.userId}`}</div>;
});

export const App = () => {
  return (
    <div>
      <RouteView route={routes.userDetails} view={AllUsersPage} />
      <RouteView route={routes.users} view={UserDetailsPage} />
    </div>
  );
};

Released under the MIT License.