mirror of
https://gitlab.silvrtree.co.uk/martind2000/frontexpress.git
synced 2025-01-25 18:16:16 +00:00
Publish to bower as well! #2
This commit is contained in:
parent
009ff8fdb9
commit
ab2feb1c30
3
.gitignore
vendored
3
.gitignore
vendored
@ -1,3 +1,2 @@
|
||||
node_modules
|
||||
coverage
|
||||
dist
|
||||
coverage
|
@ -1,13 +1,15 @@
|
||||
![frontexpress](http://fontmeme.com/embed.php?text=frontexpress&name=Atype%201%20Light.ttf&size=90&style_color=6F6F75)
|
||||
|
||||
Framework for managing front-end routes with the same API as [expressjs](http://expressjs.com/)
|
||||
Frontexpress manages routes in browser like [ExpressJS](http://expressjs.com/) does on Node.
|
||||
|
||||
Same language same API on all the stack.
|
||||
|
||||
[![Build Status](https://travis-ci.org/camelaissani/frontexpress.svg?branch=master)](https://travis-ci.org/camelaissani/frontexpress)
|
||||
[![Code Climate](https://codeclimate.com/github/camelaissani/frontexpress/badges/gpa.svg)](https://codeclimate.com/github/camelaissani/frontexpress)
|
||||
[![Coverage Status](https://coveralls.io/repos/github/camelaissani/frontexpress/badge.svg?branch=master)](https://coveralls.io/github/camelaissani/frontexpress?branch=master)
|
||||
![Coverage Status](https://david-dm.org/camelaissani/frontexpress.svg)
|
||||
|
||||
Listen user/browser navigation and manage front-end routes with **frontexpress**:
|
||||
Code the front-end logic with the same style than on the back-end with express
|
||||
|
||||
```js
|
||||
import frontexpress from 'frontexpress';
|
||||
@ -289,4 +291,4 @@ After registering a middleware function, the application invokes it with these p
|
||||
|
||||
[MIT](LICENSE)
|
||||
|
||||
|
||||
|
||||
|
29
bower.json
Normal file
29
bower.json
Normal file
@ -0,0 +1,29 @@
|
||||
{
|
||||
"name": "frontexpress",
|
||||
"description": "Frontexpress manages routes in browser like ExpressJS on Node",
|
||||
"main": "dist/frontexpress.js",
|
||||
"authors": [
|
||||
"Camel Aissani <camel.aissani@gmail.com> (https://nuageprive.fr)"
|
||||
],
|
||||
"license": "MIT",
|
||||
"keywords": [
|
||||
"front",
|
||||
"framework",
|
||||
"web",
|
||||
"router",
|
||||
"middleware",
|
||||
"app",
|
||||
"api",
|
||||
"express",
|
||||
"frontexpress"
|
||||
],
|
||||
"homepage": "https://github.com/camelaissani/frontexpress",
|
||||
"ignore": [
|
||||
"**/.*",
|
||||
"node_modules",
|
||||
"bower_components",
|
||||
"test",
|
||||
"tests",
|
||||
"coverage"
|
||||
]
|
||||
}
|
674
dist/application.js
vendored
Executable file
674
dist/application.js
vendored
Executable file
@ -0,0 +1,674 @@
|
||||
'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; }; }(); /**
|
||||
* Module dependencies.
|
||||
* @private
|
||||
*/
|
||||
|
||||
var _methods = require('./methods');
|
||||
|
||||
var _methods2 = _interopRequireDefault(_methods);
|
||||
|
||||
var _settings = require('./settings');
|
||||
|
||||
var _settings2 = _interopRequireDefault(_settings);
|
||||
|
||||
var _router = require('./router');
|
||||
|
||||
var _router2 = _interopRequireDefault(_router);
|
||||
|
||||
var _middleware = require('./middleware');
|
||||
|
||||
var _middleware2 = _interopRequireDefault(_middleware);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
|
||||
|
||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
||||
|
||||
/**
|
||||
* Application class.
|
||||
*/
|
||||
|
||||
var Application = function () {
|
||||
|
||||
/**
|
||||
* Initialize the application.
|
||||
*
|
||||
* - setup default configuration
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
function Application() {
|
||||
_classCallCheck(this, Application);
|
||||
|
||||
this.routers = [];
|
||||
this.isDOMLoaded = false;
|
||||
this.isDOMReady = false;
|
||||
this.settings = new _settings2.default();
|
||||
}
|
||||
|
||||
/**
|
||||
* Assign `setting` to `val`, or return `setting`'s value.
|
||||
*
|
||||
* app.set('foo', 'bar');
|
||||
* app.set('foo');
|
||||
* // => "bar"
|
||||
*
|
||||
* @param {String} setting
|
||||
* @param {*} [val]
|
||||
* @return {app} for chaining
|
||||
* @public
|
||||
*/
|
||||
|
||||
_createClass(Application, [{
|
||||
key: 'set',
|
||||
value: function set() {
|
||||
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
|
||||
args[_key] = arguments[_key];
|
||||
}
|
||||
|
||||
// get behaviour
|
||||
if (args.length === 1) {
|
||||
var _name = [args];
|
||||
return this.settings.get(_name);
|
||||
}
|
||||
|
||||
// set behaviour
|
||||
var name = args[0];
|
||||
var value = args[1];
|
||||
|
||||
this.settings.set(name, value);
|
||||
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Listen for DOM initialization and history state changes.
|
||||
*
|
||||
* The callback function is called once the DOM has
|
||||
* the `document.readyState` equals to 'interactive'.
|
||||
*
|
||||
* app.listen(()=> {
|
||||
* console.log('App is listening requests');
|
||||
* console.log('DOM is ready!');
|
||||
* });
|
||||
*
|
||||
*
|
||||
* @param {Function} callback
|
||||
* @public
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'listen',
|
||||
value: function listen(callback) {
|
||||
var _this = this;
|
||||
|
||||
window.onbeforeunload = function () {
|
||||
_this._callMiddlewareExited();
|
||||
};
|
||||
|
||||
window.onpopstate = function (event) {
|
||||
if (event.state) {
|
||||
var _event$state = event.state;
|
||||
var request = _event$state.request;
|
||||
var response = _event$state.response;
|
||||
|
||||
var currentRoutes = _this._routes(request.uri, request.method);
|
||||
|
||||
_this._callMiddlewareEntered(currentRoutes, request);
|
||||
_this._callMiddlewareUpdated(currentRoutes, request, response);
|
||||
}
|
||||
};
|
||||
|
||||
document.onreadystatechange = function () {
|
||||
var request = { method: 'GET', uri: window.location.pathname + window.location.search };
|
||||
var response = { status: 200, statusText: 'OK' };
|
||||
var currentRoutes = _this._routes();
|
||||
// DOM state
|
||||
if (document.readyState === 'loading' && !_this.isDOMLoaded) {
|
||||
_this.isDOMLoaded = true;
|
||||
_this._callMiddlewareEntered(currentRoutes, request);
|
||||
} else if (document.readyState === 'interactive' && !_this.isDOMReady) {
|
||||
if (!_this.isDOMLoaded) {
|
||||
_this.isDOMLoaded = true;
|
||||
_this._callMiddlewareEntered(currentRoutes, request);
|
||||
}
|
||||
_this.isDOMReady = true;
|
||||
_this._callMiddlewareUpdated(currentRoutes, request, response);
|
||||
if (callback) {
|
||||
callback(request, response);
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a new `Router` instance for the _uri_.
|
||||
* See the Router api docs for details.
|
||||
*
|
||||
* app.route('/');
|
||||
* // => new Router instance
|
||||
*
|
||||
* @param {String} uri
|
||||
* @return {Router} for chaining
|
||||
*
|
||||
* @public
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'route',
|
||||
value: function route(uri) {
|
||||
var router = new _router2.default(uri);
|
||||
this.routers.push(router);
|
||||
return router;
|
||||
}
|
||||
|
||||
/**
|
||||
* Use the given middleware function or object, with optional _uri_.
|
||||
* Default _uri_ is "/".
|
||||
*
|
||||
* // middleware function will be applied on path "/"
|
||||
* app.use((req, res, next) => {console.log('Hello')});
|
||||
*
|
||||
* // middleware object will be applied on path "/"
|
||||
* app.use(new Middleware());
|
||||
*
|
||||
* @param {String} uri
|
||||
* @param {Middleware|Function} middleware object or function
|
||||
* @return {app} for chaining
|
||||
*
|
||||
* @public
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'use',
|
||||
value: function use() {
|
||||
for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
|
||||
args[_key2] = arguments[_key2];
|
||||
}
|
||||
|
||||
if (args.length === 0) {
|
||||
throw new TypeError('use method takes at least a middleware or a router');
|
||||
}
|
||||
|
||||
var baseUri = void 0,
|
||||
middleware = void 0,
|
||||
router = void 0,
|
||||
which = void 0;
|
||||
|
||||
if (args.length === 1) {
|
||||
which = args[0];
|
||||
} else {
|
||||
baseUri = args[0];
|
||||
which = args[1];
|
||||
}
|
||||
|
||||
if (!(which instanceof _middleware2.default) && typeof which !== 'function' && !(which instanceof _router2.default)) {
|
||||
throw new TypeError('use method takes at least a middleware or a router');
|
||||
}
|
||||
|
||||
if (which instanceof _router2.default) {
|
||||
router = which;
|
||||
router.baseUri = baseUri;
|
||||
} else {
|
||||
middleware = which;
|
||||
router = new _router2.default(baseUri);
|
||||
var _iteratorNormalCompletion = true;
|
||||
var _didIteratorError = false;
|
||||
var _iteratorError = undefined;
|
||||
|
||||
try {
|
||||
for (var _iterator = _methods2.default[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
||||
var method = _step.value;
|
||||
|
||||
router[method.toLowerCase()](middleware);
|
||||
}
|
||||
} catch (err) {
|
||||
_didIteratorError = true;
|
||||
_iteratorError = err;
|
||||
} finally {
|
||||
try {
|
||||
if (!_iteratorNormalCompletion && _iterator.return) {
|
||||
_iterator.return();
|
||||
}
|
||||
} finally {
|
||||
if (_didIteratorError) {
|
||||
throw _iteratorError;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
this.routers.push(router);
|
||||
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gather routes from all routers filtered by _uri_ and HTTP _method_.
|
||||
* See Router#routes() documentation for details.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: '_routes',
|
||||
value: function _routes() {
|
||||
var uri = arguments.length <= 0 || arguments[0] === undefined ? window.location.pathname + window.location.search : arguments[0];
|
||||
var method = arguments.length <= 1 || arguments[1] === undefined ? 'GET' : arguments[1];
|
||||
|
||||
var currentRoutes = [];
|
||||
var _iteratorNormalCompletion2 = true;
|
||||
var _didIteratorError2 = false;
|
||||
var _iteratorError2 = undefined;
|
||||
|
||||
try {
|
||||
for (var _iterator2 = this.routers[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
|
||||
var router = _step2.value;
|
||||
|
||||
var routes = router.routes(uri, method);
|
||||
currentRoutes.push.apply(currentRoutes, _toConsumableArray(routes));
|
||||
}
|
||||
} catch (err) {
|
||||
_didIteratorError2 = true;
|
||||
_iteratorError2 = err;
|
||||
} finally {
|
||||
try {
|
||||
if (!_iteratorNormalCompletion2 && _iterator2.return) {
|
||||
_iterator2.return();
|
||||
}
|
||||
} finally {
|
||||
if (_didIteratorError2) {
|
||||
throw _iteratorError2;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return currentRoutes;
|
||||
}
|
||||
|
||||
/**
|
||||
* Call `Middleware#entered` on _currentRoutes_.
|
||||
* Invoked before sending ajax request or when DOM
|
||||
* is loading (document.readyState === 'loading').
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: '_callMiddlewareEntered',
|
||||
value: function _callMiddlewareEntered(currentRoutes, request) {
|
||||
var _iteratorNormalCompletion3 = true;
|
||||
var _didIteratorError3 = false;
|
||||
var _iteratorError3 = undefined;
|
||||
|
||||
try {
|
||||
for (var _iterator3 = currentRoutes[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) {
|
||||
var route = _step3.value;
|
||||
|
||||
if (route.middleware.entered) {
|
||||
route.middleware.entered(request);
|
||||
}
|
||||
if (route.middleware.next && !route.middleware.next()) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
_didIteratorError3 = true;
|
||||
_iteratorError3 = err;
|
||||
} finally {
|
||||
try {
|
||||
if (!_iteratorNormalCompletion3 && _iterator3.return) {
|
||||
_iterator3.return();
|
||||
}
|
||||
} finally {
|
||||
if (_didIteratorError3) {
|
||||
throw _iteratorError3;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Call `Middleware#updated` or middleware function on _currentRoutes_.
|
||||
* Invoked on ajax request responding or on DOM ready
|
||||
* (document.readyState === 'interactive').
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: '_callMiddlewareUpdated',
|
||||
value: function _callMiddlewareUpdated(currentRoutes, request, response) {
|
||||
var _iteratorNormalCompletion4 = true;
|
||||
var _didIteratorError4 = false;
|
||||
var _iteratorError4 = undefined;
|
||||
|
||||
try {
|
||||
for (var _iterator4 = currentRoutes[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) {
|
||||
var route = _step4.value;
|
||||
|
||||
route.visited = request;
|
||||
// calls middleware updated method
|
||||
if (route.middleware.updated) {
|
||||
route.middleware.updated(request, response);
|
||||
if (route.middleware.next && !route.middleware.next()) {
|
||||
break;
|
||||
}
|
||||
} else {
|
||||
// calls middleware method
|
||||
var breakMiddlewareLoop = true;
|
||||
var next = function next() {
|
||||
breakMiddlewareLoop = false;
|
||||
};
|
||||
route.middleware(request, response, next);
|
||||
if (breakMiddlewareLoop) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
_didIteratorError4 = true;
|
||||
_iteratorError4 = err;
|
||||
} finally {
|
||||
try {
|
||||
if (!_iteratorNormalCompletion4 && _iterator4.return) {
|
||||
_iterator4.return();
|
||||
}
|
||||
} finally {
|
||||
if (_didIteratorError4) {
|
||||
throw _iteratorError4;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Call `Middleware#exited` on _currentRoutes_.
|
||||
* Invoked before sending a new ajax request or before DOM unloading.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: '_callMiddlewareExited',
|
||||
value: function _callMiddlewareExited() {
|
||||
// calls middleware exited method
|
||||
var _iteratorNormalCompletion5 = true;
|
||||
var _didIteratorError5 = false;
|
||||
var _iteratorError5 = undefined;
|
||||
|
||||
try {
|
||||
for (var _iterator5 = this.routers[Symbol.iterator](), _step5; !(_iteratorNormalCompletion5 = (_step5 = _iterator5.next()).done); _iteratorNormalCompletion5 = true) {
|
||||
var router = _step5.value;
|
||||
|
||||
var routes = router.visited();
|
||||
var _iteratorNormalCompletion6 = true;
|
||||
var _didIteratorError6 = false;
|
||||
var _iteratorError6 = undefined;
|
||||
|
||||
try {
|
||||
for (var _iterator6 = routes[Symbol.iterator](), _step6; !(_iteratorNormalCompletion6 = (_step6 = _iterator6.next()).done); _iteratorNormalCompletion6 = true) {
|
||||
var route = _step6.value;
|
||||
|
||||
if (route.middleware.exited) {
|
||||
route.middleware.exited(route.visited);
|
||||
route.visited = null;
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
_didIteratorError6 = true;
|
||||
_iteratorError6 = err;
|
||||
} finally {
|
||||
try {
|
||||
if (!_iteratorNormalCompletion6 && _iterator6.return) {
|
||||
_iterator6.return();
|
||||
}
|
||||
} finally {
|
||||
if (_didIteratorError6) {
|
||||
throw _iteratorError6;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
_didIteratorError5 = true;
|
||||
_iteratorError5 = err;
|
||||
} finally {
|
||||
try {
|
||||
if (!_iteratorNormalCompletion5 && _iterator5.return) {
|
||||
_iterator5.return();
|
||||
}
|
||||
} finally {
|
||||
if (_didIteratorError5) {
|
||||
throw _iteratorError5;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Call `Middleware#failed` or middleware function on _currentRoutes_.
|
||||
* Invoked when ajax request fails.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: '_callMiddlewareFailed',
|
||||
value: function _callMiddlewareFailed(currentRoutes, request, response) {
|
||||
var _iteratorNormalCompletion7 = true;
|
||||
var _didIteratorError7 = false;
|
||||
var _iteratorError7 = undefined;
|
||||
|
||||
try {
|
||||
for (var _iterator7 = currentRoutes[Symbol.iterator](), _step7; !(_iteratorNormalCompletion7 = (_step7 = _iterator7.next()).done); _iteratorNormalCompletion7 = true) {
|
||||
var route = _step7.value;
|
||||
|
||||
// calls middleware failed method
|
||||
if (route.middleware.failed) {
|
||||
route.middleware.failed(request, response);
|
||||
if (route.middleware.next && !route.middleware.next()) {
|
||||
break;
|
||||
}
|
||||
} else {
|
||||
// calls middleware method
|
||||
var breakMiddlewareLoop = true;
|
||||
var next = function next() {
|
||||
breakMiddlewareLoop = false;
|
||||
};
|
||||
route.middleware(request, response, next);
|
||||
if (breakMiddlewareLoop) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
_didIteratorError7 = true;
|
||||
_iteratorError7 = err;
|
||||
} finally {
|
||||
try {
|
||||
if (!_iteratorNormalCompletion7 && _iterator7.return) {
|
||||
_iterator7.return();
|
||||
}
|
||||
} finally {
|
||||
if (_didIteratorError7) {
|
||||
throw _iteratorError7;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Make an ajax request. Manage History#pushState if history object set.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: '_fetch',
|
||||
value: function _fetch(request, resolve, reject) {
|
||||
var _this2 = this;
|
||||
|
||||
var method = request.method;
|
||||
var uri = request.uri;
|
||||
var headers = request.headers;
|
||||
var data = request.data;
|
||||
var history = request.history;
|
||||
|
||||
|
||||
var httpMethodTransformer = this.get('http ' + method + ' transformer');
|
||||
if (httpMethodTransformer) {
|
||||
uri = httpMethodTransformer.uri ? httpMethodTransformer.uri({ uri: uri, headers: headers, data: data }) : uri;
|
||||
headers = httpMethodTransformer.headers ? httpMethodTransformer.headers({ uri: uri, headers: headers, data: data }) : headers;
|
||||
data = httpMethodTransformer.data ? httpMethodTransformer.data({ uri: uri, headers: headers, data: data }) : data;
|
||||
}
|
||||
|
||||
// calls middleware exited method
|
||||
this._callMiddlewareExited();
|
||||
|
||||
// gathers all routes impacted by the uri
|
||||
var currentRoutes = this._routes(uri, method);
|
||||
|
||||
// calls middleware entered method
|
||||
this._callMiddlewareEntered(currentRoutes, request);
|
||||
|
||||
// invokes http request
|
||||
this.settings.get('http requester').fetch(request, function (req, res) {
|
||||
if (history) {
|
||||
window.history.pushState({ request: req, response: res }, history.title, history.uri);
|
||||
}
|
||||
_this2._callMiddlewareUpdated(currentRoutes, req, res);
|
||||
if (resolve) {
|
||||
resolve(req, res);
|
||||
}
|
||||
}, function (req, res) {
|
||||
_this2._callMiddlewareFailed(currentRoutes, req, res);
|
||||
if (reject) {
|
||||
reject(req, res);
|
||||
}
|
||||
});
|
||||
}
|
||||
}]);
|
||||
|
||||
return Application;
|
||||
}();
|
||||
|
||||
exports.default = Application;
|
||||
|
||||
|
||||
_methods2.default.reduce(function (reqProto, method) {
|
||||
|
||||
/**
|
||||
* Use the given middleware function or object, with optional _uri_ on
|
||||
* HTTP methods: get, post, put, delete...
|
||||
* Default _uri_ is "/".
|
||||
*
|
||||
* // middleware function will be applied on path "/"
|
||||
* app.get((req, res, next) => {console.log('Hello')});
|
||||
*
|
||||
* // middleware object will be applied on path "/" and
|
||||
* app.get(new Middleware());
|
||||
*
|
||||
* // get a setting value
|
||||
* app.set('foo', 'bar');
|
||||
* app.get('foo');
|
||||
* // => "bar"
|
||||
*
|
||||
* @param {String} uri or setting
|
||||
* @param {Middleware|Function} middleware object or function
|
||||
* @return {app} for chaining
|
||||
* @public
|
||||
*/
|
||||
|
||||
var middlewareMethodName = method.toLowerCase();
|
||||
reqProto[middlewareMethodName] = function () {
|
||||
for (var _len3 = arguments.length, args = Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
|
||||
args[_key3] = arguments[_key3];
|
||||
}
|
||||
|
||||
if (middlewareMethodName === 'get') {
|
||||
if (args.length === 0) {
|
||||
throw new TypeError(middlewareMethodName + ' method takes at least a string or a middleware');
|
||||
} else if (args.length === 1) {
|
||||
var name = args[0];
|
||||
|
||||
if (typeof name === 'string') {
|
||||
return this.settings.get(name);
|
||||
}
|
||||
}
|
||||
} else if (args.length === 0) {
|
||||
throw new TypeError(middlewareMethodName + ' method takes at least a middleware');
|
||||
}
|
||||
|
||||
var baseUri = void 0,
|
||||
middleware = void 0,
|
||||
which = void 0;
|
||||
|
||||
if (args.length === 1) {
|
||||
which = args[0];
|
||||
} else {
|
||||
baseUri = args[0];
|
||||
which = args[1];
|
||||
}
|
||||
|
||||
if (!(which instanceof _middleware2.default) && typeof which !== 'function') {
|
||||
throw new TypeError(middlewareMethodName + ' method takes at least a middleware');
|
||||
}
|
||||
|
||||
var router = new _router2.default();
|
||||
middleware = which;
|
||||
router[middlewareMethodName](baseUri, middleware);
|
||||
|
||||
this.routers.push(router);
|
||||
|
||||
return this;
|
||||
};
|
||||
|
||||
/**
|
||||
* Ajax request (get, post, put, delete...).
|
||||
*
|
||||
* // HTTP GET method
|
||||
* httpGet('/route1');
|
||||
*
|
||||
* // HTTP GET method
|
||||
* httpGet({uri: '/route1', data: {'p1': 'val1'});
|
||||
* // uri invoked => /route1?p1=val1
|
||||
*
|
||||
* // HTTP GET method with browser history management
|
||||
* httpGet({uri: '/api/users', history: {state: {foo: "bar"}, title: 'users page', uri: '/view/users'});
|
||||
*
|
||||
* Samples above can be applied on other HTTP methods.
|
||||
*
|
||||
* @param {String|Object} uri or object containing uri, http headers, data, history
|
||||
* @param {Function} success callback
|
||||
* @param {Function} failure callback
|
||||
* @public
|
||||
*/
|
||||
var httpMethodName = 'http' + method.charAt(0).toUpperCase() + method.slice(1).toLowerCase();
|
||||
reqProto[httpMethodName] = function (request, resolve, reject) {
|
||||
var uri = request.uri;
|
||||
var headers = request.headers;
|
||||
var data = request.data;
|
||||
var history = request.history;
|
||||
|
||||
if (!uri) {
|
||||
uri = request;
|
||||
}
|
||||
return this._fetch({
|
||||
uri: uri,
|
||||
method: method,
|
||||
headers: headers,
|
||||
data: data,
|
||||
history: history
|
||||
}, resolve, reject);
|
||||
};
|
||||
|
||||
return reqProto;
|
||||
}, Application.prototype);
|
46
dist/frontexpress.js
vendored
Executable file
46
dist/frontexpress.js
vendored
Executable file
@ -0,0 +1,46 @@
|
||||
'use strict';
|
||||
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
|
||||
var _application = require('./application');
|
||||
|
||||
var _application2 = _interopRequireDefault(_application);
|
||||
|
||||
var _router = require('./router');
|
||||
|
||||
var _router2 = _interopRequireDefault(_router);
|
||||
|
||||
var _middleware = require('./middleware');
|
||||
|
||||
var _middleware2 = _interopRequireDefault(_middleware);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
/**
|
||||
* Create a frontexpress application.
|
||||
*
|
||||
* @return {Function}
|
||||
* @api public
|
||||
*/
|
||||
|
||||
var frontexpress = function frontexpress() {
|
||||
return new _application2.default();
|
||||
};
|
||||
|
||||
/**
|
||||
* Expose Router, Middleware constructors.
|
||||
*/
|
||||
/**
|
||||
* Module dependencies.
|
||||
*/
|
||||
|
||||
frontexpress.Router = function (baseUri) {
|
||||
return new _router2.default(baseUri);
|
||||
};
|
||||
frontexpress.Middleware = function (name) {
|
||||
return new _middleware2.default(name);
|
||||
};
|
||||
|
||||
exports.default = frontexpress;
|
11
dist/methods.js
vendored
Normal file
11
dist/methods.js
vendored
Normal file
@ -0,0 +1,11 @@
|
||||
'use strict';
|
||||
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
/**
|
||||
* HTTP method list
|
||||
* @private
|
||||
*/
|
||||
|
||||
exports.default = ['GET', 'HEAD', 'POST', 'PUT', 'DELETE', 'CONNECT', 'OPTIONS', 'TRACE', 'PATCH'];
|
112
dist/middleware.js
vendored
Executable file
112
dist/middleware.js
vendored
Executable file
@ -0,0 +1,112 @@
|
||||
'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; }; }();
|
||||
|
||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
||||
|
||||
/**
|
||||
* Middleware object.
|
||||
* @public
|
||||
*/
|
||||
|
||||
var Middleware = function () {
|
||||
|
||||
/**
|
||||
* Middleware initialization
|
||||
*
|
||||
* @param {String} middleware name
|
||||
*/
|
||||
|
||||
function Middleware() {
|
||||
var name = arguments.length <= 0 || arguments[0] === undefined ? '' : arguments[0];
|
||||
|
||||
_classCallCheck(this, Middleware);
|
||||
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
/**
|
||||
* Invoked by the app before an ajax request is sent or
|
||||
* during the DOM loading (document.readyState === 'loading').
|
||||
* See Application#_callMiddlewareEntered documentation for details.
|
||||
*
|
||||
* Override this method to add your custom behaviour
|
||||
*
|
||||
* @param {Object} request
|
||||
* @public
|
||||
*/
|
||||
|
||||
_createClass(Middleware, [{
|
||||
key: 'entered',
|
||||
value: function entered(request) {}
|
||||
|
||||
/**
|
||||
* Invoked by the app before a new ajax request is sent or before the DOM is unloaded.
|
||||
* See Application#_callMiddlewareExited documentation for details.
|
||||
*
|
||||
* Override this method to add your custom behaviour
|
||||
*
|
||||
* @param {Object} request
|
||||
* @public
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'exited',
|
||||
value: function exited(request) {}
|
||||
|
||||
/**
|
||||
* Invoked by the app after an ajax request has responded or on DOM ready
|
||||
* (document.readyState === 'interactive').
|
||||
* See Application#_callMiddlewareUpdated documentation for details.
|
||||
*
|
||||
* Override this method to add your custom behaviour
|
||||
*
|
||||
* @param {Object} request
|
||||
* @param {Object} response
|
||||
* @public
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'updated',
|
||||
value: function updated(request, response) {}
|
||||
|
||||
/**
|
||||
* Invoked by the app when an ajax request has failed.
|
||||
*
|
||||
* Override this method to add your custom behaviour
|
||||
*
|
||||
* @param {Object} request
|
||||
* @param {Object} response
|
||||
* @public
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'failed',
|
||||
value: function failed(request, response) {}
|
||||
|
||||
/**
|
||||
* Allow the hand over to the next middleware object or function.
|
||||
*
|
||||
* Override this method and return `false` to break execution of
|
||||
* middleware chain.
|
||||
*
|
||||
* @return {Boolean} `true` by default
|
||||
*
|
||||
* @public
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'next',
|
||||
value: function next() {
|
||||
return true;
|
||||
}
|
||||
}]);
|
||||
|
||||
return Middleware;
|
||||
}();
|
||||
|
||||
exports.default = Middleware;
|
151
dist/requester.js
vendored
Executable file
151
dist/requester.js
vendored
Executable file
@ -0,0 +1,151 @@
|
||||
'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; }; }();
|
||||
|
||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
||||
|
||||
/**
|
||||
* Module dependencies.
|
||||
* @private
|
||||
*/
|
||||
|
||||
var Requester = function () {
|
||||
function Requester() {
|
||||
_classCallCheck(this, Requester);
|
||||
}
|
||||
|
||||
_createClass(Requester, [{
|
||||
key: 'fetch',
|
||||
|
||||
|
||||
/**
|
||||
* Make an ajax request.
|
||||
*
|
||||
* @param {Object} request
|
||||
* @param {Function} success callback
|
||||
* @param {Function} failure callback
|
||||
* @private
|
||||
*/
|
||||
|
||||
value: function fetch(request, resolve, reject) {
|
||||
var _this = this;
|
||||
|
||||
var method = request.method;
|
||||
var uri = request.uri;
|
||||
var headers = request.headers;
|
||||
var data = request.data;
|
||||
var history = request.history;
|
||||
|
||||
|
||||
var success = function success(responseText) {
|
||||
resolve(request, { status: 200, statusText: 'OK', responseText: responseText });
|
||||
};
|
||||
|
||||
var fail = function fail(_ref) {
|
||||
var status = _ref.status;
|
||||
var statusText = _ref.statusText;
|
||||
var errorThrown = _ref.errorThrown;
|
||||
|
||||
var errors = _this._analyzeErrors({ status: status, statusText: statusText, errorThrown: errorThrown });
|
||||
reject(request, { status: status, statusText: statusText, errorThrown: errorThrown, errors: errors });
|
||||
};
|
||||
|
||||
var xmlhttp = new XMLHttpRequest();
|
||||
xmlhttp.onreadystatechange = function () {
|
||||
if (xmlhttp.readyState === 4) {
|
||||
if (xmlhttp.status === 200) {
|
||||
success(xmlhttp.responseText);
|
||||
} else {
|
||||
fail({ status: xmlhttp.status, statusText: xmlhttp.statusText });
|
||||
}
|
||||
}
|
||||
};
|
||||
try {
|
||||
xmlhttp.open(method, uri, true);
|
||||
if (headers) {
|
||||
var _iteratorNormalCompletion = true;
|
||||
var _didIteratorError = false;
|
||||
var _iteratorError = undefined;
|
||||
|
||||
try {
|
||||
for (var _iterator = Object.keys(headers)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
||||
var header = _step.value;
|
||||
|
||||
xmlhttp.setRequestHeader(header, headers[header]);
|
||||
}
|
||||
} catch (err) {
|
||||
_didIteratorError = true;
|
||||
_iteratorError = err;
|
||||
} finally {
|
||||
try {
|
||||
if (!_iteratorNormalCompletion && _iterator.return) {
|
||||
_iterator.return();
|
||||
}
|
||||
} finally {
|
||||
if (_didIteratorError) {
|
||||
throw _iteratorError;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (data) {
|
||||
xmlhttp.send(data);
|
||||
} else {
|
||||
xmlhttp.send();
|
||||
}
|
||||
} catch (errorThrown) {
|
||||
fail({ errorThrown: errorThrown });
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Analyse response errors.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: '_analyzeErrors',
|
||||
value: function _analyzeErrors(response) {
|
||||
// manage exceptions
|
||||
if (response.errorThrown) {
|
||||
if (response.errorThrown.name === 'SyntaxError') {
|
||||
return 'Problem during data decoding [JSON]';
|
||||
}
|
||||
if (response.errorThrown.name === 'TimeoutError') {
|
||||
return 'Server is taking too long to reply';
|
||||
}
|
||||
if (response.errorThrown.name === 'AbortError') {
|
||||
return 'Request cancelled on server';
|
||||
}
|
||||
if (response.errorThrown.name === 'NetworkError') {
|
||||
return 'A network error occurred';
|
||||
}
|
||||
throw response.errorThrown;
|
||||
}
|
||||
|
||||
// manage status
|
||||
if (response.status === 0) {
|
||||
return 'Server access problem. Check your network connection';
|
||||
}
|
||||
if (response.status === 401) {
|
||||
return 'Your session has expired, Please reconnect. [code: 401]';
|
||||
}
|
||||
if (response.status === 404) {
|
||||
return 'Page not found on server. [code: 404]';
|
||||
}
|
||||
if (response.status === 500) {
|
||||
return 'Internal server error. [code: 500]';
|
||||
}
|
||||
return 'Unknown error. ' + (response.statusText ? response.statusText : '');
|
||||
}
|
||||
}]);
|
||||
|
||||
return Requester;
|
||||
}();
|
||||
|
||||
exports.default = Requester;
|
393
dist/router.js
vendored
Executable file
393
dist/router.js
vendored
Executable file
@ -0,0 +1,393 @@
|
||||
'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; }; }(); /**
|
||||
* Module dependencies.
|
||||
* @private
|
||||
*/
|
||||
|
||||
var _methods = require('./methods');
|
||||
|
||||
var _methods2 = _interopRequireDefault(_methods);
|
||||
|
||||
var _middleware = require('./middleware');
|
||||
|
||||
var _middleware2 = _interopRequireDefault(_middleware);
|
||||
|
||||
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"); } }
|
||||
|
||||
/**
|
||||
* Route object.
|
||||
* @private
|
||||
*/
|
||||
|
||||
var Route = function () {
|
||||
|
||||
/**
|
||||
* Initialize the route.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
function Route(router, uriPart, method, middleware) {
|
||||
_classCallCheck(this, Route);
|
||||
|
||||
this.router = router;
|
||||
this.uriPart = uriPart;
|
||||
this.method = method;
|
||||
this.middleware = middleware;
|
||||
this.visited = false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return route's uri.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
_createClass(Route, [{
|
||||
key: 'uri',
|
||||
get: function get() {
|
||||
if (!this.uriPart && !this.method) {
|
||||
return undefined;
|
||||
}
|
||||
|
||||
if (this.uriPart instanceof RegExp) {
|
||||
return this.uriPart;
|
||||
}
|
||||
|
||||
if (this.router.baseUri instanceof RegExp) {
|
||||
return this.router.baseUri;
|
||||
}
|
||||
|
||||
if (this.router.baseUri && this.uriPart) {
|
||||
return (this.router.baseUri.trim() + this.uriPart.trim()).replace(/\/{2,}/, '/');
|
||||
}
|
||||
|
||||
if (this.router.baseUri) {
|
||||
return this.router.baseUri.trim();
|
||||
}
|
||||
|
||||
return this.uriPart;
|
||||
}
|
||||
}]);
|
||||
|
||||
return Route;
|
||||
}();
|
||||
|
||||
/**
|
||||
* Router object.
|
||||
* @public
|
||||
*/
|
||||
|
||||
var Router = function () {
|
||||
|
||||
/**
|
||||
* Initialize the router.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
function Router(uri) {
|
||||
_classCallCheck(this, Router);
|
||||
|
||||
if (uri) {
|
||||
this._baseUri = uri;
|
||||
}
|
||||
this._routes = [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Do some checks and set _baseUri.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
_createClass(Router, [{
|
||||
key: '_add',
|
||||
|
||||
|
||||
/**
|
||||
* Add a route to the router.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
value: function _add(route) {
|
||||
this._routes.push(route);
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gather routes from routers filtered by _uri_ and HTTP _method_.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'routes',
|
||||
value: function routes(uri, method) {
|
||||
return this._routes.filter(function (route) {
|
||||
if (!route.uri && !route.method) {
|
||||
return true;
|
||||
}
|
||||
if (route.method !== method) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!route.uri) {
|
||||
return true;
|
||||
}
|
||||
|
||||
var uriToCheck = uri;
|
||||
|
||||
//remove query string from uri to test
|
||||
var questionMarkIndex = uriToCheck.indexOf('?');
|
||||
if (questionMarkIndex >= 0) {
|
||||
uriToCheck = uriToCheck.slice(0, questionMarkIndex);
|
||||
}
|
||||
|
||||
//remove anchor from uri to test
|
||||
var hashIndex = uriToCheck.indexOf('#');
|
||||
if (hashIndex >= 0) {
|
||||
uriToCheck = uriToCheck.slice(0, hashIndex);
|
||||
}
|
||||
|
||||
if (route.uri instanceof RegExp) {
|
||||
return uriToCheck.match(route.uri);
|
||||
}
|
||||
|
||||
return route.uri === uriToCheck;
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Gather visited routes from routers.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'visited',
|
||||
value: function visited() {
|
||||
return this._routes.filter(function (route) {
|
||||
return route.visited;
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Use the given middleware function or object on this router.
|
||||
*
|
||||
* // middleware function
|
||||
* router.use((req, res, next) => {console.log('Hello')});
|
||||
*
|
||||
* // middleware object
|
||||
* router.use(new Middleware());
|
||||
*
|
||||
* @param {Middleware|Function} middleware object or function
|
||||
* @return {Router} for chaining
|
||||
*
|
||||
* @public
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'use',
|
||||
value: function use(middleware) {
|
||||
if (!(middleware instanceof _middleware2.default) && typeof middleware !== 'function') {
|
||||
throw new TypeError('use method takes at least a middleware');
|
||||
}
|
||||
|
||||
this._add(new Route(this, undefined, undefined, middleware));
|
||||
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Use the given middleware function or object on this router for
|
||||
* all HTTP methods.
|
||||
*
|
||||
* // middleware function
|
||||
* router.all((req, res, next) => {console.log('Hello')});
|
||||
*
|
||||
* // middleware object
|
||||
* router.all(new Middleware());
|
||||
*
|
||||
* @param {Middleware|Function} middleware object or function
|
||||
* @return {Router} for chaining
|
||||
*
|
||||
* @public
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'all',
|
||||
value: function all() {
|
||||
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
|
||||
args[_key] = arguments[_key];
|
||||
}
|
||||
|
||||
if (args.length === 0) {
|
||||
throw new TypeError('use all method takes at least a middleware');
|
||||
}
|
||||
var middleware = void 0;
|
||||
|
||||
if (args.length === 1) {
|
||||
middleware = args[0];
|
||||
} else {
|
||||
middleware = args[1];
|
||||
}
|
||||
|
||||
if (!(middleware instanceof _middleware2.default) && typeof middleware !== 'function') {
|
||||
throw new TypeError('use all method takes at least a middleware');
|
||||
}
|
||||
|
||||
var _iteratorNormalCompletion = true;
|
||||
var _didIteratorError = false;
|
||||
var _iteratorError = undefined;
|
||||
|
||||
try {
|
||||
for (var _iterator = _methods2.default[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
||||
var method = _step.value;
|
||||
|
||||
this[method.toLowerCase()].apply(this, args);
|
||||
}
|
||||
} catch (err) {
|
||||
_didIteratorError = true;
|
||||
_iteratorError = err;
|
||||
} finally {
|
||||
try {
|
||||
if (!_iteratorNormalCompletion && _iterator.return) {
|
||||
_iterator.return();
|
||||
}
|
||||
} finally {
|
||||
if (_didIteratorError) {
|
||||
throw _iteratorError;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return this;
|
||||
}
|
||||
}, {
|
||||
key: 'baseUri',
|
||||
set: function set(uri) {
|
||||
if (!uri) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (!this._baseUri) {
|
||||
this._baseUri = uri;
|
||||
return;
|
||||
}
|
||||
|
||||
if (this._baseUri instanceof RegExp) {
|
||||
throw new TypeError('the router already contains a regexp uri ' + this._baseUri.toString() + ' It cannot be mixed with ' + uri.toString());
|
||||
}
|
||||
|
||||
if (uri instanceof RegExp) {
|
||||
throw new TypeError('the router already contains an uri ' + this._baseUri.toString() + ' It cannot be mixed with regexp ' + uri.toString());
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Return router's _baseUri.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
,
|
||||
get: function get() {
|
||||
return this._baseUri;
|
||||
}
|
||||
}]);
|
||||
|
||||
return Router;
|
||||
}();
|
||||
|
||||
exports.default = Router;
|
||||
var _iteratorNormalCompletion2 = true;
|
||||
var _didIteratorError2 = false;
|
||||
var _iteratorError2 = undefined;
|
||||
|
||||
try {
|
||||
var _loop = function _loop() {
|
||||
var method = _step2.value;
|
||||
|
||||
|
||||
/**
|
||||
* Use the given middleware function or object, with optional _uri_ on
|
||||
* HTTP methods: get, post, put, delete...
|
||||
* Default _uri_ is "/".
|
||||
*
|
||||
* // middleware function will be applied on path "/"
|
||||
* router.get((req, res, next) => {console.log('Hello')});
|
||||
*
|
||||
* // middleware object will be applied on path "/" and
|
||||
* router.get(new Middleware());
|
||||
*
|
||||
* // middleware function will be applied on path "/user"
|
||||
* router.post('/user', (req, res, next) => {console.log('Hello')});
|
||||
*
|
||||
* // middleware object will be applied on path "/user" and
|
||||
* router.post('/user', new Middleware());
|
||||
*
|
||||
* @param {String} uri
|
||||
* @param {Middleware|Function} middleware object or function
|
||||
* @return {Router} for chaining
|
||||
* @public
|
||||
*/
|
||||
|
||||
var methodName = method.toLowerCase();
|
||||
Router.prototype[methodName] = function () {
|
||||
for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
|
||||
args[_key2] = arguments[_key2];
|
||||
}
|
||||
|
||||
if (args.length === 0) {
|
||||
throw new TypeError('use ' + methodName + ' method takes at least a middleware');
|
||||
}
|
||||
var uri = void 0,
|
||||
middleware = void 0;
|
||||
|
||||
if (args.length === 1) {
|
||||
middleware = args[0];
|
||||
} else {
|
||||
uri = args[0];
|
||||
middleware = args[1];
|
||||
}
|
||||
|
||||
if (!(middleware instanceof _middleware2.default) && typeof middleware !== 'function') {
|
||||
throw new TypeError('use ' + methodName + ' method takes at least a middleware');
|
||||
}
|
||||
|
||||
if (uri && this._baseUri && this._baseUri instanceof RegExp) {
|
||||
throw new TypeError('router contains a regexp cannot mix with route uri/regexp');
|
||||
}
|
||||
|
||||
this._add(new Route(this, uri, method, middleware));
|
||||
|
||||
return this;
|
||||
};
|
||||
};
|
||||
|
||||
for (var _iterator2 = _methods2.default[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
|
||||
_loop();
|
||||
}
|
||||
} catch (err) {
|
||||
_didIteratorError2 = true;
|
||||
_iteratorError2 = err;
|
||||
} finally {
|
||||
try {
|
||||
if (!_iteratorNormalCompletion2 && _iterator2.return) {
|
||||
_iterator2.return();
|
||||
}
|
||||
} finally {
|
||||
if (_didIteratorError2) {
|
||||
throw _iteratorError2;
|
||||
}
|
||||
}
|
||||
}
|
127
dist/settings.js
vendored
Normal file
127
dist/settings.js
vendored
Normal file
@ -0,0 +1,127 @@
|
||||
'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; }; }(); /**
|
||||
* Module dependencies.
|
||||
* @private
|
||||
*/
|
||||
|
||||
var _requester = require('./requester');
|
||||
|
||||
var _requester2 = _interopRequireDefault(_requester);
|
||||
|
||||
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"); } }
|
||||
|
||||
/**
|
||||
* Settings object.
|
||||
* @private
|
||||
*/
|
||||
|
||||
var Settings = function () {
|
||||
|
||||
/**
|
||||
* Initialize the settings.
|
||||
*
|
||||
* - setup default configuration
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
||||
function Settings() {
|
||||
_classCallCheck(this, Settings);
|
||||
|
||||
// default settings
|
||||
this.settings = {
|
||||
'http requester': new _requester2.default(),
|
||||
|
||||
'http GET transformer': {
|
||||
uri: function uri(_ref) {
|
||||
var _uri = _ref.uri;
|
||||
var headers = _ref.headers;
|
||||
var data = _ref.data;
|
||||
|
||||
if (!data) {
|
||||
return _uri;
|
||||
}
|
||||
|
||||
var anchor = '';
|
||||
var uriWithoutAnchor = _uri;
|
||||
var hashIndex = _uri.indexOf('#');
|
||||
if (hashIndex >= 1) {
|
||||
uriWithoutAnchor = _uri.slice(0, hashIndex);
|
||||
anchor = _uri.slice(hashIndex, _uri.length);
|
||||
}
|
||||
|
||||
uriWithoutAnchor = Object.keys(data).reduce(function (gUri, d, index) {
|
||||
if (index === 0 && gUri.indexOf('?') === -1) {
|
||||
gUri += '?';
|
||||
} else {
|
||||
gUri += '&';
|
||||
}
|
||||
gUri += d + '=' + data[d];
|
||||
return gUri;
|
||||
}, uriWithoutAnchor);
|
||||
|
||||
return uriWithoutAnchor + anchor;
|
||||
},
|
||||
data: function data(_ref2) {
|
||||
var uri = _ref2.uri;
|
||||
var headers = _ref2.headers;
|
||||
var _data = _ref2.data;
|
||||
|
||||
return undefined;
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
this.rules = {
|
||||
'http requester': function httpRequester(requester) {
|
||||
if (typeof requester.fetch !== 'function') {
|
||||
throw new TypeError('setting http requester has no fetch method');
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
* Assign `setting` to `val`
|
||||
*
|
||||
* @param {String} setting
|
||||
* @param {*} [val]
|
||||
* @private
|
||||
*/
|
||||
|
||||
_createClass(Settings, [{
|
||||
key: 'set',
|
||||
value: function set(name, value) {
|
||||
var checkRules = this.rules[name];
|
||||
if (checkRules) {
|
||||
checkRules(value);
|
||||
}
|
||||
this.settings[name] = value;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return `setting`'s value.
|
||||
*
|
||||
* @param {String} setting
|
||||
* @private
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'get',
|
||||
value: function get(name) {
|
||||
return this.settings[name];
|
||||
}
|
||||
}]);
|
||||
|
||||
return Settings;
|
||||
}();
|
||||
|
||||
exports.default = Settings;
|
||||
;
|
@ -1,7 +1,7 @@
|
||||
{
|
||||
"name": "frontexpress",
|
||||
"version": "0.1.5",
|
||||
"description": "Minimalist front end router framework a la express",
|
||||
"version": "0.1.6",
|
||||
"description": "Frontexpress manages routes in browser like ExpressJS on Node",
|
||||
"main": "dist/frontexpress.js",
|
||||
"scripts": {
|
||||
"lint": "eslint .",
|
||||
@ -21,8 +21,6 @@
|
||||
"web",
|
||||
"router",
|
||||
"middleware",
|
||||
"rest",
|
||||
"restful",
|
||||
"app",
|
||||
"api",
|
||||
"express",
|
||||
|
Loading…
Reference in New Issue
Block a user