-
Notifications
You must be signed in to change notification settings - Fork 0
0.3.0 Templates
var T = require('osws-templates');
Available only on the server!
(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"
(id: string) => Module.exports
As require, but do not cache the result.
// module.js
module.exports = 1;
// index.js
T.include('module.js');
// => 1
(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' }
(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"
});
(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' });
(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"
};
- TData: Renderer|sync|async|Mixin
- TCallback: (error, result) => void
- TSelector: string
- TInjector: () => void
- TAttributes: [name: string]: TData
- TContext: TData
Node.js:
var T = require('oswst');
Require.js:
define(['oswst'], function(T) {});
window
:
var T = window.oswst(_, async);
-
Templates
- .compile
- .include
- .render
- .renderContext
- .renderAttributes
- .renderSelector
- .sync
- .isSyncFunction
- .async
- .isAsyncFunction
- .Prototype()
- .Renderer > .Prototype
- .Data > .Renderer
- .data > .Data
- .Tag > .data
- .Single > .Tag
- .singles[string]
- .Double > .Tag
- .doubles[string]
- .Doctype > .Tag
- .doctypes[string]
- .xml > .Tag
- .Mixin > .Data
- .mixin > .Mixin
- .mixins[string]
- .Module > .Renderer
- .with