2018-04-18 12:01:26 -07:00
|
|
|
"use strict";
|
|
|
|
|
|
|
|
var _react = _interopRequireDefault(require("react"));
|
|
|
|
|
|
|
|
var _server = require("react-dom/server");
|
|
|
|
|
|
|
|
var _redux = require("redux");
|
|
|
|
|
|
|
|
var _reactRedux = require("react-redux");
|
|
|
|
|
|
|
|
var _reactRouterDom = require("react-router-dom");
|
|
|
|
|
2018-04-18 12:11:25 -07:00
|
|
|
var _renderFullPage = _interopRequireDefault(require("../renderFullPage"));
|
2018-04-18 12:01:26 -07:00
|
|
|
|
|
|
|
var _reduxSaga = _interopRequireDefault(require("redux-saga"));
|
|
|
|
|
|
|
|
var _effects = require("redux-saga/effects");
|
|
|
|
|
2018-06-06 15:12:07 -07:00
|
|
|
var _reactHelmet = _interopRequireDefault(require("react-helmet"));
|
|
|
|
|
2018-09-27 22:56:10 -05:00
|
|
|
var httpContext = _interopRequireWildcard(require("express-http-context"));
|
|
|
|
|
2018-05-23 11:16:47 -07:00
|
|
|
var _reducers = _interopRequireDefault(require("@reducers"));
|
2018-05-23 01:18:50 -07:00
|
|
|
|
2018-05-23 11:16:47 -07:00
|
|
|
var _GAListener = _interopRequireDefault(require("@components/GAListener"));
|
2018-05-23 01:18:50 -07:00
|
|
|
|
2018-05-23 11:16:47 -07:00
|
|
|
var _app = _interopRequireDefault(require("@app"));
|
2018-05-23 01:18:50 -07:00
|
|
|
|
2018-05-23 11:16:47 -07:00
|
|
|
var _sagas = _interopRequireDefault(require("@sagas"));
|
2018-05-23 01:18:50 -07:00
|
|
|
|
2018-05-23 11:16:47 -07:00
|
|
|
var _actions = _interopRequireDefault(require("@actions"));
|
2018-04-18 12:01:26 -07:00
|
|
|
|
2018-09-27 22:56:10 -05:00
|
|
|
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
|
|
|
|
|
2018-04-18 12:01:26 -07:00
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
|
|
|
2018-11-05 10:26:59 -05:00
|
|
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
|
|
|
|
|
|
|
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
|
|
|
2018-11-01 10:58:12 -04:00
|
|
|
var createCanonicalLink = require('../../../utils/createCanonicalLink');
|
|
|
|
|
|
|
|
var getCanonicalUrlFromShow = function getCanonicalUrlFromShow(show) {
|
|
|
|
var requestId = show.requestList[show.request.id];
|
|
|
|
var requestType = show.request.type;
|
|
|
|
|
|
|
|
switch (requestType) {
|
|
|
|
case 'ASSET_DETAILS':
|
2018-11-05 10:26:59 -05:00
|
|
|
var asset = show.assetList[requestId.key];
|
2018-11-01 10:58:12 -04:00
|
|
|
return createCanonicalLink({
|
2018-11-05 10:26:59 -05:00
|
|
|
asset: _objectSpread({}, asset.claimData, {
|
|
|
|
shortId: asset.shortId
|
|
|
|
})
|
2018-11-01 10:58:12 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
case 'CHANNEL':
|
|
|
|
return createCanonicalLink({
|
|
|
|
channel: show.channelList[requestId.key]
|
|
|
|
});
|
|
|
|
|
|
|
|
default:
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-04-18 12:01:26 -07:00
|
|
|
var returnSagaWithParams = function returnSagaWithParams(saga, params) {
|
|
|
|
return (
|
|
|
|
/*#__PURE__*/
|
|
|
|
regeneratorRuntime.mark(function _callee() {
|
|
|
|
return regeneratorRuntime.wrap(function _callee$(_context) {
|
|
|
|
while (1) {
|
|
|
|
switch (_context.prev = _context.next) {
|
|
|
|
case 0:
|
|
|
|
_context.next = 2;
|
|
|
|
return (0, _effects.call)(saga, params);
|
|
|
|
|
|
|
|
case 2:
|
|
|
|
case "end":
|
|
|
|
return _context.stop();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}, _callee, this);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = function (req, res) {
|
2018-09-27 22:56:10 -05:00
|
|
|
var context = {};
|
2018-04-18 12:01:26 -07:00
|
|
|
|
2018-09-27 22:56:10 -05:00
|
|
|
var _httpContext$get = httpContext.get('routeData'),
|
|
|
|
_httpContext$get$acti = _httpContext$get.action,
|
|
|
|
action = _httpContext$get$acti === void 0 ? false : _httpContext$get$acti,
|
|
|
|
_httpContext$get$saga = _httpContext$get.saga,
|
|
|
|
saga = _httpContext$get$saga === void 0 ? false : _httpContext$get$saga;
|
2018-04-18 12:01:26 -07:00
|
|
|
|
2018-09-27 22:56:10 -05:00
|
|
|
var runSaga = action !== false && saga !== false;
|
2018-04-18 12:01:26 -07:00
|
|
|
|
2018-09-27 22:56:10 -05:00
|
|
|
var renderPage = function renderPage(store) {
|
2018-10-09 13:10:06 -05:00
|
|
|
// Workaround, remove when a solution for async httpContext exists
|
|
|
|
var showState = store.getState().show;
|
|
|
|
var assetKeys = Object.keys(showState.assetList);
|
|
|
|
|
|
|
|
if (assetKeys.length !== 0) {
|
|
|
|
res.claimId = showState.assetList[assetKeys[0]].claimId;
|
|
|
|
} else {
|
|
|
|
var channelKeys = Object.keys(showState.channelList);
|
2018-10-10 11:28:53 -05:00
|
|
|
|
|
|
|
if (channelKeys.length !== 0) {
|
|
|
|
res.claimId = showState.channelList[channelKeys[0]].longId;
|
|
|
|
res.isChannel = true;
|
|
|
|
}
|
2018-10-09 13:10:06 -05:00
|
|
|
} // render component to a string
|
|
|
|
|
|
|
|
|
2018-04-18 12:01:26 -07:00
|
|
|
var html = (0, _server.renderToString)(_react.default.createElement(_reactRedux.Provider, {
|
|
|
|
store: store
|
|
|
|
}, _react.default.createElement(_reactRouterDom.StaticRouter, {
|
|
|
|
location: req.url,
|
|
|
|
context: context
|
2018-06-06 12:01:11 -07:00
|
|
|
}, _react.default.createElement(_GAListener.default, null, _react.default.createElement(_app.default, null))))); // get head tags from helmet
|
2018-04-18 12:01:26 -07:00
|
|
|
|
|
|
|
var helmet = _reactHelmet.default.renderStatic(); // check for a redirect
|
|
|
|
|
|
|
|
|
|
|
|
if (context.url) {
|
|
|
|
return res.redirect(301, context.url);
|
|
|
|
} // get the initial state from our Redux store
|
|
|
|
|
|
|
|
|
|
|
|
var preloadedState = store.getState(); // send the rendered page back to the client
|
|
|
|
|
|
|
|
res.send((0, _renderFullPage.default)(helmet, html, preloadedState));
|
2018-09-27 22:56:10 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
if (runSaga) {
|
|
|
|
// create and apply middleware
|
|
|
|
var sagaMiddleware = (0, _reduxSaga.default)();
|
|
|
|
var middleware = (0, _redux.applyMiddleware)(sagaMiddleware); // create a new Redux store instance
|
|
|
|
|
|
|
|
var store = (0, _redux.createStore)(_reducers.default, middleware); // create an action to handle the given url,
|
|
|
|
// and create a the saga needed to handle that action
|
|
|
|
|
|
|
|
var boundAction = action(req.params, req.url);
|
|
|
|
var boundSaga = returnSagaWithParams(saga, boundAction); // run the saga middleware with the saga call
|
|
|
|
|
|
|
|
sagaMiddleware.run(boundSaga).done.then(function () {
|
2018-11-01 10:58:12 -04:00
|
|
|
// redirect if request does not use canonical url
|
|
|
|
var canonicalUrl = getCanonicalUrlFromShow(store.getState().show);
|
|
|
|
|
|
|
|
if (canonicalUrl && canonicalUrl !== req.originalUrl) {
|
|
|
|
console.log("redirecting ".concat(req.originalUrl, " to ").concat(canonicalUrl));
|
|
|
|
res.redirect(canonicalUrl);
|
|
|
|
}
|
|
|
|
|
2018-09-27 22:56:10 -05:00
|
|
|
return renderPage(store);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
var _store = (0, _redux.createStore)(_reducers.default);
|
|
|
|
|
|
|
|
renderPage(_store);
|
|
|
|
}
|
2018-04-18 12:01:26 -07:00
|
|
|
};
|