mirror of
https://gitea.invidious.io/iv-org/shard-kilt.git
synced 2024-08-15 00:43:15 +00:00
105 lines
3.3 KiB
Markdown
105 lines
3.3 KiB
Markdown
# Kilt [![Build Status](https://travis-ci.org/jeromegn/kilt.svg?branch=master)](https://travis-ci.org/jeromegn/kilt) [![Dependency Status](https://shards.rocks/badge/github/jeromegn/kilt/status.svg)](https://shards.rocks/github/jeromegn/kilt) [![devDependency Status](https://shards.rocks/badge/github/jeromegn/kilt/dev_status.svg)](https://shards.rocks/github/jeromegn/kilt)
|
||
|
||
Generic templating interface for Crystal.
|
||
|
||
## Goal
|
||
|
||
Simplify developers' lives by abstracting template rendering for multiple template languages.
|
||
|
||
## Supported out of the box
|
||
|
||
| Language | File extensions | Required libraries | Maintainer |
|
||
| -------- | --------------- | ------------------ | ---------- |
|
||
| ECR | .ecr | none (part of the stdlib) | |
|
||
| Mustache | .mustache | [crustache](https://github.com/MakeNowJust/crustache) | [@MakeNowJust](https://github.com/MakeNowJust) |
|
||
| Slang | .slang | [slang](https://github.com/jeromegn/slang) | [@jeromegn](https://github.com/jeromegn) |
|
||
| Temel | .temel | [temel](https://github.com/f/temel) | [@f](https://github.com/f) |
|
||
| Crikey | .crikey | [crikey](https://github.com/domgetter/crikey) | [@domgetter](https://github.com/domgetter) |
|
||
|
||
See also:
|
||
[Registering your own template engine](#registering-your-own-template-engine).
|
||
|
||
## Installation
|
||
|
||
Add this to your application's `shard.yml`:
|
||
|
||
```yaml
|
||
dependencies:
|
||
kilt:
|
||
github: jeromegn/kilt
|
||
|
||
# Any other template languages Crystal shard
|
||
```
|
||
|
||
## Usage
|
||
|
||
- Kilt essentially adds two macros `Kilt.embed` and `Kilt.file`, the code is really simple.
|
||
- Add template language dependencies, as listed in the support table above.
|
||
|
||
Both macros take a `filename` and a `io_name` (the latter defaults to `"__kilt_io__"`)
|
||
|
||
### Example
|
||
|
||
```crystal
|
||
require "kilt"
|
||
|
||
# For slang, add:
|
||
require "kilt/slang"
|
||
|
||
# With a Class
|
||
|
||
class YourView
|
||
Kilt.file("path/to/template.ecr") # Adds a to_s method
|
||
end
|
||
puts YourView.new.to_s # => <compiled template>
|
||
|
||
|
||
# Embedded
|
||
|
||
str = Kilt.render "path/to/template.slang"
|
||
|
||
# or
|
||
|
||
str = String.build do |__kilt_io__|
|
||
Kilt.embed "path/to/template.slang"
|
||
end
|
||
|
||
puts str # => <compiled template>
|
||
```
|
||
|
||
## Registering your own template engine
|
||
|
||
Use `Kilt.register_engine(extension, embed_command)` macro:
|
||
|
||
```crystal
|
||
require "kilt"
|
||
|
||
module MyEngine
|
||
macro embed(filename, io_name)
|
||
# ....
|
||
end
|
||
end
|
||
|
||
Kilt.register_engine("myeng", MyEngine.embed)
|
||
```
|
||
|
||
This can be part of your own `my-engine` library: in this case it should depend
|
||
on `kilt` directly, or this could be a part of adapter library, like:
|
||
`kilt-my-engine`, which will depend on both `kilt` and `my-engine`.
|
||
|
||
## Contributing
|
||
|
||
Please contribute your own "adapter" if you create a template language for Crystal that's not yet supported here!
|
||
|
||
1. Fork it ( https://github.com/jeromegn/kilt/fork )
|
||
2. Create your feature branch (git checkout -b my-awesome-template-language)
|
||
3. Commit your changes (git commit -am 'Add my-awesome-template-language')
|
||
4. Push to the branch (git push origin my-awesome-template-language)
|
||
5. Create a new Pull Request
|
||
|
||
## Contributors
|
||
|
||
- [jeromegn](https://github.com/jeromegn) Jerome Gravel-Niquet - creator, maintainer
|
||
- [waterlink](https://github.com/waterlink) Oleksii Fedorov
|
||
- [MakeNowJust](https://github.com/MakeNowJust) TSUYUSATO Kitsune
|
||
- [f](https://github.com/f) Fatih Kadir Akın
|