@twreporter/universal-header 2.2.15-rc.2 → 2.3.0-rc.0

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.
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.slogan = exports["default"] = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _slogan = _interopRequireDefault(require("./slogan"));
11
+
12
+ var _headerContext = _interopRequireDefault(require("../contexts/header-context"));
13
+
14
+ var _theme = require("@twreporter/core/lib/constants/theme");
15
+
16
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
17
+
18
+ /* eslint-disable react/prop-types */
19
+ var _default = {
20
+ title: 'Slogan',
21
+ component: _slogan["default"],
22
+ argTypes: {
23
+ theme: _theme.THEME_STORYBOOK_ARG_TYPE
24
+ }
25
+ };
26
+ exports["default"] = _default;
27
+
28
+ var slogan = function slogan(props) {
29
+ var theme = props.theme;
30
+ var context = {
31
+ theme: theme
32
+ };
33
+ return /*#__PURE__*/_react["default"].createElement(_headerContext["default"].Provider, {
34
+ value: context
35
+ }, /*#__PURE__*/_react["default"].createElement(_slogan["default"], null));
36
+ };
37
+
38
+ exports.slogan = slogan;
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = exports.actionActive = exports.actionOrder = exports.actionLabels = exports.actionKeys = void 0;
7
+
8
+ var _actionLabels, _wide, _narrow;
9
+
10
+ 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; }
11
+
12
+ var actionKeys = {
13
+ support: 'support',
14
+ newsLetter: 'newsLetter'
15
+ };
16
+ exports.actionKeys = actionKeys;
17
+ var actionLabels = (_actionLabels = {}, _defineProperty(_actionLabels, actionKeys.support, '贊助'), _defineProperty(_actionLabels, actionKeys.newsLetter, '訂閱'), _actionLabels);
18
+ exports.actionLabels = actionLabels;
19
+ var actionOrder = {
20
+ mobile: [actionKeys.support],
21
+ desktop: [actionKeys.support, actionKeys.newsLetter]
22
+ };
23
+ exports.actionOrder = actionOrder;
24
+ var actionActive = {
25
+ wide: (_wide = {}, _defineProperty(_wide, actionKeys.support, true), _defineProperty(_wide, actionKeys.newsLetter, true), _wide),
26
+ narrow: (_narrow = {}, _defineProperty(_narrow, actionKeys.support, true), _defineProperty(_narrow, actionKeys.newsLetter, false), _narrow)
27
+ };
28
+ exports.actionActive = actionActive;
29
+ var _default = {
30
+ actionKeys: actionKeys,
31
+ actionLabels: actionLabels,
32
+ actionOrder: actionOrder,
33
+ actionActive: actionActive
34
+ };
35
+ exports["default"] = _default;
@@ -3,9 +3,9 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports["default"] = exports.actionActive = exports.actionOrder = exports.actionLabels = exports.actionKeys = void 0;
6
+ exports["default"] = exports.actionOrder = exports.ACTION_BUTTON_TYPE = exports.ACTION_LABEL = exports.actionKeys = void 0;
7
7
 
8
- var _actionLabels, _wide, _narrow;
8
+ var _row, _column, _ACTION_BUTTON_TYPE;
9
9
 
10
10
  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; }
11
11
 
@@ -14,22 +14,23 @@ var actionKeys = {
14
14
  newsLetter: 'newsLetter'
15
15
  };
16
16
  exports.actionKeys = actionKeys;
