about summary refs log tree commit diff
path: root/client/src/Admin.elm
blob: 3c0f221d93ed30f857d1170e46557dcf4175c4d3 (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
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
module Admin exposing (render)

import Html exposing (..)
import Html.Attributes exposing (..)
import Html.Events exposing (..)
import RemoteData
import State
import Tailwind
import UI
import Utils


allUsers : State.Model -> Html State.Msg
allUsers model =
    case model.users of
        RemoteData.NotAsked ->
            UI.absentData { handleFetch = State.AttemptGetUsers }

        RemoteData.Loading ->
            UI.paragraph "Loading..."

        RemoteData.Failure e ->
            UI.paragraph ("Error: " ++ Utils.explainHttpError e)

        RemoteData.Success xs ->
            div []
                [ UI.header 3 "Admins"
                , users xs.admin
                , UI.header 3 "Managers"
                , users xs.manager
                , UI.header 3 "Users"
                , users xs.user
                ]


users : List String -> Html State.Msg
users xs =
    ul []
        (xs
            |> List.map
                (\x ->
                    li [ [ "py-4", "flex" ] |> Tailwind.use |> class ]
                        [ p [ [ "flex-1" ] |> Tailwind.use |> class ] [ text x ]
                        , div [ [ "flex-1" ] |> Tailwind.use |> class ]
                            [ UI.simpleButton
                                { label = "Delete"
                                , handleClick = State.AttemptDeleteUser x
                                }
                            ]
                        ]
                )
        )


render : State.Model -> Html State.Msg
render model =
    div
        [ [ "container"
          , "mx-auto"
          , "text-center"
          ]
            |> Tailwind.use
            |> class
        ]
        [ UI.header 2 "Welcome back!"
        , UI.simpleButton
            { label = "Logout"
            , handleClick = State.AttemptLogout
            }
        , div []
            [ UI.baseButton
                { label = "Switch to users"
                , handleClick = State.UpdateAdminTab State.Users
                , enabled = not (model.adminTab == State.Users)
                , extraClasses = []
                }
            ]
        , case model.adminTab of
            State.Users ->
                allUsers model
        , case model.logoutError of
            Nothing ->
                text ""

            Just e ->
                UI.errorBanner
                    { title = "Error logging out"
                    , body = Utils.explainHttpError e
                    }
        , case model.deleteUserError of
            Nothing ->
                text ""

            Just e ->
                UI.errorBanner
                    { title = "Error attempting to delete user"
                    , body = Utils.explainHttpError e
                    }
        ]