aboutsummaryrefslogtreecommitdiffstats
path: root/apps/mobile/app/dashboard/(tabs)/lists.tsx
blob: a293757b8eb775a1472f33e9bc2decbdd9e8c655 (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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
import { useEffect, useState } from "react";
import { FlatList, View } from "react-native";
import { Link } from "expo-router";
import { api } from "@/lib/trpc";

export default function Lists() {
  const [refreshing, setRefreshing] = useState(false);
  const { data: lists, isPending } = api.lists.list.useQuery();
  const apiUtils = api.useUtils();

  useEffect(() => {
    setRefreshing(isPending);
  }, [isPending]);

  if (!lists) {
    // Add spinner
    return <View />;
  }

  const onRefresh = () => {
    apiUtils.lists.list.invalidate();
  };

  const links = [
    {
      id: "fav",
      logo: "⭐️",
      name: "Favourites",
      href: "/dashboard/favourites",
    },
    {
      id: "arch",
      logo: "🗄️",
      name: "Archive",
      href: "/dashboard/archive",
    },
  ];

  links.push(
    ...lists.lists.map((l) => ({
      id: l.id,
      logo: l.icon,
      name: l.name,
      href: `/dashboard/lists/${l.id}`,
    })),
  );

  return (
    <FlatList
      contentContainerStyle={{
        gap: 10,
        marginTop: 10,
      }}
      renderItem={(l) => (
        <View className="mx-2 block rounded-xl border border-gray-100 bg-white px-4 py-2">
          <Link key={l.item.id} href={l.item.href} className="text-lg">
            {l.item.logo} {l.item.name}
          </Link>
        </View>
      )}
      data={links}
      refreshing={refreshing}
      onRefresh={onRefresh}
    />
  );
}