17
- var actionLabels = (_actionLabels = {}, _defineProperty(_actionLabels, actionKeys.support, '贊助'), _defineProperty(_actionLabels, actionKeys.newsLetter, '訂閱'), _actionLabels);
18
- exports.actionLabels = actionLabels;
17
+ var ACTION_LABEL = {
18
+ row: (_row = {}, _defineProperty(_row, actionKeys.support, '贊助'), _defineProperty(_row, actionKeys.newsLetter, '訂閱'), _row),
19
+ column: (_column = {}, _defineProperty(_column, actionKeys.support, '贊助我們'), _defineProperty(_column, actionKeys.newsLetter, '訂閱電子報'), _column)
20
+ };
21
+ exports.ACTION_LABEL = ACTION_LABEL;
22
+ var ACTION_BUTTON_TYPE = (_ACTION_BUTTON_TYPE = {}, _defineProperty(_ACTION_BUTTON_TYPE, actionKeys.support, 'primary'), _defineProperty(_ACTION_BUTTON_TYPE, actionKeys.newsLetter, 'secondary'), _ACTION_BUTTON_TYPE);
23
+ exports.ACTION_BUTTON_TYPE = ACTION_BUTTON_TYPE;
19
24
  var actionOrder = {
20
25
  mobile: [actionKeys.support],
21
- desktop: [actionKeys.support, actionKeys.newsLetter]
26
+ desktop: [actionKeys.newsLetter, actionKeys.support],
27
+ hamburger: [actionKeys.newsLetter, actionKeys.support]
22
28
  };
23
29
  exports.actionOrder = actionOrder;
24
- var actionActive = {
25
- wide: (_wide = {}, _defineProperty(_wide, actionKeys.support, true), _defineProperty(_wide, actionKeys.newsLetter, true), _wide),
26
- narrow: (_narrow = {}, _defineProperty(_narrow, actionKeys.support, true), _defineProperty(_narrow, actionKeys.newsLetter, false), _narrow)
27
- };
28
- exports.actionActive = actionActive;
29
30
  var _default = {
30
31
  actionKeys: actionKeys,
31
- actionLabels: actionLabels,
32
32
  actionOrder: actionOrder,
33
- actionActive: actionActive
33
+ ACTION_LABEL: ACTION_LABEL,
34
+ ACTION_BUTTON_TYPE: ACTION_BUTTON_TYPE
34
35
  };
35
36
  exports["default"] = _default;
