1
0
mirror of /repos/Prototyper.git synced 2025-12-31 06:41:29 +01:00
Prototyper/preview.js
2013-04-20 01:23:21 +02:00

170 lines
5.3 KiB
JavaScript

var Handlebars = require('handlebars');
var markdown = require('markdown').markdown;
var _ = require('underscore');
var less = require('less');
var when = require('when');
module.exports = function (config, mongodataInstance) {
var sourceHead =
'<script src="//cdnjs.cloudflare.com/ajax/libs/modernizr/2.6.2/modernizr.min.js"></script>\n' +
'{{#if debug}}' +
'<link href="/content/{{collection}}/{{name}}/style.css" media="all" rel="stylesheet/less" type="text/css">\n' +
'<script src="//cdnjs.cloudflare.com/ajax/libs/less.js/1.3.3/less.min.js"></script>\n' +
'{{else}}' +
'<link href="/content/{{collection}}/{{name}}/style.css" media="all" rel="stylesheet" type="text/css">\n' +
'{{/if}}';
var sourceBody =
'<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>\n' +
'<script src="//cdnjs.cloudflare.com/ajax/libs/knockout/2.2.1/knockout-min.js"></script>\n' +
'<script src="//cdnjs.cloudflare.com/ajax/libs/knockout-validation/1.0.2/knockout.validation.min.js"></script>\n' +
'<script src="//cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/2.3.1/js/bootstrap.min.js"></script>\n' +
'<script src="/content/{{collection}}/{{name}}/behaviour.js"></script>\n';
var getPreviewHTML = function (options, content, callback) {
config.debug && console.log('getPreviewHTML',content);
var html = content;
var promises = replaceMarkers(options, html);
when.all(
promises,
function onSucces (results) {
console.log('getPreviewHTML replaceMakers results',results);
_.forEach(results, function (result) {
if (result) {
html = html.replaceAll(result.regExp, result.replacement);
}
});
return callback(null, html);
},
function onFailure(err) {
return callback(err);
}
)
};
var replaceMarkers = function (options, html) {
function replace(marker, getReplacement) {
var deferred = when.defer();
var regExp = new RegExp('<!--\\s*@@' + marker + '\\s*-->');
var result = html.match(regExp);
if (result) {
getReplacement(result, function (err, replacement) {
if (err) {
deferred.reject(err);
} else {
deferred.resolve({regExp:regExp, replacement:replacement})
}
})
} else {
deferred.resolve();
}
return deferred.promise;
}
console.log('marker options',options);
var promises = [];
/* markers:
[type]_[collection]_[name]_[attribute]
script -> <script src="/content/collection/name/attribute.js"/>
style -> <link href="/content/collection/name/attribute.css" media="all" rel="stylesheet" type="text/css">
markdown_[collection]_[nameX]_[attribute]
markdown -> parse /content/collection/name/attribute into html and include
template_[collectionX]_[nameX]_[attributeX]_context_[collectionY]_[nameY]
template -> put /content/collectionX/nameX/attributeX thru handlebars.. context=collectionY/nameY/attributeY and include
remove_.*_end_remove
remove_ -> removes markers and everything in between
[type]_[collection]_[name]
script -> <script src="/content/collection/name.js"/>
contains all type='script' attributes concatenated based on 'order'
style -> <link href="/content/collection/name.css" media="all" rel="stylesheet" type="text/css">
contains all type='style' attributes concatenated based on 'order'
*/
promises.push(
replace('script_([A-Za-z0-9]+)_([A-Za-z0-9]+)_([A-Za-z0-9]+)', function (result, callback) {
var context = {
collection: result[0],
name: result[1],
attribute: result[2]
};
return callback( null,
'<script src="/content/' + context.collection + '/' + context.name + '/' + context.attribute + '.js"/>\n'
);
}));
promises.push(
replace('style_([A-Za-z0-9]+)_([A-Za-z0-9]+)_([A-Za-z0-9]+)', function (result, callback) {
var context = {
collection: result[0],
name: result[1],
attribute: result[2]
};
return callback( null,
'<link href="/content/' + context.collection + '/' + context.name + '/' + context.attribute + '.css" media="all" rel="stylesheet" type="text/css">\n'
);
}));
promises.push(
replace('template_([A-Za-z0-9]+)_([A-Za-z0-9]+)_([A-Za-z0-9]+)_context_([A-Za-z0-9]+)_([A-Za-z0-9]+)',
function (result, callback) {
var template = {
collection: result[0],
name: result[1],
attribute: result[2]
};
var context = {
collection: result[3],
name: result[4]
};
mongodataInstance.getMongoAttribute(template, function (err, result) {
if (err) {
return callback(err);
}
var template = Handlebars.compile(result[options.attribute]);
mongodataInstance.getMongoContent(context, function (err, result) {
if (err) {
return callback(err);
}
return callback(null, template(result));
});
});
}));
promises.push(
replace('markdown_([A-Za-z0-9]+)_([A-Za-z0-9]+)_([A-Za-z0-9]+)', function (result, callback) {
var attribute = {
collection: result[0],
name: result[1],
attribute: result[2]
};
mongodataInstance.getMongoAttribute(attribute, function (err, result) {
if (err) {
return callback(err);
}
var html = markdown.toHTML(result[options.attribute]);
return callback(null, html);
});
}));
return promises;
};
return {
getPreviewHTML: getPreviewHTML,
_replaceMarkers: replaceMarkers
};
};