1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00
unleash.unleash/frontend/src/hooks/useLoading.ts
Nuno Góis 4167a60588
feat: biome lint frontend (#4903)
Follows up on https://github.com/Unleash/unleash/pull/4853 to add Biome
to the frontend as well.


![image](https://github.com/Unleash/unleash/assets/14320932/1906faf1-fc29-4172-a4d4-b2716d72cd65)

Added a few `biome-ignore` to speed up the process but we may want to
check and fix them in the future.
2023-10-02 13:25:46 +01:00

25 lines
660 B
TypeScript

import { createRef, useLayoutEffect } from 'react';
type refElement = HTMLDivElement;
const useLoading = (loading: boolean, selector = '[data-loading=true]') => {
const ref = createRef<refElement>();
useLayoutEffect(() => {
if (ref.current) {
const elements = ref.current.querySelectorAll(selector);
elements.forEach((element) => {
if (loading) {
element.classList.add('skeleton');
} else {
element.classList.remove('skeleton');
}
});
}
}, [loading, ref]);
return ref;
};
export default useLoading;