module Pages.Services exposing (Model, Msg, page) import Config.Colour as T exposing (..) import Config.Format as O exposing (..) import Config.Identity as I exposing (..) import Config.Viewport exposing (..) import Effect exposing (Effect) import Element exposing (..) import Element.Font as F import Headers.Helpers exposing (headerMaker) import Headers.Pages.Services exposing (servicesHeader) import Html.Attributes as H exposing (style) import Layouts import Page exposing (Page) import Route exposing (Route) import Services.Helpers exposing (..) import Services.Offerings.DebateAnalysis exposing (..) import Services.Offerings.DebateTutoring exposing (..) import Services.Offerings.ElmBuilds exposing (..) import Services.Offerings.NixBuilds exposing (..) import Services.Offerings.NutritionScience exposing (..) import Shared exposing (..) import View exposing (View) page : Shared.Model -> Route () -> Page Model Msg page shared route = Page.new { init = init , update = update , subscriptions = subscriptions , view = view } |> Page.withLayout toLayout toLayout : Model -> Layouts.Layout Msg toLayout model = Layouts.Navbar { currentRoute = servicesName } -- INIT type alias Model = {} init : () -> ( Model, Effect Msg ) init () = ( {} , Effect.map (\_ -> NoOp) (Effect.sendCmd resetViewport) ) -- UPDATE type Msg = NoOp update : Msg -> Model -> ( Model, Effect Msg ) update msg model = case msg of NoOp -> ( model , Effect.none ) -- SUBSCRIPTIONS subscriptions : Model -> Sub Msg subscriptions model = Sub.none -- VIEW view : Model -> View Msg view model = { title = servicesName , attributes = [] , element = servicesContainer } servicesContainer : Element msg servicesContainer = topLevelContainer servicesList servicesList : Element msg servicesList = column pageList <| List.concat [ List.map headerMaker [ servicesHeader ] , List.map serviceMaker [ servicesDebateAnalysis , servicesDebateTutoring , servicesNutritionScience , servicesNixBuilds , servicesElmBuilds ] ]