From 4801593c898b48ec6f0040677d87c6c5d47eaeb6 Mon Sep 17 00:00:00 2001 From: KtorZ Date: Mon, 3 Sep 2018 22:12:14 +0200 Subject: [PATCH] Review examples and the way they're built This to avoid having to carry unneeded dependencies in the library. I use a symlink as a trick to make the module available to the examples without having to require it explicitly as a dependency This commit also makes 'deploy.sh' less verbose & fix example publication - If the tag doesn't already exist, it displays an error message in the console which we ought to ignore. - Also, the publication to gh-pages was completely broken. It will now nicely create a single commit with only the exported artefacts and get back to master. Finally, we are making examples a bit more sexy - Review overall look-and-feel (colors, fonts, sizes, etc.) - Remove the 'clientId' input and hard-code a demo clientId - Display current 'Model' next to the actual content --- deploy.sh | 21 ++-- examples/elm.json | 27 +++++ examples/images/google.png | Bin 10841 -> 0 bytes examples/implicit/Main.elm | 209 ++++++++++++++++++++++++------------- examples/src | 1 + 5 files changed, 176 insertions(+), 82 deletions(-) create mode 100644 examples/elm.json delete mode 100644 examples/images/google.png create mode 120000 examples/src diff --git a/deploy.sh b/deploy.sh index 818f49e..08db4ed 100755 --- a/deploy.sh +++ b/deploy.sh @@ -27,19 +27,24 @@ else fi ## Create tag and publish -git tag -d $version +git tag -d $version 1>/dev/null 2>&1 git tag -a $version -m "release version $version" && git push origin $version elm publish || exit 1 + ## Deploy examples git checkout "gh-pages" || exit 1 -for d in examples/*; do - if [ "$d" != "examples/images" ]; then - elm make "$d/Main.elm" - mv index.html $d - fi +git merge --squash - +git commit -m "tmp" +cd examples +for d in $(find . -type d ! -path '*elm-stuff*' ! -name '.') ; do + elm make --optimize --output $d/index.html "$d/Main.elm" + git add -f $d/index.html done -git add . && git commit -m "release version $version" -git push origin HEAD && git checkout - +git commit -m "release version $version" +git rebase HEAD~ --onto HEAD~2 +git push origin HEAD +git checkout - + echo "==========\nDONE." diff --git a/examples/elm.json b/examples/elm.json new file mode 100644 index 0000000..4bf007f --- /dev/null +++ b/examples/elm.json @@ -0,0 +1,27 @@ +{ + "type": "application", + "source-directories": [ + "src" + ], + "elm-version": "0.19.0", + "dependencies": { + "direct": { + "elm/browser": "1.0.0", + "elm/core": "1.0.0", + "elm/html": "1.0.0", + "elm/http": "1.0.0", + "elm/json": "1.0.0", + "elm/url": "1.0.0", + "truqu/elm-base64": "2.0.4" + }, + "indirect": { + "elm/regex": "1.0.0", + "elm/time": "1.0.0", + "elm/virtual-dom": "1.0.0" + } + }, + "test-dependencies": { + "direct": {}, + "indirect": {} + } +} diff --git a/examples/images/google.png b/examples/images/google.png deleted file mode 100644 index 7ef3e0106832b7eac7a52c857adef47c59f9b320..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10841 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 RQ0-q>_tA{QZBM&UgZirhXqF|- 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 diff --git a/examples/implicit/Main.elm b/examples/implicit/Main.elm index 6ccfd69..b1c9101 100644 --- a/examples/implicit/Main.elm +++ b/examples/implicit/Main.elm @@ -29,10 +29,7 @@ main = type alias Model = - { oauth : - { clientId : String - , redirectUri : Url - } + { redirectUri : Url , error : Maybe String , token : Maybe OAuth.Token , profile : Maybe Profile @@ -54,6 +51,27 @@ profileDecoder = (Json.field "picture" Json.string) +preModel : Int -> Model -> String +preModel n model = + preRecord n + "Model" + [ ( "redirectUri", preString 30 <| Url.toString model.redirectUri ) + , ( "error", preMaybe (preString 30) model.error ) + , ( "token", preMaybe (\s -> preString 30 <| OAuth.showToken s) model.token ) + , ( "profile", preMaybe (preProfile (n + 1)) model.profile ) + ] + + +preProfile : Int -> Profile -> String +preProfile n profile = + preRecord n + "Profile" + [ ( "email", preString 30 profile.email ) + , ( "name", preString 30 profile.name ) + , ( "picture", preString 30 profile.picture ) + ] + + -- Msg @@ -62,10 +80,8 @@ type Msg -- No Operation, terminal case = NoOp - -- The 'clientId' input has changed - | ClientIdChanged String - -- The 'clientId' input has been submitted - | ClientIdSubmitted + -- The 'sign-in' button has been hit + | SignInRequested -- Got a response from the googleapis user info | GotUserInfo (Result Http.Error Profile) @@ -78,7 +94,7 @@ init : () -> Url -> Key -> ( Model, Cmd Msg ) init _ origin navKey = let model = - { oauth = { clientId = "", redirectUri = origin } + { redirectUri = origin , error = Nothing , token = Nothing , profile = Nothing @@ -134,25 +150,16 @@ showParseErr oauthErr = update : Msg -> Model -> ( Model, Cmd Msg ) -update msg ({ oauth } as model) = +update msg model = case msg of NoOp -> ( model, Cmd.none ) - ClientIdChanged clientId -> - let - oauthBis = - { oauth | clientId = clientId } - in - ( { model | oauth = oauthBis } - , Cmd.none - ) - - ClientIdSubmitted -> + SignInRequested -> ( model , OAuth.Implicit.authorize - { clientId = model.oauth.clientId - , redirectUri = model.oauth.redirectUri + { clientId = clientId + , redirectUri = model.redirectUri , responseType = OAuth.Token , scope = [ "email", "profile" ] , state = Nothing @@ -183,7 +190,7 @@ view model = content = case ( model.token, model.profile ) of ( Nothing, Nothing ) -> - viewForm model.oauth.clientId + viewSignInButton ( Just token, Nothing ) -> viewFetching @@ -192,25 +199,21 @@ view model = viewProfile profile in { title = "Elm OAuth2 Example - Implicit Flow" - , body = [ viewBody content model.error ] + , body = [ viewBody model content ] } -viewBody : Html Msg -> Maybe String -> Html Msg -viewBody content error = +viewBody : Model -> Html Msg -> Html Msg +viewBody model content = div [ style "display" "flex" , style "flex-direction" "column" , style "align-items" "center" - , style "padding" "3em" + , style "justify-content" "center" + , style "height" "95vh" + , style "overflow" "hidden" ] - [ h2 - [ style "display" "flex" - , style "font-family" "Roboto, Arial, sans-serif" - , style "color" "#141414" - ] - [ text "OAuth 2.0 Implicit Flow Example" ] - , case error of + [ case model.error of Nothing -> div [ style "display" "none" ] [] @@ -227,46 +230,45 @@ viewBody content error = , style "color" "#ffffff" ] [ text msg ] - , content + , div + [ style "display" "flex" + , style "align-items" "center" + , style "justify-content" "center" + , style "width" "70%" + ] + [ content + , pre [ style "padding" "2em" ] [ text (preModel 1 model) ] + ] ] -viewForm : String -> Html Msg -viewForm clientId = - Html.form - [ onSubmit ClientIdSubmitted - , style "flex-direction" "column" - ] - [ input - [ onInput ClientIdChanged - , type_ "text" - , placeholder "clientId" - , value clientId - , style "border" "none" - , style "border-bottom" "1px solid #757575" - , style "color" "#757575" - , style "font" "1.5em" - , style "font" "Roboto Arial" - , style "outline" "none" - , style "padding" "0.5em 1em" - , style "text-align" "center" - ] - [] - , button - [ style "background" "url('/elm-oauth2/examples/images/google.png') 1em center no-repeat" - , style "background-size" "2em" - , style "border" "none" - , style "box-shadow" "rgba(0,0,0,0.25) 0px 2px 4px 0px" - , style "color" "#757575" - , style "font" "Roboto Arial" - , style "margin" "1em" - , style "outline" "none" - , style "padding" "1em 1em 1em 3em" - , style "text-align" "right" - , onClick ClientIdSubmitted - ] - [ text "Sign in" ] + +-- type alias Model = +-- { redirectUri : Url +-- , error : Maybe String +-- , token : Maybe OAuth.Token +-- , profile : Maybe Profile +-- } + + +viewSignInButton : Html Msg +viewSignInButton = + button + [ style "background" "0 center no-repeat url('')" + , style "background-size" "100px" + , style "border" "none" + , style "box-shadow" "rgba(0,0,0,0.25) 0px 2px 4px 0px" + , style "color" "#757575" + , style "font" "24px Roboto, Arial" + , style "outline" "none" + , style "cursor" "pointer" + , style "height" "100px" + , style "width" "200px" + , style "text-align" "right" + , style "padding" "0 0.5em" + , onClick SignInRequested ] + [ text "Sign in" ] viewFetching : Html Msg @@ -288,17 +290,76 @@ viewProfile profile = ] [ img [ src profile.picture - , style "height" "150px" - , style "margin" "1em" - , style "width" "150px" + , style "height" "25vh" + , style "width" "25vh" + , style "border-radius" "50%" + , style "box-shadow" "rgba(0,0,0,0.25) 0 0 4px 2px" ] [] - , text <| profile.name ++ " <" ++ profile.email ++ ">" + , div + [ style "margin" "2em" + , style "font" "24px Roboto, Arial" + , style "color" "#757575" + ] + [ text <| profile.name ] ] +-- Formatting Helpers + + +preString : Int -> String -> String +preString maxSize str = + if String.length str > maxSize then + String.left maxSize str ++ "..." + + else + str + + +preRecord : Int -> String -> List ( String, String ) -> String +preRecord n name fields = + let + preField ( k, v ) = + k ++ " = " ++ v + + padded s = + "\n" ++ String.repeat (n * 2) " " ++ s + in + case fields of + [] -> + name + + [ fst ] -> + name ++ " = { " ++ preField fst ++ " }" + + fst :: rest -> + String.concat + [ name ++ " =" ++ padded "{ " ++ preField fst ++ padded ", " + , String.join (padded ", ") (List.map preField rest) + , padded "}" + ] + + +preMaybe : (a -> String) -> Maybe a -> String +preMaybe pre m = + case m of + Nothing -> + "Nothing" + + Just a -> + "Just (" ++ pre a ++ ")" + + + -- Constants / Google APIs endpoints +-- Demo clientId, configured to target the github repository's gh-pages only + + +clientId : String +clientId = + "909608474358-sucp6e4js3nvfkfnab5t69qoelampt3t.apps.googleusercontent.com" authorizationEndpoint : Url diff --git a/examples/src b/examples/src new file mode 120000 index 0000000..5cd551c --- /dev/null +++ b/examples/src @@ -0,0 +1 @@ +../src \ No newline at end of file