Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
39 changes: 39 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,12 @@ Swag is a growing collection of helpers for [Handlebars.js](https://github.com/w
Swag = require('swag');

Swag.registerHelpers(Handlebars);

//Usage with express3-handlebars
exphbs = require('express3-handlebars);
hbs = exphbs.create({
handlebars: Handlebars //Pass the Handlebar instance with Swag
});

## Swag.registerHelpers
This method will register all Swag helpers with the instance of Handlebars you pass to it.
Expand Down Expand Up @@ -626,6 +632,23 @@ Usage:
{{round value}}

6
#### random

Returns a random number within the provided limit.

Parameters:

lower [int] - The lower limit for the random number. (Required)
upper [int] - The upper limit for the random number. (Required)

Usage:

lower = 10
upper = 50

{{random lower upper}}

27

## Numbers

Expand Down Expand Up @@ -1139,7 +1162,23 @@ Usage:
# Your template
{{partial "planet_express" data template}}

### PhotosetLayout

Generates layout for [Photoset Grid](http://stylehatch.github.io/photoset-grid/) plugin to render Tumblr like image layouts.

Parameters:
images[array] - An array of images for which the layout has to be generated. (Required)
Eg: ["image1.jpg","image2.jpg","image3.jpg"]

Usage:
```
<div class="photoset-grid" data-layout="{{photoLayout images}}" style="visibility:;">
{{#unserialize images}}
<img src="/{{item}}" data-highres="/{{item}}">
{{/unserialize}}
</div>
```


[![Bitdeli Badge](https://d2weczhvl823v0.cloudfront.net/elving/swag/trend.png)](https://bitdeli.com/free "Bitdeli Badge")

23 changes: 23 additions & 0 deletions lib/swag.js
Original file line number Diff line number Diff line change
Expand Up @@ -407,6 +407,20 @@
}
return result;
}, 'array');

Swag.addHelper('unserialize', function(_array,options) {
var array = JSON.parse(_array);
var index, result, value, _i, _len;
result = '';
for (index = _i = 0, _len = array.length; _i < _len; index = ++_i) {
value = array[index];
result += options.fn({
item: value,
index: index
});
}
return result;
}, 'array');

Swag.addHelper('eachProperty', function(obj, options) {
var key, result, value;
Expand All @@ -420,6 +434,15 @@
}
return result;
}, 'object');

Swag.addHelper('photoLayout', function(_array,options) {
var array = JSON.parse(_array);
var _len = array.length;
if(_len == 1) return 1;
if(_len == 2) return 21;
if(_len == 3) return 12;
if(_len > 3) return 121;
});

Swag.addHelper('add', function(value, addition) {
value = parseFloat(value);
Expand Down
6 changes: 6 additions & 0 deletions src/swag.math.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -36,3 +36,9 @@ Swag.addHelper 'round', (value) ->
value = parseFloat value
Math.round value
, 'number'

Swag.addHelper 'random', (lower, upper) ->
lower = parseInt lower
upper = parseInt upper
Math.floor Math.random() * (upper - lower + 1) + lower
, ['number', 'number']