mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-22 17:07:58 +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,36 @@
|
||||
// Copyright 2017-2025 @pezkuwi/react-hooks authors & contributors
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
import type React from 'react';
|
||||
import type { ElementPosition } from '@pezkuwi/react-components/Popup/types';
|
||||
|
||||
import { useEffect, useState } from 'react';
|
||||
|
||||
import { createNamedHook } from './createNamedHook.js';
|
||||
import { useIsMountedRef } from './useIsMountedRef.js';
|
||||
import { useScroll } from './useScroll.js';
|
||||
import { useWindowSize } from './useWindowSize.js';
|
||||
|
||||
function useElementPositionImpl (ref: React.MutableRefObject<HTMLElement | undefined | null>): ElementPosition | undefined {
|
||||
const [elementPosition, setElementPosition] = useState<ElementPosition>();
|
||||
const mountedRef = useIsMountedRef();
|
||||
const windowSize = useWindowSize();
|
||||
const scrollY = useScroll();
|
||||
|
||||
useEffect(() => {
|
||||
if (mountedRef.current && ref?.current) {
|
||||
const { height, width, x, y } = ref.current.getBoundingClientRect();
|
||||
|
||||
setElementPosition({
|
||||
height,
|
||||
width,
|
||||
x,
|
||||
y
|
||||
});
|
||||
}
|
||||
}, [mountedRef, ref, scrollY, windowSize]);
|
||||
|
||||
return elementPosition;
|
||||
}
|
||||
|
||||
export const useElementPosition = createNamedHook('useElementPosition', useElementPositionImpl);
|
||||
Reference in New Issue
Block a user