style Dashboard

This commit is contained in:
Lieu Le
2019-09-13 11:27:52 +07:00
parent 558fb07261
commit 07322c9084
17151 changed files with 1686347 additions and 103 deletions

145
node_modules/tiny-lr/src/client.js generated vendored Normal file
View File

@@ -0,0 +1,145 @@
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _events = require('events');
var _events2 = _interopRequireDefault(_events);
var _fayeWebsocket = require('faye-websocket');
var _fayeWebsocket2 = _interopRequireDefault(_fayeWebsocket);
var _objectAssign = require('object-assign');
var _objectAssign2 = _interopRequireDefault(_objectAssign);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
var debug = require('debug')('tinylr:client');
var idCounter = 0;
var Client = function (_events$EventEmitter) {
_inherits(Client, _events$EventEmitter);
function Client(req, socket, head) {
var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
_classCallCheck(this, Client);
var _this = _possibleConstructorReturn(this, (Client.__proto__ || Object.getPrototypeOf(Client)).call(this));
_this.options = options;
_this.ws = new _fayeWebsocket2.default(req, socket, head);
_this.ws.onmessage = _this.message.bind(_this);
_this.ws.onclose = _this.close.bind(_this);
_this.id = _this.uniqueId('ws');
return _this;
}
_createClass(Client, [{
key: 'message',
value: function message(event) {
var data = this.data(event);
if (this[data.command]) return this[data.command](data);
}
}, {
key: 'close',
value: function close(event) {
if (this.ws) {
this.ws.close();
this.ws = null;
}
this.emit('end', event);
}
// Commands
}, {
key: 'hello',
value: function hello() {
this.send({
command: 'hello',
protocols: ['http://livereload.com/protocols/official-7'],
serverName: 'tiny-lr'
});
}
}, {
key: 'info',
value: function info(data) {
if (data) {
debug('Info', data);
this.emit('info', (0, _objectAssign2.default)({}, data, { id: this.id }));
this.plugins = data.plugins;
this.url = data.url;
}
return (0, _objectAssign2.default)({}, data || {}, { id: this.id, url: this.url });
}
// Server commands
}, {
key: 'reload',
value: function reload(files) {
files.forEach(function (file) {
this.send({
command: 'reload',
path: file,
liveCSS: this.options.liveCSS !== false,
reloadMissingCSS: this.options.reloadMissingCSS !== false,
liveImg: this.options.liveImg !== false
});
}, this);
}
}, {
key: 'alert',
value: function alert(message) {
this.send({
command: 'alert',
message: message
});
}
// Utilities
}, {
key: 'data',
value: function data(event) {
var data = {};
try {
data = JSON.parse(event.data);
} catch (e) {}
return data;
}
}, {
key: 'send',
value: function send(data) {
if (!this.ws) return;
this.ws.send(JSON.stringify(data));
}
}, {
key: 'uniqueId',
value: function uniqueId(prefix) {
var id = idCounter++;
return prefix ? prefix + id : id;
}
}]);
return Client;
}(_events2.default.EventEmitter);
exports.default = Client;
module.exports = exports['default'];

61
node_modules/tiny-lr/src/index.js generated vendored Normal file
View File

@@ -0,0 +1,61 @@
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _server = require('./server');
var _server2 = _interopRequireDefault(_server);
var _client = require('./client');
var _client2 = _interopRequireDefault(_client);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var debug = require('debug')('tinylr');
// Need to keep track of LR servers when notifying
var servers = [];
exports.default = tinylr;
// Expose Server / Client objects
tinylr.Server = _server2.default;
tinylr.Client = _client2.default;
// and the middleware helpers
tinylr.middleware = middleware;
tinylr.changed = changed;
// Main entry point
function tinylr(opts) {
var srv = new _server2.default(opts);
servers.push(srv);
return srv;
}
// A facade to Server#handle
function middleware(opts) {
var srv = new _server2.default(opts);
servers.push(srv);
return function tinylr(req, res, next) {
srv.handler(req, res, next);
};
}
// Changed helper, helps with notifying the server of a file change
function changed(done) {
var files = [].slice.call(arguments);
if (typeof files[files.length - 1] === 'function') done = files.pop();
done = typeof done === 'function' ? done : function () {};
debug('Notifying %d servers - Files: ', servers.length, files);
servers.forEach(function (srv) {
var params = { params: { files: files } };
srv && srv.changed(params);
});
done();
}
module.exports = exports['default'];

396
node_modules/tiny-lr/src/server.js generated vendored Normal file
View File

