mirror of
https://github.com/YunoHost/yunohost-admin.git
synced 2024-09-03 20:06:15 +02:00
Use Handlebars instead of Mustache as templating engine.
This commit is contained in:
parent
bd2dd6a6a0
commit
4d54eaf8b5
6 changed files with 2882 additions and 665 deletions
|
@ -43,9 +43,9 @@
|
|||
</div>
|
||||
|
||||
<script type="text/javascript" src="js/vendor/jquery-1.10.1.min.js"></script>
|
||||
<script type="text/javascript" src="js/vendor/mustache.js"></script>
|
||||
<script type="text/javascript" src="js/vendor/handlebars-v1.3.0.js"></script>
|
||||
<script type="text/javascript" src="js/vendor/sammy.js"></script>
|
||||
<script type="text/javascript" src="js/vendor/sammy.mustache.js"></script>
|
||||
<script type="text/javascript" src="js/vendor/sammy.handlebars.js"></script>
|
||||
<script type="text/javascript" src="js/vendor/sammy.json.js"></script>
|
||||
<script type="text/javascript" src="js/vendor/sammy.storage.js"></script>
|
||||
<script type="text/javascript" src="js/vendor/bootstrap.min.js"></script>
|
||||
|
|
|
@ -5,7 +5,7 @@ app = Sammy('#main', function (sam) {
|
|||
*
|
||||
*/
|
||||
// Plugins
|
||||
sam.use('Mustache', 'ms');
|
||||
sam.use('Handlebars', 'ms');
|
||||
|
||||
// Look for supported type of storage to use
|
||||
var storageType;
|
||||
|
|
2746
js/vendor/handlebars-v1.3.0.js
vendored
Normal file
2746
js/vendor/handlebars-v1.3.0.js
vendored
Normal file
File diff suppressed because it is too large
Load diff
536
js/vendor/mustache.js
vendored
536
js/vendor/mustache.js
vendored
|
@ -1,536 +0,0 @@
|
|||
/*!
|
||||
* mustache.js - Logic-less {{mustache}} templates with JavaScript
|
||||
* http://github.com/janl/mustache.js
|
||||
*/
|
||||
|
||||
/*global define: false*/
|
||||
|
||||
(function (root, factory) {
|
||||
if (typeof exports === "object" && exports) {
|
||||
factory(exports); // CommonJS
|
||||
} else {
|
||||
var mustache = {};
|
||||
factory(mustache);
|
||||
if (typeof define === "function" && define.amd) {
|
||||
define(mustache); // AMD
|
||||
} else {
|
||||
root.Mustache = mustache; // <script>
|
||||
}
|
||||
}
|
||||
}(this, function (mustache) {
|
||||
|
||||
var whiteRe = /\s*/;
|
||||
var spaceRe = /\s+/;
|
||||
var nonSpaceRe = /\S/;
|
||||
var eqRe = /\s*=/;
|
||||
var curlyRe = /\s*\}/;
|
||||
var tagRe = /#|\^|\/|>|\{|&|=|!/;
|
||||
|
||||
// Workaround for https://issues.apache.org/jira/browse/COUCHDB-577
|
||||
// See https://github.com/janl/mustache.js/issues/189
|
||||
var RegExp_test = RegExp.prototype.test;
|
||||
function testRegExp(re, string) {
|
||||
return RegExp_test.call(re, string);
|
||||
}
|
||||
|
||||
function isWhitespace(string) {
|
||||
return !testRegExp(nonSpaceRe, string);
|
||||
}
|
||||
|
||||
var Object_toString = Object.prototype.toString;
|
||||
var isArray = Array.isArray || function (obj) {
|
||||
return Object_toString.call(obj) === '[object Array]';
|
||||
};
|
||||
|
||||
function escapeRegExp(string) {
|
||||
return string.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g, "\\$&");
|
||||
}
|
||||
|
||||
var entityMap = {
|
||||
"&": "&",
|
||||
"<": "<",
|
||||
">": ">",
|
||||
'"': '"',
|
||||
"'": ''',
|
||||
"/": '/'
|
||||
};
|
||||
|
||||
function escapeHtml(string) {
|
||||
return String(string).replace(/[&<>"'\/]/g, function (s) {
|
||||
return entityMap[s];
|
||||
});
|
||||
}
|
||||
|
||||
function Scanner(string) {
|
||||
this.string = string;
|
||||
this.tail = string;
|
||||
this.pos = 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns `true` if the tail is empty (end of string).
|
||||
*/
|
||||
Scanner.prototype.eos = function () {
|
||||
return this.tail === "";
|
||||
};
|
||||
|
||||
/**
|
||||
* Tries to match the given regular expression at the current position.
|
||||
* Returns the matched text if it can match, the empty string otherwise.
|
||||
*/
|
||||
Scanner.prototype.scan = function (re) {
|
||||
var match = this.tail.match(re);
|
||||
|
||||
if (match && match.index === 0) {
|
||||
this.tail = this.tail.substring(match[0].length);
|
||||
this.pos += match[0].length;
|
||||
return match[0];
|
||||
}
|
||||
|
||||
return "";
|
||||
};
|
||||
|
||||
/**
|
||||
* Skips all text until the given regular expression can be matched. Returns
|
||||
* the skipped string, which is the entire tail if no match can be made.
|
||||
*/
|
||||
Scanner.prototype.scanUntil = function (re) {
|
||||
var match, pos = this.tail.search(re);
|
||||
|
||||
switch (pos) {
|
||||
case -1:
|
||||
match = this.tail;
|
||||
this.pos += this.tail.length;
|
||||
this.tail = "";
|
||||
break;
|
||||
case 0:
|
||||
match = "";
|
||||
break;
|
||||
default:
|
||||
match = this.tail.substring(0, pos);
|
||||
this.tail = this.tail.substring(pos);
|
||||
this.pos += pos;
|
||||
}
|
||||
|
||||
return match;
|
||||
};
|
||||
|
||||
function Context(view, parent) {
|
||||
this.view = view || {};
|
||||
this.parent = parent;
|
||||
this._cache = {};
|
||||
}
|
||||
|
||||
Context.make = function (view) {
|
||||
return (view instanceof Context) ? view : new Context(view);
|
||||
};
|
||||
|
||||
Context.prototype.push = function (view) {
|
||||
return new Context(view, this);
|
||||
};
|
||||
|
||||
Context.prototype.lookup = function (name) {
|
||||
var value = this._cache[name];
|
||||
|
||||
if (!value) {
|
||||
if (name == '.') {
|
||||
value = this.view;
|
||||
} else {
|
||||
var context = this;
|
||||
|
||||
while (context) {
|
||||
if (name.indexOf('.') > 0) {
|
||||
value = context.view;
|
||||
var names = name.split('.'), i = 0;
|
||||
while (value && i < names.length) {
|
||||
value = value[names[i++]];
|
||||
}
|
||||
} else {
|
||||
value = context.view[name];
|
||||
}
|
||||
|
||||
if (value != null) break;
|
||||
|
||||
context = context.parent;
|
||||
}
|
||||
}
|
||||
|
||||
this._cache[name] = value;
|
||||
}
|
||||
|
||||
if (typeof value === 'function') value = value.call(this.view);
|
||||
|
||||
return value;
|
||||
};
|
||||
|
||||
function Writer() {
|
||||
this.clearCache();
|
||||
}
|
||||
|
||||
Writer.prototype.clearCache = function () {
|
||||
this._cache = {};
|
||||
this._partialCache = {};
|
||||
};
|
||||
|
||||
Writer.prototype.compile = function (template, tags) {
|
||||
var fn = this._cache[template];
|
||||
|
||||
if (!fn) {
|
||||
var tokens = mustache.parse(template, tags);
|
||||
fn = this._cache[template] = this.compileTokens(tokens, template);
|
||||
}
|
||||
|
||||
return fn;
|
||||
};
|
||||
|
||||
Writer.prototype.compilePartial = function (name, template, tags) {
|
||||
var fn = this.compile(template, tags);
|
||||
this._partialCache[name] = fn;
|
||||
return fn;
|
||||
};
|
||||
|
||||
Writer.prototype.getPartial = function (name) {
|
||||
if (!(name in this._partialCache) && this._loadPartial) {
|
||||
this.compilePartial(name, this._loadPartial(name));
|
||||
}
|
||||
|
||||
return this._partialCache[name];
|
||||
};
|
||||
|
||||
Writer.prototype.compileTokens = function (tokens, template) {
|
||||
var self = this;
|
||||
return function (view, partials) {
|
||||
if (partials) {
|
||||
if (typeof partials === 'function') {
|
||||
self._loadPartial = partials;
|
||||
} else {
|
||||
for (var name in partials) {
|
||||
self.compilePartial(name, partials[name]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return renderTokens(tokens, self, Context.make(view), template);
|
||||
};
|
||||
};
|
||||
|
||||
Writer.prototype.render = function (template, view, partials) {
|
||||
return this.compile(template)(view, partials);
|
||||
};
|
||||
|
||||
/**
|
||||
* Low-level function that renders the given `tokens` using the given `writer`
|
||||
* and `context`. The `template` string is only needed for templates that use
|
||||
* higher-order sections to extract the portion of the original template that
|
||||
* was contained in that section.
|
||||
*/
|
||||
function renderTokens(tokens, writer, context, template) {
|
||||
var buffer = '';
|
||||
|
||||
var token, tokenValue, value;
|
||||
for (var i = 0, len = tokens.length; i < len; ++i) {
|
||||
token = tokens[i];
|
||||
tokenValue = token[1];
|
||||
|
||||
switch (token[0]) {
|
||||
case '#':
|
||||
value = context.lookup(tokenValue);
|
||||
|
||||
if (typeof value === 'object') {
|
||||
if (isArray(value)) {
|
||||
for (var j = 0, jlen = value.length; j < jlen; ++j) {
|
||||
buffer += renderTokens(token[4], writer, context.push(value[j]), template);
|
||||
}
|
||||
} else if (value) {
|
||||
buffer += renderTokens(token[4], writer, context.push(value), template);
|
||||
}
|
||||
} else if (typeof value === 'function') {
|
||||
var text = template == null ? null : template.slice(token[3], token[5]);
|
||||
value = value.call(context.view, text, function (template) {
|
||||
return writer.render(template, context);
|
||||
});
|
||||
if (value != null) buffer += value;
|
||||
} else if (value) {
|
||||
buffer += renderTokens(token[4], writer, context, template);
|
||||
}
|
||||
|
||||
break;
|
||||
case '^':
|
||||
value = context.lookup(tokenValue);
|
||||
|
||||
// Use JavaScript's definition of falsy. Include empty arrays.
|
||||
// See https://github.com/janl/mustache.js/issues/186
|
||||
if (!value || (isArray(value) && value.length === 0)) {
|
||||
buffer += renderTokens(token[4], writer, context, template);
|
||||
}
|
||||
|
||||
break;
|
||||
case '>':
|
||||
value = writer.getPartial(tokenValue);
|
||||
if (typeof value === 'function') buffer += value(context);
|
||||
break;
|
||||
case '&':
|
||||
value = context.lookup(tokenValue);
|
||||
if (value != null) buffer += value;
|
||||
break;
|
||||
case 'name':
|
||||
value = context.lookup(tokenValue);
|
||||
if (value != null) buffer += mustache.escape(value);
|
||||
break;
|
||||
case 'text':
|
||||
buffer += tokenValue;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return buffer;
|
||||
}
|
||||
|
||||
/**
|
||||
* Forms the given array of `tokens` into a nested tree structure where
|
||||
* tokens that represent a section have two additional items: 1) an array of
|
||||
* all tokens that appear in that section and 2) the index in the original
|
||||
* template that represents the end of that section.
|
||||
*/
|
||||
function nestTokens(tokens) {
|
||||
var tree = [];
|
||||
var collector = tree;
|
||||
var sections = [];
|
||||
|
||||
var token;
|
||||
for (var i = 0, len = tokens.length; i < len; ++i) {
|
||||
token = tokens[i];
|
||||
switch (token[0]) {
|
||||
case '#':
|
||||
case '^':
|
||||
sections.push(token);
|
||||
collector.push(token);
|
||||
collector = token[4] = [];
|
||||
break;
|
||||
case '/':
|
||||
var section = sections.pop();
|
||||
section[5] = token[2];
|
||||
collector = sections.length > 0 ? sections[sections.length - 1][4] : tree;
|
||||
break;
|
||||
default:
|
||||
collector.push(token);
|
||||
}
|
||||
}
|
||||
|
||||
return tree;
|
||||
}
|
||||
|
||||
/**
|
||||
* Combines the values of consecutive text tokens in the given `tokens` array
|
||||
* to a single token.
|
||||
*/
|
||||
function squashTokens(tokens) {
|
||||
var squashedTokens = [];
|
||||
|
||||
var token, lastToken;
|
||||
for (var i = 0, len = tokens.length; i < len; ++i) {
|
||||
token = tokens[i];
|
||||
if (token) {
|
||||
if (token[0] === 'text' && lastToken && lastToken[0] === 'text') {
|
||||
lastToken[1] += token[1];
|
||||
lastToken[3] = token[3];
|
||||
} else {
|
||||
lastToken = token;
|
||||
squashedTokens.push(token);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return squashedTokens;
|
||||
}
|
||||
|
||||
function escapeTags(tags) {
|
||||
return [
|
||||
new RegExp(escapeRegExp(tags[0]) + "\\s*"),
|
||||
new RegExp("\\s*" + escapeRegExp(tags[1]))
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Breaks up the given `template` string into a tree of token objects. If
|
||||
* `tags` is given here it must be an array with two string values: the
|
||||
* opening and closing tags used in the template (e.g. ["<%", "%>"]). Of
|
||||
* course, the default is to use mustaches (i.e. Mustache.tags).
|
||||
*/
|
||||
function parseTemplate(template, tags) {
|
||||
template = template || '';
|
||||
tags = tags || mustache.tags;
|
||||
|
||||
if (typeof tags === 'string') tags = tags.split(spaceRe);
|
||||
if (tags.length !== 2) throw new Error('Invalid tags: ' + tags.join(', '));
|
||||
|
||||
var tagRes = escapeTags(tags);
|
||||
var scanner = new Scanner(template);
|
||||
|
||||
var sections = []; // Stack to hold section tokens
|
||||
var tokens = []; // Buffer to hold the tokens
|
||||
var spaces = []; // Indices of whitespace tokens on the current line
|
||||
var hasTag = false; // Is there a {{tag}} on the current line?
|
||||
var nonSpace = false; // Is there a non-space char on the current line?
|
||||
|
||||
// Strips all whitespace tokens array for the current line
|
||||
// if there was a {{#tag}} on it and otherwise only space.
|
||||
function stripSpace() {
|
||||
if (hasTag && !nonSpace) {
|
||||
while (spaces.length) {
|
||||
delete tokens[spaces.pop()];
|
||||
}
|
||||
} else {
|
||||
spaces = [];
|
||||
}
|
||||
|
||||
hasTag = false;
|
||||
nonSpace = false;
|
||||
}
|
||||
|
||||
var start, type, value, chr, token;
|
||||
while (!scanner.eos()) {
|
||||
start = scanner.pos;
|
||||
|
||||
// Match any text between tags.
|
||||
value = scanner.scanUntil(tagRes[0]);
|
||||
if (value) {
|
||||
for (var i = 0, len = value.length; i < len; ++i) {
|
||||
chr = value.charAt(i);
|
||||
|
||||
if (isWhitespace(chr)) {
|
||||
spaces.push(tokens.length);
|
||||
} else {
|
||||
nonSpace = true;
|
||||
}
|
||||
|
||||
tokens.push(['text', chr, start, start + 1]);
|
||||
start += 1;
|
||||
|
||||
// Check for whitespace on the current line.
|
||||
if (chr == '\n') stripSpace();
|
||||
}
|
||||
}
|
||||
|
||||
// Match the opening tag.
|
||||
if (!scanner.scan(tagRes[0])) break;
|
||||
hasTag = true;
|
||||
|
||||
// Get the tag type.
|
||||
type = scanner.scan(tagRe) || 'name';
|
||||
scanner.scan(whiteRe);
|
||||
|
||||
// Get the tag value.
|
||||
if (type === '=') {
|
||||
value = scanner.scanUntil(eqRe);
|
||||
scanner.scan(eqRe);
|
||||
scanner.scanUntil(tagRes[1]);
|
||||
} else if (type === '{') {
|
||||
value = scanner.scanUntil(new RegExp('\\s*' + escapeRegExp('}' + tags[1])));
|
||||
scanner.scan(curlyRe);
|
||||
scanner.scanUntil(tagRes[1]);
|
||||
type = '&';
|
||||
} else {
|
||||
value = scanner.scanUntil(tagRes[1]);
|
||||
}
|
||||
|
||||
// Match the closing tag.
|
||||
if (!scanner.scan(tagRes[1])) throw new Error('Unclosed tag at ' + scanner.pos);
|
||||
|
||||
token = [type, value, start, scanner.pos];
|
||||
tokens.push(token);
|
||||
|
||||
if (type === '#' || type === '^') {
|
||||
sections.push(token);
|
||||
} else if (type === '/') {
|
||||
// Check section nesting.
|
||||
if (sections.length === 0) throw new Error('Unopened section "' + value + '" at ' + start);
|
||||
var openSection = sections.pop();
|
||||
if (openSection[1] !== value) throw new Error('Unclosed section "' + openSection[1] + '" at ' + start);
|
||||
} else if (type === 'name' || type === '{' || type === '&') {
|
||||
nonSpace = true;
|
||||
} else if (type === '=') {
|
||||
// Set the tags for the next time around.
|
||||
tags = value.split(spaceRe);
|
||||
if (tags.length !== 2) throw new Error('Invalid tags at ' + start + ': ' + tags.join(', '));
|
||||
tagRes = escapeTags(tags);
|
||||
}
|
||||
}
|
||||
|
||||
// Make sure there are no open sections when we're done.
|
||||
var openSection = sections.pop();
|
||||
if (openSection) throw new Error('Unclosed section "' + openSection[1] + '" at ' + scanner.pos);
|
||||
|
||||
tokens = squashTokens(tokens);
|
||||
|
||||
return nestTokens(tokens);
|
||||
}
|
||||
|
||||
mustache.name = "mustache.js";
|
||||
mustache.version = "0.7.2";
|
||||
mustache.tags = ["{{", "}}"];
|
||||
|
||||
mustache.Scanner = Scanner;
|
||||
mustache.Context = Context;
|
||||
mustache.Writer = Writer;
|
||||
|
||||
mustache.parse = parseTemplate;
|
||||
|
||||
// Export the escaping function so that the user may override it.
|
||||
// See https://github.com/janl/mustache.js/issues/244
|
||||
mustache.escape = escapeHtml;
|
||||
|
||||
// All Mustache.* functions use this writer.
|
||||
var defaultWriter = new Writer();
|
||||
|
||||
/**
|
||||
* Clears all cached templates and partials in the default writer.
|
||||
*/
|
||||
mustache.clearCache = function () {
|
||||
return defaultWriter.clearCache();
|
||||
};
|
||||
|
||||
/**
|
||||
* Compiles the given `template` to a reusable function using the default
|
||||
* writer.
|
||||
*/
|
||||
mustache.compile = function (template, tags) {
|
||||
return defaultWriter.compile(template, tags);
|
||||
};
|
||||
|
||||
/**
|
||||
* Compiles the partial with the given `name` and `template` to a reusable
|
||||
* function using the default writer.
|
||||
*/
|
||||
mustache.compilePartial = function (name, template, tags) {
|
||||
return defaultWriter.compilePartial(name, template, tags);
|
||||
};
|
||||
|
||||
/**
|
||||
* Compiles the given array of tokens (the output of a parse) to a reusable
|
||||
* function using the default writer.
|
||||
*/
|
||||
mustache.compileTokens = function (tokens, template) {
|
||||
return defaultWriter.compileTokens(tokens, template);
|
||||
};
|
||||
|
||||
/**
|
||||
* Renders the `template` with the given `view` and `partials` using the
|
||||
* default writer.
|
||||
*/
|
||||
mustache.render = function (template, view, partials) {
|
||||
return defaultWriter.render(template, view, partials);
|
||||
};
|
||||
|
||||
// This is here for backwards compatibility with 0.4.x.
|
||||
mustache.to_html = function (template, view, partials, send) {
|
||||
var result = mustache.render(template, view, partials);
|
||||
|
||||
if (typeof send === "function") {
|
||||
send(result);
|
||||
} else {
|
||||
return result;
|
||||
}
|
||||
};
|
||||
|
||||
}));
|
133
js/vendor/sammy.handlebars.js
vendored
Normal file
133
js/vendor/sammy.handlebars.js
vendored
Normal file
|
@ -0,0 +1,133 @@
|
|||
(function (factory) {
|
||||
if (typeof define === 'function' && define.amd) {
|
||||
define(['jquery', 'sammy', 'handlebars'], factory);
|
||||
} else {
|
||||
(window.Sammy = window.Sammy || {}).Handlebars = factory(window.jQuery, window.Sammy);
|
||||
}
|
||||
}(function ($, Sammy, Handlebars) {
|
||||
// version 1.0.0 has no support for AMD but upwards does, this way we support both.
|
||||
Handlebars = Handlebars || window.Handlebars;
|
||||
|
||||
// <tt>Sammy.Handlebars</tt> provides a quick way of using Handlebars templates in your app.
|
||||
//
|
||||
// Note: As of Sammy 0.7 Handlebars itself is not included in the source. Please download and
|
||||
// include handlebars.js before Sammy.Handlebars.
|
||||
//
|
||||
// Handlebars.js is an extension to the Mustache templating language created by Chris Wanstrath. Handlebars.js
|
||||
// and Mustache are both logicless templating languages that keep the view and the code separated like
|
||||
// we all know they should be.
|
||||
//
|
||||
// By default using Sammy.Handlbars in your app adds the <tt>handlebars()</tt> method to the EventContext
|
||||
// prototype. However, just like <tt>Sammy.Template</tt> you can change the default name of the method
|
||||
// by passing a second argument (e.g. you could use the hbr() as the method alias so that all the template
|
||||
// files could be in the form file.hbr instead of file.handlebars)
|
||||
//
|
||||
// ### Example #1
|
||||
//
|
||||
// The template (mytemplate.hb):
|
||||
//
|
||||
// <h1>{{title}}<h1>
|
||||
//
|
||||
// Hey, {{name}}! Welcome to Handlebars!
|
||||
//
|
||||
// The app:
|
||||
//
|
||||
// var app = $.sammy(function() {
|
||||
// // include the plugin and alias handlebars() to hb()
|
||||
// this.use('Handlebars', 'hb');
|
||||
//
|
||||
// this.get('#/hello/:name', function() {
|
||||
// // set local vars
|
||||
// this.title = 'Hello!'
|
||||
// this.name = this.params.name;
|
||||
// // render the template and pass it through handlebars
|
||||
// this.partial('mytemplate.hb');
|
||||
// });
|
||||
// });
|
||||
//
|
||||
// $(function() {
|
||||
// app.run()
|
||||
// });
|
||||
//
|
||||
// If I go to #/hello/AQ in the browser, Sammy will render this to the <tt>body</tt>:
|
||||
//
|
||||
// <h1>Hello!</h1>
|
||||
//
|
||||
// Hey, AQ! Welcome to Handlebars!
|
||||
//
|
||||
//
|
||||
// ### Example #2 - Handlebars partials
|
||||
//
|
||||
// The template (mytemplate.hb)
|
||||
//
|
||||
// Hey, {{name}}! {{>hello_friend}}
|
||||
//
|
||||
//
|
||||
// The partial (mypartial.hb)
|
||||
//
|
||||
// Say hello to your friend {{friend}}!
|
||||
//
|
||||
// The app:
|
||||
//
|
||||
// var app = $.sammy(function() {
|
||||
// // include the plugin and alias handlebars() to hb()
|
||||
// this.use('Handlebars', 'hb');
|
||||
//
|
||||
// this.get('#/hello/:name/to/:friend', function(context) {
|
||||
// // fetch handlebars-partial first
|
||||
// this.load('mypartial.hb')
|
||||
// .then(function(partial) {
|
||||
// // set local vars
|
||||
// context.partials = {hello_friend: partial};
|
||||
// context.name = context.params.name;
|
||||
// context.friend = context.params.friend;
|
||||
//
|
||||
// // render the template and pass it through handlebars
|
||||
// context.partial('mytemplate.hb');
|
||||
// });
|
||||
// });
|
||||
// });
|
||||
//
|
||||
// $(function() {
|
||||
// app.run()
|
||||
// });
|
||||
//
|
||||
// If I go to #/hello/AQ/to/dP in the browser, Sammy will render this to the <tt>body</tt>:
|
||||
//
|
||||
// Hey, AQ! Say hello to your friend dP!
|
||||
//
|
||||
// Note: You dont have to include the handlebars.js file on top of the plugin as the plugin
|
||||
// includes the full source.
|
||||
//
|
||||
Sammy.Handlebars = function(app, method_alias) {
|
||||
var handlebars_cache = {};
|
||||
// *Helper* Uses handlebars.js to parse a template and interpolate and work with the passed data
|
||||
//
|
||||
// ### Arguments
|
||||
//
|
||||
// * `template` A String template.
|
||||
// * `data` An Object containing the replacement values for the template.
|
||||
// data is extended with the <tt>EventContext</tt> allowing you to call its methods within the template.
|
||||
//
|
||||
var handlebars = function(template, data, partials, name) {
|
||||
// use name for caching
|
||||
if (typeof name == 'undefined') { name = template; }
|
||||
var fn = handlebars_cache[name];
|
||||
if (!fn) {
|
||||
fn = handlebars_cache[name] = Handlebars.compile(template);
|
||||
}
|
||||
|
||||
data = $.extend({}, this, data);
|
||||
partials = $.extend({}, data.partials, partials);
|
||||
|
||||
return fn(data, {"partials":partials});
|
||||
};
|
||||
|
||||
// set the default method name/extension
|
||||
if (!method_alias) { method_alias = 'handlebars'; }
|
||||
app.helper(method_alias, handlebars);
|
||||
};
|
||||
|
||||
return Sammy.Handlebars;
|
||||
|
||||
}));
|
126
js/vendor/sammy.mustache.js
vendored
126
js/vendor/sammy.mustache.js
vendored
|
@ -1,126 +0,0 @@
|
|||
(function (factory) {
|
||||
if (typeof define === 'function' && define.amd) {
|
||||
define(['jquery', 'sammy', 'mustache'], factory);
|
||||
} else {
|
||||
(window.Sammy = window.Sammy || {}).Mustache = factory(window.jQuery, window.Sammy, window.Mustache);
|
||||
}
|
||||
}(function ($, Sammy, Mustache) {
|
||||
|
||||
// <tt>Sammy.Mustache</tt> provides a quick way of using mustache style templates in your app.
|
||||
// The plugin wraps the awesome mustache.js lib created and maintained by Jan Lehnardt
|
||||
// at http://github.com/janl/mustache.js
|
||||
//
|
||||
// Note: As of Sammy 0.7 the Mustache lib is not included in the templates source. Please download
|
||||
// mustache.js and include it before Sammy.Mustache.
|
||||
//
|
||||
// Mustache is a clever templating system that relys on double brackets {{}} for interpolation.
|
||||
// For full details on syntax check out the original Ruby implementation created by Chris Wanstrath at
|
||||
// http://github.com/defunkt/mustache
|
||||
//
|
||||
// By default using Sammy.Mustache in your app adds the <tt>mustache()</tt> method to the EventContext
|
||||
// prototype. However, just like <tt>Sammy.Template</tt> you can change the default name of the method
|
||||
// by passing a second argument (e.g. you could use the ms() as the method alias so that all the template
|
||||
// files could be in the form file.ms instead of file.mustache)
|
||||
//
|
||||
// ### Example #1
|
||||
//
|
||||
// The template (mytemplate.ms):
|
||||
//
|
||||
// <h1>{{title}}<h1>
|
||||
//
|
||||
// Hey, {{name}}! Welcome to Mustache!
|
||||
//
|
||||
// The app:
|
||||
//
|
||||
// var app = $.sammy(function() {
|
||||
// // include the plugin and alias mustache() to ms()
|
||||
// this.use('Mustache', 'ms');
|
||||
//
|
||||
// this.get('#/hello/:name', function() {
|
||||
// // set local vars
|
||||
// this.title = 'Hello!'
|
||||
// this.name = this.params.name;
|
||||
// // render the template and pass it through mustache
|
||||
// this.partial('mytemplate.ms');
|
||||
// });
|
||||
// });
|
||||
//
|
||||
// $(function() {
|
||||
// app.run()
|
||||
// });
|
||||
//
|
||||
// If I go to #/hello/AQ in the browser, Sammy will render this to the <tt>body</tt>:
|
||||
//
|
||||
// <h1>Hello!</h1>
|
||||
//
|
||||
// Hey, AQ! Welcome to Mustache!
|
||||
//
|
||||
//
|
||||
// ### Example #2 - Mustache partials
|
||||
//
|
||||
// The template (mytemplate.ms)
|
||||
//
|
||||
// Hey, {{name}}! {{>hello_friend}}
|
||||
//
|
||||
//
|
||||
// The partial (mypartial.ms)
|
||||
//
|
||||
// Say hello to your friend {{friend}}!
|
||||
//
|
||||
// The app:
|
||||
//
|
||||
// var app = $.sammy(function() {
|
||||
// // include the plugin and alias mustache() to ms()
|
||||
// this.use('Mustache', 'ms');
|
||||
//
|
||||
// this.get('#/hello/:name/to/:friend', function(context) {
|
||||
// // fetch mustache-partial first
|
||||
// this.load('mypartial.ms')
|
||||
// .then(function(partial) {
|
||||
// // set local vars
|
||||
// context.partials = {hello_friend: partial};
|
||||
// context.name = context.params.name;
|
||||
// context.friend = context.params.friend;
|
||||
//
|
||||
// // render the template and pass it through mustache
|
||||
// context.partial('mytemplate.ms');
|
||||
// });
|
||||
// });
|
||||
// });
|
||||
//
|
||||
// $(function() {
|
||||
// app.run()
|
||||
// });
|
||||
//
|
||||
// If I go to #/hello/AQ/to/dP in the browser, Sammy will render this to the <tt>body</tt>:
|
||||
//
|
||||
// Hey, AQ! Say hello to your friend dP!
|
||||
//
|
||||
// Note: You need to include the mustache.js file before this plugin.
|
||||
//
|
||||
Sammy.Mustache = function(app, method_alias) {
|
||||
|
||||
// *Helper* Uses Mustache.js to parse a template and interpolate and work with the passed data
|
||||
//
|
||||
// ### Arguments
|
||||
//
|
||||
// * `template` A String template. {{}} Tags are evaluated and interpolated by Mustache.js
|
||||
// * `data` An Object containing the replacement values for the template.
|
||||
// data is extended with the <tt>EventContext</tt> allowing you to call its methods within the template.
|
||||
// * `partials` An Object containing one or more partials (String templates
|
||||
// that are called from the main template).
|
||||
//
|
||||
var mustache = function(template, data, partials) {
|
||||
data = $.extend({}, this, data);
|
||||
partials = $.extend({}, data.partials, partials);
|
||||
return Mustache.to_html(template, data, partials);
|
||||
};
|
||||
|
||||
// set the default method name/extension
|
||||
if (!method_alias) { method_alias = 'mustache'; }
|
||||
app.helper(method_alias, mustache);
|
||||
};
|
||||
|
||||
return Sammy.Mustache;
|
||||
|
||||
}));
|
Loading…
Add table
Reference in a new issue