aboutsummaryrefslogtreecommitdiff
path: root/apps/web/src/contexts/MemoryContext.tsx
blob: eab1e4fe50a01b6b726c536118a9fd14d8c0680c (plain) (blame)
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
37
38
39
40
41
42
43
44
45
46
47
"use client";
import React, { useCallback } from "react";
import { CollectedSpaces } from "../../types/memory";

// temperory (will change)
export const MemoryContext = React.createContext<{
  spaces: CollectedSpaces[];
  deleteSpace: (id: number) => Promise<void>;
  addSpace: (space: CollectedSpaces) => Promise<void>;
}>({
  spaces: [],
  addSpace: async (space) => {},
  deleteSpace: async (id) => {},
});

export const MemoryProvider: React.FC<
  { spaces: CollectedSpaces[] } & React.PropsWithChildren
> = ({ children, spaces: initalSpaces }) => {
  const [spaces, setSpaces] = React.useState<CollectedSpaces[]>(initalSpaces);

  const addSpace = useCallback(
    async (space: CollectedSpaces) => {
      setSpaces((prev) => [...prev, space]);
    },
    [spaces],
  );
  const deleteSpace = useCallback(
    async (id: number) => {
      setSpaces((prev) => prev.filter((s) => s.id !== id));
    },
    [spaces],
  );

  return (
    <MemoryContext.Provider value={{ spaces, addSpace, deleteSpace }}>
      {children}
    </MemoryContext.Provider>
  );
};

export const useMemory = () => {
  const context = React.useContext(MemoryContext);
  if (context === undefined) {
    throw new Error("useMemory must be used within a MemoryProvider");
  }
  return context;
};