@@ -0,0 +1,396 @@
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _fs = require('fs');
var _fs2 = _interopRequireDefault(_fs);
var _http = require('http');
var _http2 = _interopRequireDefault(_http);
var _https = require('https');
var _https2 = _interopRequireDefault(_https);
var _events = require('events');
var _events2 = _interopRequireDefault(_events);
var _url = require('url');
var _client = require('./client');
var _client2 = _interopRequireDefault(_client);
var _package = require('../package.json');
var _package2 = _interopRequireDefault(_package);
var _any = require('body/any');
var _any2 = _interopRequireDefault(_any);
var _qs = require('qs');
var _qs2 = _interopRequireDefault(_qs);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
var debug = require('debug')('tinylr:server');
var CONTENT_TYPE = 'content-type';
var FORM_TYPE = 'application/x-www-form-urlencoded';
function buildRootPath() {
var prefix = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '/';
var rootUrl = prefix;
// Add trailing slash
if (prefix[prefix.length - 1] !== '/') {
rootUrl = rootUrl + '/';
}
// Add leading slash
if (prefix[0] !== '/') {
rootUrl = '/' + rootUrl;
}
return rootUrl;
}
var Server = function (_events$EventEmitter) {
_inherits(Server, _events$EventEmitter);
function Server() {
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
_classCallCheck(this, Server);
var _this = _possibleConstructorReturn(this, (Server.__proto__ || Object.getPrototypeOf(Server)).call(this));
_this.options = options;
options.livereload = options.livereload || require.resolve('livereload-js/dist/livereload.js');
// todo: change falsy check to allow 0 for random port
options.port = parseInt(options.port || 35729, 10);
if (options.errorListener) {
_this.errorListener = options.errorListener;
}
_this.rootPath = buildRootPath(options.prefix);
_this.clients = {};
_this.configure(options.app);
_this.routes(options.app);
return _this;
}
_createClass(Server, [{
key: 'routes',
value: function routes() {
if (!this.options.dashboard) {
this.on('GET ' + this.rootPath, this.index.bind(this));
}
this.on('GET ' + this.rootPath + 'changed', this.changed.bind(this));
this.on('POST ' + this.rootPath + 'changed', this.changed.bind(this));
this.on('POST ' + this.rootPath + 'alert', this.alert.bind(this));
this.on('GET ' + this.rootPath + 'livereload.js', this.livereload.bind(this));
this.on('GET ' + this.rootPath + 'kill', this.close.bind(this));
}
}, {
key: 'configure',
value: function configure(app) {
var _this2 = this;
debug('Configuring %s', app ? 'connect / express application' : 'HTTP server');
var handler = this.options.handler || this.handler;
if (!app) {
if (this.options.key && this.options.cert || this.options.pfx) {
this.server = _https2.default.createServer(this.options, handler.bind(this));
} else {
this.server = _http2.default.createServer(handler.bind(this));
}
this.server.on('upgrade', this.websocketify.bind(this));
this.server.on('error', this.error.bind(this));
return this;
}
this.app = app;
this.app.listen = function (port, done) {
done = done || function () {};
if (port !== _this2.options.port) {
debug('Warn: LiveReload port is not standard (%d). You are listening on %d', _this2.options.port, port);
debug('You\'ll need to rely on the LiveReload snippet');
debug('> http://feedback.livereload.com/knowledgebase/articles/86180-how-do-i-add-the-script-tag-manually-');
}
var srv = _this2.server = _http2.default.createServer(app);
srv.on('upgrade', _this2.websocketify.bind(_this2));
srv.on('error', _this2.error.bind(_this2));
srv.on('close', _this2.close.bind(_this2));
return srv.listen(port, done);
};
return this;
}
}, {
key: 'handler',
value: function handler(req, res, next) {
var _this3 = this;
var middleware = typeof next === 'function';
debug('LiveReload handler %s (middleware: %s)', req.url, middleware ? 'on' : 'off');
next = next || this.defaultHandler.bind(this, res);
req.headers[CONTENT_TYPE] = req.headers[CONTENT_TYPE] || FORM_TYPE;
return (0, _any2.default)(req, res, function (err, body) {
if (err) return next(err);
req.body = body;
if (!req.query) {
req.query = req.url.indexOf('?') !== -1 ? _qs2.default.parse((0, _url.parse)(req.url).query) : {};
}
return _this3.handle(req, res, next);
});
}
}, {
key: 'index',
value: function index(req, res) {
res.setHeader('Content-Type', 'application/json');
res.write(JSON.stringify({
tinylr: 'Welcome',
version: _package2.default.version
}));
res.end();
}
}, {
key: 'handle',
value: function handle(req, res, next) {
var url = (0, _url.parse)(req.url);
debug('Request:', req.method, url.href);
var middleware = typeof next === 'function';
// do the routing
var route = req.method + ' ' + url.pathname;
var respond = this.emit(route, req, res);
if (respond) return;
if (middleware) return next();
// Only apply content-type on non middleware setup #70
return this.notFound(res);
}
}, {
key: 'defaultHandler',
value: function defaultHandler(res, err) {
if (!err) return this.notFound(res);
this.error(err);
res.setHeader('Content-Type', 'text/plain');
res.statusCode = 500;
res.end('Error: ' + err.stack);
}
}, {
key: 'notFound',
value: function notFound(res) {
res.setHeader('Content-Type', 'application/json');
res.writeHead(404);
res.write(JSON.stringify({
error: 'not_found',
reason: 'no such route'
}));
res.end();
}
}, {
key: 'websocketify',
value: function websocketify(req, socket, head) {
var _this4 = this;
var client = new _client2.default(req, socket, head, this.options);
this.clients[client.id] = client;
// handle socket error to prevent possible app crash, such as ECONNRESET
socket.on('error', function (e) {
// ignore frequent ECONNRESET error (seems inevitable when refresh)
if (e.code === 'ECONNRESET') return;
_this4.error(e);
});
client.once('info', function (data) {
debug('Create client %s (url: %s)', data.id, data.url);
_this4.emit('MSG /create', data.id, data.url);
});
client.once('end', function () {
debug('Destroy client %s (url: %s)', client.id, client.url);
_this4.emit('MSG /destroy', client.id, client.url);
delete _this4.clients[client.id];
});
}
}, {
key: 'listen',
value: function listen(port, host, fn) {
port = port || this.options.port;
// Last used port for error display
this.port = port;
if (typeof host === 'function') {
fn = host;
host = undefined;
}
this.server.listen(port, host, fn);
}
}, {
key: 'close',
value: function close(req, res) {
Object.keys(this.clients).forEach(function (id) {
this.clients[id].close();
}, this);
if (this.server._handle) this.server.close(this.emit.bind(this, 'close'));
if (res) res.end();
}
}, {
key: 'error',
value: function error(e) {
if (this.errorListener) {
this.errorListener(e);
return;
}
console.error();
if (typeof e === 'undefined') {
console.error('... Uhoh. Got error %s ...', e);
} else {
console.error('... Uhoh. Got error %s ...', e.message);
console.error(e.stack);
if (e.code !== 'EADDRINUSE') return;
console.error();
console.error('You already have a server listening on %s', this.port);
console.error('You should stop it and try again.');
console.error();
}
}
// Routes
}, {
key: 'livereload',
value: function livereload(req, res) {
res.setHeader('Content-Type', 'application/javascript');
_fs2.default.createReadStream(this.options.livereload).pipe(res);
}
}, {
key: 'changed',
value: function changed(req, res) {
var files = this.param('files', req);
debug('Changed event (Files: %s)', files.join(' '));
var clients = this.notifyClients(files);
if (!res) return;
res.setHeader('Content-Type', 'application/json');
res.write(JSON.stringify({
clients: clients,
files: files
}));
res.end();
}
}, {
key: 'alert',
value: function alert(req, res) {
var message = this.param('message', req);
debug('Alert event (Message: %s)', message);
var clients = this.alertClients(message);
if (!res) return;
res.setHeader('Content-Type', 'application/json');
res.write(JSON.stringify({
clients: clients,
message: message
}));
res.end();
}
}, {
key: 'notifyClients',
value: function notifyClients(files) {
var clients = Object.keys(this.clients).map(function (id) {
var client = this.clients[id];
debug('Reloading client %s (url: %s)', client.id, client.url);
client.reload(files);
return {
id: client.id,
url: client.url
};
}, this);
return clients;
}
}, {
key: 'alertClients',
value: function alertClients(message) {
var clients = Object.keys(this.clients).map(function (id) {
var client = this.clients[id];
debug('Alert client %s (url: %s)', client.id, client.url);
client.alert(message);
return {
id: client.id,
url: client.url
};
}, this);
return clients;
}
// Lookup param from body / params / query.
}, {
key: 'param',
value: function param(name, req) {
var param = void 0;
if (req.body && req.body[name]) param = req.body[name];else if (req.params && req.params[name]) param = req.params[name];else if (req.query && req.query[name]) param = req.query[name];
// normalize files array
if (name === 'files') {
param = Array.isArray(param) ? param : typeof param === 'string' ? param.split(/[\s,]/) : [];
}
return param;
}
}]);
return Server;
}(_events2.default.EventEmitter);
exports.default = Server;
module.exports = exports['default'];