mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2024-10-31 22:18:52 +00:00
230 lines
5.6 KiB
TypeScript
230 lines
5.6 KiB
TypeScript
/*
|
|
GoToSocial
|
|
Copyright (C) GoToSocial Authors admin@gotosocial.org
|
|
SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Affero General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Affero General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import { MenuItem } from "../../lib/navigation/menu";
|
|
import React, { lazy, Suspense } from "react";
|
|
import { BaseUrlContext, useBaseUrl, useHasPermission } from "../../lib/navigation/util";
|
|
import { Redirect, Route, Router, Switch } from "wouter";
|
|
import { ReportOverview } from "./reports/overview";
|
|
import ReportDetail from "./reports/detail";
|
|
import { ErrorBoundary } from "../../lib/navigation/error";
|
|
import Loading from "../../components/loading";
|
|
|
|
/*
|
|
EXPORTED COMPONENTS
|
|
*/
|
|
|
|
/**
|
|
* Moderation menu. Reports, accounts,
|
|
* domain permissions import + export.
|
|
*/
|
|
export function ModerationMenu() {
|
|
return (
|
|
<MenuItem
|
|
name="Moderation"
|
|
itemUrl="moderation"
|
|
defaultChild="reports"
|
|
permissions={["moderator"]}
|
|
>
|
|
<ModerationReportsMenu />
|
|
<ModerationAccountsMenu />
|
|
<ModerationDomainPermsMenu />
|
|
</MenuItem>
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Moderation router. Reports, accounts,
|
|
* domain permissions import + export.
|
|
*/
|
|
export function ModerationRouter() {
|
|
const parentUrl = useBaseUrl();
|
|
const thisBase = "/moderation";
|
|
const absBase = parentUrl + thisBase;
|
|
|
|
// Don't route if logged-in user
|
|
// doesn't have permissions to access.
|
|
if (!useHasPermission(["moderator"])) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<BaseUrlContext.Provider value={absBase}>
|
|
<Router base={thisBase}>
|
|
<ModerationReportsRouter />
|
|
<ModerationAccountsRouter />
|
|
<ModerationDomainPermsRouter />
|
|
</Router>
|
|
</BaseUrlContext.Provider>
|
|
);
|
|
}
|
|
|
|
/*
|
|
INTERNAL COMPONENTS
|
|
*/
|
|
|
|
/*
|
|
MENUS
|
|
*/
|
|
|
|
function ModerationReportsMenu() {
|
|
return (
|
|
<MenuItem
|
|
name="Reports"
|
|
itemUrl="reports"
|
|
icon="fa-flag"
|
|
/>
|
|
);
|
|
}
|
|
|
|
function ModerationAccountsMenu() {
|
|
return (
|
|
<MenuItem
|
|
name="Accounts"
|
|
itemUrl="accounts"
|
|
defaultChild="overview"
|
|
icon="fa-users"
|
|
>
|
|
<MenuItem
|
|
name="Overview"
|
|
itemUrl="overview"
|
|
icon="fa-list"
|
|
/>
|
|
<MenuItem
|
|
name="Pending"
|
|
itemUrl="pending"
|
|
icon="fa-question"
|
|
/>
|
|
</MenuItem>
|
|
);
|
|
}
|
|
|
|
function ModerationDomainPermsMenu() {
|
|
return (
|
|
<MenuItem
|
|
name="Domain Permissions"
|
|
itemUrl="domain-permissions"
|
|
defaultChild="blocks"
|
|
icon="fa-hubzilla"
|
|
>
|
|
<MenuItem
|
|
name="Blocks"
|
|
itemUrl="blocks"
|
|
icon="fa-close"
|
|
/>
|
|
<MenuItem
|
|
name="Allows"
|
|
itemUrl="allows"
|
|
icon="fa-check"
|
|
/>
|
|
<MenuItem
|
|
name="Import/Export"
|
|
itemUrl="import-export"
|
|
icon="fa-floppy-o"
|
|
/>
|
|
</MenuItem>
|
|
);
|
|
}
|
|
|
|
/*
|
|
ROUTERS
|
|
*/
|
|
|
|
function ModerationReportsRouter() {
|
|
const parentUrl = useBaseUrl();
|
|
const thisBase = "/reports";
|
|
const absBase = parentUrl + thisBase;
|
|
|
|
return (
|
|
<BaseUrlContext.Provider value={absBase}>
|
|
<Router base={thisBase}>
|
|
<Switch>
|
|
<Route path={"/:reportId"} component={ReportDetail} />
|
|
<Route component={ReportOverview}/>
|
|
</Switch>
|
|
</Router>
|
|
</BaseUrlContext.Provider>
|
|
);
|
|
}
|
|
|
|
/**
|
|
* - /settings/moderation/accounts/overview
|
|
* - /settings/moderation/accounts/pending
|
|
* - /settings/moderation/accounts/:accountID
|
|
*/
|
|
function ModerationAccountsRouter() {
|
|
const parentUrl = useBaseUrl();
|
|
const thisBase = "/accounts";
|
|
const absBase = parentUrl + thisBase;
|
|
|
|
const AccountsOverview = lazy(() => import('./accounts'));
|
|
const AccountsPending = lazy(() => import('./accounts/pending'));
|
|
const AccountDetail = lazy(() => import('./accounts/detail'));
|
|
|
|
return (
|
|
<BaseUrlContext.Provider value={absBase}>
|
|
<Router base={thisBase}>
|
|
<ErrorBoundary>
|
|
<Suspense fallback={<Loading/>}>
|
|
<Switch>
|
|
<Route path="/overview" component={AccountsOverview}/>
|
|
<Route path="/pending" component={AccountsPending}/>
|
|
<Route path="/:accountID" component={AccountDetail}/>
|
|
<Route><Redirect to="/overview"/></Route>
|
|
</Switch>
|
|
</Suspense>
|
|
</ErrorBoundary>
|
|
</Router>
|
|
</BaseUrlContext.Provider>
|
|
);
|
|
}
|
|
|
|
/**
|
|
* - /settings/moderation/domain-permissions/:permType
|
|
* - /settings/moderation/domain-permissions/:permType/:domain
|
|
* - /settings/moderation/domain-permissions/import-export
|
|
* - /settings/moderation/domain-permissions/process
|
|
*/
|
|
function ModerationDomainPermsRouter() {
|
|
const parentUrl = useBaseUrl();
|
|
const thisBase = "/domain-permissions";
|
|
const absBase = parentUrl + thisBase;
|
|
|
|
const DomainPermissionsOverview = lazy(() => import('./domain-permissions/overview'));
|
|
const DomainPermDetail = lazy(() => import('./domain-permissions/detail'));
|
|
const ImportExport = lazy(() => import('./domain-permissions/import-export'));
|
|
|
|
return (
|
|
<BaseUrlContext.Provider value={absBase}>
|
|
<Router base={thisBase}>
|
|
<ErrorBoundary>
|
|
<Suspense fallback={<Loading/>}>
|
|
<Switch>
|
|
<Route path="/import-export" component={ImportExport} />
|
|
<Route path="/process" component={ImportExport} />
|
|
<Route path="/:permType" component={DomainPermissionsOverview} />
|
|
<Route path="/:permType/:domain" component={DomainPermDetail} />
|
|
<Route><Redirect to="/blocks"/></Route>
|
|
</Switch>
|
|
</Suspense>
|
|
</ErrorBoundary>
|
|
</Router>
|
|
</BaseUrlContext.Provider>
|
|
);
|
|
}
|