Spaces:
Running
Running
File size: 645 Bytes
843fee0 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
import { useEffect, useState } from "react";
import { createDb } from "~/duck";
export const useDuckDb = () => {
const [db, setDb] = useState<Awaited<ReturnType<typeof createDb>> | null>(
null
);
useEffect(() => {
const status = {
killed: false,
};
const initDb = async () => {
const db = await createDb();
if (status.killed) {
db.terminate();
return;
}
setDb(db);
};
initDb();
return () => {
status.killed = true;
setDb((db) => {
if (db) {
db.terminate();
}
return null;
});
};
}, []);
return db;
};
|