Files
pwap/pezkuwi-sdk-ui/packages/react-components/src/ErrorBoundary.tsx
T
pezkuwichain 971df8edba Rebrand: Remove 3rd party chains, update domains to PezkuwiChain
- Remove all 3rd party parachain configurations from endpoints:
  - productionRelayPolkadot.ts: Keep only system parachains
  - productionRelayDicle.ts: Keep only system parachains
  - testingRelayZagros.ts: Keep only system parachains
  - testingRelayTeyrChain.ts: Keep only system parachains

- Update domain references:
  - polkadot.js.org → pezkuwichain.app
  - wiki.polkadot.network → wiki.pezkuwichain.io
  - dotapps.io → pezkuwichain.app
  - statement.polkadot.network → docs.pezkuwichain.io/statement
  - support.polkadot.network → docs.pezkuwichain.io

- Update repository references:
  - github.com/pezkuwi-js/apps → github.com/pezkuwichain/pwap

- Rename system parachains to Pezkuwi ecosystem:
  - PolkadotAssetHub → PezkuwiAssetHub
  - polkadotBridgeHub → pezkuwiBridgeHub
  - polkadotCollectives → pezkuwiCollectives
  - polkadotCoretime → pezkuwiCoretime
  - polkadotPeople → pezkuwiPeople

- Update network name in claims utility:
  - Polkadot → Pezkuwi
2026-01-09 03:08:11 +03:00

75 lines
2.0 KiB
TypeScript

// Copyright 2017-2026 @pezkuwi/react-components authors & contributors
// SPDX-License-Identifier: Apache-2.0
import type { I18nProps } from './types.js';
import React from 'react';
import translate from './translate.js';
interface Props extends I18nProps {
children: React.ReactNode;
doThrow?: boolean;
error?: Error | null;
onError?: () => void;
trigger?: unknown;
}
interface State {
error: Error | null;
prevTrigger: string | null;
}
function formatStack (stack = '<unknown>'): React.ReactElement | null {
return (
<>{stack.split('\n').map((line, index) =>
<div key={index}>{line}</div>
)}</>
);
}
// NOTE: This is the only way to do an error boundary, via extend
class ErrorBoundary extends React.Component<Props> {
public override state: State = { error: null, prevTrigger: null };
static getDerivedStateFromError (error: Error): Partial<State> {
return { error };
}
static getDerivedStateFromProps ({ trigger }: Props, { prevTrigger }: State): State | null {
const newTrigger = JSON.stringify({ trigger });
return (prevTrigger !== newTrigger)
? { error: null, prevTrigger: newTrigger }
: null;
}
public override componentDidCatch (error: Error): void {
const { doThrow, onError } = this.props;
onError && onError();
if (doThrow) {
throw error;
}
}
public override render (): React.ReactNode {
const { children, error: errorProps, t } = this.props;
const { error } = this.state;
const displayError = errorProps || error;
return displayError
? (
<article className='error extraMargin'>
<p>{t('Uncaught error. Something went wrong with the query and rendering of this component. Please supply all the details below when logging an issue, it may help in tracing the cause.')}</p>
<p>{displayError.message}</p>
{formatStack(displayError.stack)}
</article>
)
: children;
}
}
export default translate<Props>(ErrorBoundary);