Skip to content

0.3.0 Templates

ivansglazunov edited this page Feb 17, 2015 · 15 revisions

Templates

var T = require('osws-templates');

sources/compile

Available only on the server!

.compile

(filebody: string, filepath: string) => Module.exports

String as a separate module.

Do not cache the result.

T.compile('module.exports = __dirname;', 'script.js');
// => "script.js"

.include

(id: string) => Module.exports

As require, but do not cache the result.

// module.js
module.exports = 1;
// index.js
T.include('module.js');
// => 1

sources/render

.render

(data: TData, callback: TCallback, context?: TContext) => void

Universal renderer.

Ignores native data JavaScript. Processes only the data of module.

Asynchronous only.

Not for manual use! For internal use only!

// syntax example
T.render(123, function(error, result) {
    error // null
    result // 123
}, { a: 1 });

// native data
T.render(123, console.log); // null, 123
T.render('string', console.log); // null, "string"
T.render(function() {}, console.log); // null, function() {}
T.render([1, 2, 3], console.log); // null, [1, 2, 3]
T.render({ a: 1, b: 2, c: 3}, console.log); // null, { a: 1, b: 2, c: 3 }

// data of module
T.render(T.sync(function() { return 123; }), console.log); // null, 123
T.render(T.async(function(callback) { callback(null, 123); }), console.log); // null, 123
T.render(T.Renderer().data(123)), console.log); // null, 123
T.render([
    T.sync(function() { return 1; }),
    T.async(function() { callback(null, 2); }),
    T.Renderer().data(3)
], console.log); // null, [1, 2, '3']
T.render({
    a: T.sync(function() { return 1; }),
    b: T.async(function() { callback(null, 2); }),
    c: T.Renderer().data(3)
}); // null, { a: 1, b: 2, c: '3' }

.renderContext

(string: string, context: Object, callback: TCallback) => void;

By default - wrap around method _.template.

You can override this method in its sole discretion.

Asynchronous only.

Not for manual use! For internal use only!

T.renderContext('<%= a %>', { a: 1 }, function(error, result) {
    error // null
    result // "1"
});

.renderAttributes

(attributes: TAttributes, callback: TCallback, context?: TContext => void

Hash object representing attributes turns into a string syntax XML/XHML/HTML.

T.renderAttributes({
    a: 'string',
    b: null,
    c: T.sync(function() { return 'sync' }),
    d: T.async(function(callback) { callback(null, 'async'); }),
    e: T.Renderer().data('<%= e %>')
}, function(error, result) {
    error // null
    result // ' a="string" b c="sync" d="async" e="data"'
}, { e: 'data' });

.renderSelector

(attributes: TAttributes, selector: TSelector) => void;

Parser for userful TSelector.

Used regular expressions:

(/(\[)|(\])|#([-\w\d]+)|\.([-\w\d]+)|([\w\d-]+)="(['\w\d\s-:\\\/\.\,\]\[={}<>%@#$%^&*~`]*)"|([\w\d-]+)='(["\w\d\s-:\\\/\.\,\]\[={}<>%@#$%^&*~`]*)'|([\w\d-]+)=([\w\d-:\\\/\.={}<>%@#$%^&*~`]*)|("['\w\d\s-:\\\/\.\,\]\[={}<>%@#$%^&*~`]+")|('["\w\d\s-:\\\/\.\,\]\[={}<>%@#$%^&*~`]+')|([_\w-:\\\/]+)/g)

Tested here: (https://www.regex101.com/r/cM5jC6/13)[https://www.regex101.com/r/cM5jC6/13]

With selector:

.class-name.withBig.letters.AndFromIt#Id1#Id2[attr1=http://link.without/quotes.png,attr2='http://link.with/single/quotes'][attr3="http://link.with/double/quotes",attr4'attr5' "attr6"][alt=#simple!]

Result:

var attributes = {};
T.renderSelector = function(attributes, selector) {
    class: 'class-name withBig letters AndFromIt',
    id: 'Id2',
    attr1: 'http://link.without/quotes.png',
    attr2: 'http://link.with/single/quotes',
    attr3: "http://link.with/double/quotes",
    attr4: null,
    "'attr5'": null,
    '"attr6"': null,
    alt: "#simple"
};
Clone this wiki locally