Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/phenax/h
Html templating library for kotlin
https://github.com/phenax/h
html kotlin template-engine
Last synced: 3 months ago
JSON representation
Html templating library for kotlin
- Host: GitHub
- URL: https://github.com/phenax/h
- Owner: phenax
- License: apache-2.0
- Created: 2017-11-11T13:07:30.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2020-08-22T13:59:31.000Z (over 4 years ago)
- Last Synced: 2024-05-02T05:53:41.403Z (10 months ago)
- Topics: html, kotlin, template-engine
- Language: Kotlin
- Homepage:
- Size: 101 KB
- Stars: 17
- Watchers: 4
- Forks: 5
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# h
[](https://circleci.com/gh/phenax/h)
[](https://codecov.io/gh/phenax/h)
[](https://github.com/phenax/h/releases/latest)
[](https://opensource.org/licenses/Apache-2.0)Html templating library for kotlin.
## Get started
#### Download
* Download the latest release. ([View releases](https://github.com/phenax/h/releases))
* Clone the repo for the source code `git clone https://github.com/phenax/h`.
* Test it with `./gradlew test`. Generated test report -> `build/reports/tests/test`.#### Examples
Simple component examples in `/examples`#### Create a component
```kotlin
import io.github.phenax.h.Component
import io.github.phenax.h.Layout
import io.github.phenax.h.node.DOMNode
import io.github.phenax.h.layouts.EmptyLayoutclass CardComponent(val myTitle: String): Component() {
// Layout(EmptyLayout is no wrapper. You can use a custom layout)
override val layout = EmptyLayout()// This renders a div card component
//
//Card title
//Card description
//
override fun render(): DOMNode {
return div( mapOf( "class" to "card" ),
listOf(
h1( mapOf( "class" to "card--title" ), myTitle),
p( mapOf( "class" to "card--description" ), "Card description" )
)
)
}
}val helloWorldCard = CardComponent("Hello world")
```OR
```kotlin
import io.github.phenax.h.*fun createCard(myTitle: String) = component {
div( mapOf( "class" to "card" ),
listOf(
h1( mapOf( "class" to "card--title" ), myTitle),
p( mapOf( "class" to "card--description" ), "Card description")
)
)
}val helloWorldCard = createCard("Hello world")
```#### Create a layout
```kotlin
import io.github.phenax.h.Component
import io.github.phenax.h.Layout
import io.github.phenax.h.node.DOMNodeclass HtmlLayout(val title: String = "Moosic"): Layout() {
override fun render(component: AbstractComponent): DOMNode {
return (
html(null, listOf(
head(null, listOf(
h("title", null, listOf( text(title) ) ),
style("/css/style.css"), // External stylesheet
style(null, "html, body { background-color: red; }") // Inline style
)),
body(null, listOf(
div(null, h(component)),
script("/js/script.js", mapOf( "defer" to "defer", "async" to "async" ))
))
))
)
}
}
```#### Use components inside other components
```kotlin
class UserCardComponent(user: User): Component() {
override val layout = EmptyLayout()
override fun render(): DOMNode {
return div(null, listOf(
div(null, listOf( text(user.name) )),
div(null, listOf( text('@' + user.nickname) )),
))
}
}class UserListComponent(usersList: List): Component() {
override val layout = EmptyLayout()
override fun render(): DOMNode {
return div(null,
usersList.map { user ->
div(null, listOf( h(UserCardComponent(user)) ))
}
)
}
}
```#### Render to html string
```kotlin
val component = CardComponent()
println(component.renderToHtml())
```