Merge branch 'fix/attachments-cleanup' into 'develop'
[akkoma] / priv / static / packs / features / domain_blocks.js.map
index aa9e8b23c7f5e81de59553ffbe099d1a87a98993..f1e7caa3889ba6a51eb5b0ac84331ded348401cb 100644 (file)
@@ -1 +1 @@
-{"version":3,"sources":["webpack:///features/domain_blocks.js","webpack:///./app/javascript/mastodon/containers/domain_container.js","webpack:///./node_modules/babel-runtime/helpers/objectDestructuringEmpty.js","webpack:///./app/javascript/mastodon/components/domain.js","webpack:///./app/javascript/mastodon/features/ui/components/column_header.js","webpack:///./app/javascript/mastodon/features/ui/components/column.js","webpack:///./app/javascript/mastodon/components/load_more.js","webpack:///./app/javascript/mastodon/components/column_back_button.js","webpack:///./app/javascript/mastodon/components/scrollable_list.js","webpack:///./app/javascript/mastodon/containers/intersection_observer_article_container.js","webpack:///./app/javascript/mastodon/components/intersection_observer_article.js","webpack:///./app/javascript/mastodon/features/ui/util/schedule_idle_task.js","webpack:///./node_modules/tiny-queue/index.js","webpack:///./app/javascript/mastodon/features/ui/util/get_rect_from_entry.js","webpack:///./app/javascript/mastodon/features/ui/util/intersection_observer_wrapper.js","webpack:///./app/javascript/mastodon/components/column_back_button_slim.js","webpack:///./app/javascript/mastodon/features/domain_blocks/index.js"],"names":["webpackJsonp","1013","module","__webpack_exports__","__webpack_require__","__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__","__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default","n","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_objectDestructuringEmpty__","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_objectDestructuringEmpty___default","__WEBPACK_IMPORTED_MODULE_2_react__","__WEBPACK_IMPORTED_MODULE_3_react_redux__","__WEBPACK_IMPORTED_MODULE_4__actions_domain_blocks__","__WEBPACK_IMPORTED_MODULE_5_react_intl__","__WEBPACK_IMPORTED_MODULE_6__components_domain__","__WEBPACK_IMPORTED_MODULE_7__actions_modal__","messages","Object","blockDomainConfirm","id","defaultMessage","makeMapStateToProps","state","_ref","mapDispatchToProps","dispatch","_ref2","intl","onBlockDomain","domain","message","values","confirm","formatMessage","onConfirm","onUnblockDomain","1014","exports","__esModule","default","obj","TypeError","1015","d","Account","_class","_class2","_temp2","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default","__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__","__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default","__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__","__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default","__WEBPACK_IMPORTED_MODULE_4_react__","__WEBPACK_IMPORTED_MODULE_5_prop_types__","__WEBPACK_IMPORTED_MODULE_5_prop_types___default","__WEBPACK_IMPORTED_MODULE_6__icon_button__","__WEBPACK_IMPORTED_MODULE_7_react_intl__","__WEBPACK_IMPORTED_MODULE_8_react_immutable_pure_component__","__WEBPACK_IMPORTED_MODULE_8_react_immutable_pure_component___default","unblockDomain","_ImmutablePureCompone","_temp","_this","_ret","this","_len","arguments","length","args","Array","_key","call","apply","concat","handleDomainUnblock","props","prototype","render","_props","className","active","icon","title","onClick","a","propTypes","string","func","isRequired","object","153","ColumnHeader","__WEBPACK_IMPORTED_MODULE_4_react___default","__WEBPACK_IMPORTED_MODULE_5_classnames__","__WEBPACK_IMPORTED_MODULE_5_classnames___default","_React$PureComponent","handleClick","type","columnHeaderId","iconElement","PureComponent","283","Column","__WEBPACK_IMPORTED_MODULE_4_lodash_debounce__","__WEBPACK_IMPORTED_MODULE_4_lodash_debounce___default","__WEBPACK_IMPORTED_MODULE_5_react__","__WEBPACK_IMPORTED_MODULE_5_react___default","__WEBPACK_IMPORTED_MODULE_6__column_header__","__WEBPACK_IMPORTED_MODULE_7__scroll__","__WEBPACK_IMPORTED_MODULE_8__is_mobile__","handleHeaderClick","scrollable","node","querySelector","_interruptScrollAnimation","handleScroll","setRef","c","scrollTop","heading","children","hideHeadingOnMobile","showHeading","window","innerWidth","replace","header","createElement","ref","role","aria-labelledby","onScroll","284","LoadMore","disabled","visible","style","visibility","defaultProps","285","ColumnBackButton","__WEBPACK_IMPORTED_MODULE_6_prop_types__","__WEBPACK_IMPORTED_MODULE_6_prop_types___default","history","context","router","push","goBack","contextTypes","287","ScrollableList","__WEBPACK_IMPORTED_MODULE_4_lodash_throttle__","__WEBPACK_IMPORTED_MODULE_4_lodash_throttle___default","__WEBPACK_IMPORTED_MODULE_6_react_router_scroll_4__","__WEBPACK_IMPORTED_MODULE_7_prop_types__","__WEBPACK_IMPORTED_MODULE_7_prop_types___default","__WEBPACK_IMPORTED_MODULE_8__containers_intersection_observer_article_container__","__WEBPACK_IMPORTED_MODULE_9__load_more__","__WEBPACK_IMPORTED_MODULE_10__features_ui_util_intersection_observer_wrapper__","__WEBPACK_IMPORTED_MODULE_11_immutable__","__WEBPACK_IMPORTED_MODULE_12_classnames__","__WEBPACK_IMPORTED_MODULE_12_classnames___default","__WEBPACK_IMPORTED_MODULE_13__features_ui_util_fullscreen__","_PureComponent","fullscreen","intersectionObserverWrapper","_this$node","scrollHeight","clientHeight","onLoadMore","isLoading","onScrollToTop","trailing","onFullScreenChange","setState","handleLoadMore","e","preventDefault","componentDidMount","attachScrollListener","attachIntersectionObserver","getSnapshotBeforeUpdate","prevProps","Children","count","getFirstChildKey","componentDidUpdate","prevState","snapshot","newScrollTop","componentWillUnmount","detachScrollListener","detachIntersectionObserver","connect","root","rootMargin","disconnect","addEventListener","removeEventListener","firstChild","get","isArray","key","_this2","scrollKey","trackScroll","shouldUpdateScroll","hasMore","prepend","emptyMessage","childrenCount","loadMore","scrollableArea","map","child","index","listLength","saveHeightKey","route","location","288","__WEBPACK_IMPORTED_MODULE_0_react_redux__","__WEBPACK_IMPORTED_MODULE_1__components_intersection_observer_article__","__WEBPACK_IMPORTED_MODULE_2__actions_height_cache__","cachedHeight","getIn","onHeightChange","height","289","IntersectionObserverArticle","__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_classCallCheck__","__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_classCallCheck___default","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_possibleConstructorReturn__","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_possibleConstructorReturn___default","__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_inherits__","__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_inherits___default","__WEBPACK_IMPORTED_MODULE_3_react__","__WEBPACK_IMPORTED_MODULE_3_react___default","__WEBPACK_IMPORTED_MODULE_4__features_ui_util_schedule_idle_task__","__WEBPACK_IMPORTED_MODULE_5__features_ui_util_get_rect_from_entry__","__WEBPACK_IMPORTED_MODULE_6_immutable__","updateOnPropsForRendered","updateOnPropsForUnrendered","_React$Component","isHidden","handleIntersection","entry","calculateHeight","updateStateAfterIntersection","isIntersecting","hideIfNotIntersecting","_this$props","componentMounted","handleRef","shouldComponentUpdate","nextProps","nextState","isUnrendered","every","prop","observe","_props2","unobserve","_props3","_state","aria-posinset","aria-setsize","data-id","tabIndex","cloneElement","hidden","opacity","overflow","Component","290","runTasks","deadline","taskQueue","timeRemaining","shift","requestIdleCallback","runningRequestIdleCallback","scheduleIdleTask","task","__WEBPACK_IMPORTED_MODULE_0_tiny_queue__","__WEBPACK_IMPORTED_MODULE_0_tiny_queue___default","291","Queue","item","last","next","first","undefined","slice","start","end","Infinity","output","i","292","getRectFromEntry","hasBoundingRectBug","boundingRect","target","getBoundingClientRect","observerRect","boundingClientRect","top","width","bottom","left","right","293","IntersectionObserverWrapper","callbacks","observerBacklog","observer","options","onIntersection","entries","forEach","getAttribute","IntersectionObserver","callback","297","ColumnBackButtonSlim","__WEBPACK_IMPORTED_MODULE_6__column_back_button__","_ColumnBackButton","847","defineProperty","value","Blocks","_dec","__WEBPACK_IMPORTED_MODULE_6_react_redux__","__WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes__","__WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes___default","__WEBPACK_IMPORTED_MODULE_8_prop_types__","__WEBPACK_IMPORTED_MODULE_8_prop_types___default","__WEBPACK_IMPORTED_MODULE_9__components_loading_indicator__","__WEBPACK_IMPORTED_MODULE_10__ui_components_column__","__WEBPACK_IMPORTED_MODULE_11__components_column_back_button_slim__","__WEBPACK_IMPORTED_MODULE_12__containers_domain_container__","__WEBPACK_IMPORTED_MODULE_13__actions_domain_blocks__","__WEBPACK_IMPORTED_MODULE_14_react_intl__","__WEBPACK_IMPORTED_MODULE_15_react_immutable_pure_component__","__WEBPACK_IMPORTED_MODULE_15_react_immutable_pure_component___default","__WEBPACK_IMPORTED_MODULE_16__components_scrollable_list__","mapStateToProps","domains","leading","componentWillMount","params","list"],"mappings":"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","file":"features/domain_blocks.js","sourcesContent":["webpackJsonp([12],{\n\n/***/ 1013:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_objectDestructuringEmpty__ = __webpack_require__(1014);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_objectDestructuringEmpty___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_objectDestructuringEmpty__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_react_redux__ = __webpack_require__(9);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__actions_domain_blocks__ = __webpack_require__(158);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react_intl__ = __webpack_require__(7);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__components_domain__ = __webpack_require__(1015);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__actions_modal__ = __webpack_require__(26);\n\n\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"f\" /* defineMessages */])({\n  blockDomainConfirm: {\n    'id': 'confirmations.domain_block.confirm',\n    'defaultMessage': 'Hide entire domain'\n  }\n});\n\nvar makeMapStateToProps = function makeMapStateToProps() {\n  var mapStateToProps = function mapStateToProps(state, _ref) {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_objectDestructuringEmpty___default()(_ref);\n\n    return {};\n  };\n\n  return mapStateToProps;\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch, _ref2) {\n  var intl = _ref2.intl;\n  return {\n    onBlockDomain: function onBlockDomain(domain) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_7__actions_modal__[\"d\" /* openModal */])('CONFIRM', {\n        message: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n          id: 'confirmations.domain_block.message',\n          defaultMessage: 'Are you really, really sure you want to block the entire {domain}? In most cases a few targeted blocks or mutes are sufficient and preferable.',\n          values: { domain: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('strong', {}, void 0, domain) }\n        }),\n        confirm: intl.formatMessage(messages.blockDomainConfirm),\n        onConfirm: function onConfirm() {\n          return dispatch(Object(__WEBPACK_IMPORTED_MODULE_4__actions_domain_blocks__[\"e\" /* blockDomain */])(domain));\n        }\n      }));\n    },\n    onUnblockDomain: function onUnblockDomain(domain) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_4__actions_domain_blocks__[\"h\" /* unblockDomain */])(domain));\n    }\n  };\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"g\" /* injectIntl */])(Object(__WEBPACK_IMPORTED_MODULE_3_react_redux__[\"connect\"])(makeMapStateToProps, mapDispatchToProps)(__WEBPACK_IMPORTED_MODULE_6__components_domain__[\"a\" /* default */])));\n\n/***/ }),\n\n/***/ 1014:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nexports.__esModule = true;\n\nexports.default = function (obj) {\n  if (obj == null) throw new TypeError(\"Cannot destructure undefined\");\n};\n\n/***/ }),\n\n/***/ 1015:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return Account; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_prop_types__ = __webpack_require__(5);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_prop_types__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__icon_button__ = __webpack_require__(23);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_intl__ = __webpack_require__(7);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_react_immutable_pure_component__ = __webpack_require__(12);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_8_react_immutable_pure_component__);\n\n\n\n\n\nvar _class, _class2, _temp2;\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_7_react_intl__[\"f\" /* defineMessages */])({\n  unblockDomain: {\n    'id': 'account.unblock_domain',\n    'defaultMessage': 'Unhide {domain}'\n  }\n});\n\nvar Account = Object(__WEBPACK_IMPORTED_MODULE_7_react_intl__[\"g\" /* injectIntl */])(_class = (_temp2 = _class2 = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(Account, _ImmutablePureCompone);\n\n  function Account() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, Account);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ImmutablePureCompone.call.apply(_ImmutablePureCompone, [this].concat(args))), _this), _this.handleDomainUnblock = function () {\n      _this.props.onUnblockDomain(_this.props.domain);\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  Account.prototype.render = function render() {\n    var _props = this.props,\n        domain = _props.domain,\n        intl = _props.intl;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'domain'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'domain__wrapper'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('span', {\n      className: 'domain__domain-name'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('strong', {}, void 0, domain)), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'domain__buttons'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6__icon_button__[\"a\" /* default */], {\n      active: true,\n      icon: 'unlock-alt',\n      title: intl.formatMessage(messages.unblockDomain, { domain: domain }),\n      onClick: this.handleDomainUnblock\n    }))));\n  };\n\n  return Account;\n}(__WEBPACK_IMPORTED_MODULE_8_react_immutable_pure_component___default.a), _class2.propTypes = {\n  domain: __WEBPACK_IMPORTED_MODULE_5_prop_types___default.a.string,\n  onUnblockDomain: __WEBPACK_IMPORTED_MODULE_5_prop_types___default.a.func.isRequired,\n  intl: __WEBPACK_IMPORTED_MODULE_5_prop_types___default.a.object.isRequired\n}, _temp2)) || _class;\n\n\n\n/***/ }),\n\n/***/ 153:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return ColumnHeader; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_classnames__ = __webpack_require__(10);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_classnames__);\n\n\n\n\n\n\n\n\nvar ColumnHeader = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(ColumnHeader, _React$PureComponent);\n\n  function ColumnHeader() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, ColumnHeader);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.call.apply(_React$PureComponent, [this].concat(args))), _this), _this.handleClick = function () {\n      _this.props.onClick();\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  ColumnHeader.prototype.render = function render() {\n    var _props = this.props,\n        icon = _props.icon,\n        type = _props.type,\n        active = _props.active,\n        columnHeaderId = _props.columnHeaderId;\n\n    var iconElement = '';\n\n    if (icon) {\n      iconElement = __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n        className: 'fa fa-fw fa-' + icon + ' column-header__icon'\n      });\n    }\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('h1', {\n      className: __WEBPACK_IMPORTED_MODULE_5_classnames___default()('column-header', { active: active }),\n      id: columnHeaderId || null\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n      onClick: this.handleClick\n    }, void 0, iconElement, type));\n  };\n\n  return ColumnHeader;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\n\n\n/***/ }),\n\n/***/ 283:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return Column; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_lodash_debounce__ = __webpack_require__(32);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_lodash_debounce___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_lodash_debounce__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__column_header__ = __webpack_require__(153);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__scroll__ = __webpack_require__(90);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__is_mobile__ = __webpack_require__(43);\n\n\n\n\n\n\n\n\n\n\n\nvar Column = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(Column, _React$PureComponent);\n\n  function Column() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, Column);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.call.apply(_React$PureComponent, [this].concat(args))), _this), _this.handleHeaderClick = function () {\n      var scrollable = _this.node.querySelector('.scrollable');\n\n      if (!scrollable) {\n        return;\n      }\n\n      _this._interruptScrollAnimation = Object(__WEBPACK_IMPORTED_MODULE_7__scroll__[\"b\" /* scrollTop */])(scrollable);\n    }, _this.handleScroll = __WEBPACK_IMPORTED_MODULE_4_lodash_debounce___default()(function () {\n      if (typeof _this._interruptScrollAnimation !== 'undefined') {\n        _this._interruptScrollAnimation();\n      }\n    }, 200), _this.setRef = function (c) {\n      _this.node = c;\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  Column.prototype.scrollTop = function scrollTop() {\n    var scrollable = this.node.querySelector('.scrollable');\n\n    if (!scrollable) {\n      return;\n    }\n\n    this._interruptScrollAnimation = Object(__WEBPACK_IMPORTED_MODULE_7__scroll__[\"b\" /* scrollTop */])(scrollable);\n  };\n\n  Column.prototype.render = function render() {\n    var _props = this.props,\n        heading = _props.heading,\n        icon = _props.icon,\n        children = _props.children,\n        active = _props.active,\n        hideHeadingOnMobile = _props.hideHeadingOnMobile;\n\n\n    var showHeading = heading && (!hideHeadingOnMobile || hideHeadingOnMobile && !Object(__WEBPACK_IMPORTED_MODULE_8__is_mobile__[\"b\" /* isMobile */])(window.innerWidth));\n\n    var columnHeaderId = showHeading && heading.replace(/ /g, '-');\n    var header = showHeading && __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6__column_header__[\"a\" /* default */], {\n      icon: icon,\n      active: active,\n      type: heading,\n      onClick: this.handleHeaderClick,\n      columnHeaderId: columnHeaderId\n    });\n    return __WEBPACK_IMPORTED_MODULE_5_react___default.a.createElement(\n      'div',\n      {\n        ref: this.setRef,\n        role: 'region',\n        'aria-labelledby': columnHeaderId,\n        className: 'column',\n        onScroll: this.handleScroll\n      },\n      header,\n      children\n    );\n  };\n\n  return Column;\n}(__WEBPACK_IMPORTED_MODULE_5_react___default.a.PureComponent);\n\n\n\n/***/ }),\n\n/***/ 284:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return LoadMore; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react_intl__ = __webpack_require__(7);\n\n\n\n\n\nvar _class, _temp;\n\n\n\nvar LoadMore = (_temp = _class = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(LoadMore, _React$PureComponent);\n\n  function LoadMore() {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, LoadMore);\n\n    return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.apply(this, arguments));\n  }\n\n  LoadMore.prototype.render = function render() {\n    var _props = this.props,\n        disabled = _props.disabled,\n        visible = _props.visible;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n      className: 'load-more',\n      disabled: disabled || !visible,\n      style: { visibility: visible ? 'visible' : 'hidden' },\n      onClick: this.props.onClick\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'status.load_more',\n      defaultMessage: 'Load more'\n    }));\n  };\n\n  return LoadMore;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent), _class.defaultProps = {\n  visible: true\n}, _temp);\n\n\n/***/ }),\n\n/***/ 285:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return ColumnBackButton; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react_intl__ = __webpack_require__(7);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_prop_types__ = __webpack_require__(5);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_prop_types__);\n\n\n\n\n\nvar _class, _temp2;\n\n\n\n\n\nvar ColumnBackButton = (_temp2 = _class = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(ColumnBackButton, _React$PureComponent);\n\n  function ColumnBackButton() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, ColumnBackButton);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.call.apply(_React$PureComponent, [this].concat(args))), _this), _this.handleClick = function () {\n      if (window.history && window.history.length === 1) {\n        _this.context.router.history.push('/');\n      } else {\n        _this.context.router.history.goBack();\n      }\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  ColumnBackButton.prototype.render = function render() {\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n      onClick: this.handleClick,\n      className: 'column-back-button'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n      className: 'fa fa-fw fa-chevron-left column-back-button__icon'\n    }), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'column_back_button.label',\n      defaultMessage: 'Back'\n    }));\n  };\n\n  return ColumnBackButton;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent), _class.contextTypes = {\n  router: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.object\n}, _temp2);\n\n\n/***/ }),\n\n/***/ 287:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return ScrollableList; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_lodash_throttle__ = __webpack_require__(93);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_lodash_throttle___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_lodash_throttle__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_react_router_scroll_4__ = __webpack_require__(154);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_prop_types__ = __webpack_require__(5);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_7_prop_types__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__containers_intersection_observer_article_container__ = __webpack_require__(288);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__load_more__ = __webpack_require__(284);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__features_ui_util_intersection_observer_wrapper__ = __webpack_require__(293);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_immutable__ = __webpack_require__(8);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_immutable___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_11_immutable__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_12_classnames__ = __webpack_require__(10);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_12_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_12_classnames__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_13__features_ui_util_fullscreen__ = __webpack_require__(157);\n\n\n\n\n\n\nvar _class, _temp2;\n\n\n\n\n\n\n\n\n\n\n\n\nvar ScrollableList = (_temp2 = _class = function (_PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(ScrollableList, _PureComponent);\n\n  function ScrollableList() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, ScrollableList);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _PureComponent.call.apply(_PureComponent, [this].concat(args))), _this), _this.state = {\n      fullscreen: null\n    }, _this.intersectionObserverWrapper = new __WEBPACK_IMPORTED_MODULE_10__features_ui_util_intersection_observer_wrapper__[\"a\" /* default */](), _this.handleScroll = __WEBPACK_IMPORTED_MODULE_4_lodash_throttle___default()(function () {\n      if (_this.node) {\n        var _this$node = _this.node,\n            scrollTop = _this$node.scrollTop,\n            scrollHeight = _this$node.scrollHeight,\n            clientHeight = _this$node.clientHeight;\n\n        var offset = scrollHeight - scrollTop - clientHeight;\n\n        if (400 > offset && _this.props.onLoadMore && !_this.props.isLoading) {\n          _this.props.onLoadMore();\n        }\n\n        if (scrollTop < 100 && _this.props.onScrollToTop) {\n          _this.props.onScrollToTop();\n        } else if (_this.props.onScroll) {\n          _this.props.onScroll();\n        }\n      }\n    }, 150, {\n      trailing: true\n    }), _this.onFullScreenChange = function () {\n      _this.setState({ fullscreen: Object(__WEBPACK_IMPORTED_MODULE_13__features_ui_util_fullscreen__[\"d\" /* isFullscreen */])() });\n    }, _this.setRef = function (c) {\n      _this.node = c;\n    }, _this.handleLoadMore = function (e) {\n      e.preventDefault();\n      _this.props.onLoadMore();\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  ScrollableList.prototype.componentDidMount = function componentDidMount() {\n    this.attachScrollListener();\n    this.attachIntersectionObserver();\n    Object(__WEBPACK_IMPORTED_MODULE_13__features_ui_util_fullscreen__[\"a\" /* attachFullscreenListener */])(this.onFullScreenChange);\n\n    // Handle initial scroll posiiton\n    this.handleScroll();\n  };\n\n  ScrollableList.prototype.getSnapshotBeforeUpdate = function getSnapshotBeforeUpdate(prevProps) {\n    var someItemInserted = __WEBPACK_IMPORTED_MODULE_5_react___default.a.Children.count(prevProps.children) > 0 && __WEBPACK_IMPORTED_MODULE_5_react___default.a.Children.count(prevProps.children) < __WEBPACK_IMPORTED_MODULE_5_react___default.a.Children.count(this.props.children) && this.getFirstChildKey(prevProps) !== this.getFirstChildKey(this.props);\n    if (someItemInserted && this.node.scrollTop > 0) {\n      return this.node.scrollHeight - this.node.scrollTop;\n    } else {\n      return null;\n    }\n  };\n\n  ScrollableList.prototype.componentDidUpdate = function componentDidUpdate(prevProps, prevState, snapshot) {\n    // Reset the scroll position when a new child comes in in order not to\n    // jerk the scrollbar around if you're already scrolled down the page.\n    if (snapshot !== null) {\n      var newScrollTop = this.node.scrollHeight - snapshot;\n\n      if (this.node.scrollTop !== newScrollTop) {\n        this.node.scrollTop = newScrollTop;\n      }\n    }\n  };\n\n  ScrollableList.prototype.componentWillUnmount = function componentWillUnmount() {\n    this.detachScrollListener();\n    this.detachIntersectionObserver();\n    Object(__WEBPACK_IMPORTED_MODULE_13__features_ui_util_fullscreen__[\"b\" /* detachFullscreenListener */])(this.onFullScreenChange);\n  };\n\n  ScrollableList.prototype.attachIntersectionObserver = function attachIntersectionObserver() {\n    this.intersectionObserverWrapper.connect({\n      root: this.node,\n      rootMargin: '300% 0px'\n    });\n  };\n\n  ScrollableList.prototype.detachIntersectionObserver = function detachIntersectionObserver() {\n    this.intersectionObserverWrapper.disconnect();\n  };\n\n  ScrollableList.prototype.attachScrollListener = function attachScrollListener() {\n    this.node.addEventListener('scroll', this.handleScroll);\n  };\n\n  ScrollableList.prototype.detachScrollListener = function detachScrollListener() {\n    this.node.removeEventListener('scroll', this.handleScroll);\n  };\n\n  ScrollableList.prototype.getFirstChildKey = function getFirstChildKey(props) {\n    var children = props.children;\n\n    var firstChild = children;\n    if (children instanceof __WEBPACK_IMPORTED_MODULE_11_immutable__[\"List\"]) {\n      firstChild = children.get(0);\n    } else if (Array.isArray(children)) {\n      firstChild = children[0];\n    }\n    return firstChild && firstChild.key;\n  };\n\n  ScrollableList.prototype.render = function render() {\n    var _this2 = this;\n\n    var _props = this.props,\n        children = _props.children,\n        scrollKey = _props.scrollKey,\n        trackScroll = _props.trackScroll,\n        shouldUpdateScroll = _props.shouldUpdateScroll,\n        isLoading = _props.isLoading,\n        hasMore = _props.hasMore,\n        prepend = _props.prepend,\n        emptyMessage = _props.emptyMessage,\n        onLoadMore = _props.onLoadMore;\n    var fullscreen = this.state.fullscreen;\n\n    var childrenCount = __WEBPACK_IMPORTED_MODULE_5_react___default.a.Children.count(children);\n\n    var loadMore = hasMore && childrenCount > 0 && onLoadMore ? __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__load_more__[\"a\" /* default */], {\n      visible: !isLoading,\n      onClick: this.handleLoadMore\n    }) : null;\n    var scrollableArea = null;\n\n    if (isLoading || childrenCount > 0 || !emptyMessage) {\n      scrollableArea = __WEBPACK_IMPORTED_MODULE_5_react___default.a.createElement(\n        'div',\n        { className: __WEBPACK_IMPORTED_MODULE_12_classnames___default()('scrollable', { fullscreen: fullscreen }), ref: this.setRef },\n        __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n          role: 'feed',\n          className: 'item-list'\n        }, void 0, prepend, __WEBPACK_IMPORTED_MODULE_5_react___default.a.Children.map(this.props.children, function (child, index) {\n          return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_8__containers_intersection_observer_article_container__[\"a\" /* default */], {\n            id: child.key,\n            index: index,\n            listLength: childrenCount,\n            intersectionObserverWrapper: _this2.intersectionObserverWrapper,\n            saveHeightKey: trackScroll ? _this2.context.router.route.location.key + ':' + scrollKey : null\n          }, child.key, child);\n        }), loadMore)\n      );\n    } else {\n      scrollableArea = __WEBPACK_IMPORTED_MODULE_5_react___default.a.createElement(\n        'div',\n        { className: 'empty-column-indicator', ref: this.setRef },\n        emptyMessage\n      );\n    }\n\n    if (trackScroll) {\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_router_scroll_4__[\"a\" /* ScrollContainer */], {\n        scrollKey: scrollKey,\n        shouldUpdateScroll: shouldUpdateScroll\n      }, void 0, scrollableArea);\n    } else {\n      return scrollableArea;\n    }\n  };\n\n  return ScrollableList;\n}(__WEBPACK_IMPORTED_MODULE_5_react__[\"PureComponent\"]), _class.contextTypes = {\n  router: __WEBPACK_IMPORTED_MODULE_7_prop_types___default.a.object\n}, _class.defaultProps = {\n  trackScroll: true\n}, _temp2);\n\n\n/***/ }),\n\n/***/ 288:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react_redux__ = __webpack_require__(9);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__components_intersection_observer_article__ = __webpack_require__(289);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__actions_height_cache__ = __webpack_require__(94);\n\n\n\n\nvar makeMapStateToProps = function makeMapStateToProps(state, props) {\n  return {\n    cachedHeight: state.getIn(['height_cache', props.saveHeightKey, props.id])\n  };\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch) {\n  return {\n    onHeightChange: function onHeightChange(key, id, height) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_2__actions_height_cache__[\"d\" /* setHeight */])(key, id, height));\n    }\n  };\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_0_react_redux__[\"connect\"])(makeMapStateToProps, mapDispatchToProps)(__WEBPACK_IMPORTED_MODULE_1__components_intersection_observer_article__[\"a\" /* default */]));\n\n/***/ }),\n\n/***/ 289:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return IntersectionObserverArticle; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__features_ui_util_schedule_idle_task__ = __webpack_require__(290);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__features_ui_util_get_rect_from_entry__ = __webpack_require__(292);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_immutable__ = __webpack_require__(8);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_immutable___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_immutable__);\n\n\n\n\n\n\n\n\n\n// Diff these props in the \"rendered\" state\nvar updateOnPropsForRendered = ['id', 'index', 'listLength'];\n// Diff these props in the \"unrendered\" state\nvar updateOnPropsForUnrendered = ['id', 'index', 'listLength', 'cachedHeight'];\n\nvar IntersectionObserverArticle = function (_React$Component) {\n  __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_inherits___default()(IntersectionObserverArticle, _React$Component);\n\n  function IntersectionObserverArticle() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_classCallCheck___default()(this, IntersectionObserverArticle);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$Component.call.apply(_React$Component, [this].concat(args))), _this), _this.state = {\n      isHidden: false // set to true in requestIdleCallback to trigger un-render\n    }, _this.handleIntersection = function (entry) {\n      _this.entry = entry;\n\n      Object(__WEBPACK_IMPORTED_MODULE_4__features_ui_util_schedule_idle_task__[\"a\" /* default */])(_this.calculateHeight);\n      _this.setState(_this.updateStateAfterIntersection);\n    }, _this.updateStateAfterIntersection = function (prevState) {\n      if (prevState.isIntersecting && !_this.entry.isIntersecting) {\n        Object(__WEBPACK_IMPORTED_MODULE_4__features_ui_util_schedule_idle_task__[\"a\" /* default */])(_this.hideIfNotIntersecting);\n      }\n      return {\n        isIntersecting: _this.entry.isIntersecting,\n        isHidden: false\n      };\n    }, _this.calculateHeight = function () {\n      var _this$props = _this.props,\n          onHeightChange = _this$props.onHeightChange,\n          saveHeightKey = _this$props.saveHeightKey,\n          id = _this$props.id;\n      // save the height of the fully-rendered element (this is expensive\n      // on Chrome, where we need to fall back to getBoundingClientRect)\n\n      _this.height = Object(__WEBPACK_IMPORTED_MODULE_5__features_ui_util_get_rect_from_entry__[\"a\" /* default */])(_this.entry).height;\n\n      if (onHeightChange && saveHeightKey) {\n        onHeightChange(saveHeightKey, id, _this.height);\n      }\n    }, _this.hideIfNotIntersecting = function () {\n      if (!_this.componentMounted) {\n        return;\n      }\n\n      // When the browser gets a chance, test if we're still not intersecting,\n      // and if so, set our isHidden to true to trigger an unrender. The point of\n      // this is to save DOM nodes and avoid using up too much memory.\n      // See: https://github.com/tootsuite/mastodon/issues/2900\n      _this.setState(function (prevState) {\n        return { isHidden: !prevState.isIntersecting };\n      });\n    }, _this.handleRef = function (node) {\n      _this.node = node;\n    }, _temp), __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  IntersectionObserverArticle.prototype.shouldComponentUpdate = function shouldComponentUpdate(nextProps, nextState) {\n    var _this2 = this;\n\n    var isUnrendered = !this.state.isIntersecting && (this.state.isHidden || this.props.cachedHeight);\n    var willBeUnrendered = !nextState.isIntersecting && (nextState.isHidden || nextProps.cachedHeight);\n    if (!!isUnrendered !== !!willBeUnrendered) {\n      // If we're going from rendered to unrendered (or vice versa) then update\n      return true;\n    }\n    // Otherwise, diff based on props\n    var propsToDiff = isUnrendered ? updateOnPropsForUnrendered : updateOnPropsForRendered;\n    return !propsToDiff.every(function (prop) {\n      return Object(__WEBPACK_IMPORTED_MODULE_6_immutable__[\"is\"])(nextProps[prop], _this2.props[prop]);\n    });\n  };\n\n  IntersectionObserverArticle.prototype.componentDidMount = function componentDidMount() {\n    var _props = this.props,\n        intersectionObserverWrapper = _props.intersectionObserverWrapper,\n        id = _props.id;\n\n\n    intersectionObserverWrapper.observe(id, this.node, this.handleIntersection);\n\n    this.componentMounted = true;\n  };\n\n  IntersectionObserverArticle.prototype.componentWillUnmount = function componentWillUnmount() {\n    var _props2 = this.props,\n        intersectionObserverWrapper = _props2.intersectionObserverWrapper,\n        id = _props2.id;\n\n    intersectionObserverWrapper.unobserve(id, this.node);\n\n    this.componentMounted = false;\n  };\n\n  IntersectionObserverArticle.prototype.render = function render() {\n    var _props3 = this.props,\n        children = _props3.children,\n        id = _props3.id,\n        index = _props3.index,\n        listLength = _props3.listLength,\n        cachedHeight = _props3.cachedHeight;\n    var _state = this.state,\n        isIntersecting = _state.isIntersecting,\n        isHidden = _state.isHidden;\n\n\n    if (!isIntersecting && (isHidden || cachedHeight)) {\n      return __WEBPACK_IMPORTED_MODULE_3_react___default.a.createElement(\n        'article',\n        {\n          ref: this.handleRef,\n          'aria-posinset': index,\n          'aria-setsize': listLength,\n          style: { height: (this.height || cachedHeight) + 'px', opacity: 0, overflow: 'hidden' },\n          'data-id': id,\n          tabIndex: '0'\n        },\n        children && __WEBPACK_IMPORTED_MODULE_3_react___default.a.cloneElement(children, { hidden: true })\n      );\n    }\n\n    return __WEBPACK_IMPORTED_MODULE_3_react___default.a.createElement(\n      'article',\n      { ref: this.handleRef, 'aria-posinset': index, 'aria-setsize': listLength, 'data-id': id, tabIndex: '0' },\n      children && __WEBPACK_IMPORTED_MODULE_3_react___default.a.cloneElement(children, { hidden: false })\n    );\n  };\n\n  return IntersectionObserverArticle;\n}(__WEBPACK_IMPORTED_MODULE_3_react___default.a.Component);\n\n\n\n/***/ }),\n\n/***/ 290:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_tiny_queue__ = __webpack_require__(291);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_tiny_queue___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_tiny_queue__);\n// Wrapper to call requestIdleCallback() to schedule low-priority work.\n// See https://developer.mozilla.org/en-US/docs/Web/API/Background_Tasks_API\n// for a good breakdown of the concepts behind this.\n\n\n\nvar taskQueue = new __WEBPACK_IMPORTED_MODULE_0_tiny_queue___default.a();\nvar runningRequestIdleCallback = false;\n\nfunction runTasks(deadline) {\n  while (taskQueue.length && deadline.timeRemaining() > 0) {\n    taskQueue.shift()();\n  }\n  if (taskQueue.length) {\n    requestIdleCallback(runTasks);\n  } else {\n    runningRequestIdleCallback = false;\n  }\n}\n\nfunction scheduleIdleTask(task) {\n  taskQueue.push(task);\n  if (!runningRequestIdleCallback) {\n    runningRequestIdleCallback = true;\n    requestIdleCallback(runTasks);\n  }\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (scheduleIdleTask);\n\n/***/ }),\n\n/***/ 291:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\n// Simple FIFO queue implementation to avoid having to do shift()\n// on an array, which is slow.\n\nfunction Queue() {\n  this.length = 0;\n}\n\nQueue.prototype.push = function (item) {\n  var node = { item: item };\n  if (this.last) {\n    this.last = this.last.next = node;\n  } else {\n    this.last = this.first = node;\n  }\n  this.length++;\n};\n\nQueue.prototype.shift = function () {\n  var node = this.first;\n  if (node) {\n    this.first = node.next;\n    if (! --this.length) {\n      this.last = undefined;\n    }\n    return node.item;\n  }\n};\n\nQueue.prototype.slice = function (start, end) {\n  start = typeof start === 'undefined' ? 0 : start;\n  end = typeof end === 'undefined' ? Infinity : end;\n\n  var output = [];\n\n  var i = 0;\n  for (var node = this.first; node; node = node.next) {\n    if (--end < 0) {\n      break;\n    } else if (++i > start) {\n      output.push(node.item);\n    }\n  }\n  return output;\n};\n\nmodule.exports = Queue;\n\n/***/ }),\n\n/***/ 292:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n\n// Get the bounding client rect from an IntersectionObserver entry.\n// This is to work around a bug in Chrome: https://crbug.com/737228\n\nvar hasBoundingRectBug = void 0;\n\nfunction getRectFromEntry(entry) {\n  if (typeof hasBoundingRectBug !== 'boolean') {\n    var boundingRect = entry.target.getBoundingClientRect();\n    var observerRect = entry.boundingClientRect;\n    hasBoundingRectBug = boundingRect.height !== observerRect.height || boundingRect.top !== observerRect.top || boundingRect.width !== observerRect.width || boundingRect.bottom !== observerRect.bottom || boundingRect.left !== observerRect.left || boundingRect.right !== observerRect.right;\n  }\n  return hasBoundingRectBug ? entry.target.getBoundingClientRect() : entry.boundingClientRect;\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (getRectFromEntry);\n\n/***/ }),\n\n/***/ 293:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_classCallCheck__);\n\n\n// Wrapper for IntersectionObserver in order to make working with it\n// a bit easier. We also follow this performance advice:\n// \"If you need to observe multiple elements, it is both possible and\n// advised to observe multiple elements using the same IntersectionObserver\n// instance by calling observe() multiple times.\"\n// https://developers.google.com/web/updates/2016/04/intersectionobserver\n\nvar IntersectionObserverWrapper = function () {\n  function IntersectionObserverWrapper() {\n    __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_classCallCheck___default()(this, IntersectionObserverWrapper);\n\n    this.callbacks = {};\n    this.observerBacklog = [];\n    this.observer = null;\n  }\n\n  IntersectionObserverWrapper.prototype.connect = function connect(options) {\n    var _this = this;\n\n    var onIntersection = function onIntersection(entries) {\n      entries.forEach(function (entry) {\n        var id = entry.target.getAttribute('data-id');\n        if (_this.callbacks[id]) {\n          _this.callbacks[id](entry);\n        }\n      });\n    };\n\n    this.observer = new IntersectionObserver(onIntersection, options);\n    this.observerBacklog.forEach(function (_ref) {\n      var id = _ref[0],\n          node = _ref[1],\n          callback = _ref[2];\n\n      _this.observe(id, node, callback);\n    });\n    this.observerBacklog = null;\n  };\n\n  IntersectionObserverWrapper.prototype.observe = function observe(id, node, callback) {\n    if (!this.observer) {\n      this.observerBacklog.push([id, node, callback]);\n    } else {\n      this.callbacks[id] = callback;\n      this.observer.observe(node);\n    }\n  };\n\n  IntersectionObserverWrapper.prototype.unobserve = function unobserve(id, node) {\n    if (this.observer) {\n      delete this.callbacks[id];\n      this.observer.unobserve(node);\n    }\n  };\n\n  IntersectionObserverWrapper.prototype.disconnect = function disconnect() {\n    if (this.observer) {\n      this.callbacks = {};\n      this.observer.disconnect();\n      this.observer = null;\n    }\n  };\n\n  return IntersectionObserverWrapper;\n}();\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (IntersectionObserverWrapper);\n\n/***/ }),\n\n/***/ 297:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return ColumnBackButtonSlim; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react_intl__ = __webpack_require__(7);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__column_back_button__ = __webpack_require__(285);\n\n\n\n\n\n\n\n\nvar ColumnBackButtonSlim = function (_ColumnBackButton) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(ColumnBackButtonSlim, _ColumnBackButton);\n\n  function ColumnBackButtonSlim() {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, ColumnBackButtonSlim);\n\n    return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ColumnBackButton.apply(this, arguments));\n  }\n\n  ColumnBackButtonSlim.prototype.render = function render() {\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'column-back-button--slim'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      role: 'button',\n      tabIndex: '0',\n      onClick: this.handleClick,\n      className: 'column-back-button column-back-button--slim-button'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n      className: 'fa fa-fw fa-chevron-left column-back-button__icon'\n    }), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'column_back_button.label',\n      defaultMessage: 'Back'\n    })));\n  };\n\n  return ColumnBackButtonSlim;\n}(__WEBPACK_IMPORTED_MODULE_6__column_back_button__[\"a\" /* default */]);\n\n\n\n/***/ }),\n\n/***/ 847:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nObject.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Blocks; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_lodash_debounce__ = __webpack_require__(32);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_lodash_debounce___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_lodash_debounce__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_react_redux__ = __webpack_require__(9);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes__ = __webpack_require__(14);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_prop_types__ = __webpack_require__(5);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_8_prop_types__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__components_loading_indicator__ = __webpack_require__(298);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__ui_components_column__ = __webpack_require__(283);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11__components_column_back_button_slim__ = __webpack_require__(297);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_12__containers_domain_container__ = __webpack_require__(1013);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_13__actions_domain_blocks__ = __webpack_require__(158);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_14_react_intl__ = __webpack_require__(7);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_15_react_immutable_pure_component__ = __webpack_require__(12);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_15_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_15_react_immutable_pure_component__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_16__components_scrollable_list__ = __webpack_require__(287);\n\n\n\n\n\n\nvar _dec, _class, _class2, _temp2;\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_14_react_intl__[\"f\" /* defineMessages */])({\n  heading: {\n    'id': 'column.domain_blocks',\n    'defaultMessage': 'Hidden domains'\n  },\n  unblockDomain: {\n    'id': 'account.unblock_domain',\n    'defaultMessage': 'Unhide {domain}'\n  }\n});\n\nvar mapStateToProps = function mapStateToProps(state) {\n  return {\n    domains: state.getIn(['domain_lists', 'blocks', 'items'])\n  };\n};\n\nvar Blocks = (_dec = Object(__WEBPACK_IMPORTED_MODULE_6_react_redux__[\"connect\"])(mapStateToProps), _dec(_class = Object(__WEBPACK_IMPORTED_MODULE_14_react_intl__[\"g\" /* injectIntl */])(_class = (_temp2 = _class2 = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(Blocks, _ImmutablePureCompone);\n\n  function Blocks() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, Blocks);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ImmutablePureCompone.call.apply(_ImmutablePureCompone, [this].concat(args))), _this), _this.handleLoadMore = __WEBPACK_IMPORTED_MODULE_4_lodash_debounce___default()(function () {\n      _this.props.dispatch(Object(__WEBPACK_IMPORTED_MODULE_13__actions_domain_blocks__[\"f\" /* expandDomainBlocks */])());\n    }, 300, { leading: true }), _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  Blocks.prototype.componentWillMount = function componentWillMount() {\n    this.props.dispatch(Object(__WEBPACK_IMPORTED_MODULE_13__actions_domain_blocks__[\"g\" /* fetchDomainBlocks */])());\n  };\n\n  Blocks.prototype.render = function render() {\n    var _props = this.props,\n        intl = _props.intl,\n        domains = _props.domains;\n\n\n    if (!domains) {\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_10__ui_components_column__[\"a\" /* default */], {}, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__components_loading_indicator__[\"a\" /* default */], {}));\n    }\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_10__ui_components_column__[\"a\" /* default */], {\n      icon: 'minus-circle',\n      heading: intl.formatMessage(messages.heading)\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_11__components_column_back_button_slim__[\"a\" /* default */], {}), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_16__components_scrollable_list__[\"a\" /* default */], {\n      scrollKey: 'domain_blocks',\n      onLoadMore: this.handleLoadMore\n    }, void 0, domains.map(function (domain) {\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_12__containers_domain_container__[\"a\" /* default */], {\n        domain: domain\n      }, domain);\n    })));\n  };\n\n  return Blocks;\n}(__WEBPACK_IMPORTED_MODULE_15_react_immutable_pure_component___default.a), _class2.propTypes = {\n  params: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.object.isRequired,\n  dispatch: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func.isRequired,\n  domains: __WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes___default.a.list,\n  intl: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.object.isRequired\n}, _temp2)) || _class) || _class);\n\n\n/***/ })\n\n});\n\n\n// WEBPACK FOOTER //\n// features/domain_blocks.js","import React from 'react';\nimport { connect } from 'react-redux';\nimport { blockDomain, unblockDomain } from '../actions/domain_blocks';\nimport { defineMessages, injectIntl, FormattedMessage } from 'react-intl';\nimport Domain from '../components/domain';\nimport { openModal } from '../actions/modal';\n\nconst messages = defineMessages({\n  blockDomainConfirm: { id: 'confirmations.domain_block.confirm', defaultMessage: 'Hide entire domain' },\n});\n\nconst makeMapStateToProps = () => {\n  const mapStateToProps = (state, { }) => ({\n  });\n\n  return mapStateToProps;\n};\n\nconst mapDispatchToProps = (dispatch, { intl }) => ({\n  onBlockDomain (domain) {\n    dispatch(openModal('CONFIRM', {\n      message: <FormattedMessage id='confirmations.domain_block.message' defaultMessage='Are you really, really sure you want to block the entire {domain}? In most cases a few targeted blocks or mutes are sufficient and preferable.' values={{ domain: <strong>{domain}</strong> }} />,\n      confirm: intl.formatMessage(messages.blockDomainConfirm),\n      onConfirm: () => dispatch(blockDomain(domain)),\n    }));\n  },\n\n  onUnblockDomain (domain) {\n    dispatch(unblockDomain(domain));\n  },\n});\n\nexport default injectIntl(connect(makeMapStateToProps, mapDispatchToProps)(Domain));\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/containers/domain_container.js","\"use strict\";\n\nexports.__esModule = true;\n\nexports.default = function (obj) {\n  if (obj == null) throw new TypeError(\"Cannot destructure undefined\");\n};\n\n\n// WEBPACK FOOTER //\n// ./node_modules/babel-runtime/helpers/objectDestructuringEmpty.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport IconButton from './icon_button';\nimport { defineMessages, injectIntl } from 'react-intl';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\n\nconst messages = defineMessages({\n  unblockDomain: { id: 'account.unblock_domain', defaultMessage: 'Unhide {domain}' },\n});\n\n@injectIntl\nexport default class Account extends ImmutablePureComponent {\n\n  static propTypes = {\n    domain: PropTypes.string,\n    onUnblockDomain: PropTypes.func.isRequired,\n    intl: PropTypes.object.isRequired,\n  };\n\n  handleDomainUnblock = () => {\n    this.props.onUnblockDomain(this.props.domain);\n  }\n\n  render () {\n    const { domain, intl } = this.props;\n\n    return (\n      <div className='domain'>\n        <div className='domain__wrapper'>\n          <span className='domain__domain-name'>\n            <strong>{domain}</strong>\n          </span>\n\n          <div className='domain__buttons'>\n            <IconButton active icon='unlock-alt' title={intl.formatMessage(messages.unblockDomain, { domain })} onClick={this.handleDomainUnblock} />\n          </div>\n        </div>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/components/domain.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\n\nexport default class ColumnHeader extends React.PureComponent {\n\n  static propTypes = {\n    icon: PropTypes.string,\n    type: PropTypes.string,\n    active: PropTypes.bool,\n    onClick: PropTypes.func,\n    columnHeaderId: PropTypes.string,\n  };\n\n  handleClick = () => {\n    this.props.onClick();\n  }\n\n  render () {\n    const { icon, type, active, columnHeaderId } = this.props;\n    let iconElement = '';\n\n    if (icon) {\n      iconElement = <i className={`fa fa-fw fa-${icon} column-header__icon`} />;\n    }\n\n    return (\n      <h1 className={classNames('column-header', { active })} id={columnHeaderId || null}>\n        <button onClick={this.handleClick}>\n          {iconElement}\n          {type}\n        </button>\n      </h1>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/ui/components/column_header.js","import React from 'react';\nimport ColumnHeader from './column_header';\nimport PropTypes from 'prop-types';\nimport { debounce } from 'lodash';\nimport { scrollTop } from '../../../scroll';\nimport { isMobile } from '../../../is_mobile';\n\nexport default class Column extends React.PureComponent {\n\n  static propTypes = {\n    heading: PropTypes.string,\n    icon: PropTypes.string,\n    children: PropTypes.node,\n    active: PropTypes.bool,\n    hideHeadingOnMobile: PropTypes.bool,\n  };\n\n  handleHeaderClick = () => {\n    const scrollable = this.node.querySelector('.scrollable');\n\n    if (!scrollable) {\n      return;\n    }\n\n    this._interruptScrollAnimation = scrollTop(scrollable);\n  }\n\n  scrollTop () {\n    const scrollable = this.node.querySelector('.scrollable');\n\n    if (!scrollable) {\n      return;\n    }\n\n    this._interruptScrollAnimation = scrollTop(scrollable);\n  }\n\n\n  handleScroll = debounce(() => {\n    if (typeof this._interruptScrollAnimation !== 'undefined') {\n      this._interruptScrollAnimation();\n    }\n  }, 200)\n\n  setRef = (c) => {\n    this.node = c;\n  }\n\n  render () {\n    const { heading, icon, children, active, hideHeadingOnMobile } = this.props;\n\n    const showHeading = heading && (!hideHeadingOnMobile || (hideHeadingOnMobile && !isMobile(window.innerWidth)));\n\n    const columnHeaderId = showHeading && heading.replace(/ /g, '-');\n    const header = showHeading && (\n      <ColumnHeader icon={icon} active={active} type={heading} onClick={this.handleHeaderClick} columnHeaderId={columnHeaderId} />\n    );\n    return (\n      <div\n        ref={this.setRef}\n        role='region'\n        aria-labelledby={columnHeaderId}\n        className='column'\n        onScroll={this.handleScroll}\n      >\n        {header}\n        {children}\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/ui/components/column.js","import React from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport PropTypes from 'prop-types';\n\nexport default class LoadMore extends React.PureComponent {\n\n  static propTypes = {\n    onClick: PropTypes.func,\n    disabled: PropTypes.bool,\n    visible: PropTypes.bool,\n  }\n\n  static defaultProps = {\n    visible: true,\n  }\n\n  render() {\n    const { disabled, visible } = this.props;\n\n    return (\n      <button className='load-more' disabled={disabled || !visible} style={{ visibility: visible ? 'visible' : 'hidden' }} onClick={this.props.onClick}>\n        <FormattedMessage id='status.load_more' defaultMessage='Load more' />\n      </button>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/components/load_more.js","import React from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport PropTypes from 'prop-types';\n\nexport default class ColumnBackButton extends React.PureComponent {\n\n  static contextTypes = {\n    router: PropTypes.object,\n  };\n\n  handleClick = () => {\n    if (window.history && window.history.length === 1) {\n      this.context.router.history.push('/');\n    } else {\n      this.context.router.history.goBack();\n    }\n  }\n\n  render () {\n    return (\n      <button onClick={this.handleClick} className='column-back-button'>\n        <i className='fa fa-fw fa-chevron-left column-back-button__icon' />\n        <FormattedMessage id='column_back_button.label' defaultMessage='Back' />\n      </button>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/components/column_back_button.js","import React, { PureComponent } from 'react';\nimport { ScrollContainer } from 'react-router-scroll-4';\nimport PropTypes from 'prop-types';\nimport IntersectionObserverArticleContainer from '../containers/intersection_observer_article_container';\nimport LoadMore from './load_more';\nimport IntersectionObserverWrapper from '../features/ui/util/intersection_observer_wrapper';\nimport { throttle } from 'lodash';\nimport { List as ImmutableList } from 'immutable';\nimport classNames from 'classnames';\nimport { attachFullscreenListener, detachFullscreenListener, isFullscreen } from '../features/ui/util/fullscreen';\n\nexport default class ScrollableList extends PureComponent {\n\n  static contextTypes = {\n    router: PropTypes.object,\n  };\n\n  static propTypes = {\n    scrollKey: PropTypes.string.isRequired,\n    onLoadMore: PropTypes.func,\n    onScrollToTop: PropTypes.func,\n    onScroll: PropTypes.func,\n    trackScroll: PropTypes.bool,\n    shouldUpdateScroll: PropTypes.func,\n    isLoading: PropTypes.bool,\n    hasMore: PropTypes.bool,\n    prepend: PropTypes.node,\n    emptyMessage: PropTypes.node,\n    children: PropTypes.node,\n  };\n\n  static defaultProps = {\n    trackScroll: true,\n  };\n\n  state = {\n    fullscreen: null,\n  };\n\n  intersectionObserverWrapper = new IntersectionObserverWrapper();\n\n  handleScroll = throttle(() => {\n    if (this.node) {\n      const { scrollTop, scrollHeight, clientHeight } = this.node;\n      const offset = scrollHeight - scrollTop - clientHeight;\n\n      if (400 > offset && this.props.onLoadMore && !this.props.isLoading) {\n        this.props.onLoadMore();\n      }\n\n      if (scrollTop < 100 && this.props.onScrollToTop) {\n        this.props.onScrollToTop();\n      } else if (this.props.onScroll) {\n        this.props.onScroll();\n      }\n    }\n  }, 150, {\n    trailing: true,\n  });\n\n  componentDidMount () {\n    this.attachScrollListener();\n    this.attachIntersectionObserver();\n    attachFullscreenListener(this.onFullScreenChange);\n\n    // Handle initial scroll posiiton\n    this.handleScroll();\n  }\n\n  getSnapshotBeforeUpdate (prevProps) {\n    const someItemInserted = React.Children.count(prevProps.children) > 0 &&\n      React.Children.count(prevProps.children) < React.Children.count(this.props.children) &&\n      this.getFirstChildKey(prevProps) !== this.getFirstChildKey(this.props);\n    if (someItemInserted && this.node.scrollTop > 0) {\n      return this.node.scrollHeight - this.node.scrollTop;\n    } else {\n      return null;\n    }\n  }\n\n  componentDidUpdate (prevProps, prevState, snapshot) {\n    // Reset the scroll position when a new child comes in in order not to\n    // jerk the scrollbar around if you're already scrolled down the page.\n    if (snapshot !== null) {\n      const newScrollTop = this.node.scrollHeight - snapshot;\n\n      if (this.node.scrollTop !== newScrollTop) {\n        this.node.scrollTop = newScrollTop;\n      }\n    }\n  }\n\n  componentWillUnmount () {\n    this.detachScrollListener();\n    this.detachIntersectionObserver();\n    detachFullscreenListener(this.onFullScreenChange);\n  }\n\n  onFullScreenChange = () => {\n    this.setState({ fullscreen: isFullscreen() });\n  }\n\n  attachIntersectionObserver () {\n    this.intersectionObserverWrapper.connect({\n      root: this.node,\n      rootMargin: '300% 0px',\n    });\n  }\n\n  detachIntersectionObserver () {\n    this.intersectionObserverWrapper.disconnect();\n  }\n\n  attachScrollListener () {\n    this.node.addEventListener('scroll', this.handleScroll);\n  }\n\n  detachScrollListener () {\n    this.node.removeEventListener('scroll', this.handleScroll);\n  }\n\n  getFirstChildKey (props) {\n    const { children } = props;\n    let firstChild = children;\n    if (children instanceof ImmutableList) {\n      firstChild = children.get(0);\n    } else if (Array.isArray(children)) {\n      firstChild = children[0];\n    }\n    return firstChild && firstChild.key;\n  }\n\n  setRef = (c) => {\n    this.node = c;\n  }\n\n  handleLoadMore = (e) => {\n    e.preventDefault();\n    this.props.onLoadMore();\n  }\n\n  render () {\n    const { children, scrollKey, trackScroll, shouldUpdateScroll, isLoading, hasMore, prepend, emptyMessage, onLoadMore } = this.props;\n    const { fullscreen } = this.state;\n    const childrenCount = React.Children.count(children);\n\n    const loadMore     = (hasMore && childrenCount > 0 && onLoadMore) ? <LoadMore visible={!isLoading} onClick={this.handleLoadMore} /> : null;\n    let scrollableArea = null;\n\n    if (isLoading || childrenCount > 0 || !emptyMessage) {\n      scrollableArea = (\n        <div className={classNames('scrollable', { fullscreen })} ref={this.setRef}>\n          <div role='feed' className='item-list'>\n            {prepend}\n\n            {React.Children.map(this.props.children, (child, index) => (\n              <IntersectionObserverArticleContainer\n                key={child.key}\n                id={child.key}\n                index={index}\n                listLength={childrenCount}\n                intersectionObserverWrapper={this.intersectionObserverWrapper}\n                saveHeightKey={trackScroll ? `${this.context.router.route.location.key}:${scrollKey}` : null}\n              >\n                {child}\n              </IntersectionObserverArticleContainer>\n            ))}\n\n            {loadMore}\n          </div>\n        </div>\n      );\n    } else {\n      scrollableArea = (\n        <div className='empty-column-indicator' ref={this.setRef}>\n          {emptyMessage}\n        </div>\n      );\n    }\n\n    if (trackScroll) {\n      return (\n        <ScrollContainer scrollKey={scrollKey} shouldUpdateScroll={shouldUpdateScroll}>\n          {scrollableArea}\n        </ScrollContainer>\n      );\n    } else {\n      return scrollableArea;\n    }\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/components/scrollable_list.js","import { connect } from 'react-redux';\nimport IntersectionObserverArticle from '../components/intersection_observer_article';\nimport { setHeight } from '../actions/height_cache';\n\nconst makeMapStateToProps = (state, props) => ({\n  cachedHeight: state.getIn(['height_cache', props.saveHeightKey, props.id]),\n});\n\nconst mapDispatchToProps = (dispatch) => ({\n\n  onHeightChange (key, id, height) {\n    dispatch(setHeight(key, id, height));\n  },\n\n});\n\nexport default connect(makeMapStateToProps, mapDispatchToProps)(IntersectionObserverArticle);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/containers/intersection_observer_article_container.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport scheduleIdleTask from '../features/ui/util/schedule_idle_task';\nimport getRectFromEntry from '../features/ui/util/get_rect_from_entry';\nimport { is } from 'immutable';\n\n// Diff these props in the \"rendered\" state\nconst updateOnPropsForRendered = ['id', 'index', 'listLength'];\n// Diff these props in the \"unrendered\" state\nconst updateOnPropsForUnrendered = ['id', 'index', 'listLength', 'cachedHeight'];\n\nexport default class IntersectionObserverArticle extends React.Component {\n\n  static propTypes = {\n    intersectionObserverWrapper: PropTypes.object.isRequired,\n    id: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    index: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    listLength: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    saveHeightKey: PropTypes.string,\n    cachedHeight: PropTypes.number,\n    onHeightChange: PropTypes.func,\n    children: PropTypes.node,\n  };\n\n  state = {\n    isHidden: false, // set to true in requestIdleCallback to trigger un-render\n  }\n\n  shouldComponentUpdate (nextProps, nextState) {\n    const isUnrendered = !this.state.isIntersecting && (this.state.isHidden || this.props.cachedHeight);\n    const willBeUnrendered = !nextState.isIntersecting && (nextState.isHidden || nextProps.cachedHeight);\n    if (!!isUnrendered !== !!willBeUnrendered) {\n      // If we're going from rendered to unrendered (or vice versa) then update\n      return true;\n    }\n    // Otherwise, diff based on props\n    const propsToDiff = isUnrendered ? updateOnPropsForUnrendered : updateOnPropsForRendered;\n    return !propsToDiff.every(prop => is(nextProps[prop], this.props[prop]));\n  }\n\n  componentDidMount () {\n    const { intersectionObserverWrapper, id } = this.props;\n\n    intersectionObserverWrapper.observe(\n      id,\n      this.node,\n      this.handleIntersection\n    );\n\n    this.componentMounted = true;\n  }\n\n  componentWillUnmount () {\n    const { intersectionObserverWrapper, id } = this.props;\n    intersectionObserverWrapper.unobserve(id, this.node);\n\n    this.componentMounted = false;\n  }\n\n  handleIntersection = (entry) => {\n    this.entry = entry;\n\n    scheduleIdleTask(this.calculateHeight);\n    this.setState(this.updateStateAfterIntersection);\n  }\n\n  updateStateAfterIntersection = (prevState) => {\n    if (prevState.isIntersecting && !this.entry.isIntersecting) {\n      scheduleIdleTask(this.hideIfNotIntersecting);\n    }\n    return {\n      isIntersecting: this.entry.isIntersecting,\n      isHidden: false,\n    };\n  }\n\n  calculateHeight = () => {\n    const { onHeightChange, saveHeightKey, id } = this.props;\n    // save the height of the fully-rendered element (this is expensive\n    // on Chrome, where we need to fall back to getBoundingClientRect)\n    this.height = getRectFromEntry(this.entry).height;\n\n    if (onHeightChange && saveHeightKey) {\n      onHeightChange(saveHeightKey, id, this.height);\n    }\n  }\n\n  hideIfNotIntersecting = () => {\n    if (!this.componentMounted) {\n      return;\n    }\n\n    // When the browser gets a chance, test if we're still not intersecting,\n    // and if so, set our isHidden to true to trigger an unrender. The point of\n    // this is to save DOM nodes and avoid using up too much memory.\n    // See: https://github.com/tootsuite/mastodon/issues/2900\n    this.setState((prevState) => ({ isHidden: !prevState.isIntersecting }));\n  }\n\n  handleRef = (node) => {\n    this.node = node;\n  }\n\n  render () {\n    const { children, id, index, listLength, cachedHeight } = this.props;\n    const { isIntersecting, isHidden } = this.state;\n\n    if (!isIntersecting && (isHidden || cachedHeight)) {\n      return (\n        <article\n          ref={this.handleRef}\n          aria-posinset={index}\n          aria-setsize={listLength}\n          style={{ height: `${this.height || cachedHeight}px`, opacity: 0, overflow: 'hidden' }}\n          data-id={id}\n          tabIndex='0'\n        >\n          {children && React.cloneElement(children, { hidden: true })}\n        </article>\n      );\n    }\n\n    return (\n      <article ref={this.handleRef} aria-posinset={index} aria-setsize={listLength} data-id={id} tabIndex='0'>\n        {children && React.cloneElement(children, { hidden: false })}\n      </article>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/components/intersection_observer_article.js","// Wrapper to call requestIdleCallback() to schedule low-priority work.\n// See https://developer.mozilla.org/en-US/docs/Web/API/Background_Tasks_API\n// for a good breakdown of the concepts behind this.\n\nimport Queue from 'tiny-queue';\n\nconst taskQueue = new Queue();\nlet runningRequestIdleCallback = false;\n\nfunction runTasks(deadline) {\n  while (taskQueue.length && deadline.timeRemaining() > 0) {\n    taskQueue.shift()();\n  }\n  if (taskQueue.length) {\n    requestIdleCallback(runTasks);\n  } else {\n    runningRequestIdleCallback = false;\n  }\n}\n\nfunction scheduleIdleTask(task) {\n  taskQueue.push(task);\n  if (!runningRequestIdleCallback) {\n    runningRequestIdleCallback = true;\n    requestIdleCallback(runTasks);\n  }\n}\n\nexport default scheduleIdleTask;\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/ui/util/schedule_idle_task.js","'use strict';\n\n// Simple FIFO queue implementation to avoid having to do shift()\n// on an array, which is slow.\n\nfunction Queue() {\n  this.length = 0;\n}\n\nQueue.prototype.push = function (item) {\n  var node = {item: item};\n  if (this.last) {\n    this.last = this.last.next = node;\n  } else {\n    this.last = this.first = node;\n  }\n  this.length++;\n};\n\nQueue.prototype.shift = function () {\n  var node = this.first;\n  if (node) {\n    this.first = node.next;\n    if (!(--this.length)) {\n      this.last = undefined;\n    }\n    return node.item;\n  }\n};\n\nQueue.prototype.slice = function (start, end) {\n  start = typeof start === 'undefined' ? 0 : start;\n  end = typeof end === 'undefined' ? Infinity : end;\n\n  var output = [];\n\n  var i = 0;\n  for (var node = this.first; node; node = node.next) {\n    if (--end < 0) {\n      break;\n    } else if (++i > start) {\n      output.push(node.item);\n    }\n  }\n  return output;\n}\n\nmodule.exports = Queue;\n\n\n\n// WEBPACK FOOTER //\n// ./node_modules/tiny-queue/index.js","\n// Get the bounding client rect from an IntersectionObserver entry.\n// This is to work around a bug in Chrome: https://crbug.com/737228\n\nlet hasBoundingRectBug;\n\nfunction getRectFromEntry(entry) {\n  if (typeof hasBoundingRectBug !== 'boolean') {\n    const boundingRect = entry.target.getBoundingClientRect();\n    const observerRect = entry.boundingClientRect;\n    hasBoundingRectBug = boundingRect.height !== observerRect.height ||\n      boundingRect.top !== observerRect.top ||\n      boundingRect.width !== observerRect.width ||\n      boundingRect.bottom !== observerRect.bottom ||\n      boundingRect.left !== observerRect.left ||\n      boundingRect.right !== observerRect.right;\n  }\n  return hasBoundingRectBug ? entry.target.getBoundingClientRect() : entry.boundingClientRect;\n}\n\nexport default getRectFromEntry;\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/ui/util/get_rect_from_entry.js","// Wrapper for IntersectionObserver in order to make working with it\n// a bit easier. We also follow this performance advice:\n// \"If you need to observe multiple elements, it is both possible and\n// advised to observe multiple elements using the same IntersectionObserver\n// instance by calling observe() multiple times.\"\n// https://developers.google.com/web/updates/2016/04/intersectionobserver\n\nclass IntersectionObserverWrapper {\n\n  callbacks = {};\n  observerBacklog = [];\n  observer = null;\n\n  connect (options) {\n    const onIntersection = (entries) => {\n      entries.forEach(entry => {\n        const id = entry.target.getAttribute('data-id');\n        if (this.callbacks[id]) {\n          this.callbacks[id](entry);\n        }\n      });\n    };\n\n    this.observer = new IntersectionObserver(onIntersection, options);\n    this.observerBacklog.forEach(([ id, node, callback ]) => {\n      this.observe(id, node, callback);\n    });\n    this.observerBacklog = null;\n  }\n\n  observe (id, node, callback) {\n    if (!this.observer) {\n      this.observerBacklog.push([ id, node, callback ]);\n    } else {\n      this.callbacks[id] = callback;\n      this.observer.observe(node);\n    }\n  }\n\n  unobserve (id, node) {\n    if (this.observer) {\n      delete this.callbacks[id];\n      this.observer.unobserve(node);\n    }\n  }\n\n  disconnect () {\n    if (this.observer) {\n      this.callbacks = {};\n      this.observer.disconnect();\n      this.observer = null;\n    }\n  }\n\n}\n\nexport default IntersectionObserverWrapper;\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/ui/util/intersection_observer_wrapper.js","import React from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport ColumnBackButton from './column_back_button';\n\nexport default class ColumnBackButtonSlim extends ColumnBackButton {\n\n  render () {\n    return (\n      <div className='column-back-button--slim'>\n        <div role='button' tabIndex='0' onClick={this.handleClick} className='column-back-button column-back-button--slim-button'>\n          <i className='fa fa-fw fa-chevron-left column-back-button__icon' />\n          <FormattedMessage id='column_back_button.label' defaultMessage='Back' />\n        </div>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/components/column_back_button_slim.js","import React from 'react';\nimport { connect } from 'react-redux';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport PropTypes from 'prop-types';\nimport LoadingIndicator from '../../components/loading_indicator';\nimport Column from '../ui/components/column';\nimport ColumnBackButtonSlim from '../../components/column_back_button_slim';\nimport DomainContainer from '../../containers/domain_container';\nimport { fetchDomainBlocks, expandDomainBlocks } from '../../actions/domain_blocks';\nimport { defineMessages, injectIntl } from 'react-intl';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\nimport { debounce } from 'lodash';\nimport ScrollableList from '../../components/scrollable_list';\n\nconst messages = defineMessages({\n  heading: { id: 'column.domain_blocks', defaultMessage: 'Hidden domains' },\n  unblockDomain: { id: 'account.unblock_domain', defaultMessage: 'Unhide {domain}' },\n});\n\nconst mapStateToProps = state => ({\n  domains: state.getIn(['domain_lists', 'blocks', 'items']),\n});\n\n@connect(mapStateToProps)\n@injectIntl\nexport default class Blocks extends ImmutablePureComponent {\n\n  static propTypes = {\n    params: PropTypes.object.isRequired,\n    dispatch: PropTypes.func.isRequired,\n    domains: ImmutablePropTypes.list,\n    intl: PropTypes.object.isRequired,\n  };\n\n  componentWillMount () {\n    this.props.dispatch(fetchDomainBlocks());\n  }\n\n  handleLoadMore = debounce(() => {\n    this.props.dispatch(expandDomainBlocks());\n  }, 300, { leading: true });\n\n  render () {\n    const { intl, domains } = this.props;\n\n    if (!domains) {\n      return (\n        <Column>\n          <LoadingIndicator />\n        </Column>\n      );\n    }\n\n    return (\n      <Column icon='minus-circle' heading={intl.formatMessage(messages.heading)}>\n        <ColumnBackButtonSlim />\n        <ScrollableList scrollKey='domain_blocks' onLoadMore={this.handleLoadMore}>\n          {domains.map(domain =>\n            <DomainContainer key={domain} domain={domain} />\n          )}\n        </ScrollableList>\n      </Column>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/domain_blocks/index.js"],"sourceRoot":""}
\ No newline at end of file
+{"version":3,"sources":["webpack:///app/javascript/tank/sources/git/git.pleroma.social/pleroma/mastofe/app/javascript/mastodon/components/domain.js","webpack:///app/javascript/tank/sources/git/git.pleroma.social/pleroma/mastofe/app/javascript/mastodon/containers/domain_container.js","webpack:///app/javascript/tank/sources/git/git.pleroma.social/pleroma/mastofe/app/javascript/mastodon/features/domain_blocks/index.js"],"names":["messages","defineMessages","unblockDomain","Account","injectIntl","props","onUnblockDomain","domain","render","this","intl","className","active","icon","title","formatMessage","onClick","handleDomainUnblock","ImmutablePureComponent","PropTypes","string","func","isRequired","object","blockDomainConfirm","connect","dispatch","onBlockDomain","openModal","message","id","defaultMessage","values","confirm","onConfirm","blockDomain","Domain","heading","Blocks","state","domains","getIn","hasMore","expandDomainBlocks","leading","componentWillMount","fetchDomainBlocks","shouldUpdateScroll","multiColumn","emptyMessage","bindToDocument","scrollKey","onLoadMore","handleLoadMore","map","params","bool","ImmutablePropTypes","orderedSet"],"mappings":"yQAMMA,EAAWC,YAAe,CAC9BC,cAAc,CAAD,gEAITC,EADUC,a,wMASQ,WACpB,EAAKC,MAAMC,gBAAgB,EAAKD,MAAME,U,sCAGxCC,OAAA,WAAW,IAAD,EACiBC,KAAKJ,MAAtBE,EADA,EACAA,OAAQG,EADR,EACQA,KAEhB,OACE,mBAAKC,UAAU,eAAf,EACE,mBAAKA,UAAU,wBAAf,EACE,oBAAMA,UAAU,4BAAhB,EACE,+BAASJ,IAGX,mBAAKI,UAAU,wBAAf,EACE,YAAC,IAAD,CAAYC,QAAM,EAACC,KAAK,SAASC,MAAOJ,EAAKK,cAAcf,EAASE,cAAe,CAAEK,WAAWS,QAASP,KAAKQ,0B,GAvBpGC,K,0BAED,CACjBX,OAAQY,IAAUC,OAClBd,gBAAiBa,IAAUE,KAAKC,WAChCZ,KAAMS,IAAUI,OAAOD,a,iBCTrBtB,EAAWC,YAAe,CAC9BuB,mBAAmB,CAAD,+EAuBLpB,cAAWqB,kBApBE,WAG1B,OAFwB,iBAAO,KAKN,SAACC,EAAD,OAAahB,EAAb,EAAaA,KAAb,MAAyB,CAClDiB,cADkD,SACnCpB,GACbmB,EAASE,YAAU,UAAW,CAC5BC,QAAS,YAAC,IAAD,CAAkBC,GAAG,qCAAqCC,eAAe,iJAAiJC,OAAQ,CAAEzB,OAAQ,+BAASA,MAC9P0B,QAASvB,EAAKK,cAAcf,EAASwB,oBACrCU,UAAW,kBAAMR,EAASS,YAAY5B,SAI1CD,gBATkD,SASjCC,GACfmB,EAASxB,YAAcK,OAIDkB,CAAiDW,I,+CCjB3E,IAAMpC,EAAWC,YAAe,CAC9BoC,QAAQ,CAAD,2DACPnC,cAAc,CAAD,gEAUToC,EAFUb,kBALQ,SAAAc,GAAK,MAAK,CAChCC,QAASD,EAAME,MAAM,CAAC,eAAgB,SAAU,UAChDC,UAAWH,EAAME,MAAM,CAAC,eAAgB,SAAU,W,GAInDrC,a,mMAiBkB,IAAS,WACxB,EAAKC,MAAMqB,SAASiB,gBACnB,IAAK,CAAEC,SAAS,K,8CANnBC,mBAAA,WACEpC,KAAKJ,MAAMqB,SAASoB,gB,EAOtBtC,OAAA,WAAW,IAAD,EAC4DC,KAAKJ,MAAjEK,EADA,EACAA,KAAM8B,EADN,EACMA,QAASO,EADf,EACeA,mBAAoBL,EADnC,EACmCA,QAASM,EAD5C,EAC4CA,YAEpD,IAAKR,EACH,OACE,YAAC,IAAD,UACE,YAAC,IAAD,KAKN,IAAMS,EAAe,YAAC,IAAD,CAAkBnB,GAAG,6BAA6BC,eAAe,qCAEtF,OACE,YAAC,IAAD,CAAQmB,gBAAiBF,EAAanC,KAAK,eAAewB,QAAS3B,EAAKK,cAAcf,EAASqC,eAA/F,EACE,YAAC,IAAD,IACA,YAAC,IAAD,CACEc,UAAU,gBACVC,WAAY3C,KAAK4C,eACjBX,QAASA,EACTK,mBAAoBA,EACpBE,aAAcA,EACdC,gBAAiBF,QANnB,EAQGR,EAAQc,IAAI,SAAA/C,GAAM,OACjB,YAAC,EAAD,CAA8BA,OAAQA,GAAhBA,Q,GA7CbW,K,0BAEA,CACjBqC,OAAQpC,IAAUI,OAAOD,WACzBI,SAAUP,IAAUE,KAAKC,WACzByB,mBAAoB5B,IAAUE,KAC9BqB,QAASvB,IAAUqC,KACnBhB,QAASiB,IAAmBC,WAC5BhD,KAAMS,IAAUI,OAAOD,WACvB0B,YAAa7B,IAAUqC,O","file":"features/domain_blocks.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport IconButton from './icon_button';\nimport { defineMessages, injectIntl } from 'react-intl';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\n\nconst messages = defineMessages({\n  unblockDomain: { id: 'account.unblock_domain', defaultMessage: 'Unhide {domain}' },\n});\n\nexport default @injectIntl\nclass Account extends ImmutablePureComponent {\n\n  static propTypes = {\n    domain: PropTypes.string,\n    onUnblockDomain: PropTypes.func.isRequired,\n    intl: PropTypes.object.isRequired,\n  };\n\n  handleDomainUnblock = () => {\n    this.props.onUnblockDomain(this.props.domain);\n  }\n\n  render () {\n    const { domain, intl } = this.props;\n\n    return (\n      <div className='domain'>\n        <div className='domain__wrapper'>\n          <span className='domain__domain-name'>\n            <strong>{domain}</strong>\n          </span>\n\n          <div className='domain__buttons'>\n            <IconButton active icon='unlock' title={intl.formatMessage(messages.unblockDomain, { domain })} onClick={this.handleDomainUnblock} />\n          </div>\n        </div>\n      </div>\n    );\n  }\n\n}\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport { blockDomain, unblockDomain } from '../actions/domain_blocks';\nimport { defineMessages, injectIntl, FormattedMessage } from 'react-intl';\nimport Domain from '../components/domain';\nimport { openModal } from '../actions/modal';\n\nconst messages = defineMessages({\n  blockDomainConfirm: { id: 'confirmations.domain_block.confirm', defaultMessage: 'Hide entire domain' },\n});\n\nconst makeMapStateToProps = () => {\n  const mapStateToProps = () => ({});\n\n  return mapStateToProps;\n};\n\nconst mapDispatchToProps = (dispatch, { intl }) => ({\n  onBlockDomain (domain) {\n    dispatch(openModal('CONFIRM', {\n      message: <FormattedMessage id='confirmations.domain_block.message' defaultMessage='Are you really, really sure you want to block the entire {domain}? In most cases a few targeted blocks or mutes are sufficient and preferable.' values={{ domain: <strong>{domain}</strong> }} />,\n      confirm: intl.formatMessage(messages.blockDomainConfirm),\n      onConfirm: () => dispatch(blockDomain(domain)),\n    }));\n  },\n\n  onUnblockDomain (domain) {\n    dispatch(unblockDomain(domain));\n  },\n});\n\nexport default injectIntl(connect(makeMapStateToProps, mapDispatchToProps)(Domain));\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport { defineMessages, injectIntl, FormattedMessage } from 'react-intl';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { debounce } from 'lodash';\nimport LoadingIndicator from '../../components/loading_indicator';\nimport Column from '../ui/components/column';\nimport ColumnBackButtonSlim from '../../components/column_back_button_slim';\nimport DomainContainer from '../../containers/domain_container';\nimport { fetchDomainBlocks, expandDomainBlocks } from '../../actions/domain_blocks';\nimport ScrollableList from '../../components/scrollable_list';\n\nconst messages = defineMessages({\n  heading: { id: 'column.domain_blocks', defaultMessage: 'Hidden domains' },\n  unblockDomain: { id: 'account.unblock_domain', defaultMessage: 'Unhide {domain}' },\n});\n\nconst mapStateToProps = state => ({\n  domains: state.getIn(['domain_lists', 'blocks', 'items']),\n  hasMore: !!state.getIn(['domain_lists', 'blocks', 'next']),\n});\n\nexport default @connect(mapStateToProps)\n@injectIntl\nclass Blocks extends ImmutablePureComponent {\n\n  static propTypes = {\n    params: PropTypes.object.isRequired,\n    dispatch: PropTypes.func.isRequired,\n    shouldUpdateScroll: PropTypes.func,\n    hasMore: PropTypes.bool,\n    domains: ImmutablePropTypes.orderedSet,\n    intl: PropTypes.object.isRequired,\n    multiColumn: PropTypes.bool,\n  };\n\n  componentWillMount () {\n    this.props.dispatch(fetchDomainBlocks());\n  }\n\n  handleLoadMore = debounce(() => {\n    this.props.dispatch(expandDomainBlocks());\n  }, 300, { leading: true });\n\n  render () {\n    const { intl, domains, shouldUpdateScroll, hasMore, multiColumn } = this.props;\n\n    if (!domains) {\n      return (\n        <Column>\n          <LoadingIndicator />\n        </Column>\n      );\n    }\n\n    const emptyMessage = <FormattedMessage id='empty_column.domain_blocks' defaultMessage='There are no hidden domains yet.' />;\n\n    return (\n      <Column bindToDocument={!multiColumn} icon='minus-circle' heading={intl.formatMessage(messages.heading)}>\n        <ColumnBackButtonSlim />\n        <ScrollableList\n          scrollKey='domain_blocks'\n          onLoadMore={this.handleLoadMore}\n          hasMore={hasMore}\n          shouldUpdateScroll={shouldUpdateScroll}\n          emptyMessage={emptyMessage}\n          bindToDocument={!multiColumn}\n        >\n          {domains.map(domain =>\n            <DomainContainer key={domain} domain={domain} />\n          )}\n        </ScrollableList>\n      </Column>\n    );\n  }\n\n}\n"],"sourceRoot":""}
\ No newline at end of file