saleor-dashboard/src/apps/apps-routing.tsx
Lukasz Ostrowski 58a3c26f7e
src/apps refactors batch (#3773)
* Add refactors to apps folder

Remove default exports in apps/views

Rename apps/views components, ensure they have similar convention

Refactor apps indexes files

Rename marketplace mentions to appstore

Rename useMarketplaceApps to useAppstoreApps

Rename some marketplace mentions to appstore

fix test

* Add changeset
2023-06-27 09:29:40 +02:00

71 lines
1.9 KiB
TypeScript

import {
AppDetailsUrlQueryParams,
AppInstallUrlQueryParams,
} from "@dashboard/apps/urls";
import { sectionNames } from "@dashboard/intl";
import { parse as parseQs } from "qs";
import React from "react";
import { useIntl } from "react-intl";
import { Route, RouteComponentProps, Switch } from "react-router-dom";
import {
AppInstallView,
AppListView,
AppManageView,
AppView,
} from "src/apps/views";
import { WindowTitle } from "../components/WindowTitle";
import { AppListUrlQueryParams, AppPaths } from "./urls";
const AppManageRoute: React.FC<RouteComponentProps<{ id: string }>> = ({
match,
}) => {
const qs = parseQs(location.search.substr(1));
const params: AppDetailsUrlQueryParams = qs;
return (
<AppManageView id={decodeURIComponent(match.params.id)} params={params} />
);
};
const AppViewRoute: React.FC<RouteComponentProps<{ id: string }>> = ({
match,
}) => <AppView id={decodeURIComponent(match.params.id)} />;
const AppInstallRoute: React.FC<RouteComponentProps> = props => {
const qs = parseQs(location.search.substr(1));
const params: AppInstallUrlQueryParams = qs;
return <AppInstallView params={params} {...props} />;
};
const AppListRoute: React.FC<RouteComponentProps> = () => {
const qs = parseQs(location.search.substr(1));
const params: AppListUrlQueryParams = qs;
return <AppListView params={params} />;
};
export const AppsSectionRoot = () => {
const intl = useIntl();
return (
<>
<WindowTitle title={intl.formatMessage(sectionNames.apps)} />
<Switch>
<Route exact path={AppPaths.appListPath} component={AppListRoute} />
<Route
exact
path={AppPaths.appInstallPath}
component={AppInstallRoute}
/>
<Route
exact
path={AppPaths.resolveAppDetailsPath(":id")}
component={AppManageRoute}
/>
<Route path={AppPaths.resolveAppPath(":id")} component={AppViewRoute} />
</Switch>
</>
);
};