Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/steve8708/compylr

Compile your angular apps to render on any server. Blazing fast page loads, ultra simple configuration, full support for angular templates, expression, and actions
https://github.com/steve8708/compylr

Last synced: 2 months ago
JSON representation

Compile your angular apps to render on any server. Blazing fast page loads, ultra simple configuration, full support for angular templates, expression, and actions

Awesome Lists containing this project

README

        

![Compylr](http://i.imgur.com/A3XYEWM.png)

Angular.js apps rendered on the server, no node.js required!

Compile angular apps for rendering on any backend, regardless of language or platform.
Server side rendering, full angular expression support, 100% SEO compatible,
optional client/server route, logic, and state sharing.

## Purpose
* Simplicity: write your angular app, let Compylr do the rest
* Best of both worlds: first render on the server, then let angular take over once the page is displayed
* Minimal pageload times pre-load
* Maximum performance post-load
* Backend agnostic
* Easily share state and route logic on client and server
* Support full RESTful URL structure for optimal page crawling

## How it works
* Compiles angular templates to handlebars templates
* (Optionally) Standardizes route configuration using JSON for angular and any backend (via an adapter)
* (Optionally) Standardizes state management with angular and any backend (via an adapter)

## Installation
`npm install --save compylr`

## Example

#### Angular Template Input
```html

{{foo}}




{{ foo && bar }}
```

#### Compiled Temlpate Output
Includes {{}} for handlebars and attributes + escaped {{}} ({) for angular interpolations
```html
{{#forEach 'foo' in bar}}

{{foo}}


{{> path/to/partial}}


{{/forEach}}

{{#if foo.length}}

{{/if}}

{{#ifExpression "foo && bar"}}

{{/ifExpression}}


{{expression "foo && bar"}}

```

#### Render Your Template
Render your template with handlebars
and pass in any data you need

**Coffeescript Example**
```coffeescript
app.engine 'handlebars'
res.render 'index', products: products
```

**Java Example**
```java
Handlebars handlebars = new Handlebars();
Template template = handlebars.compile("index");
System.out.println(template.apply("Handlebars.java"));
```

#### State & Route Configuration (Optional)
Configure your state and routes in one place and Compylr
will compile them into application logic for both your client and server.

`compylr.json`

```javascript
{
"routes": {
"/:page/:tab/:product": {
"data": {
"showModal": true
},
"compute": {
"activeTab.name": "$params.tab",
"activeProduct": "results[$params.product]"
}
}
},
"data": {
"activeProduct": {},
"query": {
"value": ""
},
"mode": {
"name": "search"
},
"openTab": {
"name": "insights"
}
}
}
```

#### Server Events & Actions (Optional)
Compilr runs your applications routes and states on both the client
and the server. This means that you can run things like

* ``
* ``
* ``

And this will update state logic in your templates, such as
* `

`
* `

{{selectedProduct.name}}

{{selectedProduct.description}}

`
* `
`

This means your applications not only render on the server, but can
function as fully standalone applications without any JS at all!
This is all taken care of automatigically by Compylr.

For example, this interactive webpage written in angular can function 100%
on the server and without JS when copiled by Compylr.

Pre-compile:

```html

{{selectedProduct.name}}


{{selectedProduct.name}}


{{selectedProduct.description}}



```

Post-compile:

```html
{{#forEach 'product' in productResults}}

{{selectedProduct.name}}

{{/forEach}}
{{#if selectedProduct}}


{{selectedProduct.name}}


{{selectedProduct.description}}



{{/if}}
```

Note in the above example the key to this is in the href "?action=". This is compiled
from your angular template and tells the server adapter the state and/or route
changes to make

This is all possible because of compylr's concept of a shared session state tree
and route configuration

## Key Features
* 100% SEO friendly
* Ultra high performance
* You don't need to run your whole app on the server to render a template. So don't.
Instead cross compile templates and sync state.
* Angular application logic
* Use ng-click to trigger client __and__ server actions
(e.g. changing states and routes) even without any browser javascript!
* Client and server rendering (render on server, once app loaded renders on client)
* Pushtate support (always keep urls in sync)
* Simple state and route configuration
* Shared session state on client and server with simple configuration
* Shared route logic on client and server with simple configuration
* Backend agnostic. Supports any backend with a simple adapter
* Full expression support - e.g. `ng-show="foo && bar[foo] || bar.foo"`
* Event support - e.g. `ng-click="foo = !foo"`
* Form support
* Offline support
* Templates compile to 100% valid handlebars
* Handlebars helpers compatible - extend with your own
* Template resolution
* All angular template attributes are 100% safe. They are converted
to handlebars expressions and to ng-attributes so the template
can be immediately displayed in the browser but angular can still
find all necessary hooks to take control of the application once loaded
* e.g. `{{foo}}` ➜ `{{foo}}`

## Supported Attributes
* ng-repeat
* ng-include
* ng-show
* ng-hide
* ng-if
* ng-click (With optional state syncing)
* ng-class
* ng-style
* ng-attr-*
* ng-href, ng-value, ng-src
* ng-bind
* interpolations
* `{{foo}} `
* expressions
* `{{foo && bar}} `

## Project Status
Functional demo complete. Working on production ready v1.0.0

## Usage

```coffeescript
compylr = require 'compylr'
compiled = compylr path: 'path/to/angular/template.html'
```

Or, more a more complete example

```coffeescript
# Load our dependencies
compylr = require 'compylr'
fs = require 'fs'
expressHandlebars = require 'express3-handlebars'
express = require 'express'
handlebars = require 'handlebars'

# Set handlebars as our rendering engine
app.engine 'html', expressHandlebars templatesDir: './templates'

# Specify our templates directory
app.set 'views', './templates'

# Write our main template
fs.writeFileSync 'templates/index.html', compylr path: 'path/to/angular/template.html'

# Load compylr handlebars heleprs for rendering
compylr.setHelpers handelbars

# Create an express app
app = express()

# Get the index route and render our compiled index.html with some data
app.get 'index', (req, res) ->
res.render 'index', foo: 'bar'

```

CLI (coming soon...)

`compylr src/path/* dest/path/*`
`./node_modules/.bin/compylr src/path/* dest/path/*`

## Development
View and run `example/script.coffee` for an example on how to run uncompiled
coffeescript on a sample file. Modify `example/sample-angular-template.tpl.html`
then run `coffee example/script.coffee` to verify that your changes work as
expected.

## Todo
* Localization
* Compile whole directories with src and dest directories
* Support for angular filters
* Support for other templating languages (e.g. jinja on python)
* Support for logic sharing
* On node through code sharing
* On other platforms (python, java, etc) through expression parsing

## Demo
Coming soon...