2
0
Fork 0
es5-ff-spa-loader/example/app_server/example.js

128 lines
4.6 KiB
JavaScript
Raw Normal View History

2015-12-23 00:16:54 +00:00
'use strict';
2016-01-24 20:38:21 +00:00
var httpPort = 9090;
2015-12-23 00:16:54 +00:00
var express = require('express');
var path = require('path');
var fs = require('fs');
2016-01-14 21:42:13 +00:00
var fetch = require('fetch');
var cors = require('cors');
2016-01-17 20:57:59 +00:00
var morgan = require('morgan');
2016-01-24 20:38:21 +00:00
var UglifyJS = require("uglify-js");
var Hashes = require('jshashes');
2016-01-14 21:42:13 +00:00
var clientResourcesWeb = [];
var clientResources = {
js: [],
css: [],
cssData: []
2016-01-17 20:57:59 +00:00
};
2016-01-14 21:42:13 +00:00
var addClientResource = function(clientResource, resourceType) {
clientResources[resourceType].push(clientResource);
2016-01-17 20:57:59 +00:00
};
2015-12-23 00:16:54 +00:00
2016-01-14 21:42:13 +00:00
var fetchHashResource = function(fetchEntry,cb) {
2016-01-24 20:38:21 +00:00
var serverUrl = 'http://localhost:'+httpPort;
var hashDigest = new Hashes.SHA1;
2016-01-14 21:42:13 +00:00
fetch.fetchUrl(serverUrl + fetchEntry.url,function(err, meta, data) {
if (err !== null) { return cb(err); }
2016-01-24 20:38:21 +00:00
var assetHash = hashDigest.hex(''+data);
2016-01-14 21:42:13 +00:00
clientResourcesWeb.push({
url: fetchEntry.url,
type: fetchEntry.type,
hash: assetHash
});
cb(null);
});
};
var fetchHashResources = function(fetchList, cb) {
var resourceStack = fetchList;
var resourceLoader = function() {
resourceStack = resourceStack.slice(1);
if (resourceStack.length === 0) {
cb(null);
} else {
fetchHashResource(resourceStack[0],resourceLoader);
}
};
fetchHashResource(resourceStack[0],resourceLoader);
};
var createClientResourceFetchList = function() {
var fetchList = [];
2016-01-17 20:57:59 +00:00
for (var clientResourceIdxJs in clientResources.js) {
var urlJs = clientResources.js[clientResourceIdxJs];
fetchList.push({url:urlJs,type:'js'});
2016-01-14 21:42:13 +00:00
}
2016-01-17 20:57:59 +00:00
for (var clientResourceIdxCss in clientResources.css) {
var urlCss = clientResources.css[clientResourceIdxCss];
fetchList.push({url:urlCss,type:'css'});
2016-01-14 21:42:13 +00:00
}
2016-01-17 20:57:59 +00:00
for (var clientResourceIdxCssData in clientResources.cssData) {
var urlCssData = clientResources.cssData[clientResourceIdxCssData];
fetchList.push({url:urlCssData,type:'cssData'});
2016-01-14 21:42:13 +00:00
}
return fetchList;
};
2015-12-23 00:16:54 +00:00
function renderTemplatePath(viewPath) {
return function (req, res) {
res.locals.query = req.query;
var qi = req.url.indexOf('?');
if (qi === -1) {
qi = req.url.length;
}
res.render(viewPath + req.url.substring(req.route.path.length-1, qi));
};
}
2016-01-17 20:57:59 +00:00
function renderIndex() {
2015-12-23 00:16:54 +00:00
return function (req, res) {
2016-01-24 20:38:21 +00:00
var inlineScript = UglifyJS.minify(__dirname+'/../../es5-ff-spa-loader.js');
2015-12-23 00:16:54 +00:00
res.render('index', {
2016-01-24 20:38:21 +00:00
inlineScript: inlineScript.code
2015-12-23 00:16:54 +00:00
});
};
}
2016-01-24 20:38:21 +00:00
// Add resources ORDERED per type
2016-01-14 21:42:13 +00:00
addClientResource('/static/module/jquery/jquery.js','js');
addClientResource('/static/module/angular/angular.js','js');
addClientResource('/static/module/angular-route/angular-route.js','js');
addClientResource('/static/module/bootstrap/css/bootstrap.css','css');
addClientResource('/static/module/bootstrap/js/bootstrap.js','js');
addClientResource('/static/css/boot.css','css');
addClientResource('/static/css/style.css','css');
2016-01-24 20:38:21 +00:00
addClientResource('/static/js/example-app.js','js'); // deps: jquery,angular
addClientResource('/static/js/controller/page-bar.js','js'); // deps: example-app.js
2016-01-14 21:42:13 +00:00
addClientResource('/static/js/controller/page-foo.js','js');
addClientResource('/static/js/controller/page-index.js','js');
2015-12-23 00:16:54 +00:00
var server = express();
2016-01-17 20:57:59 +00:00
server.use(morgan('dev'));
2016-01-14 21:42:13 +00:00
server.use(cors({credentials: true, origin: '*'}));
server.set('view engine', 'ejs');
server.set('views', path.join(__dirname,'www_views'));
2016-02-26 23:24:43 +00:00
server.use(function(req, res, next) { res.header('X-My-Api', 'noknok');next(); });
2016-01-14 21:42:13 +00:00
server.use('/static', express.static(path.join(__dirname,'www_static')));
2016-01-24 20:38:21 +00:00
server.use('/static/module/bootstrap', express.static(path.join(__dirname,'../node_modules/bootstrap/dist')));
server.use('/static/module/jquery', express.static(path.join(__dirname,'../node_modules/jquery/dist')));
server.use('/static/module/angular', express.static(path.join(__dirname,'../node_modules/angular')));
server.use('/static/module/angular-route', express.static(path.join(__dirname,'../node_modules/angular-route')));
server.get('/static/spa-client-resources', function (req,res) {res.json({data: {resources: clientResourcesWeb}});});
2016-02-16 15:09:23 +00:00
server.get('/static/spa-loader.css', function (req,res) {res.sendFile('es5-ff-spa-loader.css', { root: path.join(__dirname, '/../../') });});
2016-01-24 20:38:21 +00:00
server.get('/', function (req, res) {res.redirect('/example-ui');});
server.get('/example-ui/thtml/*', renderTemplatePath('thtml/'));
server.get('/example-ui', renderIndex());
server.listen(httpPort);
console.info('Server started on port '+httpPort);
2016-01-14 21:42:13 +00:00
var res = createClientResourceFetchList();
fetchHashResources(res, function(err) {
2016-01-17 20:57:59 +00:00
if (err !== null) {console.log(err);}
2016-01-14 21:42:13 +00:00
console.log('Total assets build: '+clientResourcesWeb.length);
});