mirror of
https://github.com/makeplane/plane.git
synced 2025-12-21 06:09:31 +01:00
* [WEB-1116] feat: pages realtime sync (#5057) * init: live server for editor realtime sync * chore: authentication added * chore: updated logic to convert html to binary for old pages * chore: added description json on page update * chore: made all functions generic * chore: save description in json and html formats * refactor: document editor components * chore: uncomment ui package components * fix: without props extensions refactor * fix: merge conflicts resolved from preview * chore: init docker compose * chore: pages custom error codes * chore: add health check endpoint to the live server * chore: update without props extensions type * chore: better error handling * chore: update react-hook-form versions --------- Co-authored-by: NarayanBavisetti <narayan3119@gmail.com> Co-authored-by: sriram veeraghanta <veeraghanta.sriram@gmail.com> * fix: docker related fixes * fix: module type fixes * fix: nginx update * fix: adding live server workflow * fix: workflow fixes * fix: docker compose fixes * fix: workflow fixes * fix: path config * fix: docker compose warnings * fix: nginx port forwarding * fix: update docker compose with new env * fix: env var fixes * fix: error handling * fix: docker compose env var * fix: compose fixes * chore: update server start message * chore: handle errors * fix: build errors * chore: update port * chore: update server port * chore: show error on authentication fail * chore: show error on authentication fail * feat: add redis extension * chore: updated restore version logic --------- Co-authored-by: NarayanBavisetti <narayan3119@gmail.com> Co-authored-by: sriram veeraghanta <veeraghanta.sriram@gmail.com> Co-authored-by: Palanikannan M <akashmalinimurugu@gmail.com>
23 lines
627 B
TypeScript
23 lines
627 B
TypeScript
import { useState, useEffect } from "react";
|
|
|
|
const useOnlineStatus = () => {
|
|
// states
|
|
const [isOnline, setIsOnline] = useState(typeof navigator !== "undefined" ? navigator.onLine : true);
|
|
|
|
const updateOnlineStatus = () => setIsOnline(navigator.onLine);
|
|
|
|
useEffect(() => {
|
|
window.addEventListener("online", updateOnlineStatus);
|
|
window.addEventListener("offline", updateOnlineStatus);
|
|
|
|
return () => {
|
|
window.removeEventListener("online", updateOnlineStatus);
|
|
window.removeEventListener("offline", updateOnlineStatus);
|
|
};
|
|
}, []);
|
|
|
|
return { isOnline };
|
|
};
|
|
|
|
export default useOnlineStatus;
|