@twreporter/universal-header 2.2.0-rc.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/CHANGELOG.md +302 -0
  2. package/LICENSE +21 -0
  3. package/README.md +223 -0
  4. package/lib/actions/auth.js +105 -0
  5. package/lib/actions/error-action-creators.js +162 -0
  6. package/lib/components/action-button.js +216 -0
  7. package/lib/components/channels.js +420 -0
  8. package/lib/components/customized-link.js +49 -0
  9. package/lib/components/drop-down-menu.js +138 -0
  10. package/lib/components/hamburger-icons.js +270 -0
  11. package/lib/components/hamburger-menu.js +152 -0
  12. package/lib/components/header.js +233 -0
  13. package/lib/components/icons.js +276 -0
  14. package/lib/components/mobile-header.js +264 -0
  15. package/lib/components/search-box.js +214 -0
  16. package/lib/components/slogan.js +57 -0
  17. package/lib/constants/action-types.js +14 -0
  18. package/lib/constants/actions.js +35 -0
  19. package/lib/constants/categories.js +32 -0
  20. package/lib/constants/channels.js +41 -0
  21. package/lib/constants/colors.js +17 -0
  22. package/lib/constants/external-links.js +13 -0
  23. package/lib/constants/fonts.js +32 -0
  24. package/lib/constants/prop-types.js +46 -0
  25. package/lib/constants/services.js +31 -0
  26. package/lib/constants/slogan.js +9 -0
  27. package/lib/constants/theme.js +13 -0
  28. package/lib/containers/header.js +375 -0
  29. package/lib/contexts/header-context.js +17 -0
  30. package/lib/index.js +18 -0
  31. package/lib/reducers/auth.js +109 -0
  32. package/lib/reducers/index.js +22 -0
  33. package/lib/standalone-header.js +110 -0
  34. package/lib/utils/animations.js +32 -0
  35. package/lib/utils/icon.js +905 -0
  36. package/lib/utils/jwt.js +37 -0
  37. package/lib/utils/links.js +177 -0
  38. package/lib/utils/theme.js +415 -0
  39. package/package.json +38 -0
