forked from sheetjs/sheetjs
SheetJS
f03e32fc9a
- frameworks: react, react-native, preact, next.js, weex, nuxt.js - deployments: nodejs server, duktape, chakra, electron, nw.js
42 lines
1.4 KiB
JavaScript
42 lines
1.4 KiB
JavaScript
/* xlsx.js (C) 2013-present SheetJS -- http://sheetjs.com */
|
|
var Hapi = require('hapi'), server = new Hapi.Server();
|
|
var logit = require('./_logit');
|
|
var Worker = require('webworker-threads').Worker;
|
|
var data = "a,b,c\n1,2,3".split("\n").map(x => x.split(","));
|
|
|
|
function get_data(req, res, type) {
|
|
var work = new Worker(function(){
|
|
var XLSX = require('xlsx');
|
|
this.onmessage = function(e) {
|
|
console.log("get data " + e.data);
|
|
var ws = XLSX.utils.aoa_to_sheet(e.data[1]);
|
|
var wb = XLSX.utils.book_new();
|
|
XLSX.utils.book_append_sheet(wb, ws, "SheetJS");
|
|
console.log("prepared wb");
|
|
postMessage(XLSX.write(wb, {type:'binary', bookType:type}));
|
|
console.log("sent data");
|
|
};
|
|
});
|
|
work.onmessage = function(e) { console.log(e); res(e); };
|
|
work.postMessage([type, data]);
|
|
}
|
|
|
|
var port = 7262;
|
|
server.connection({ host:'localhost', port: port});
|
|
|
|
server.route({ method: 'GET', path: '/', handler: function(req, res) {
|
|
logit(req.raw.req, req.raw.res);
|
|
if(req.query.t) return get_data(req, res, req.query.t);
|
|
else if(req.query.f) return get_file(req, res, req.query.f);
|
|
return res('Forbidden').code(403);
|
|
}});
|
|
server.route({ method: 'POST', path: '/', handler: function(req, res) {
|
|
logit(req.raw.req, req.raw.res);
|
|
if(req.query.f) return post_file(req, res, req.query.f);
|
|
return post_data(req, res);
|
|
}});
|
|
server.start(function(err) {
|
|
if(err) throw err;
|
|
console.log('Serving HTTP on port ' + port);
|
|
});
|