@@ -0,0 +1,389 @@
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 _propTypes = _interopRequireDefault(require("prop-types"));
11
+
12
+ var _react = _interopRequireDefault(require("react"));
13
+
14
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
15
+
16
+ var _reactRedux = require("react-redux");
17
+
18
+ var _headerContext = _interopRequireDefault(require("../contexts/header-context"));
19
+
20
+ var _links = _interopRequireDefault(require("../utils/links"));
21
+
22
+ var _categories = require("../constants/categories");
23
+
24
+ var _channels = require("../constants/channels");
25
+
26
+ var _actionsOld = require("../constants/actions-old");
27
+
28
+ var _services = require("../constants/services");
29
+
30
+ var _propTypes2 = _interopRequireDefault(require("../constants/prop-types"));
31
+
32
+ var _headerOld = _interopRequireDefault(require("../components/header-old"));
33
+
34
+ var _mobileHeader = _interopRequireDefault(require("../components/mobile-header"));
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 _excluded = ["releaseBranch", "isAuthed", "isLinkExternal", "theme"];
43
+
44
+ var _templateObject, _templateObject2, _templateObject3;
45
+
46
+ 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); }
47
+
48
+ 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; }
49
+
50
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
51
+
52
+ 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; }
53
+
54
+ 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; }
55
+
56
+ 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); }
57
+
58
+ 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; }
59
+
60
+ 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; }
61
+
62
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
63
+
64
+ 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); } }
65
+
66
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
67
+
68
+ 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); }
69
+
70
+ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
71
+
72
+ 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); }; }
73
+
74
+ 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); }
75
+
76
+ function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
77
+
78
+ 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; } }
79
+
80
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
81
+
82
+ 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; }
83
+
84
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
85
+
86
+ var _ = {
87
+ get: _get["default"],
88
+ map: _map["default"]
89
+ };
90
+ var HIDE_HEADER_THRESHOLD = 8;
91
+ var TRANSFORM_HEADER_THRESHOLD = 40;
92
+ var TRANSFORM_TIMEOUT = 800;
93
+ var stickyTop = /*#__PURE__*/(0, _styledComponents.css)(["position:sticky;top:0;z-index:1000;"]);
94
+
95
+ var MobileOnly = /*#__PURE__*/_styledComponents["default"].div.withConfig({
96
+ displayName: "header-old__MobileOnly",
97
+ componentId: "sc-1455rjc-0"
98
+ })(["display:none;", ""], _mediaQuery["default"].mobileOnly(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n display: block;\n ", "\n "])), stickyTop));
99
+
100
+ var TabletOnly = /*#__PURE__*/_styledComponents["default"].div.withConfig({
101
+ displayName: "header-old__TabletOnly",
102
+ componentId: "sc-1455rjc-1"
103
+ })(["display:none;", ""], _mediaQuery["default"].tabletOnly(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n display: block;\n ", "\n "])), stickyTop));
104
+
105
+ var DesktopAndAbove = /*#__PURE__*/_styledComponents["default"].div.withConfig({
106
+ displayName: "header-old__DesktopAndAbove",
107
+ componentId: "sc-1455rjc-2"
108
+ })(["display:none;", ""], _mediaQuery["default"].desktopAndAbove(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["\n display: block;\n ", "\n "])), stickyTop));
109
+
110
+ var Container = /*#__PURE__*/function (_React$PureComponent) {
111
+ _inherits(Container, _React$PureComponent);
112
+
113
+ var _super = _createSuper(Container);
114
+
115
+ function Container(props) {
116
+ var _this;
117
+
118
+ _classCallCheck(this, Container);
119
+
120
+ _this = _super.call(this, props);
121
+ _this.state = {
122
+ toUseNarrow: false,
123
+ hideHeader: false
124
+ };
125
+ _this.lastKnownPageYOffset = 0;
126
+ _this.ticking = false;
127
+ _this.handleScroll = _this.__handleScroll.bind(_assertThisInitialized(_this)); // Below parameters are used to calculate scroll transform status.
128
+
129
+ _this.currentY = 0;
130
+ _this.readyY = 0;
131
+ _this.isTransforming = false;
132
+ _this.transformTimer = null;
133
+ return _this;
134
+ }
135
+
136
+ _createClass(Container, [{
137
+ key: "componentDidMount",
138
+ value: function componentDidMount() {
139
+ window.addEventListener('scroll', this.handleScroll, {
140
+ passive: true
141
+ });
142
+ }
143
+ }, {
144
+ key: "componentWillUnmount",
145
+ value: function componentWillUnmount() {
146
+ window.removeEventListener('scroll', this.handleScroll);
147
+ this.lastKnownPageYOffset = null;
148
+ this.ticking = null;
149
+ this.handleScroll = null;
150
+ this.currentY = null;
151
+ this.readyY = null;
152
+ this.isTransforming = null;
153
+ this.transformTimer = null;
154
+ }
155
+ /**
156
+ * Wrap __handleScroll() with requestAnimationFrame() to avoid triggering browser reflow due to reading window.pageYOffset.
157
+ * ref: https://developer.mozilla.org/en-US/docs/web/api/document/scroll_event#Example
158
+ */
159
+
160
+ }, {
161
+ key: "__handleScroll",
162
+ value: function __handleScroll() {
163
+ var _this2 = this;
164
+
165
+ this.lastKnownPageYOffset = window.pageYOffset;
166
+
167
+ if (!this.ticking) {
168
+ window.requestAnimationFrame(function () {
169
+ _this2.__updateScrollState(_this2.lastKnownPageYOffset);
170
+
171
+ _this2.ticking = false;
172
+ });
173
+ this.ticking = true;
174
+ }
175
+ }
176
+ }, {
177
+ key: "__updateScrollState",
178
+ value: function __updateScrollState(currentScrollTop) {
179
+ var scrollDirection = currentScrollTop > this.currentY ? 'down' : 'up';
180
+ this.currentY = currentScrollTop;
181
+
182
+ var updateState = this.__getScrollState(currentScrollTop, scrollDirection);
183
+
184
+ this.setState(updateState);
185
+ }
186
+ }, {
187
+ key: "__getScrollState",
188
+ value: function __getScrollState(scrollTop, scrollDirection) {
189
+ var _this3 = this;
190
+
191
+ var isCurrentNarrow = this.state.toUseNarrow;
192
+ var nextToUseNarrow = scrollTop > TRANSFORM_HEADER_THRESHOLD;
193
+ var scrollState = {};
194
+
195
+ if (this.isTransforming) {
196
+ return scrollState;
197
+ }
198
+
199
+ if (scrollDirection === 'up') {
200
+ this.readyY = scrollTop;
201
+ scrollState.hideHeader = false;
202
+ }
203
+
204
+ if (scrollDirection === 'down') {
205
+ // after transforming to narrow header, header should hide when scroll down
206
+ if (isCurrentNarrow && scrollTop - this.readyY > HIDE_HEADER_THRESHOLD) {
207
+ scrollState.hideHeader = true;
208
+ }
209
+ }
210
+
211
+ if (isCurrentNarrow) {
212
+ // after transforming to narrow header, always remain narrow when scroll down
213
+ scrollState.toUseNarrow = scrollDirection === 'down' ? true : nextToUseNarrow;
214
+ } else {
215
+ // after transfroming to wide header, always remain wide when scroll up
216
+ scrollState.toUseNarrow = scrollDirection === 'up' ? false : nextToUseNarrow;
217
+ } // register transform timer to mark header transform status
218
+
219
+
220
+ if (isCurrentNarrow !== scrollState.toUseNarrow) {
221
+ if (!this.transformTimer) {
222
+ this.isTransforming = true;
223
+ this.transformTimer = setTimeout(function () {
224
+ _this3.isTransforming = false;
225
+ _this3.readyY = _this3.currentY;
226
+ _this3.transformTimer = null;
227
+ }, TRANSFORM_TIMEOUT);
228
+ }
229
+ }
230
+
231
+ return scrollState;
232
+ }
233
+ }, {
234
+ key: "__prepareServiceProps",
235
+ value: function __prepareServiceProps(isAuthed) {
236
+ var serviceProps = _.map(_services.serviceOrder, function (key) {
237
+ return {
238
+ key: key
239
+ };
240
+ });
241
+
242
+ if (isAuthed) {
243
+ var logoutKey = _services.serviceKeys.logout;
244
+ serviceProps.push({
245
+ key: logoutKey
246
+ });
247
+ } else {
248
+ var loginKey = _services.serviceKeys.login;
249
+ serviceProps.push({
250
+ key: loginKey
251
+ });
252
+ }
253
+
254
+ return serviceProps;
255
+ }
256
+ }, {
257
+ key: "__prepareChannelProps",
258
+ value: function __prepareChannelProps(releaseBranch, isLinkExternal) {
259
+ var channelProps = _.map(_channels.channelOrder, function (key) {
260
+ return {
261
+ key: key,
262
+ label: _channels.channelLabels[key],
263
+ type: _channels.channelTypes[key],
264
+ pathname: _channels.channelPathnames[key],
265
+ link: _links["default"].getChannelLinks(isLinkExternal, releaseBranch)[key]
266
+ };
267
+ });
268
+
269
+ return channelProps;
270
+ }
271
+ }, {
272
+ key: "__prepareCategoriesProps",
273
+ value: function __prepareCategoriesProps(releaseBranch, isLinkExternal, channelProps) {
274
+ channelProps[channelProps.length - 1].dropDownMenu = _.map(_categories.categoryOrder, function (key) {
275
+ return {
276
+ key: key,
277
+ label: _categories.categoryLabels[key],
278
+ pathname: _categories.categoryPathnames[key],
279
+ link: _links["default"].getCategoryLinks(isLinkExternal, releaseBranch)[key]
280
+ };
281
+ });
282
+ }
283
+ }, {
284
+ key: "__prepareActionProps",
285
+ value: function __prepareActionProps() {
286
+ var isActive = _actionsOld.actionActive;
287
+
288
+ var mobileActionProps = _.map(_actionsOld.actionOrder.mobile, function (key) {
289
+ return {
290
+ key: key
291
+ };
292
+ });
293
+
294
+ var desktopAndTabletActionProps = _.map(_actionsOld.actionOrder.desktop, function (key) {
295
+ return {
296
+ key: key
297
+ };
298
+ });
299
+
300
+ var narrowActionProps = _.map(_actionsOld.actionOrder.desktop, function (key) {
301
+ return {
302
+ key: key,
303
+ active: isActive.narrow[key]
304
+ };
305
+ });
306
+
307
+ return {
308
+ mobile: mobileActionProps,
309
+ tablet: desktopAndTabletActionProps,
310
+ hamburger: desktopAndTabletActionProps,
311
+ desktop: desktopAndTabletActionProps,
312
+ narrow: narrowActionProps
313
+ };
314
+ }
315
+ }, {
316
+ key: "render",
317
+ value: function render() {
318
+ var _this$props = this.props,
319
+ releaseBranch = _this$props.releaseBranch,
320
+ isAuthed = _this$props.isAuthed,
321
+ isLinkExternal = _this$props.isLinkExternal,
322
+ theme = _this$props.theme,
323
+ passThrough = _objectWithoutProperties(_this$props, _excluded);
324
+
325
+ var _this$state = this.state,
326
+ toUseNarrow = _this$state.toUseNarrow,
327
+ hideHeader = _this$state.hideHeader;
328
+ var contextValue = {
329
+ releaseBranch: releaseBranch,
330
+ isAuthed: isAuthed,
331
+ isLinkExternal: isLinkExternal,
332
+ theme: theme,
333
+ toUseNarrow: toUseNarrow,
334
+ hideHeader: hideHeader
335
+ };
336
+
337
+ var serviceProps = this.__prepareServiceProps(isAuthed);
338
+
339
+ var channelProps = this.__prepareChannelProps(releaseBranch, isLinkExternal);
340
+
341
+ var actionProps = this.__prepareActionProps();
342
+
343
+ this.__prepareCategoriesProps(releaseBranch, isLinkExternal, channelProps);
344
+
345
+ return /*#__PURE__*/_react["default"].createElement(_headerContext["default"].Provider, {
346
+ value: contextValue
347
+ }, /*#__PURE__*/_react["default"].createElement(MobileOnly, null, /*#__PURE__*/_react["default"].createElement(_mobileHeader["default"], _extends({
348
+ actions: actionProps.mobile,
349
+ menuChannels: channelProps,
350
+ menuServices: serviceProps,
351
+ menuActions: actionProps.hamburger,
352
+ narrowActions: actionProps.narrow
353
+ }, passThrough))), /*#__PURE__*/_react["default"].createElement(TabletOnly, null, /*#__PURE__*/_react["default"].createElement(_mobileHeader["default"], _extends({
354
+ actions: actionProps.tablet,
355
+ menuChannels: channelProps,
356
+ menuServices: serviceProps,
357
+ menuActions: actionProps.hamburger,
358
+ narrowActions: actionProps.narrow
359
+ }, passThrough))), /*#__PURE__*/_react["default"].createElement(DesktopAndAbove, null, /*#__PURE__*/_react["default"].createElement(_headerOld["default"], _extends({
360
+ channels: channelProps,
361
+ services: serviceProps,
362
+ actions: actionProps.desktop,
363
+ narrowActions: actionProps.narrow
364
+ }, passThrough))));
365
+ }
366
+ }]);
367
+
368
+ return Container;
369
+ }(_react["default"].PureComponent);
370
+
371
+ _defineProperty(Container, "defaultProps", _objectSpread(_objectSpread({}, _propTypes2["default"].context.defaultProps), {}, {
372
+ pathname: ''
373
+ }));
374
+
375
+ _defineProperty(Container, "propTypes", _objectSpread(_objectSpread({}, _propTypes2["default"].context.propTypes), {}, {
376
+ pathname: _propTypes["default"].string
377
+ }));
378
+
379
+ function mapStateToProps(state) {
380
+ return {
381
+ isAuthed: _.get(state, 'auth.isAuthed', false) // bookmarks: _.get(state, 'header.bookmarks'),
382
+ // notifications: _.get(state, 'headers.notifications'),
383
+
384
+ };
385
+ }
386
+
387
+ var _default = (0, _reactRedux.connect)(mapStateToProps)(Container);
388
+
389
+ exports["default"] = _default;