Refactor new user command
This commit is contained in:
parent
db2def5388
commit
8623eb8dfd
19
src/Main.elm
19
src/Main.elm
|
@ -111,6 +111,12 @@ update msg model = case msg of
|
||||||
requestScrollCmd : Cmd Msg
|
requestScrollCmd : Cmd Msg
|
||||||
requestScrollCmd = Task.attempt ViewportAfterMessage (Browser.Dom.getViewportOf "messages-wrapper")
|
requestScrollCmd = Task.attempt ViewportAfterMessage (Browser.Dom.getViewportOf "messages-wrapper")
|
||||||
|
|
||||||
|
newUsersCmd : Model -> List Username -> Cmd Msg
|
||||||
|
newUsersCmd m us = m.token
|
||||||
|
|> Maybe.map (\t -> List.map (userData m.apiUrl t) us)
|
||||||
|
|> Maybe.withDefault []
|
||||||
|
|> Cmd.batch
|
||||||
|
|
||||||
updateSendRoomTextResponse : Model -> Int -> Result Http.Error String -> (Model, Cmd Msg)
|
updateSendRoomTextResponse : Model -> Int -> Result Http.Error String -> (Model, Cmd Msg)
|
||||||
updateSendRoomTextResponse m t r =
|
updateSendRoomTextResponse m t r =
|
||||||
let
|
let
|
||||||
|
@ -173,15 +179,14 @@ updateUploadSelected m rid f fs msg =
|
||||||
updateHistoryResponse : Model -> RoomId -> Result Http.Error HistoryResponse -> (Model, Cmd Msg)
|
updateHistoryResponse : Model -> RoomId -> Result Http.Error HistoryResponse -> (Model, Cmd Msg)
|
||||||
updateHistoryResponse m r hr =
|
updateHistoryResponse m r hr =
|
||||||
let
|
let
|
||||||
newUsersCmd h = Cmd.batch
|
userDataCmd h = newUsersCmd m
|
||||||
<| List.map (userData m.apiUrl (Maybe.withDefault "" m.token))
|
|
||||||
<| newUsers m
|
<| newUsers m
|
||||||
<| uniqueBy (\s -> s)
|
<| uniqueBy identity
|
||||||
<| List.map .sender
|
<| List.map .sender
|
||||||
<| h.chunk
|
<| h.chunk
|
||||||
in
|
in
|
||||||
case hr of
|
case hr of
|
||||||
Ok h -> ({ m | sync = appendHistoryResponse m.sync r h }, newUsersCmd h)
|
Ok h -> ({ m | sync = appendHistoryResponse m.sync r h }, userDataCmd h)
|
||||||
Err _ -> ({ m | errors = "Unable to load older history from server"::m.errors }, Cmd.none)
|
Err _ -> ({ m | errors = "Unable to load older history from server"::m.errors }, Cmd.none)
|
||||||
|
|
||||||
updateHistory : Model -> RoomId -> (Model, Cmd Msg)
|
updateHistory : Model -> RoomId -> (Model, Cmd Msg)
|
||||||
|
@ -307,9 +312,7 @@ updateSyncResponse model r notify =
|
||||||
nextBatch = Result.withDefault model.sync.nextBatch
|
nextBatch = Result.withDefault model.sync.nextBatch
|
||||||
<| Result.map .nextBatch r
|
<| Result.map .nextBatch r
|
||||||
syncCmd = sync model.apiUrl token nextBatch
|
syncCmd = sync model.apiUrl token nextBatch
|
||||||
newUserCmd sr = Cmd.batch
|
userDataCmd sr = newUsersCmd model
|
||||||
<| List.map (userData model.apiUrl
|
|
||||||
<| Maybe.withDefault "" model.token)
|
|
||||||
<| newUsers model
|
<| newUsers model
|
||||||
<| allUsers sr
|
<| allUsers sr
|
||||||
notification sr = findFirstBy
|
notification sr = findFirstBy
|
||||||
|
@ -354,7 +357,7 @@ updateSyncResponse model r notify =
|
||||||
Ok sr -> (newModel sr
|
Ok sr -> (newModel sr
|
||||||
, Cmd.batch
|
, Cmd.batch
|
||||||
[ syncCmd
|
[ syncCmd
|
||||||
, newUserCmd sr
|
, userDataCmd sr
|
||||||
, notificationCmd sr
|
, notificationCmd sr
|
||||||
, setScrollCmd sr
|
, setScrollCmd sr
|
||||||
, setReadReceiptCmd sr
|
, setReadReceiptCmd sr
|
||||||
|
|
Loading…
Reference in New Issue
Block a user