{"version":3,"sources":["webpack:///features/favourited_statuses-b15a9a6cc711cca1eb76.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/containers/status_container.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/status_list.js","webpack:///./app/javascript/mastodon/features/favourited_statuses/index.js"],"names":["webpackJsonp","150","module","__webpack_exports__","__webpack_require__","d","ColumnHeader","__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_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_4_react___default","_React$PureComponent","_temp","_this","_ret","this","_len","arguments","length","args","Array","_key","call","apply","concat","handleClick","props","onClick","prototype","render","_props","type","active","columnHeaderId","icon","className","role","tabIndex","id","a","PureComponent","259","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","Object","handleScroll","setRef","c","scrollTop","heading","children","hideHeadingOnMobile","showHeading","window","innerWidth","replace","header","createElement","ref","aria-labelledby","onScroll","260","LoadMore","_class","__WEBPACK_IMPORTED_MODULE_5_react_intl__","visible","disabled","style","visibility","defaultMessage","defaultProps","261","__WEBPACK_IMPORTED_MODULE_1_react__","__WEBPACK_IMPORTED_MODULE_2_react_redux__","__WEBPACK_IMPORTED_MODULE_3__components_status__","__WEBPACK_IMPORTED_MODULE_4__selectors__","__WEBPACK_IMPORTED_MODULE_5__actions_compose__","__WEBPACK_IMPORTED_MODULE_6__actions_interactions__","__WEBPACK_IMPORTED_MODULE_7__actions_accounts__","__WEBPACK_IMPORTED_MODULE_8__actions_statuses__","__WEBPACK_IMPORTED_MODULE_9__actions_reports__","__WEBPACK_IMPORTED_MODULE_10__actions_modal__","__WEBPACK_IMPORTED_MODULE_11_react_intl__","__WEBPACK_IMPORTED_MODULE_12__initial_state__","messages","deleteConfirm","deleteMessage","blockConfirm","muteConfirm","makeMapStateToProps","getStatus","state","status","mapDispatchToProps","dispatch","_ref","intl","onReply","router","onModalReblog","onReblog","e","get","shiftKey","onFavourite","onPin","onEmbed","url","onDelete","message","formatMessage","confirm","onConfirm","onMention","account","onOpenMedia","media","index","onOpenVideo","time","onBlock","values","name","onReport","onMute","onMuteConversation","262","ScrollableList","_temp2","__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","lastMouseMove","intersectionObserverWrapper","_this$node","scrollHeight","clientHeight","offset","_oldScrollPosition","onScrollToBottom","isLoading","onScrollToTop","trailing","handleMouseMove","_lastMouseMove","Date","handleMouseLeave","onFullScreenChange","setState","fullscreen","handleLoadMore","preventDefault","componentDidMount","attachScrollListener","attachIntersectionObserver","componentDidUpdate","prevProps","Children","count","getFirstChildKey","newScrollTop","componentWillUnmount","detachScrollListener","detachIntersectionObserver","connect","root","rootMargin","disconnect","addEventListener","removeEventListener","firstChild","isArray","key","_recentlyMoved","_this2","scrollKey","trackScroll","shouldUpdateScroll","hasMore","prepend","emptyMessage","childrenCount","loadMore","scrollableArea","onMouseMove","onMouseLeave","map","child","listLength","saveHeightKey","context","route","location","contextTypes","object","263","__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","264","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","prevState","isIntersecting","hideIfNotIntersecting","_this$props","componentMounted","handleRef","shouldComponentUpdate","nextProps","nextState","isUnrendered","every","prop","observe","_props2","unobserve","_props3","_state","aria-posinset","aria-setsize","data-id","cloneElement","hidden","opacity","overflow","Component","265","runTasks","deadline","taskQueue","timeRemaining","shift","requestIdleCallback","runningRequestIdleCallback","scheduleIdleTask","task","push","__WEBPACK_IMPORTED_MODULE_0_tiny_queue__","__WEBPACK_IMPORTED_MODULE_0_tiny_queue___default","266","exports","Queue","item","last","next","first","undefined","slice","start","end","Infinity","output","i","267","getRectFromEntry","hasBoundingRectBug","boundingRect","target","getBoundingClientRect","observerRect","boundingClientRect","top","width","bottom","left","right","268","IntersectionObserverWrapper","callbacks","observerBacklog","observer","options","onIntersection","entries","forEach","getAttribute","IntersectionObserver","callback","269","StatusList","__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_extends__","__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_extends___default","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_jsx__","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_jsx___default","__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_objectWithoutProperties__","__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_objectWithoutProperties___default","__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_classCallCheck__","__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_classCallCheck___default","__WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_possibleConstructorReturn__","__WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_possibleConstructorReturn___default","__WEBPACK_IMPORTED_MODULE_5_babel_runtime_helpers_inherits__","__WEBPACK_IMPORTED_MODULE_5_babel_runtime_helpers_inherits___default","__WEBPACK_IMPORTED_MODULE_6_react__","__WEBPACK_IMPORTED_MODULE_6_react___default","__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__containers_status_container__","__WEBPACK_IMPORTED_MODULE_10_react_immutable_pure_component__","__WEBPACK_IMPORTED_MODULE_10_react_immutable_pure_component___default","__WEBPACK_IMPORTED_MODULE_11__scrollable_list__","_ImmutablePureCompone","handleMoveUp","elementIndex","statusIds","indexOf","_selectChild","handleMoveDown","element","focus","other","scrollableContent","size","statusId","onMoveUp","onMoveDown","propTypes","string","isRequired","list","func","bool","769","defineProperty","value","Favourites","_dec","_class2","__WEBPACK_IMPORTED_MODULE_5_react_redux__","__WEBPACK_IMPORTED_MODULE_6_prop_types__","__WEBPACK_IMPORTED_MODULE_6_prop_types___default","__WEBPACK_IMPORTED_MODULE_8__actions_favourites__","__WEBPACK_IMPORTED_MODULE_9__ui_components_column__","__WEBPACK_IMPORTED_MODULE_10__components_column_header__","__WEBPACK_IMPORTED_MODULE_11__actions_columns__","__WEBPACK_IMPORTED_MODULE_12__components_status_list__","__WEBPACK_IMPORTED_MODULE_13_react_intl__","__WEBPACK_IMPORTED_MODULE_14_react_immutable_pure_component__","__WEBPACK_IMPORTED_MODULE_14_react_immutable_pure_component___default","mapStateToProps","handlePin","columnId","handleMove","dir","_this$props2","column","handleScrollToBottom","componentWillMount","multiColumn","pinned","title","onMove","showBackButton"],"mappings":"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","file":"features/favourited_statuses-b15a9a6cc711cca1eb76.js","sourcesContent":["webpackJsonp([12],{\n\n/***/ 150:\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\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        type = _props.type,\n        active = _props.active,\n        columnHeaderId = _props.columnHeaderId;\n\n\n    var icon = '';\n\n    if (this.props.icon) {\n      icon = __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n        className: 'fa fa-fw fa-' + this.props.icon + ' column-header__icon'\n      });\n    }\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      role: 'heading',\n      tabIndex: '0',\n      className: 'column-header ' + (active ? 'active' : ''),\n      onClick: this.handleClick,\n      id: columnHeaderId || null\n    }, void 0, icon, type);\n  };\n\n  return ColumnHeader;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\n\n\n/***/ }),\n\n/***/ 259:\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__(42);\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__(150);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__scroll__ = __webpack_require__(91);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__is_mobile__ = __webpack_require__(33);\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/***/ 260:\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__(6);\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 visible = this.props.visible;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n      className: 'load-more',\n      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/***/ 261:\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_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_react_redux__ = __webpack_require__(9);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__components_status__ = __webpack_require__(153);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__selectors__ = __webpack_require__(69);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__actions_compose__ = __webpack_require__(15);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__actions_interactions__ = __webpack_require__(43);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__actions_accounts__ = __webpack_require__(22);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__actions_statuses__ = __webpack_require__(57);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__actions_reports__ = __webpack_require__(151);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__actions_modal__ = __webpack_require__(31);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_react_intl__ = __webpack_require__(6);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_12__initial_state__ = __webpack_require__(18);\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_11_react_intl__[\"f\" /* defineMessages */])({\n  deleteConfirm: {\n    'id': 'confirmations.delete.confirm',\n    'defaultMessage': 'Delete'\n  },\n  deleteMessage: {\n    'id': 'confirmations.delete.message',\n    'defaultMessage': 'Are you sure you want to delete this status?'\n  },\n  blockConfirm: {\n    'id': 'confirmations.block.confirm',\n    'defaultMessage': 'Block'\n  },\n  muteConfirm: {\n    'id': 'confirmations.mute.confirm',\n    'defaultMessage': 'Mute'\n  }\n});\n\nvar makeMapStateToProps = function makeMapStateToProps() {\n  var getStatus = Object(__WEBPACK_IMPORTED_MODULE_4__selectors__[\"e\" /* makeGetStatus */])();\n\n  var mapStateToProps = function mapStateToProps(state, props) {\n    return {\n      status: getStatus(state, props.id)\n    };\n  };\n\n  return mapStateToProps;\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch, _ref) {\n  var intl = _ref.intl;\n  return {\n    onReply: function onReply(status, router) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_5__actions_compose__[\"O\" /* replyCompose */])(status, router));\n    },\n    onModalReblog: function onModalReblog(status) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_6__actions_interactions__[\"q\" /* reblog */])(status));\n    },\n    onReblog: function onReblog(status, e) {\n      if (status.get('reblogged')) {\n        dispatch(Object(__WEBPACK_IMPORTED_MODULE_6__actions_interactions__[\"t\" /* unreblog */])(status));\n      } else {\n        if (e.shiftKey || !__WEBPACK_IMPORTED_MODULE_12__initial_state__[\"b\" /* boostModal */]) {\n          this.onModalReblog(status);\n        } else {\n          dispatch(Object(__WEBPACK_IMPORTED_MODULE_10__actions_modal__[\"d\" /* openModal */])('BOOST', { status: status, onReblog: this.onModalReblog }));\n        }\n      }\n    },\n    onFavourite: function onFavourite(status) {\n      if (status.get('favourited')) {\n        dispatch(Object(__WEBPACK_IMPORTED_MODULE_6__actions_interactions__[\"r\" /* unfavourite */])(status));\n      } else {\n        dispatch(Object(__WEBPACK_IMPORTED_MODULE_6__actions_interactions__[\"m\" /* favourite */])(status));\n      }\n    },\n    onPin: function onPin(status) {\n      if (status.get('pinned')) {\n        dispatch(Object(__WEBPACK_IMPORTED_MODULE_6__actions_interactions__[\"s\" /* unpin */])(status));\n      } else {\n        dispatch(Object(__WEBPACK_IMPORTED_MODULE_6__actions_interactions__[\"p\" /* pin */])(status));\n      }\n    },\n    onEmbed: function onEmbed(status) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_10__actions_modal__[\"d\" /* openModal */])('EMBED', { url: status.get('url') }));\n    },\n    onDelete: function onDelete(status) {\n      if (!__WEBPACK_IMPORTED_MODULE_12__initial_state__[\"d\" /* deleteModal */]) {\n        dispatch(Object(__WEBPACK_IMPORTED_MODULE_8__actions_statuses__[\"e\" /* deleteStatus */])(status.get('id')));\n      } else {\n        dispatch(Object(__WEBPACK_IMPORTED_MODULE_10__actions_modal__[\"d\" /* openModal */])('CONFIRM', {\n          message: intl.formatMessage(messages.deleteMessage),\n          confirm: intl.formatMessage(messages.deleteConfirm),\n          onConfirm: function onConfirm() {\n            return dispatch(Object(__WEBPACK_IMPORTED_MODULE_8__actions_statuses__[\"e\" /* deleteStatus */])(status.get('id')));\n          }\n        }));\n      }\n    },\n    onMention: function onMention(account, router) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_5__actions_compose__[\"M\" /* mentionCompose */])(account, router));\n    },\n    onOpenMedia: function onOpenMedia(media, index) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_10__actions_modal__[\"d\" /* openModal */])('MEDIA', { media: media, index: index }));\n    },\n    onOpenVideo: function onOpenVideo(media, time) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_10__actions_modal__[\"d\" /* openModal */])('VIDEO', { media: media, time: time }));\n    },\n    onBlock: function onBlock(account) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_10__actions_modal__[\"d\" /* openModal */])('CONFIRM', {\n        message: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_11_react_intl__[\"b\" /* FormattedMessage */], {\n          id: 'confirmations.block.message',\n          defaultMessage: 'Are you sure you want to block {name}?',\n          values: { name: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('strong', {}, void 0, '@', account.get('acct')) }\n        }),\n        confirm: intl.formatMessage(messages.blockConfirm),\n        onConfirm: function onConfirm() {\n          return dispatch(Object(__WEBPACK_IMPORTED_MODULE_7__actions_accounts__[\"r\" /* blockAccount */])(account.get('id')));\n        }\n      }));\n    },\n    onReport: function onReport(status) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_9__actions_reports__[\"i\" /* initReport */])(status.get('account'), status));\n    },\n    onMute: function onMute(account) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_10__actions_modal__[\"d\" /* openModal */])('CONFIRM', {\n        message: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_11_react_intl__[\"b\" /* FormattedMessage */], {\n          id: 'confirmations.mute.message',\n          defaultMessage: 'Are you sure you want to mute {name}?',\n          values: { name: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('strong', {}, void 0, '@', account.get('acct')) }\n        }),\n        confirm: intl.formatMessage(messages.muteConfirm),\n        onConfirm: function onConfirm() {\n          return dispatch(Object(__WEBPACK_IMPORTED_MODULE_7__actions_accounts__[\"B\" /* muteAccount */])(account.get('id')));\n        }\n      }));\n    },\n    onMuteConversation: function onMuteConversation(status) {\n      if (status.get('muted')) {\n        dispatch(Object(__WEBPACK_IMPORTED_MODULE_8__actions_statuses__[\"h\" /* unmuteStatus */])(status.get('id')));\n      } else {\n        dispatch(Object(__WEBPACK_IMPORTED_MODULE_8__actions_statuses__[\"g\" /* muteStatus */])(status.get('id')));\n      }\n    }\n  };\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_11_react_intl__[\"g\" /* injectIntl */])(Object(__WEBPACK_IMPORTED_MODULE_2_react_redux__[\"connect\"])(makeMapStateToProps, mapDispatchToProps)(__WEBPACK_IMPORTED_MODULE_3__components_status__[\"a\" /* default */])));\n\n/***/ }),\n\n/***/ 262:\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__(94);\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__(152);\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__(263);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__load_more__ = __webpack_require__(260);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__features_ui_util_intersection_observer_wrapper__ = __webpack_require__(268);\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__(154);\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      lastMouseMove: 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        _this._oldScrollPosition = scrollHeight - scrollTop;\n\n        if (400 > offset && _this.props.onScrollToBottom && !_this.props.isLoading) {\n          _this.props.onScrollToBottom();\n        } else 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.handleMouseMove = __WEBPACK_IMPORTED_MODULE_4_lodash_throttle___default()(function () {\n      _this._lastMouseMove = new Date();\n    }, 300), _this.handleMouseLeave = function () {\n      _this._lastMouseMove = null;\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.onScrollToBottom();\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.componentDidUpdate = function componentDidUpdate(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\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 (someItemInserted && this._oldScrollPosition && this.node.scrollTop > 0) {\n      var newScrollTop = this.node.scrollHeight - this._oldScrollPosition;\n\n      if (this.node.scrollTop !== newScrollTop) {\n        this.node.scrollTop = newScrollTop;\n      }\n    } else {\n      this._oldScrollPosition = this.node.scrollHeight - this.node.scrollTop;\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._recentlyMoved = function _recentlyMoved() {\n    return this._lastMouseMove !== null && new Date() - this._lastMouseMove < 600;\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    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 ? __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, onMouseMove: this.handleMouseMove, onMouseLeave: this.handleMouseLeave },\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/***/ 263:\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__(264);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__actions_height_cache__ = __webpack_require__(95);\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/***/ 264:\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__(265);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__features_ui_util_get_rect_from_entry__ = __webpack_require__(267);\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/***/ 265:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_tiny_queue__ = __webpack_require__(266);\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/***/ 266:\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/***/ 267:\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/***/ 268:\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/***/ 269:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return StatusList; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_extends__ = __webpack_require__(28);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_extends___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_extends__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_objectWithoutProperties__ = __webpack_require__(29);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_objectWithoutProperties___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_objectWithoutProperties__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes__ = __webpack_require__(12);\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__containers_status_container__ = __webpack_require__(261);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10_react_immutable_pure_component__ = __webpack_require__(11);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_10_react_immutable_pure_component__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11__scrollable_list__ = __webpack_require__(262);\n\n\n\n\n\n\n\nvar _class, _temp2;\n\n\n\n\n\n\n\n\nvar StatusList = (_temp2 = _class = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_5_babel_runtime_helpers_inherits___default()(StatusList, _ImmutablePureCompone);\n\n  function StatusList() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_classCallCheck___default()(this, StatusList);\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_4_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ImmutablePureCompone.call.apply(_ImmutablePureCompone, [this].concat(args))), _this), _this.handleMoveUp = function (id) {\n      var elementIndex = _this.props.statusIds.indexOf(id) - 1;\n      _this._selectChild(elementIndex);\n    }, _this.handleMoveDown = function (id) {\n      var elementIndex = _this.props.statusIds.indexOf(id) + 1;\n      _this._selectChild(elementIndex);\n    }, _this.setRef = function (c) {\n      _this.node = c;\n    }, _temp), __WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  StatusList.prototype._selectChild = function _selectChild(index) {\n    var element = this.node.node.querySelector('article:nth-of-type(' + (index + 1) + ') .focusable');\n\n    if (element) {\n      element.focus();\n    }\n  };\n\n  StatusList.prototype.render = function render() {\n    var _this2 = this;\n\n    var _props = this.props,\n        statusIds = _props.statusIds,\n        other = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_objectWithoutProperties___default()(_props, ['statusIds']);\n\n    var isLoading = other.isLoading;\n\n\n    var scrollableContent = isLoading || statusIds.size > 0 ? statusIds.map(function (statusId) {\n      return __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__containers_status_container__[\"a\" /* default */], {\n        id: statusId,\n        onMoveUp: _this2.handleMoveUp,\n        onMoveDown: _this2.handleMoveDown\n      }, statusId);\n    }) : null;\n\n    return __WEBPACK_IMPORTED_MODULE_6_react___default.a.createElement(\n      __WEBPACK_IMPORTED_MODULE_11__scrollable_list__[\"a\" /* default */],\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_extends___default()({}, other, { ref: this.setRef }),\n      scrollableContent\n    );\n  };\n\n  return StatusList;\n}(__WEBPACK_IMPORTED_MODULE_10_react_immutable_pure_component___default.a), _class.propTypes = {\n  scrollKey: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.string.isRequired,\n  statusIds: __WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes___default.a.list.isRequired,\n  onScrollToBottom: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func,\n  onScrollToTop: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func,\n  onScroll: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func,\n  trackScroll: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.bool,\n  shouldUpdateScroll: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func,\n  isLoading: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.bool,\n  hasMore: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.bool,\n  prepend: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.node,\n  emptyMessage: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.node\n}, _class.defaultProps = {\n  trackScroll: true\n}, _temp2);\n\n\n/***/ }),\n\n/***/ 769:\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 Favourites; });\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_redux__ = __webpack_require__(9);\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/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes__ = __webpack_require__(12);\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__actions_favourites__ = __webpack_require__(74);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__ui_components_column__ = __webpack_require__(259);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__components_column_header__ = __webpack_require__(98);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11__actions_columns__ = __webpack_require__(273);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_12__components_status_list__ = __webpack_require__(269);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_13_react_intl__ = __webpack_require__(6);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_14_react_immutable_pure_component__ = __webpack_require__(11);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_14_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_14_react_immutable_pure_component__);\n\n\n\n\n\nvar _dec, _class, _class2, _temp2;\n\n\n\n\n\n\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_13_react_intl__[\"f\" /* defineMessages */])({\n  heading: {\n    'id': 'column.favourites',\n    'defaultMessage': 'Favourites'\n  }\n});\n\nvar mapStateToProps = function mapStateToProps(state) {\n  return {\n    statusIds: state.getIn(['status_lists', 'favourites', 'items']),\n    hasMore: !!state.getIn(['status_lists', 'favourites', 'next'])\n  };\n};\n\nvar Favourites = (_dec = Object(__WEBPACK_IMPORTED_MODULE_5_react_redux__[\"connect\"])(mapStateToProps), _dec(_class = Object(__WEBPACK_IMPORTED_MODULE_13_react_intl__[\"g\" /* injectIntl */])(_class = (_temp2 = _class2 = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(Favourites, _ImmutablePureCompone);\n\n  function Favourites() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, Favourites);\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.handlePin = function () {\n      var _this$props = _this.props,\n          columnId = _this$props.columnId,\n          dispatch = _this$props.dispatch;\n\n\n      if (columnId) {\n        dispatch(Object(__WEBPACK_IMPORTED_MODULE_11__actions_columns__[\"f\" /* removeColumn */])(columnId));\n      } else {\n        dispatch(Object(__WEBPACK_IMPORTED_MODULE_11__actions_columns__[\"d\" /* addColumn */])('FAVOURITES', {}));\n      }\n    }, _this.handleMove = function (dir) {\n      var _this$props2 = _this.props,\n          columnId = _this$props2.columnId,\n          dispatch = _this$props2.dispatch;\n\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_11__actions_columns__[\"e\" /* moveColumn */])(columnId, dir));\n    }, _this.handleHeaderClick = function () {\n      _this.column.scrollTop();\n    }, _this.setRef = function (c) {\n      _this.column = c;\n    }, _this.handleScrollToBottom = function () {\n      _this.props.dispatch(Object(__WEBPACK_IMPORTED_MODULE_8__actions_favourites__[\"c\" /* expandFavouritedStatuses */])());\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  Favourites.prototype.componentWillMount = function componentWillMount() {\n    this.props.dispatch(Object(__WEBPACK_IMPORTED_MODULE_8__actions_favourites__[\"d\" /* fetchFavouritedStatuses */])());\n  };\n\n  Favourites.prototype.render = function render() {\n    var _props = this.props,\n        intl = _props.intl,\n        statusIds = _props.statusIds,\n        columnId = _props.columnId,\n        multiColumn = _props.multiColumn,\n        hasMore = _props.hasMore;\n\n    var pinned = !!columnId;\n\n    return __WEBPACK_IMPORTED_MODULE_4_react___default.a.createElement(\n      __WEBPACK_IMPORTED_MODULE_9__ui_components_column__[\"a\" /* default */],\n      { ref: this.setRef },\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_10__components_column_header__[\"a\" /* default */], {\n        icon: 'star',\n        title: intl.formatMessage(messages.heading),\n        onPin: this.handlePin,\n        onMove: this.handleMove,\n        onClick: this.handleHeaderClick,\n        pinned: pinned,\n        multiColumn: multiColumn,\n        showBackButton: true\n      }),\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_12__components_status_list__[\"a\" /* default */], {\n        trackScroll: !pinned,\n        statusIds: statusIds,\n        scrollKey: 'favourited_statuses-' + columnId,\n        hasMore: hasMore,\n        onScrollToBottom: this.handleScrollToBottom\n      })\n    );\n  };\n\n  return Favourites;\n}(__WEBPACK_IMPORTED_MODULE_14_react_immutable_pure_component___default.a), _class2.propTypes = {\n  dispatch: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.func.isRequired,\n  statusIds: __WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes___default.a.list.isRequired,\n  intl: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.object.isRequired,\n  columnId: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.string,\n  multiColumn: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.bool,\n  hasMore: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.bool\n}, _temp2)) || _class) || _class);\n\n\n/***/ })\n\n});\n\n\n// WEBPACK FOOTER //\n// features/favourited_statuses-b15a9a6cc711cca1eb76.js","import React from 'react';\nimport PropTypes from 'prop-types';\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 { type, active, columnHeaderId } = this.props;\n\n    let icon = '';\n\n    if (this.props.icon) {\n      icon = <i className={`fa fa-fw fa-${this.props.icon} column-header__icon`} />;\n    }\n\n    return (\n      <div role='heading' tabIndex='0' className={`column-header ${active ? 'active' : ''}`} onClick={this.handleClick} id={columnHeaderId || null}>\n        {icon}\n        {type}\n      </div>\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    visible: PropTypes.bool,\n  }\n\n  static defaultProps = {\n    visible: true,\n  }\n\n  render() {\n    const { visible } = this.props;\n\n    return (\n      <button className='load-more' 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 { connect } from 'react-redux';\nimport Status from '../components/status';\nimport { makeGetStatus } from '../selectors';\nimport {\n  replyCompose,\n  mentionCompose,\n} from '../actions/compose';\nimport {\n  reblog,\n  favourite,\n  unreblog,\n  unfavourite,\n  pin,\n  unpin,\n} from '../actions/interactions';\nimport {\n  blockAccount,\n  muteAccount,\n} from '../actions/accounts';\nimport { muteStatus, unmuteStatus, deleteStatus } from '../actions/statuses';\nimport { initReport } from '../actions/reports';\nimport { openModal } from '../actions/modal';\nimport { defineMessages, injectIntl, FormattedMessage } from 'react-intl';\nimport { boostModal, deleteModal } from '../initial_state';\n\nconst messages = defineMessages({\n  deleteConfirm: { id: 'confirmations.delete.confirm', defaultMessage: 'Delete' },\n  deleteMessage: { id: 'confirmations.delete.message', defaultMessage: 'Are you sure you want to delete this status?' },\n  blockConfirm: { id: 'confirmations.block.confirm', defaultMessage: 'Block' },\n  muteConfirm: { id: 'confirmations.mute.confirm', defaultMessage: 'Mute' },\n});\n\nconst makeMapStateToProps = () => {\n  const getStatus = makeGetStatus();\n\n  const mapStateToProps = (state, props) => ({\n    status: getStatus(state, props.id),\n  });\n\n  return mapStateToProps;\n};\n\nconst mapDispatchToProps = (dispatch, { intl }) => ({\n\n  onReply (status, router) {\n    dispatch(replyCompose(status, router));\n  },\n\n  onModalReblog (status) {\n    dispatch(reblog(status));\n  },\n\n  onReblog (status, e) {\n    if (status.get('reblogged')) {\n      dispatch(unreblog(status));\n    } else {\n      if (e.shiftKey || !boostModal) {\n        this.onModalReblog(status);\n      } else {\n        dispatch(openModal('BOOST', { status, onReblog: this.onModalReblog }));\n      }\n    }\n  },\n\n  onFavourite (status) {\n    if (status.get('favourited')) {\n      dispatch(unfavourite(status));\n    } else {\n      dispatch(favourite(status));\n    }\n  },\n\n  onPin (status) {\n    if (status.get('pinned')) {\n      dispatch(unpin(status));\n    } else {\n      dispatch(pin(status));\n    }\n  },\n\n  onEmbed (status) {\n    dispatch(openModal('EMBED', { url: status.get('url') }));\n  },\n\n  onDelete (status) {\n    if (!deleteModal) {\n      dispatch(deleteStatus(status.get('id')));\n    } else {\n      dispatch(openModal('CONFIRM', {\n        message: intl.formatMessage(messages.deleteMessage),\n        confirm: intl.formatMessage(messages.deleteConfirm),\n        onConfirm: () => dispatch(deleteStatus(status.get('id'))),\n      }));\n    }\n  },\n\n  onMention (account, router) {\n    dispatch(mentionCompose(account, router));\n  },\n\n  onOpenMedia (media, index) {\n    dispatch(openModal('MEDIA', { media, index }));\n  },\n\n  onOpenVideo (media, time) {\n    dispatch(openModal('VIDEO', { media, time }));\n  },\n\n  onBlock (account) {\n    dispatch(openModal('CONFIRM', {\n      message: <FormattedMessage id='confirmations.block.message' defaultMessage='Are you sure you want to block {name}?' values={{ name: <strong>@{account.get('acct')}</strong> }} />,\n      confirm: intl.formatMessage(messages.blockConfirm),\n      onConfirm: () => dispatch(blockAccount(account.get('id'))),\n    }));\n  },\n\n  onReport (status) {\n    dispatch(initReport(status.get('account'), status));\n  },\n\n  onMute (account) {\n    dispatch(openModal('CONFIRM', {\n      message: <FormattedMessage id='confirmations.mute.message' defaultMessage='Are you sure you want to mute {name}?' values={{ name: <strong>@{account.get('acct')}</strong> }} />,\n      confirm: intl.formatMessage(messages.muteConfirm),\n      onConfirm: () => dispatch(muteAccount(account.get('id'))),\n    }));\n  },\n\n  onMuteConversation (status) {\n    if (status.get('muted')) {\n      dispatch(unmuteStatus(status.get('id')));\n    } else {\n      dispatch(muteStatus(status.get('id')));\n    }\n  },\n\n});\n\nexport default injectIntl(connect(makeMapStateToProps, mapDispatchToProps)(Status));\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/containers/status_container.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    onScrollToBottom: 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    lastMouseMove: 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      this._oldScrollPosition = scrollHeight - scrollTop;\n\n      if (400 > offset && this.props.onScrollToBottom && !this.props.isLoading) {\n        this.props.onScrollToBottom();\n      } else 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  handleMouseMove = throttle(() => {\n    this._lastMouseMove = new Date();\n  }, 300);\n\n  handleMouseLeave = () => {\n    this._lastMouseMove = null;\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  componentDidUpdate (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\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 (someItemInserted && this._oldScrollPosition && this.node.scrollTop > 0) {\n      const newScrollTop = this.node.scrollHeight - this._oldScrollPosition;\n\n      if (this.node.scrollTop !== newScrollTop) {\n        this.node.scrollTop = newScrollTop;\n      }\n    } else {\n      this._oldScrollPosition = this.node.scrollHeight - this.node.scrollTop;\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.onScrollToBottom();\n  }\n\n  _recentlyMoved () {\n    return this._lastMouseMove !== null && ((new Date()) - this._lastMouseMove < 600);\n  }\n\n  render () {\n    const { children, scrollKey, trackScroll, shouldUpdateScroll, isLoading, hasMore, prepend, emptyMessage } = this.props;\n    const { fullscreen } = this.state;\n    const childrenCount = React.Children.count(children);\n\n    const loadMore     = (hasMore && childrenCount > 0) ? <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} onMouseMove={this.handleMouseMove} onMouseLeave={this.handleMouseLeave}>\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 ImmutablePropTypes from 'react-immutable-proptypes';\nimport PropTypes from 'prop-types';\nimport StatusContainer from '../containers/status_container';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\nimport ScrollableList from './scrollable_list';\n\nexport default class StatusList extends ImmutablePureComponent {\n\n  static propTypes = {\n    scrollKey: PropTypes.string.isRequired,\n    statusIds: ImmutablePropTypes.list.isRequired,\n    onScrollToBottom: 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  };\n\n  static defaultProps = {\n    trackScroll: true,\n  };\n\n  handleMoveUp = id => {\n    const elementIndex = this.props.statusIds.indexOf(id) - 1;\n    this._selectChild(elementIndex);\n  }\n\n  handleMoveDown = id => {\n    const elementIndex = this.props.statusIds.indexOf(id) + 1;\n    this._selectChild(elementIndex);\n  }\n\n  _selectChild (index) {\n    const element = this.node.node.querySelector(`article:nth-of-type(${index + 1}) .focusable`);\n\n    if (element) {\n      element.focus();\n    }\n  }\n\n  setRef = c => {\n    this.node = c;\n  }\n\n  render () {\n    const { statusIds, ...other } = this.props;\n    const { isLoading } = other;\n\n    const scrollableContent = (isLoading || statusIds.size > 0) ? (\n      statusIds.map((statusId) => (\n        <StatusContainer\n          key={statusId}\n          id={statusId}\n          onMoveUp={this.handleMoveUp}\n          onMoveDown={this.handleMoveDown}\n        />\n      ))\n    ) : null;\n\n    return (\n      <ScrollableList {...other} ref={this.setRef}>\n        {scrollableContent}\n      </ScrollableList>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/components/status_list.js","import React from 'react';\nimport { connect } from 'react-redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { fetchFavouritedStatuses, expandFavouritedStatuses } from '../../actions/favourites';\nimport Column from '../ui/components/column';\nimport ColumnHeader from '../../components/column_header';\nimport { addColumn, removeColumn, moveColumn } from '../../actions/columns';\nimport StatusList from '../../components/status_list';\nimport { defineMessages, injectIntl } from 'react-intl';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\n\nconst messages = defineMessages({\n  heading: { id: 'column.favourites', defaultMessage: 'Favourites' },\n});\n\nconst mapStateToProps = state => ({\n  statusIds: state.getIn(['status_lists', 'favourites', 'items']),\n  hasMore: !!state.getIn(['status_lists', 'favourites', 'next']),\n});\n\n@connect(mapStateToProps)\n@injectIntl\nexport default class Favourites extends ImmutablePureComponent {\n\n  static propTypes = {\n    dispatch: PropTypes.func.isRequired,\n    statusIds: ImmutablePropTypes.list.isRequired,\n    intl: PropTypes.object.isRequired,\n    columnId: PropTypes.string,\n    multiColumn: PropTypes.bool,\n    hasMore: PropTypes.bool,\n  };\n\n  componentWillMount () {\n    this.props.dispatch(fetchFavouritedStatuses());\n  }\n\n  handlePin = () => {\n    const { columnId, dispatch } = this.props;\n\n    if (columnId) {\n      dispatch(removeColumn(columnId));\n    } else {\n      dispatch(addColumn('FAVOURITES', {}));\n    }\n  }\n\n  handleMove = (dir) => {\n    const { columnId, dispatch } = this.props;\n    dispatch(moveColumn(columnId, dir));\n  }\n\n  handleHeaderClick = () => {\n    this.column.scrollTop();\n  }\n\n  setRef = c => {\n    this.column = c;\n  }\n\n  handleScrollToBottom = () => {\n    this.props.dispatch(expandFavouritedStatuses());\n  }\n\n  render () {\n    const { intl, statusIds, columnId, multiColumn, hasMore } = this.props;\n    const pinned = !!columnId;\n\n    return (\n      <Column ref={this.setRef}>\n        <ColumnHeader\n          icon='star'\n          title={intl.formatMessage(messages.heading)}\n          onPin={this.handlePin}\n          onMove={this.handleMove}\n          onClick={this.handleHeaderClick}\n          pinned={pinned}\n          multiColumn={multiColumn}\n          showBackButton\n        />\n\n        <StatusList\n          trackScroll={!pinned}\n          statusIds={statusIds}\n          scrollKey={`favourited_statuses-${columnId}`}\n          hasMore={hasMore}\n          onScrollToBottom={this.handleScrollToBottom}\n        />\n      </Column>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/favourited_statuses/index.js"],"sourceRoot":""}