mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-25 16:07:59 +00:00
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
This commit is contained in:
@@ -0,0 +1,43 @@
|
||||
// Copyright 2017-2025 @pezkuwi/react-hooks authors & contributors
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
// Adapted from https://hackernoon.com/simplifying-responsive-layouts-with-react-hooks-19db73893a7a
|
||||
|
||||
import type { WindowSize } from './types.js';
|
||||
|
||||
import React, { useEffect, useState } from 'react';
|
||||
|
||||
interface Props {
|
||||
children: React.ReactNode;
|
||||
}
|
||||
|
||||
function getDimensions (): WindowSize {
|
||||
return {
|
||||
height: window.innerHeight,
|
||||
width: window.innerWidth
|
||||
};
|
||||
}
|
||||
|
||||
export const WindowSizeCtx = React.createContext<WindowSize>(getDimensions());
|
||||
|
||||
export function WindowSizeCtxRoot ({ children }: Props): React.ReactElement<Props> {
|
||||
const [dimensions, setDimensions] = useState(() => getDimensions());
|
||||
|
||||
useEffect((): () => void => {
|
||||
function handleResize (): void {
|
||||
setDimensions(getDimensions());
|
||||
}
|
||||
|
||||
window.addEventListener('resize', handleResize);
|
||||
|
||||
return (): void => {
|
||||
window.removeEventListener('resize', handleResize);
|
||||
};
|
||||
}, []);
|
||||
|
||||
return (
|
||||
<WindowSizeCtx.Provider value={dimensions}>
|
||||
{children}
|
||||
</WindowSizeCtx.Provider>
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user