@@ -0,0 +1,375 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _header = _interopRequireDefault(require("../components/header"));
11
+
12
+ var _headerContext = _interopRequireDefault(require("../contexts/header-context"));
13
+
14
+ var _mobileHeader = _interopRequireDefault(require("../components/mobile-header"));
15
+
16
+ var _propTypes = _interopRequireDefault(require("prop-types"));
17
+
18
+ var _react = _interopRequireDefault(require("react"));
19
+
20
+ var _categories = _interopRequireDefault(require("../constants/categories"));
21
+
22
+ var _channels = _interopRequireDefault(require("../constants/channels"));
23
+
24
+ var _actions = _interopRequireDefault(require("../constants/actions"));
25
+
26
+ var _links = _interopRequireDefault(require("../utils/links"));
27
+
28
+ var _services = _interopRequireDefault(require("../constants/services"));
29
+
30
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
31
+
32
+ var _propTypes2 = _interopRequireDefault(require("../constants/prop-types"));
33
+
34
+ var _reactRedux = require("react-redux");
35
+
36
+ var _mediaQuery = _interopRequireDefault(require("@twreporter/core/lib/utils/media-query"));
37
+
38
+ var _get = _interopRequireDefault(require("lodash/get"));
39
+
40
+ var _map = _interopRequireDefault(require("lodash/map"));
41
+
42
+ var _throttle = _interopRequireDefault(require("lodash/throttle"));
43
+
44
+ var _excluded = ["releaseBranch", "isAuthed", "isLinkExternal", "theme"];
45
+
46
+ var _templateObject, _templateObject2, _templateObject3;
47
+
48
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
49
+
50
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
51
+
52
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
53
+
54
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
55
+
56
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
57
+
58
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
59
+
60
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
61
+
62
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
63
+
64
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
65
+
66
+ 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); } }
67
+
68
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
69
+
70
+ function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
71
+
72
+ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
73
+
74
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
75
+
76
+ function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
77
+
78
+ function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
79
+
80
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
81
+
82
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
83
+
84
+ 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; }
85
+
86
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
87
+
88
+ var _ = {
89
+ get: _get["default"],
90
+ map: _map["default"],
91
+ throttle: _throttle["default"]
92
+ };
93
+ var HIDE_HEADER_THRESHOLD = 46;
94
+ var TRANSFORM_HEADER_THRESHOLD = 20;
95
+ var TRANSFORM_TIMEOUT = 800;
96
+ var stickyTop = /*#__PURE__*/(0, _styledComponents.css)(["position:sticky;top:0;z-index:999;"]);
97
+
98
+ var MobileOnly = /*#__PURE__*/_styledComponents["default"].div.withConfig({
99
+ displayName: "header__MobileOnly",
100
+ componentId: "narage-0"
101
+ })(["display:none;", ""], _mediaQuery["default"].mobileOnly(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n display: block;\n ", "\n "])), stickyTop));
102
+
103
+ var TabletOnly = /*#__PURE__*/_styledComponents["default"].div.withConfig({
104
+ displayName: "header__TabletOnly",
105
+ componentId: "narage-1"
106
+ })(["display:none;", ""], _mediaQuery["default"].tabletOnly(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n display: block;\n ", "\n "])), stickyTop));
107
+
108
+ var DesktopAndAbove = /*#__PURE__*/_styledComponents["default"].div.withConfig({
109
+ displayName: "header__DesktopAndAbove",
110
+ componentId: "narage-2"
111
+ })(["display:none;", ""], _mediaQuery["default"].desktopAndAbove(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["\n display: block;\n ", "\n "])), stickyTop));
112
+
113
+ function mergeTwoArraysInOrder() {
114
+ var arr1 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
115
+ var arr2 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
116
+ var rtn = [];
117
+ var maxLength = Math.max(arr1.length, arr2.length);
118
+
119
+ for (var i = 0; i < maxLength; i++) {
120
+ if (arr1[i]) {
121
+ rtn.push(arr1[i]);
122
+ }
123
+
124
+ if (arr2[i]) {
125
+ rtn.push(arr2[i]);
126
+ }
127
+ }
128
+
129
+ return rtn;
130
+ }
131
+
132
+ var Container = /*#__PURE__*/function (_React$PureComponent) {
133
+ _inherits(Container, _React$PureComponent);
134
+
135
+ var _super = _createSuper(Container);
136
+
137
+ function Container(props) {
138
+ var _this;
139
+
140
+ _classCallCheck(this, Container);
141
+
142
+ _this = _super.call(this, props);
143
+ _this.state = {
144
+ toUseNarrow: false,
145
+ hideHeader: false
146
+ };
147
+ _this.handleScroll = _.throttle(_this.__handleScroll, 450).bind(_assertThisInitialized(_this)); // Below parameters are used to calculate scroll transform status.
148
+
149
+ _this.currentY = 0;
150
+ _this.readyY = 0;
151
+ _this.isTransformfasle = false;
152
+ _this.transformTimer = null;
153
+ return _this;
154
+ }
155
+
156
+ _createClass(Container, [{
157
+ key: "componentDidMount",
158
+ value: function componentDidMount() {
159
+ window.addEventListener('scroll', this.handleScroll, {
160
+ passive: true
161
+ });
162
+ }
163
+ }, {
164
+ key: "componentWillUnmount",
165
+ value: function componentWillUnmount() {
166
+ window.removeEventListener('scroll', this.handleScroll);
167
+ }
168
+ }, {
169
+ key: "__handleScroll",
170
+ value: function __handleScroll(event) {
171
+ var currentScrollTop = window.pageYOffset;
172
+ var scrollDirection = currentScrollTop > this.currentY ? 'down' : 'up';
173
+ this.currentY = currentScrollTop;
174
+
175
+ var updateState = this.__getScrollState(currentScrollTop, scrollDirection);
176
+
177
+ this.setState(updateState);
178
+ }
179
+ }, {
180
+ key: "__getScrollState",
181
+ value: function __getScrollState(scrollTop, scrollDirection) {
182
+ var _this2 = this;
183
+
184
+ var isCurrentNarrow = this.state.toUseNarrow;
185
+ var scrollState = {};
186
+
187
+ if (this.isTransforming) {
188
+ return scrollState;
189
+ }
190
+
191
+ scrollState.toUseNarrow = scrollTop > TRANSFORM_HEADER_THRESHOLD ? true : false;
192
+
193
+ if (scrollDirection === 'up') {
194
+ this.readyY = scrollTop;
195
+ scrollState.hideHeader = false;
196
+ }
197
+
198
+ if (scrollDirection === 'down') {
199
+ // after transforming to narrow header, header should hide when scroll down
200
+ if (isCurrentNarrow && scrollTop - this.readyY > HIDE_HEADER_THRESHOLD) {
201
+ scrollState.hideHeader = true;
202
+ }
203
+ } // register transform timer to mark header transform status
204
+
205
+
206
+ if (isCurrentNarrow !== scrollState.toUseNarrow) {
207
+ if (!this.transformTimer) {
208
+ this.isTransforming = true;
209
+ this.transformTimer = setTimeout(function () {
210
+ _this2.isTransforming = false;
211
+ _this2.readyY = _this2.currentY;
212
+ _this2.transformTimer = null;
213
+ }, TRANSFORM_TIMEOUT);
214
+ }
215
+ }
216
+
217
+ return scrollState;
218
+ }
219
+ }, {
220
+ key: "__prepareServiceProps",
221
+ value: function __prepareServiceProps(isAuthed) {
222
+ var serviceProps = _.map(_services["default"].serviceOrder, function (key) {
223
+ return {
224
+ key: key
225
+ };
226
+ });
227
+
228
+ if (isAuthed) {
229
+ var logoutKey = _services["default"].serviceKeys.logout;
230
+ serviceProps.push({
231
+ key: logoutKey
232
+ });
233
+ } else {
234
+ var loginKey = _services["default"].serviceKeys.login;
235
+ serviceProps.push({
236
+ key: loginKey
237
+ });
238
+ }
239
+
240
+ return serviceProps;
241
+ }
242
+ }, {
243
+ key: "__prepareChannelProps",
244
+ value: function __prepareChannelProps(releaseBranch, isLinkExternal) {
245
+ var channelProps = _.map(_channels["default"].channelOrder, function (key) {
246
+ return {
247
+ key: key,
248
+ label: _channels["default"].channelLabels[key],
249
+ type: _channels["default"].channelTypes[key],
250
+ pathname: _channels["default"].channelPathnames[key],
251
+ link: _links["default"].getChannelLinks(isLinkExternal, releaseBranch)[key]
252
+ };
253
+ });
254
+
255
+ return channelProps;
256
+ }
257
+ }, {
258
+ key: "__prepareCategoriesProps",
259
+ value: function __prepareCategoriesProps(releaseBranch, isLinkExternal, channelProps) {
260
+ channelProps[channelProps.length - 1].dropDownMenu = _.map(_categories["default"].categoryOrder, function (key) {
261
+ return {
262
+ key: key,
263
+ label: _categories["default"].categoryLabels[key],
264
+ pathname: _categories["default"].categoryPathnames[key],
265
+ link: _links["default"].getCategoryLinks(isLinkExternal, releaseBranch)[key]
266
+ };
267
+ });
268
+ }
269
+ }, {
270
+ key: "__prepareActionProps",
271
+ value: function __prepareActionProps() {
272
+ var isActive = _actions["default"].actionActive;
273
+
274
+ var mobileActionProps = _.map(_actions["default"].actionOrder.mobile, function (key) {
275
+ return {
276
+ key: key
277
+ };
278
+ });
279
+
280
+ var desktopAndTabletActionProps = _.map(_actions["default"].actionOrder.desktop, function (key) {
281
+ return {
282
+ key: key
283
+ };
284
+ });
285
+
286
+ var narrowActionProps = _.map(_actions["default"].actionOrder.desktop, function (key) {
287
+ return {
288
+ key: key,
289
+ active: isActive.narrow[key]
290
+ };
291
+ });
292
+
293
+ return {
294
+ mobile: mobileActionProps,
295
+ tablet: desktopAndTabletActionProps,
296
+ hamburger: desktopAndTabletActionProps,
297
+ desktop: desktopAndTabletActionProps,
298
+ narrow: narrowActionProps
299
+ };
300
+ }
301
+ }, {
302
+ key: "render",
303
+ value: function render() {
304
+ var _this$props = this.props,
305
+ releaseBranch = _this$props.releaseBranch,
306
+ isAuthed = _this$props.isAuthed,
307
+ isLinkExternal = _this$props.isLinkExternal,
308
+ theme = _this$props.theme,
309
+ passThrough = _objectWithoutProperties(_this$props, _excluded);
310
+
311
+ var _this$state = this.state,
312
+ toUseNarrow = _this$state.toUseNarrow,
313
+ hideHeader = _this$state.hideHeader;
314
+ var contextValue = {
315
+ releaseBranch: releaseBranch,
316
+ isAuthed: isAuthed,
317
+ isLinkExternal: isLinkExternal,
318
+ theme: theme,
319
+ toUseNarrow: toUseNarrow,
320
+ hideHeader: hideHeader
321
+ };
322
+
323
+ var serviceProps = this.__prepareServiceProps(isAuthed);
324
+
325
+ var channelProps = this.__prepareChannelProps(releaseBranch, isLinkExternal);
326
+
327
+ var actionProps = this.__prepareActionProps();
328
+
329
+ this.__prepareCategoriesProps(releaseBranch, isLinkExternal, channelProps);
330
+
331
+ return /*#__PURE__*/_react["default"].createElement(_headerContext["default"].Provider, {
332
+ value: contextValue
333
+ }, /*#__PURE__*/_react["default"].createElement(MobileOnly, null, /*#__PURE__*/_react["default"].createElement(_mobileHeader["default"], _extends({
334
+ actions: actionProps.mobile,
335
+ menuChannels: channelProps,
336
+ menuServices: serviceProps,
337
+ menuActions: actionProps.hamburger,
338
+ narrowActions: actionProps.narrow
339
+ }, passThrough))), /*#__PURE__*/_react["default"].createElement(TabletOnly, null, /*#__PURE__*/_react["default"].createElement(_mobileHeader["default"], _extends({
340
+ actions: actionProps.tablet,
341
+ menuChannels: channelProps,
342
+ menuServices: serviceProps,
343
+ menuActions: actionProps.hamburger,
344
+ narrowActions: actionProps.narrow
345
+ }, passThrough))), /*#__PURE__*/_react["default"].createElement(DesktopAndAbove, null, /*#__PURE__*/_react["default"].createElement(_header["default"], _extends({
346
+ channels: channelProps,
347
+ services: serviceProps,
348
+ actions: actionProps.desktop,
349
+ narrowActions: actionProps.narrow
350
+ }, passThrough))));
351
+ }
352
+ }]);
353
+
354
+ return Container;
355
+ }(_react["default"].PureComponent);
356
+
357
+ _defineProperty(Container, "defaultProps", _objectSpread(_objectSpread({}, _propTypes2["default"].context.defaultProps), {}, {
358
+ pathname: ''
359
+ }));
360
+
361
+ _defineProperty(Container, "propTypes", _objectSpread(_objectSpread({}, _propTypes2["default"].context.propTypes), {}, {
362
+ pathname: _propTypes["default"].string
363
+ }));
364
+
365
+ function mapStateToProps(state) {
366
+ return {
367
+ isAuthed: _.get(state, 'auth.isAuthed', false) // bookmarks: _.get(state, 'header.bookmarks'),
368
+ // notifications: _.get(state, 'headers.notifications'),
369
+
370
+ };
371
+ }
372
+
373
+ var _default = (0, _reactRedux.connect)(mapStateToProps)(Container);
374
+
375
+ exports["default"] = _default;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _propTypes = _interopRequireDefault(require("../constants/prop-types"));
11
+
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
13
+
14
+ var HeaderContext = /*#__PURE__*/_react["default"].createContext(_propTypes["default"].context.defaultProps);
15
+
16
+ var _default = HeaderContext;
17
+ exports["default"] = _default;
package/lib/index.js ADDED
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = void 0;
7
+
8
+ var _standaloneHeader = _interopRequireDefault(require("./standalone-header"));
9
+
10
+ var _header = _interopRequireDefault(require("./containers/header"));
11
+
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
13
+
14
+ var _default = {
15
+ Header: _header["default"],
16
+ StandaloneHeader: _standaloneHeader["default"]
17
+ };
18
+ exports["default"] = _default;
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = auth;
7
+
8
+ var _actionTypes = _interopRequireDefault(require("../constants/action-types"));
9
+
10
+ var _jwt = _interopRequireDefault(require("../utils/jwt"));
11
+
12
+ var _get = _interopRequireDefault(require("lodash/get"));
13
+
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
15
+
16
+ // lodash
17
+ var _ = {
18
+ get: _get["default"]
19
+ };
20
+ var initState = {
21
+ accessToken: '',
22
+ actionType: '',
23
+ lastAction: null,
24
+ isAuthed: false,
25
+ isRequesting: false,
26
+ userInfo: null
27
+ };
28
+ /**
29
+ * @param {Object} state - redux state
30
+ * @param {bool} state.isRequesting - requst is in progress
31
+ * @param {bool} state.isAuthed - indicates if authorization succeeds
32
+ * @param {Object} state.lastAction - last redux action for debugging
33
+ * @param {string} state.lastAction.actionType
34
+ * @param {Object} state.lastAction.actionPayload
35
+ * @param {Object} state.userInfo - user information
36
+ * @param {number} state.userInfo.user_id - id of user
37
+ * @param {string} state.userInfo.jwt - access_token granted for the user
38
+ * @param {string} state.userInfo.email - email of the user
39
+ * @param {Object} action - redux action
40
+ * @param {string} action.type
41
+ * @param {Object} action.payload - response of API server
42
+ * @param {string} action.payload.url - request endpoint
43
+ * @param {Object} action.payload.options - request options
44
+ * @param {string} action.payload.message - error message
45
+ */
46
+
47
+ function auth() {
48
+ var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initState;
49
+ var action = arguments.length > 1 ? arguments[1] : undefined;
50
+
51
+ switch (action.type) {
52
+ case _actionTypes["default"].AUTH_CLEAR:
53
+ {
54
+ // return empty state
55
+ return initState;
56
+ }
57
+
58
+ case _actionTypes["default"].REQUEST_AUTH:
59
+ {
60
+ return {
61
+ accessToken: initState.accessToken,
62
+ lastAction: {
63
+ type: action.type,
64
+ payload: action.payload
65
+ },
66
+ isAuthed: false,
67
+ isRequesting: true,
68
+ userInfo: initState.userInfo
69
+ };
70
+ }
71
+
72
+ case _actionTypes["default"].AUTH_FAILURE:
73
+ {
74
+ return {
75
+ accessToken: initState.accessToken,
76
+ lastAction: {
77
+ type: action.type,
78
+ payload: action.payload
79
+ },
80
+ isAuthed: false,
81
+ isRequesting: false,
82
+ userInfo: initState.userInfo
83
+ };
84
+ }
85
+
86
+ case _actionTypes["default"].AUTH_SUCCESS:
87
+ {
88
+ var jwt = _.get(action, 'payload.data.jwt', '');
89
+
90
+ var userInfo = _jwt["default"].decodePayload(jwt);
91
+
92
+ return {
93
+ accessToken: jwt,
94
+ lastAction: {
95
+ type: action.type,
96
+ payload: action.payload
97
+ },
98
+ isAuthed: true,
99
+ isRequesting: false,
100
+ userInfo: userInfo
101
+ };
102
+ }
103
+
104
+ default:
105
+ {
106
+ return state;
107
+ }
108
+ }
109
+ }
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = void 0;
7
+
8
+ var _redux = require("redux");
9
+
10
+ var _auth = _interopRequireDefault(require("./auth"));
11
+
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
13
+
14
+ var rootReducer = (0, _redux.combineReducers)({
15
+ origins: function origins() {
16
+ var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
17
+ return state;
18
+ },
19
+ auth: _auth["default"]
20
+ });
21
+ var _default = rootReducer;
22
+ exports["default"] = _default;
@@ -0,0 +1,110 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _header = _interopRequireDefault(require("./containers/header"));
11
+
12
+ var _propTypes = _interopRequireDefault(require("prop-types"));
13
+
14
+ var _react = _interopRequireDefault(require("react"));
15
+
16
+ var _requestOrigins = _interopRequireDefault(require("@twreporter/core/lib/constants/request-origins"));
17
+
18
+ var _index = _interopRequireDefault(require("./reducers/index"));
19
+
20
+ var _reduxThunk = _interopRequireDefault(require("redux-thunk"));
21
+
22
+ var _propTypes2 = _interopRequireDefault(require("./constants/prop-types"));
23
+
24
+ var _reactRedux = require("react-redux");
25
+
26
+ var _redux = require("redux");
27
+
28
+ var _auth = require("./actions/auth");
29
+
30
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
31
+
32
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
33
+
34
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
35
+
36
+ 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); } }
37
+
38
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
39
+
40
+ function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
41
+
42
+ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
43
+
44
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
45
+
46
+ function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
47
+
48
+ function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
49
+
50
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
51
+
52
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
53
+
54
+ 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; }
55
+
56
+ var StandaloneHeader = /*#__PURE__*/function (_React$PureComponent) {
57
+ _inherits(StandaloneHeader, _React$PureComponent);
58
+
59
+ var _super = _createSuper(StandaloneHeader);
60
+
61
+ function StandaloneHeader(props) {
62
+ var _this;
63
+
64
+ _classCallCheck(this, StandaloneHeader);
65
+
66
+ _this = _super.call(this, props);
67
+ var releaseBranch = _this.props.releaseBranch;
68
+ _this.store = (0, _redux.createStore)(_index["default"], {
69
+ origins: _requestOrigins["default"].forClientSideRendering[releaseBranch],
70
+ auth: {}
71
+ }, (0, _redux.applyMiddleware)(_reduxThunk["default"]));
72
+ return _this;
73
+ }
74
+
75
+ _createClass(StandaloneHeader, [{
76
+ key: "componentDidMount",
77
+ value: function componentDidMount() {
78
+ this.store.dispatch((0, _auth.getAccessToken)())["catch"](function (failAction) {
79
+ console.log(failAction);
80
+ });
81
+ }
82
+ }, {
83
+ key: "render",
84
+ value: function render() {
85
+ return /*#__PURE__*/_react["default"].createElement(_reactRedux.Provider, {
86
+ store: this.store
87
+ }, /*#__PURE__*/_react["default"].createElement(_header["default"], _extends({
88
+ isLinkExternal: true
89
+ }, this.props)));
90
+ }
91
+ }]);
92
+
93
+ return StandaloneHeader;
94
+ }(_react["default"].PureComponent);
95
+
96
+ exports["default"] = StandaloneHeader;
97
+
98
+ _defineProperty(StandaloneHeader, "propTypes", {
99
+ theme: _propTypes2["default"].context.propTypes.theme,
100
+ releaseBranch: _propTypes2["default"].context.propTypes.releaseBranch,
101
+ isAuthed: _propTypes2["default"].context.propTypes.isAuthed,
102
+ pathname: _propTypes["default"].string
103
+ });
104
+
105
+ _defineProperty(StandaloneHeader, "defaultProps", {
106
+ theme: _propTypes2["default"].context.defaultProps.theme,
107
+ releaseBranch: _propTypes2["default"].context.defaultProps.releaseBranch,
108
+ isAuthed: _propTypes2["default"].context.defaultProps.isAuthed,
109
+ pathname: ''
110
+ });