aboutsummaryrefslogtreecommitdiff
path: root/src/pages/Demographics.tsx
blob: 1130ef451e52bcaecdd764c07647cb8cc015147c (plain)
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
import React from "react";
import {useSelector} from "react-redux";
import {selectUserAge, selectUserGender, selectUserUpkAnswers, selectUserZip} from "@/models/userUpkAnswerSlice.ts";
import {titleCase} from "@/lib/utils.ts";

import {Card, CardContent, CardHeader} from "@/components/ui/card";
import {Calendar, MapPin, User} from "lucide-react";
import {BucketTask} from "@/api";
import {ColumnDef, flexRender, getCoreRowModel, useReactTable} from "@tanstack/react-table";
import {Table, TableBody, TableCell, TableHead, TableHeader, TableRow} from "@/components/ui/table.tsx";

export const UpkGrid = () => {

    const columns: ColumnDef<BucketTask>[] = [
        {
            accessorKey: "property_label",
            header: "Label",
        },
        {
            accessorKey: "answer",
            header: "Answer",
            cell: ({getValue}) => getValue()[0].value ?? getValue()[0].label
        },
    ]

    const data = useSelector(selectUserUpkAnswers)

    const table = useReactTable({
        data,
        columns,
        getCoreRowModel: getCoreRowModel(),
    })

    return (
        <div className="border rounded-md mt-6">
            <Table>
                <TableHeader>
                    {table.getHeaderGroups().map((headerGroup) => (
                        <TableRow key={headerGroup.id}>
                            {headerGroup.headers.map((header) => {
                                return (
                                    <TableHead key={header.id}>
                                        {header.isPlaceholder
                                            ? null
                                            : flexRender(
                                                header.column.columnDef.header,
                                                header.getContext()
                                            )}
                                    </TableHead>
                                )
                            })}
                        </TableRow>
                    ))}
                </TableHeader>

                <TableBody>
                    {
                        table.getRowModel().rows.map((row) => (
                            <TableRow
                                key={row.id}
                                data-state={row.getIsSelected() && "selected"}
                            >
                                {row.getVisibleCells().map((cell) => (
                                    <TableCell key={cell.id}>
                                        {flexRender(cell.column.columnDef.cell, cell.getContext())}
                                    </TableCell>
                                ))}
                            </TableRow>
                        ))
                    }
                </TableBody>
            </Table>
        </div>
    )
}

export const ContactCard = () => {

    const age = useSelector(selectUserAge)
    const zip = useSelector(selectUserZip)
    const gender = useSelector(selectUserGender)

    return (
        <Card className="w-full max-w-sm shadow-md rounded-2xl p-4">
            <CardHeader className="flex items-center space-x-4">
                <div className="w-16 h-16 rounded-full bg-gray-200 flex items-center justify-center">
                    <User className="text-gray-500"/>
                </div>
            </CardHeader>

            <CardContent className="space-y-2 pt-2">
                <div className="flex items-center space-x-2 text-sm text-muted-foreground">
                    <User className="w-4 h-4"/>
                    <span>{titleCase(gender as string) ?? " - "}</span>
                </div>
                <div className="flex items-center space-x-2 text-sm text-muted-foreground">
                    <Calendar className="w-4 h-4"/>
                    <span>{age ?? " - "} years old</span>
                </div>
                <div className="flex items-center space-x-2 text-sm text-muted-foreground">
                    <MapPin className="w-4 h-4"/>
                    <span>{zip ?? " - "}</span>
                </div>
            </CardContent>
        </Card>
    );
};


const Demographics = () => {

    return (
        <>
            <ContactCard/>
            <UpkGrid />
        </>
    )
}

export {
    Demographics
}