Files
pezkuwi-apps/packages/page-settings/src/index.tsx
T
pezkuwichain d21bfb1320 feat: initial Pezkuwi Apps rebrand from polkadot-apps
Rebranded terminology:
- Polkadot → Pezkuwi
- Kusama → Dicle
- Westend → Zagros
- Rococo → PezkuwiChain
- Substrate → Bizinikiwi
- parachain → teyrchain

Custom logos with Kurdistan brand colors (#e6007a → #86e62a):
- bizinikiwi-hexagon.svg
- sora-bizinikiwi.svg
- hezscanner.svg
- heztreasury.svg
- pezkuwiscan.svg
- pezkuwistats.svg
- pezkuwiassembly.svg
- pezkuwiholic.svg
2026-01-07 13:05:27 +03:00

96 lines
2.2 KiB
TypeScript

// Copyright 2017-2025 @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);