Project

hca

0.0
No commit activity in last 3 years
No release in over 3 years
Compiles HAML CoffeScript templates into a client-side JavaScript code
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 3.1.0

Runtime

 Project Readme

HCA (HAML-CoffeeScript Assets)

HCA compiles HAML templates with inline CoffeeScript code into client-side JavaScript template functions that are available in window.JST object.

Installation

Ruby on Rails 3.1+ is required.

Add this line to your application's Gemfile:

gem 'hca'

And then execute:

$ bundle

Configuration

You can configure HCA by adding an initializer into your config/initializers directory. Configuration options are:

  • templates_path - base templates path used for generating correct template keys in window.JST object. Default value is app/assets/javascripts
  • escape_html - escape special HTML characters. Enabled by default
  • custom_html_escape - the name of the custom HTML escape function
  • clean_value - render empty strings instead of NULL or undefined CoffeeScript values. Enabled by default
  • custom_clean_value - the name of the custom function to clean CoffeeScript values

Example

Hca.configure do |config|
  config.custom_html_escape = '_.escape' # using Underscore.js 'escape' function
  config.custom_clean_value = '$.trim' # using jQuery.trim to clean NULL or undefined CoffeeScript values
  config.templates_path = 'app/assets/javascripts/templates'
end

Usage

  • Put HAML templates to your app/assets/javascripts/... directory. Give them .hca extention.
  • Add an initializer with correct path to your .hca templates
  • Add templates to the Assets Pipeline

Example

HCA template

TODO: add an example here

Hints

  • Using custom cleanup and escape functions helps reducing the size of the generated JavaScript code.

License

MIT

HCA internally uses haml-coffee library.

Contributing

  1. Fork it (https://github.com/arg/hca/fork)
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request