@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.
- package/CHANGELOG.md +302 -0
- package/LICENSE +21 -0
- package/README.md +223 -0
- package/lib/actions/auth.js +105 -0
- package/lib/actions/error-action-creators.js +162 -0
- package/lib/components/action-button.js +216 -0
- package/lib/components/channels.js +420 -0
- package/lib/components/customized-link.js +49 -0
- package/lib/components/drop-down-menu.js +138 -0
- package/lib/components/hamburger-icons.js +270 -0
- package/lib/components/hamburger-menu.js +152 -0
- package/lib/components/header.js +233 -0
- package/lib/components/icons.js +276 -0
- package/lib/components/mobile-header.js +264 -0
- package/lib/components/search-box.js +214 -0
- package/lib/components/slogan.js +57 -0
- package/lib/constants/action-types.js +14 -0
- package/lib/constants/actions.js +35 -0
- package/lib/constants/categories.js +32 -0
- package/lib/constants/channels.js +41 -0
- package/lib/constants/colors.js +17 -0
- package/lib/constants/external-links.js +13 -0
- package/lib/constants/fonts.js +32 -0
- package/lib/constants/prop-types.js +46 -0
- package/lib/constants/services.js +31 -0
- package/lib/constants/slogan.js +9 -0
- package/lib/constants/theme.js +13 -0
- package/lib/containers/header.js +375 -0
- package/lib/contexts/header-context.js +17 -0
- package/lib/index.js +18 -0
- package/lib/reducers/auth.js +109 -0
- package/lib/reducers/index.js +22 -0
- package/lib/standalone-header.js +110 -0
- package/lib/utils/animations.js +32 -0
- package/lib/utils/icon.js +905 -0
- package/lib/utils/jwt.js +37 -0
- package/lib/utils/links.js +177 -0
- package/lib/utils/theme.js +415 -0
- 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
|
+
});
|