Skip to content

Views

Mantis provides a type-safe approach to building HTML views using V functions.

Basic Views

Create HTML views using Mantis's HTML utilities:

v
module main

import khalyomede.mantis.http { create_app, App, Response }
import khalyomede.mantis.http.route
import khalyomede.mantis.html { html, head, title, body, div, p } 

fn main() {
  app := create_app(
    routes: [
      route.get(
        name: "index"
        path: "/"
        callback: fn (app App) !Response {
          content := html({}, [ 
            head({}, [
              title({}, ['Welcome'])
            ]),
            body({}, [
              div({}, [
                p({}, ['Hello world'])
              ])
            ])
          ])

          return app.response.html(content: content)
        }
      )
    ]
  )

  app.serve() or { panic(err) }
}

Components

Break down your views into reusable components:

v
module main

import khalyomede.mantis.http { create_app, App, Response }
import khalyomede.mantis.http.route
import khalyomede.mantis.html { div, nav, a } 

fn navbar() string { 
  return nav({}, [
    a({'href': '/'}, ['Home']),
    a({'href': '/about'}, ['About']),
    a({'href': '/contact'}, ['Contact'])
  ])
}

fn main() {
  app := create_app(
    routes: [
      route.get(
        name: "index"
        path: "/"
        callback: fn (app App) !Response {
          content := div({}, [ 
            navbar(),
            div({}, ['Page content'])
          ])

          return app.response.html(content: content)
        }
      )
    ]
  )

  app.serve() or { panic(err) }
}

Attributes

Add HTML attributes to elements:

v
module main

import khalyomede.mantis.http { create_app, App, Response }
import khalyomede.mantis.http.route
import khalyomede.mantis.html { div, button } 

fn main() {
  app := create_app(
    routes: [
      route.get(
        name: "index"
        path: "/"
        callback: fn (app App) !Response {
          content := div({ 
            'class': 'container'
          }, [
            button({
              'class': 'btn btn-primary'
              'type': 'submit'
            }, [
              'Click me'
            ])
          ])

          return app.response.html(content: content)
        }
      )
    ]
  )

  app.serve() or { panic(err) }
}

Lists

Iterate over data to generate lists:

v
module main

import khalyomede.mantis.http { create_app, App, Response }
import khalyomede.mantis.http.route
import khalyomede.mantis.html { ul, li } 

fn main() {
  app := create_app(
    routes: [
      route.get(
        name: "index"
        path: "/"
        callback: fn (app App) !Response {
          items := ['One', 'Two', 'Three'] 

          list_items := items.map(fn (item string) string {
            return li({}, [item])
          })

          content := ul({}, list_items)

          return app.response.html(content: content)
        }
      )
    ]
  )

  app.serve() or { panic(err) }
}