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) }
}