mirror of
https://github.com/dillonkearns/elm-pages-v3-beta.git
synced 2024-12-22 19:31:39 +03:00
108 lines
2.5 KiB
Elm
108 lines
2.5 KiB
Elm
module Route.FileUpload exposing (Data, Model, Msg, page)
|
|
|
|
import DataSource exposing (DataSource)
|
|
import Head
|
|
import Head.Seo as Seo
|
|
import Html
|
|
import Html.Attributes as Attr
|
|
import Pages.PageUrl exposing (PageUrl)
|
|
import Pages.Url
|
|
import RouteBuilder exposing (StatelessRoute, StaticPayload)
|
|
import Server.Request as Request
|
|
import Server.Response
|
|
import Shared
|
|
import View exposing (View)
|
|
|
|
|
|
type alias Model =
|
|
{}
|
|
|
|
|
|
type alias Msg =
|
|
()
|
|
|
|
|
|
type alias RouteParams =
|
|
{}
|
|
|
|
|
|
page : StatelessRoute RouteParams Data
|
|
page =
|
|
RouteBuilder.serverRender
|
|
{ head = head
|
|
, data = data
|
|
}
|
|
|> RouteBuilder.buildNoState { view = view }
|
|
|
|
|
|
type alias Data =
|
|
Maybe Request.File
|
|
|
|
|
|
data : RouteParams -> Request.Request (DataSource (Server.Response.Response Data))
|
|
data routeParams =
|
|
Request.oneOf
|
|
[ Request.expectMultiPartFormPost
|
|
(\{ field, optionalField, fileField } ->
|
|
fileField "file"
|
|
)
|
|
|> Request.map
|
|
(\file ->
|
|
DataSource.succeed (Server.Response.render (Just file))
|
|
)
|
|
, Request.succeed
|
|
(DataSource.succeed (Server.Response.render Nothing))
|
|
]
|
|
|
|
|
|
head :
|
|
StaticPayload Data RouteParams
|
|
-> List Head.Tag
|
|
head static =
|
|
Seo.summary
|
|
{ canonicalUrlOverride = Nothing
|
|
, siteName = "elm-pages"
|
|
, image =
|
|
{ url = Pages.Url.external "TODO"
|
|
, alt = "elm-pages logo"
|
|
, dimensions = Nothing
|
|
, mimeType = Nothing
|
|
}
|
|
, description = "TODO"
|
|
, locale = Nothing
|
|
, title = "TODO title" -- metadata.title -- TODO
|
|
}
|
|
|> Seo.website
|
|
|
|
|
|
view :
|
|
Maybe PageUrl
|
|
-> Shared.Model
|
|
-> StaticPayload Data RouteParams
|
|
-> View Msg
|
|
view maybeUrl sharedModel static =
|
|
{ title = "File Upload"
|
|
, body =
|
|
[ static.data
|
|
|> Maybe.map
|
|
(\file ->
|
|
Html.div []
|
|
[ Html.h1 [] [ Html.text "Got file" ]
|
|
, Html.p [] [ Html.text file.name ]
|
|
]
|
|
)
|
|
|> Maybe.withDefault (Html.text "No file uploaded. Choose a file to get started.")
|
|
, Html.form [ Attr.method "POST", Attr.enctype "multipart/form-data" ]
|
|
[ Html.input
|
|
[ Attr.type_ "file"
|
|
, Attr.name "file"
|
|
]
|
|
[]
|
|
, Html.input
|
|
[ Attr.type_ "submit"
|
|
]
|
|
[]
|
|
]
|
|
]
|
|
}
|