added migrations for instant delivery
This commit is contained in:
111
node_modules/react-router/lib/locations/HashLocation.js
generated
vendored
Normal file
111
node_modules/react-router/lib/locations/HashLocation.js
generated
vendored
Normal file
@@ -0,0 +1,111 @@
|
||||
'use strict';
|
||||
|
||||
var LocationActions = require('../actions/LocationActions');
|
||||
var History = require('../History');
|
||||
|
||||
var _listeners = [];
|
||||
var _isListening = false;
|
||||
var _actionType;
|
||||
|
||||
function notifyChange(type) {
|
||||
if (type === LocationActions.PUSH) History.length += 1;
|
||||
|
||||
var change = {
|
||||
path: HashLocation.getCurrentPath(),
|
||||
type: type
|
||||
};
|
||||
|
||||
_listeners.forEach(function (listener) {
|
||||
listener.call(HashLocation, change);
|
||||
});
|
||||
}
|
||||
|
||||
function ensureSlash() {
|
||||
var path = HashLocation.getCurrentPath();
|
||||
|
||||
if (path.charAt(0) === '/') {
|
||||
return true;
|
||||
}HashLocation.replace('/' + path);
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
function onHashChange() {
|
||||
if (ensureSlash()) {
|
||||
// If we don't have an _actionType then all we know is the hash
|
||||
// changed. It was probably caused by the user clicking the Back
|
||||
// button, but may have also been the Forward button or manual
|
||||
// manipulation. So just guess 'pop'.
|
||||
var curActionType = _actionType;
|
||||
_actionType = null;
|
||||
notifyChange(curActionType || LocationActions.POP);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* A Location that uses `window.location.hash`.
|
||||
*/
|
||||
var HashLocation = {
|
||||
|
||||
addChangeListener: function addChangeListener(listener) {
|
||||
_listeners.push(listener);
|
||||
|
||||
// Do this BEFORE listening for hashchange.
|
||||
ensureSlash();
|
||||
|
||||
if (!_isListening) {
|
||||
if (window.addEventListener) {
|
||||
window.addEventListener('hashchange', onHashChange, false);
|
||||
} else {
|
||||
window.attachEvent('onhashchange', onHashChange);
|
||||
}
|
||||
|
||||
_isListening = true;
|
||||
}
|
||||
},
|
||||
|
||||
removeChangeListener: function removeChangeListener(listener) {
|
||||
_listeners = _listeners.filter(function (l) {
|
||||
return l !== listener;
|
||||
});
|
||||
|
||||
if (_listeners.length === 0) {
|
||||
if (window.removeEventListener) {
|
||||
window.removeEventListener('hashchange', onHashChange, false);
|
||||
} else {
|
||||
window.removeEvent('onhashchange', onHashChange);
|
||||
}
|
||||
|
||||
_isListening = false;
|
||||
}
|
||||
},
|
||||
|
||||
push: function push(path) {
|
||||
_actionType = LocationActions.PUSH;
|
||||
window.location.hash = path;
|
||||
},
|
||||
|
||||
replace: function replace(path) {
|
||||
_actionType = LocationActions.REPLACE;
|
||||
window.location.replace(window.location.pathname + window.location.search + '#' + path);
|
||||
},
|
||||
|
||||
pop: function pop() {
|
||||
_actionType = LocationActions.POP;
|
||||
History.back();
|
||||
},
|
||||
|
||||
getCurrentPath: function getCurrentPath() {
|
||||
return decodeURI(
|
||||
// We can't use window.location.hash here because it's not
|
||||
// consistent across browsers - Firefox will pre-decode it!
|
||||
window.location.href.split('#')[1] || '');
|
||||
},
|
||||
|
||||
toString: function toString() {
|
||||
return '<HashLocation>';
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
module.exports = HashLocation;
|
||||
86
node_modules/react-router/lib/locations/HistoryLocation.js
generated
vendored
Normal file
86
node_modules/react-router/lib/locations/HistoryLocation.js
generated
vendored
Normal file
@@ -0,0 +1,86 @@
|
||||
'use strict';
|
||||
|
||||
var LocationActions = require('../actions/LocationActions');
|
||||
var History = require('../History');
|
||||
|
||||
var _listeners = [];
|
||||
var _isListening = false;
|
||||
|
||||
function notifyChange(type) {
|
||||
var change = {
|
||||
path: HistoryLocation.getCurrentPath(),
|
||||
type: type
|
||||
};
|
||||
|
||||
_listeners.forEach(function (listener) {
|
||||
listener.call(HistoryLocation, change);
|
||||
});
|
||||
}
|
||||
|
||||
function onPopState(event) {
|
||||
if (event.state === undefined) {
|
||||
return;
|
||||
} // Ignore extraneous popstate events in WebKit.
|
||||
|
||||
notifyChange(LocationActions.POP);
|
||||
}
|
||||
|
||||
/**
|
||||
* A Location that uses HTML5 history.
|
||||
*/
|
||||
var HistoryLocation = {
|
||||
|
||||
addChangeListener: function addChangeListener(listener) {
|
||||
_listeners.push(listener);
|
||||
|
||||
if (!_isListening) {
|
||||
if (window.addEventListener) {
|
||||
window.addEventListener('popstate', onPopState, false);
|
||||
} else {
|
||||
window.attachEvent('onpopstate', onPopState);
|
||||
}
|
||||
|
||||
_isListening = true;
|
||||
}
|
||||
},
|
||||
|
||||
removeChangeListener: function removeChangeListener(listener) {
|
||||
_listeners = _listeners.filter(function (l) {
|
||||
return l !== listener;
|
||||
});
|
||||
|
||||
if (_listeners.length === 0) {
|
||||
if (window.addEventListener) {
|
||||
window.removeEventListener('popstate', onPopState, false);
|
||||
} else {
|
||||
window.removeEvent('onpopstate', onPopState);
|
||||
}
|
||||
|
||||
_isListening = false;
|
||||
}
|
||||
},
|
||||
|
||||
push: function push(path) {
|
||||
window.history.pushState({ path: path }, '', path);
|
||||
History.length += 1;
|
||||
notifyChange(LocationActions.PUSH);
|
||||
},
|
||||
|
||||
replace: function replace(path) {
|
||||
window.history.replaceState({ path: path }, '', path);
|
||||
notifyChange(LocationActions.REPLACE);
|
||||
},
|
||||
|
||||
pop: History.back,
|
||||
|
||||
getCurrentPath: function getCurrentPath() {
|
||||
return decodeURI(window.location.pathname + window.location.search);
|
||||
},
|
||||
|
||||
toString: function toString() {
|
||||
return '<HistoryLocation>';
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
module.exports = HistoryLocation;
|
||||
31
node_modules/react-router/lib/locations/RefreshLocation.js
generated
vendored
Normal file
31
node_modules/react-router/lib/locations/RefreshLocation.js
generated
vendored
Normal file
@@ -0,0 +1,31 @@
|
||||
'use strict';
|
||||
|
||||
var HistoryLocation = require('./HistoryLocation');
|
||||
var History = require('../History');
|
||||
|
||||
/**
|
||||
* A Location that uses full page refreshes. This is used as
|
||||
* the fallback for HistoryLocation in browsers that do not
|
||||
* support the HTML5 history API.
|
||||
*/
|
||||
var RefreshLocation = {
|
||||
|
||||
push: function push(path) {
|
||||
window.location = path;
|
||||
},
|
||||
|
||||
replace: function replace(path) {
|
||||
window.location.replace(path);
|
||||
},
|
||||
|
||||
pop: History.back,
|
||||
|
||||
getCurrentPath: HistoryLocation.getCurrentPath,
|
||||
|
||||
toString: function toString() {
|
||||
return '<RefreshLocation>';
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
module.exports = RefreshLocation;
|
||||
49
node_modules/react-router/lib/locations/StaticLocation.js
generated
vendored
Normal file
49
node_modules/react-router/lib/locations/StaticLocation.js
generated
vendored
Normal file
@@ -0,0 +1,49 @@
|
||||
'use strict';
|
||||
|
||||
var _classCallCheck = function (instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } };
|
||||
|
||||
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 invariant = require('react/lib/invariant');
|
||||
|
||||
function throwCannotModify() {
|
||||
invariant(false, 'You cannot modify a static location');
|
||||
}
|
||||
|
||||
/**
|
||||
* A location that only ever contains a single path. Useful in
|
||||
* stateless environments like servers where there is no path history,
|
||||
* only the path that was used in the request.
|
||||
*/
|
||||
|
||||
var StaticLocation = (function () {
|
||||
function StaticLocation(path) {
|
||||
_classCallCheck(this, StaticLocation);
|
||||
|
||||
this.path = path;
|
||||
}
|
||||
|
||||
_createClass(StaticLocation, [{
|
||||
key: 'getCurrentPath',
|
||||
value: function getCurrentPath() {
|
||||
return this.path;
|
||||
}
|
||||
}, {
|
||||
key: 'toString',
|
||||
value: function toString() {
|
||||
return '<StaticLocation path="' + this.path + '">';
|
||||
}
|
||||
}]);
|
||||
|
||||
return StaticLocation;
|
||||
})();
|
||||
|
||||
// TODO: Include these in the above class definition
|
||||
// once we can use ES7 property initializers.
|
||||
// https://github.com/babel/babel/issues/619
|
||||
|
||||
StaticLocation.prototype.push = throwCannotModify;
|
||||
StaticLocation.prototype.replace = throwCannotModify;
|
||||
StaticLocation.prototype.pop = throwCannotModify;
|
||||
|
||||
module.exports = StaticLocation;
|
||||
94
node_modules/react-router/lib/locations/TestLocation.js
generated
vendored
Normal file
94
node_modules/react-router/lib/locations/TestLocation.js
generated
vendored
Normal file
@@ -0,0 +1,94 @@
|
||||
'use strict';
|
||||
|
||||
var _classCallCheck = function (instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } };
|
||||
|
||||
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 invariant = require('react/lib/invariant');
|
||||
var LocationActions = require('../actions/LocationActions');
|
||||
var History = require('../History');
|
||||
|
||||
/**
|
||||
* A location that is convenient for testing and does not require a DOM.
|
||||
*/
|
||||
|
||||
var TestLocation = (function () {
|
||||
function TestLocation(history) {
|
||||
_classCallCheck(this, TestLocation);
|
||||
|
||||
this.history = history || [];
|
||||
this.listeners = [];
|
||||
this._updateHistoryLength();
|
||||
}
|
||||
|
||||
_createClass(TestLocation, [{
|
||||
key: 'needsDOM',
|
||||
get: function () {
|
||||
return false;
|
||||
}
|
||||
}, {
|
||||
key: '_updateHistoryLength',
|
||||
value: function _updateHistoryLength() {
|
||||
History.length = this.history.length;
|
||||
}
|
||||
}, {
|
||||
key: '_notifyChange',
|
||||
value: function _notifyChange(type) {
|
||||
var change = {
|
||||
path: this.getCurrentPath(),
|
||||
type: type
|
||||
};
|
||||
|
||||
for (var i = 0, len = this.listeners.length; i < len; ++i) this.listeners[i].call(this, change);
|
||||
}
|
||||
}, {
|
||||
key: 'addChangeListener',
|
||||
value: function addChangeListener(listener) {
|
||||
this.listeners.push(listener);
|
||||
}
|
||||
}, {
|
||||
key: 'removeChangeListener',
|
||||
value: function removeChangeListener(listener) {
|
||||
this.listeners = this.listeners.filter(function (l) {
|
||||
return l !== listener;
|
||||
});
|
||||
}
|
||||
}, {
|
||||
key: 'push',
|
||||
value: function push(path) {
|
||||
this.history.push(path);
|
||||
this._updateHistoryLength();
|
||||
this._notifyChange(LocationActions.PUSH);
|
||||
}
|
||||
}, {
|
||||
key: 'replace',
|
||||
value: function replace(path) {
|
||||
invariant(this.history.length, 'You cannot replace the current path with no history');
|
||||
|
||||
this.history[this.history.length - 1] = path;
|
||||
|
||||
this._notifyChange(LocationActions.REPLACE);
|
||||
}
|
||||
}, {
|
||||
key: 'pop',
|
||||
value: function pop() {
|
||||
this.history.pop();
|
||||
this._updateHistoryLength();
|
||||
this._notifyChange(LocationActions.POP);
|
||||
}
|
||||
}, {
|
||||
key: 'getCurrentPath',
|
||||
value: function getCurrentPath() {
|
||||
return this.history[this.history.length - 1];
|
||||
}
|
||||
}, {
|
||||
key: 'toString',
|
||||
value: function toString() {
|
||||
return '<TestLocation>';
|
||||
}
|
||||
}]);
|
||||
|
||||
return TestLocation;
|
||||
})();
|
||||
|
||||
module.exports = TestLocation;
|
||||
Reference in New Issue
Block a user