mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-28 22:57:56 +00:00
96 lines
2.2 KiB
TypeScript
96 lines
2.2 KiB
TypeScript
// Copyright 2017-2026 @pezkuwi/app-settings authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { AppProps as Props } from '@pezkuwi/react-components/types';
|
|
|
|
import React, { useMemo } from 'react';
|
|
import { Route, Routes } from 'react-router';
|
|
|
|
import { Tabs } from '@pezkuwi/react-components';
|
|
import { useApi } from '@pezkuwi/react-hooks';
|
|
|
|
import I18n from './I18n/index.js';
|
|
import Metadata from './Metadata/index.js';
|
|
import Developer from './Developer.js';
|
|
import General from './General.js';
|
|
import { useTranslation } from './translate.js';
|
|
import useCounter from './useCounter.js';
|
|
|
|
export { useCounter };
|
|
|
|
function SettingsApp ({ basePath, onStatusChange }: Props): React.ReactElement<Props> {
|
|
const { t } = useTranslation();
|
|
const { api, isApiConnected, isApiReady, isDevelopment } = useApi();
|
|
const numExtensions = useCounter();
|
|
|
|
const items = useMemo(() => [
|
|
{
|
|
isRoot: true,
|
|
name: 'general',
|
|
text: t('General')
|
|
},
|
|
{
|
|
count: numExtensions,
|
|
name: 'metadata',
|
|
text: t('Metadata')
|
|
},
|
|
{
|
|
name: 'developer',
|
|
text: t('Developer')
|
|
},
|
|
{
|
|
name: 'i18n',
|
|
text: t('Translate')
|
|
}
|
|
], [numExtensions, t]);
|
|
|
|
const hidden = useMemo(
|
|
() => (isApiConnected && isApiReady)
|
|
? isDevelopment || (api.runtimeMetadata.version <= 13)
|
|
? []
|
|
: ['developer']
|
|
: ['metadata', 'i18n'],
|
|
[api, isApiConnected, isApiReady, isDevelopment]
|
|
);
|
|
|
|
return (
|
|
<main className='settings--App'>
|
|
<Tabs
|
|
basePath={basePath}
|
|
hidden={hidden}
|
|
items={items}
|
|
/>
|
|
<Routes>
|
|
<Route path={basePath}>
|
|
<Route
|
|
element={
|
|
<Developer onStatusChange={onStatusChange} />
|
|
}
|
|
path='developer'
|
|
/>
|
|
<Route
|
|
element={
|
|
<I18n />
|
|
}
|
|
path='i18n'
|
|
/>
|
|
<Route
|
|
element={
|
|
<Metadata />
|
|
}
|
|
path='metadata'
|
|
/>
|
|
<Route
|
|
element={
|
|
<General />
|
|
}
|
|
index
|
|
/>
|
|
</Route>
|
|
</Routes>
|
|
</main>
|
|
);
|
|
}
|
|
|
|
export default React.memo(SettingsApp);
|