akkoma/priv/static/packs/features/home_timeline-c146f32b0118845677ee.js.map
2017-11-12 14:23:05 +01:00

1 line
166 KiB
Plaintext

{"version":3,"sources":["webpack:///features/home_timeline-c146f32b0118845677ee.js","webpack:///./app/javascript/mastodon/features/ui/containers/status_list_container.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/home_timeline/index.js","webpack:///./node_modules/react-toggle/dist/component/index.js","webpack:///./node_modules/react-toggle/dist/component/check.js","webpack:///./node_modules/react-toggle/dist/component/x.js","webpack:///./node_modules/react-toggle/dist/component/util.js","webpack:///./app/javascript/mastodon/components/setting_text.js","webpack:///./app/javascript/mastodon/features/notifications/components/setting_toggle.js","webpack:///./app/javascript/mastodon/features/home_timeline/containers/column_settings_container.js","webpack:///./app/javascript/mastodon/features/home_timeline/components/column_settings.js"],"names":["webpackJsonp","158","module","__webpack_exports__","__webpack_require__","__WEBPACK_IMPORTED_MODULE_0_lodash_debounce__","__WEBPACK_IMPORTED_MODULE_0_lodash_debounce___default","n","__WEBPACK_IMPORTED_MODULE_1_react_redux__","__WEBPACK_IMPORTED_MODULE_2__components_status_list__","__WEBPACK_IMPORTED_MODULE_3__actions_timelines__","__WEBPACK_IMPORTED_MODULE_4_immutable__","__WEBPACK_IMPORTED_MODULE_5_reselect__","__WEBPACK_IMPORTED_MODULE_6__initial_state__","makeGetStatusIds","Object","state","_ref","type","getIn","_ref2","get","columnSettings","statusIds","statuses","rawRegex","trim","regex","RegExp","e","filter","id","statusForId","showStatus","searchIndex","test","makeMapStateToProps","getStatusIds","_ref3","timelineId","isLoading","hasMore","mapDispatchToProps","dispatch","_ref4","loadMore","onScrollToBottom","leading","onScrollToTop","onScroll","260","d","LoadMore","_class","_temp","__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__","__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default","__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","__WEBPACK_IMPORTED_MODULE_5_react_intl__","_React$PureComponent","this","apply","arguments","prototype","render","visible","props","className","disabled","style","visibility","onClick","defaultMessage","a","PureComponent","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","getStatus","status","intl","onReply","router","onModalReblog","onReblog","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_5_react__","__WEBPACK_IMPORTED_MODULE_5_react___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","_this","_ret","_len","length","args","Array","_key","call","concat","lastMouseMove","intersectionObserverWrapper","handleScroll","node","_this$node","scrollTop","scrollHeight","clientHeight","offset","_oldScrollPosition","trailing","handleMouseMove","_lastMouseMove","Date","handleMouseLeave","onFullScreenChange","setState","fullscreen","setRef","c","handleLoadMore","preventDefault","componentDidMount","attachScrollListener","attachIntersectionObserver","componentDidUpdate","prevProps","Children","count","children","getFirstChildKey","newScrollTop","componentWillUnmount","detachScrollListener","detachIntersectionObserver","connect","root","rootMargin","disconnect","addEventListener","removeEventListener","firstChild","isArray","key","_recentlyMoved","_this2","_props","scrollKey","trackScroll","shouldUpdateScroll","prepend","emptyMessage","childrenCount","scrollableArea","createElement","ref","onMouseMove","onMouseLeave","role","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","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","tabIndex","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","indexOf","_selectChild","handleMoveDown","element","querySelector","focus","other","scrollableContent","size","statusId","onMoveUp","onMoveDown","propTypes","string","isRequired","list","func","bool","754","defineProperty","value","HomeTimeline","_dec","__WEBPACK_IMPORTED_MODULE_5_react_redux__","__WEBPACK_IMPORTED_MODULE_6__actions_timelines__","__WEBPACK_IMPORTED_MODULE_7__ui_containers_status_list_container__","__WEBPACK_IMPORTED_MODULE_8__components_column__","__WEBPACK_IMPORTED_MODULE_9__components_column_header__","__WEBPACK_IMPORTED_MODULE_10__actions_columns__","__WEBPACK_IMPORTED_MODULE_12__containers_column_settings_container__","__WEBPACK_IMPORTED_MODULE_13_react_router_dom__","title","mapStateToProps","hasUnread","handlePin","columnId","handleMove","dir","_this$props2","handleHeaderClick","column","multiColumn","pinned","icon","active","onMove","public","to","790","_interopRequireDefault","obj","__esModule","default","_objectWithoutProperties","keys","hasOwnProperty","_classCallCheck","instance","Constructor","TypeError","_possibleConstructorReturn","self","ReferenceError","_inherits","subClass","superClass","create","constructor","enumerable","writable","configurable","setPrototypeOf","__proto__","_extends","assign","source","_createClass","defineProperties","descriptor","protoProps","staticProps","_react","_react2","_classnames","_classnames2","_propTypes","_propTypes2","_check","_check2","_x","_x2","_util","Toggle","getPrototypeOf","handleClick","bind","handleTouchStart","handleTouchMove","handleTouchEnd","handleFocus","handleBlur","previouslyChecked","checked","defaultChecked","hasFocus","event","checkbox","input","moved","click","startX","pointerCoord","x","activated","currentX","endX","onFocus","onBlur","icons","inputProps","classes","react-toggle--checked","react-toggle--focus","react-toggle--disabled","onTouchStart","onTouchMove","onTouchEnd","getIcon","displayName","unchecked","onChange","aria-labelledby","aria-label","oneOfType","shape","791","viewBox","fill","fillRule","792","793","changedTouches","touch","clientX","y","clientY","pageX","pageY","794","SettingText","handleChange","settingKey","settings","label","display","placeholder","804","SettingToggle","__WEBPACK_IMPORTED_MODULE_5_react_toggle__","__WEBPACK_IMPORTED_MODULE_5_react_toggle___default","prefix","meta","Boolean","join","onKeyDown","htmlFor","888","__WEBPACK_IMPORTED_MODULE_1__components_column_settings__","__WEBPACK_IMPORTED_MODULE_2__actions_settings__","onSave","889","ColumnSettings","__WEBPACK_IMPORTED_MODULE_6__notifications_components_setting_toggle__","__WEBPACK_IMPORTED_MODULE_7__components_setting_text__","filter_regex"],"mappings":"AAAAA,cAAc,IAERC,IACA,SAAUC,EAAQC,EAAqBC,GAE7C,YACqB,IAAIC,GAAgDD,EAAoB,IACpEE,EAAwDF,EAAoBG,EAAEF,GAC9EG,EAA4CJ,EAAoB,GAChEK,EAAwDL,EAAoB,KAC5EM,EAAmDN,EAAoB,IACvEO,EAA0CP,EAAoB,GAE9DQ,GADkDR,EAAoBG,EAAEI,GAC/BP,EAAoB,KAE7DS,GADiDT,EAAoBG,EAAEK,GACxBR,EAAoB,KCPtFU,EAAmB,iBAAMC,QAAAH,EAAA,iBAC7B,SAACI,EAADC,GAAA,GAAUC,GAAVD,EAAUC,IAAV,OAAqBF,GAAMG,OAAO,WAAYD,GAAOH,OAAAJ,EAAA,SACrD,SAACK,EAADI,GAAA,GAAUF,GAAVE,EAAUF,IAAV,OAAqBF,GAAMG,OAAO,YAAaD,EAAM,SAAUH,OAAAJ,EAAA,UAC/D,SAACK,GAAD,MAAqBA,GAAMK,IAAI,cAC9B,SAACC,EAAgBC,EAAWC,GAC7B,GAAMC,GAAWH,EAAeH,OAAO,QAAS,QAAS,IAAIO,OACzDC,EAAa,IAEjB,KACEA,EAAQF,GAAY,GAAIG,QAAOH,EAAU,KACzC,MAAOI,IAIT,MAAON,GAAUO,OAAO,SAAAC,GACtB,GAAMC,GAAcR,EAASH,IAAIU,GAC7BE,GAAgB,CAUpB,KARkD,IAA9CX,EAAeH,OAAO,QAAS,aACjCc,EAAaA,GAA4C,OAA9BD,EAAYX,IAAI,YAGI,IAA7CC,EAAeH,OAAO,QAAS,YACjCc,EAAaA,IAAqD,OAAtCD,EAAYX,IAAI,mBAA8BW,EAAYX,IAAI,4BAA8BR,EAAA,IAGtHoB,GAAcN,GAASK,EAAYX,IAAI,aAAeR,EAAA,EAAI,CAC5D,GAAMqB,GAAcF,EAAYX,IAAI,UAAYG,EAASL,OAAOa,EAAYX,IAAI,UAAW,iBAAmBW,EAAYX,IAAI,eAC9HY,IAAcN,EAAMQ,KAAKD,GAG3B,MAAOD,QAILG,EAAsB,WAC1B,GAAMC,GAAevB,GAQrB,OANwB,UAACE,EAADsB,GAAA,GAAUC,GAAVD,EAAUC,UAAV,QACtBhB,UAAWc,EAAarB,GAASE,KAAMqB,IACvCC,UAAWxB,EAAMG,OAAO,YAAaoB,EAAY,cAAc,GAC/DE,UAAWzB,EAAMG,OAAO,YAAaoB,EAAY,YAM/CG,EAAqB,SAACC,EAADC,GAAA,GAAaL,GAAbK,EAAaL,WAAYM,EAAzBD,EAAyBC,QAAzB,QAEzBC,iBAAkBxC,IAAS,WACzBqC,EAAS5B,OAAAL,EAAA,GAAkB6B,GAAY,IACvCM,KACC,KAAOE,SAAS,IAEnBC,cAAe1C,IAAS,WACtBqC,EAAS5B,OAAAL,EAAA,GAAkB6B,GAAY,KACtC,KAEHU,SAAU3C,IAAS,WACjBqC,EAAS5B,OAAAL,EAAA,GAAkB6B,GAAY,KACtC,MAILpC,GAAA,EAAeY,OAAAP,EAAA,SAAQ4B,EAAqBM,GAAoBjC,EAAA,IDkC1DyC,IACA,SAAUhD,EAAQC,EAAqBC,GAE7C,YAC+BA,GAAoB+C,EAAEhD,EAAqB,IAAK,WAAa,MAAOiD,IAC9E,IAgBjBC,GAAQC,EAhBaC,EAA0DnD,EAAoB,GAC9EoD,EAAkEpD,EAAoBG,EAAEgD,GACxFE,EAAqErD,EAAoB,GACzFsD,EAA6EtD,EAAoBG,EAAEkD,GACnGE,EAAgFvD,EAAoB,GACpGwD,EAAwFxD,EAAoBG,EAAEoD,GAC9GE,EAA+DzD,EAAoB,GACnF0D,EAAuE1D,EAAoBG,EAAEsD,GAC7FE,EAAsC3D,EAAoB,GAC1D4D,EAA8C5D,EAAoBG,EAAEwD,GACpEE,EAA2C7D,EAAoB,GErHnEgD,GF+HLE,EAAQD,EAAS,SAAUa,GAGzC,QAASd,KAGP,MAFAM,KAA6ES,KAAMf,GAE5EQ,IAAwFO,KAAMD,EAAqBE,MAAMD,KAAME,YAkBxI,MAvBAP,KAAuEV,EAAUc,GAQjFd,EAASkB,UE7HTC,OF6H4B,WE7HnB,GACCC,GAAYL,KAAKM,MAAjBD,OAER,OAAAhB,KAAA,UAAAkB,UACoB,YADpBC,UAC2CH,EAD3CI,OAC6DC,WAAYL,EAAU,UAAY,UAD/FM,QACoHX,KAAKM,MAAMK,aAD/H,GAAAtB,IAEKS,EAAA,GAFLlC,GAEyB,mBAFzBgD,eAE2D,gBFuItD3B,GEvJ6BY,EAAAgB,EAAMC,eFwJoB5B,EEjJvD6B,cACLV,SAAS,GFkJVlB,IAKG6B,IACA,SAAUjF,EAAQC,EAAqBC,GAE7C,YACqB,IAAImD,GAA0DnD,EAAoB,GAC9EoD,EAAkEpD,EAAoBG,EAAEgD,GACxF6B,EAAsChF,EAAoB,GAE1DiF,GAD8CjF,EAAoBG,EAAE6E,GACxBhF,EAAoB,IAChEkF,EAAmDlF,EAAoB,KACvEmF,EAA2CnF,EAAoB,IAC/DoF,EAAiDpF,EAAoB,IACrEqF,EAAsDrF,EAAoB,IAC1EsF,EAAkDtF,EAAoB,IACtEuF,EAAkDvF,EAAoB,IACtEwF,EAAiDxF,EAAoB,KACrEyF,EAAgDzF,EAAoB,IACpE0F,EAA4C1F,EAAoB,GAChE2F,EAAgD3F,EAAoB,IG3JvF4F,EAAWjF,OAAA+E,EAAA,IACfG,eAAAlE,GAAA,+BAAAgD,eAAA,UACAmB,eAAAnE,GAAA,+BAAAgD,eAAA,gDACAoB,cAAApE,GAAA,8BAAAgD,eAAA,SACAqB,aAAArE,GAAA,6BAAAgD,eAAA,UAGI3C,EAAsB,WAC1B,GAAMiE,GAAYtF,OAAAwE,EAAA,IAMlB,OAJwB,UAACvE,EAAOyD,GAAR,OACtB6B,OAAQD,EAAUrF,EAAOyD,EAAM1C,OAM7BW,EAAqB,SAACC,EAAD1B,GAAA,GAAasF,GAAbtF,EAAasF,IAAb,QAEzBC,QAFkD,SAEzCF,EAAQG,GACf9D,EAAS5B,OAAAyE,EAAA,GAAac,EAAQG,KAGhCC,cANkD,SAMnCJ,GACb3D,EAAS5B,OAAA0E,EAAA,GAAOa,KAGlBK,SAVkD,SAUxCL,EAAQzE,GACZyE,EAAOjF,IAAI,aACbsB,EAAS5B,OAAA0E,EAAA,GAASa,IAEdzE,EAAE+E,WAAab,EAAA,EACjB5B,KAAKuC,cAAcJ,GAEnB3D,EAAS5B,OAAA8E,EAAA,GAAU,SAAWS,SAAQK,SAAUxC,KAAKuC,kBAK3DG,YAtBkD,SAsBrCP,GAET3D,EADE2D,EAAOjF,IAAI,cACJN,OAAA0E,EAAA,GAAYa,GAEZvF,OAAA0E,EAAA,GAAUa,KAIvBQ,MA9BkD,SA8B3CR,GAEH3D,EADE2D,EAAOjF,IAAI,UACJN,OAAA0E,EAAA,GAAMa,GAENvF,OAAA0E,EAAA,GAAIa,KAIjBS,QAtCkD,SAsCzCT,GACP3D,EAAS5B,OAAA8E,EAAA,GAAU,SAAWmB,IAAKV,EAAOjF,IAAI,WAGhD4F,SA1CkD,SA0CxCX,GAIN3D,EAHGoD,EAAA,EAGMhF,OAAA8E,EAAA,GAAU,WACjBqB,QAASX,EAAKY,cAAcnB,EAASE,eACrCkB,QAASb,EAAKY,cAAcnB,EAASC,eACrCoB,UAAW,iBAAM1E,GAAS5B,OAAA4E,EAAA,GAAaW,EAAOjF,IAAI,WAL3CN,OAAA4E,EAAA,GAAaW,EAAOjF,IAAI,SAUrCiG,UAtDkD,SAsDvCC,EAASd,GAClB9D,EAAS5B,OAAAyE,EAAA,GAAe+B,EAASd,KAGnCe,YA1DkD,SA0DrCC,EAAOC,GAClB/E,EAAS5B,OAAA8E,EAAA,GAAU,SAAW4B,QAAOC,YAGvCC,YA9DkD,SA8DrCF,EAAOG,GAClBjF,EAAS5B,OAAA8E,EAAA,GAAU,SAAW4B,QAAOG,WAGvCC,QAlEkD,SAkEzCN,GACP5E,EAAS5B,OAAA8E,EAAA,GAAU,WACjBqB,QAAA1D,IAAUsC,EAAA,GAAV/D,GAA8B,8BAA9BgD,eAA2E,yCAA3E+C,QAA8HC,KAAAvE,IAAAuE,uBAAgBR,EAAQlG,IAAI,YAC1J+F,QAASb,EAAKY,cAAcnB,EAASG,cACrCkB,UAAW,iBAAM1E,GAAS5B,OAAA2E,EAAA,GAAa6B,EAAQlG,IAAI,aAIvD2G,SA1EkD,SA0ExC1B,GACR3D,EAAS5B,OAAA6E,EAAA,GAAWU,EAAOjF,IAAI,WAAYiF,KAG7C2B,OA9EkD,SA8E1CV,GACN5E,EAAS5B,OAAA8E,EAAA,GAAU,WACjBqB,QAAA1D,IAAUsC,EAAA,GAAV/D,GAA8B,6BAA9BgD,eAA0E,wCAA1E+C,QAA4HC,KAAAvE,IAAAuE,uBAAgBR,EAAQlG,IAAI,YACxJ+F,QAASb,EAAKY,cAAcnB,EAASI,aACrCiB,UAAW,iBAAM1E,GAAS5B,OAAA2E,EAAA,GAAY6B,EAAQlG,IAAI,aAItD6G,mBAtFkD,SAsF9B5B,GAEhB3D,EADE2D,EAAOjF,IAAI,SACJN,OAAA4E,EAAA,GAAaW,EAAOjF,IAAI,OAExBN,OAAA4E,EAAA,GAAWW,EAAOjF,IAAI,UAMrClB,GAAA,EAAeY,OAAA+E,EAAA,GAAW/E,OAAAsE,EAAA,SAAQjD,EAAqBM,GAAoB4C,EAAA,KH8LrE6C,IACA,SAAUjI,EAAQC,EAAqBC,GAE7C,YAC+BA,GAAoB+C,EAAEhD,EAAqB,IAAK,WAAa,MAAOiI,IAC9E,IA6BjB/E,GAAQgF,EA7Ba9E,EAA0DnD,EAAoB,GAC9EoD,EAAkEpD,EAAoBG,EAAEgD,GACxFE,EAAqErD,EAAoB,GACzFsD,EAA6EtD,EAAoBG,EAAEkD,GACnGE,EAAgFvD,EAAoB,GACpGwD,EAAwFxD,EAAoBG,EAAEoD,GAC9GE,EAA+DzD,EAAoB,GACnF0D,EAAuE1D,EAAoBG,EAAEsD,GAC7FyE,EAAgDlI,EAAoB,IACpEmI,EAAwDnI,EAAoBG,EAAE+H,GAC9EE,EAAsCpI,EAAoB,GAC1DqI,EAA8CrI,EAAoBG,EAAEiI,GACpEE,EAAsDtI,EAAoB,KAC1EuI,EAA2CvI,EAAoB,GAC/DwI,EAAmDxI,EAAoBG,EAAEoI,GACzEE,EAAoFzI,EAAoB,KACxG0I,EAA2C1I,EAAoB,KAC/D2I,EAAiF3I,EAAoB,KACrG4I,EAA2C5I,EAAoB,GAE/D6I,GADmD7I,EAAoBG,EAAEyI,GAC7B5I,EAAoB,KAChE8I,EAAoD9I,EAAoBG,EAAE0I,GAC1EE,EAA8D/I,EAAoB,KIzVtFgI,GJ6WCC,EAAShF,EAAS,SAAU+F,GAGhD,QAAShB,KACP,GAAI9E,GAAO+F,EAAOC,CAElB5F,KAA6ES,KAAMiE,EAEnF,KAAK,GAAImB,GAAOlF,UAAUmF,OAAQC,EAAOC,MAAMH,GAAOI,EAAO,EAAGA,EAAOJ,EAAMI,IAC3EF,EAAKE,GAAQtF,UAAUsF,EAGzB,OAAerG,GAAS+F,EAAQzF,IAAwFO,KAAMiF,EAAeQ,KAAKxF,MAAMgF,GAAiBjF,MAAM0F,OAAOJ,KAAiBJ,EIjWzMrI,OACE8I,cAAe,MJkWZT,EI/VLU,4BAA8B,GAAIhB,GAAA,EJ+VgHM,EI7VlJW,aAAezB,IAAS,WACtB,GAAIc,EAAKY,KAAM,IAAAC,GACqCb,EAAKY,KAA/CE,EADKD,EACLC,UAAWC,EADNF,EACME,aAAcC,EADpBH,EACoBG,aAC3BC,EAASF,EAAeD,EAAYE,CAC1ChB,GAAKkB,mBAAqBH,EAAeD,EAErC,IAAMG,GAAUjB,EAAK5E,MAAM3B,mBAAqBuG,EAAK5E,MAAMjC,UAC7D6G,EAAK5E,MAAM3B,mBACFqH,EAAY,KAAOd,EAAK5E,MAAMzB,cACvCqG,EAAK5E,MAAMzB,gBACFqG,EAAK5E,MAAMxB,UACpBoG,EAAK5E,MAAMxB,aAGd,KACDuH,UAAU,IJkWNnB,EI/VNoB,gBAAkBlC,IAAS,WACzBc,EAAKqB,eAAiB,GAAIC,OACzB,KJ+VQtB,EI7VXuB,iBAAmB,WACjBvB,EAAKqB,eAAiB,MJ8VnBrB,EI1TLwB,mBAAqB,WACnBxB,EAAKyB,UAAWC,WAAYhK,OAAAoI,EAAA,QJ2TzBE,EI1RL2B,OAAS,SAACC,GACR5B,EAAKY,KAAOgB,GJ2RT5B,EIxRL6B,eAAiB,SAACrJ,GAChBA,EAAEsJ,iBACF9B,EAAK5E,MAAM3B,oBJwPJwG,EAiCJhG,EAAQM,IAAwFyF,EAAOC,GA8H5G,MA1KAxF,KAAuEsE,EAAgBgB,GA+CvFhB,EAAe9D,UIrWf8G,kBJqW6C,WIpW3CjH,KAAKkH,uBACLlH,KAAKmH,6BACLvK,OAAAoI,EAAA,GAAyBhF,KAAK0G,oBAG9B1G,KAAK6F,gBJwWP5B,EAAe9D,UIrWfiH,mBJqW8C,SIrW1BC,GAOlB,GANyB/C,EAAAzD,EAAMyG,SAASC,MAAMF,EAAUG,UAAY,GAClElD,EAAAzD,EAAMyG,SAASC,MAAMF,EAAUG,UAAYlD,EAAAzD,EAAMyG,SAASC,MAAMvH,KAAKM,MAAMkH,WAC3ExH,KAAKyH,iBAAiBJ,KAAerH,KAAKyH,iBAAiBzH,KAAKM,QAI1CN,KAAKoG,oBAAsBpG,KAAK8F,KAAKE,UAAY,EAAG,CAC1E,GAAM0B,GAAe1H,KAAK8F,KAAKG,aAAejG,KAAKoG,kBAE/CpG,MAAK8F,KAAKE,YAAc0B,IAC1B1H,KAAK8F,KAAKE,UAAY0B,OAGxB1H,MAAKoG,mBAAqBpG,KAAK8F,KAAKG,aAAejG,KAAK8F,KAAKE,WJuWjE/B,EAAe9D,UInWfwH,qBJmWgD,WIlW9C3H,KAAK4H,uBACL5H,KAAK6H,6BACLjL,OAAAoI,EAAA,GAAyBhF,KAAK0G,qBJsWhCzC,EAAe9D,UI/VfgH,2BJ+VsD,WI9VpDnH,KAAK4F,4BAA4BkC,SAC/BC,KAAM/H,KAAK8F,KACXkC,WAAY,cJmWhB/D,EAAe9D,UI/Vf0H,2BJ+VsD,WI9VpD7H,KAAK4F,4BAA4BqC,cJkWnChE,EAAe9D,UI/Vf+G,qBJ+VgD,WI9V9ClH,KAAK8F,KAAKoC,iBAAiB,SAAUlI,KAAK6F,eJkW5C5B,EAAe9D,UI/VfyH,qBJ+VgD,WI9V9C5H,KAAK8F,KAAKqC,oBAAoB,SAAUnI,KAAK6F,eJkW/C5B,EAAe9D,UI/VfsH,iBJ+V4C,SI/V1BnH,GAAO,GACfkH,GAAalH,EAAbkH,SACJY,EAAaZ,CAMjB,OALIA,aAAoB3C,GAAA,KACtBuD,EAAaZ,EAAStK,IAAI,GACjBqI,MAAM8C,QAAQb,KACvBY,EAAaZ,EAAS,IAEjBY,GAAcA,EAAWE,KJmWlCrE,EAAe9D,UIvVfoI,eJuV0C,WItVxC,MAA+B,QAAxBvI,KAAKuG,gBAA6B,GAAIC,MAAUxG,KAAKuG,eAAiB,KJ0V/EtC,EAAe9D,UIvVfC,OJuVkC,WIvVxB,GAAAoI,GAAAxI,KAAAyI,EACoGzI,KAAKM,MAAzGkH,EADAiB,EACAjB,SAAUkB,EADVD,EACUC,UAAWC,EADrBF,EACqBE,YAAaC,EADlCH,EACkCG,mBAAoBvK,EADtDoK,EACsDpK,UAAWC,EADjEmK,EACiEnK,QAASuK,EAD1EJ,EAC0EI,QAASC,EADnFL,EACmFK,aACnFlC,EAAe5G,KAAKnD,MAApB+J,WACFmC,EAAgBzE,EAAAzD,EAAMyG,SAASC,MAAMC,GAErC9I,EAAgBJ,GAAWyK,EAAgB,EAA5B1J,IAAkCsF,EAAA,GAAlCtE,SAAqDhC,EAArDsC,QAAyEX,KAAK+G,iBAAqB,KACpHiC,EAAiB,IAiCrB,OA9BEA,GADE3K,GAAa0K,EAAgB,IAAMD,EAEnCxE,EAAAzD,EAAAoI,cAAA,OAAK1I,UAAWwE,IAAW,cAAgB6B,eAAesC,IAAKlJ,KAAK6G,OAAQsC,YAAanJ,KAAKsG,gBAAiB8C,aAAcpJ,KAAKyG,kBAAlIpH,IAAA,OAAAgK,KACY,OADZ9I,UAC6B,iBAD7B,GAEKsI,EAEAvE,EAAAzD,EAAMyG,SAASgC,IAAItJ,KAAKM,MAAMkH,SAAU,SAAC+B,EAAOhG,GAAR,MAAAlE,KACtCqF,EAAA,GADsC9G,GAGjC2L,EAAMjB,IAH2B/E,MAI9BA,EAJ8BiG,WAKzBT,EALyBnD,4BAMR4C,EAAK5C,4BANG6D,cAOtBd,EAAiBH,EAAKkB,QAAQpH,OAAOqH,MAAMC,SAAStB,IAApD,IAA2DI,EAAc,MALnFa,EAAMjB,IAOViB,KAIJ7K,IAML4F,EAAAzD,EAAAoI,cAAA,OAAK1I,UAAU,yBAAyB2I,IAAKlJ,KAAK6G,QAC/CiC,GAKHH,EACFtJ,IACGkF,EAAA,GADHmE,UAC8BA,EAD9BE,mBAC6DA,OAD7D,GAEKI,GAIEA,GJkWJ/E,GIxhBmCI,EAAA,eJyhBanF,EIvhBhD2K,cACLvH,OAAQmC,EAAA5D,EAAUiJ,QJwhBnB5K,EIvgBM6B,cACL4H,aAAa,GJwgBdzE,IAKG6F,IACA,SAAUhO,EAAQC,EAAqBC,GAE7C,YACqB,IAAI+N,GAA4C/N,EAAoB,GAChEgO,EAA0EhO,EAAoB,KAC9FiO,EAAsDjO,EAAoB,IK/iB7FgC,EAAsB,SAACpB,EAAOyD,GAAR,OAC1B6J,aAActN,EAAMG,OAAO,eAAgBsD,EAAMmJ,cAAenJ,EAAM1C,OAGlEW,EAAqB,SAACC,GAAD,OAEzB4L,eAFwC,SAExB9B,EAAK1K,EAAIyM,GACvB7L,EAAS5B,OAAAsN,EAAA,GAAU5B,EAAK1K,EAAIyM,MAKhCrO,GAAA,EAAeY,OAAAoN,EAAA,SAAQ/L,EAAqBM,GAAoB0L,EAAA,IL0jB1DK,IACA,SAAUvO,EAAQC,EAAqBC,GAE7C,YAC+BA,GAAoB+C,EAAEhD,EAAqB,IAAK,WAAa,MAAOuO,IAC9E,IAAIC,GAAqEvO,EAAoB,GACzFwO,EAA6ExO,EAAoBG,EAAEoO,GACnGE,EAAgFzO,EAAoB,GACpG0O,EAAwF1O,EAAoBG,EAAEsO,GAC9GE,EAA+D3O,EAAoB,GACnF4O,EAAuE5O,EAAoBG,EAAEwO,GAC7FE,EAAsC7O,EAAoB,GAC1D8O,EAA8C9O,EAAoBG,EAAE0O,GACpEE,EAAqE/O,EAAoB,KACzFgP,EAAsEhP,EAAoB,KAC1FiP,EAA0CjP,EAAoB,GMllBjFkP,GNmlBqElP,EAAoBG,EAAE8O,IMnlB/D,KAAM,QAAS,eAE3CE,GAA8B,KAAM,QAAS,aAAc,gBAE5Cb,EN8lBa,SAAUc,GAG1C,QAASd,KACP,GAAIpL,GAAO+F,EAAOC,CAElBsF,KAA6EzK,KAAMuK,EAEnF,KAAK,GAAInF,GAAOlF,UAAUmF,OAAQC,EAAOC,MAAMH,GAAOI,EAAO,EAAGA,EAAOJ,EAAMI,IAC3EF,EAAKE,GAAQtF,UAAUsF,EAGzB,OAAerG,GAAS+F,EAAQyF,IAAwF3K,KAAMqL,EAAiB5F,KAAKxF,MAAMoL,GAAmBrL,MAAM0F,OAAOJ,KAAiBJ,EM7lB7MrI,OACEyO,UAAU,GN8lBPpG,EM5jBLqG,mBAAqB,SAACC,GACpBtG,EAAKsG,MAAQA,EAEb5O,OAAAoO,EAAA,GAAiB9F,EAAKuG,iBACtBvG,EAAKyB,SAASzB,EAAKwG,+BN6jBhBxG,EM1jBLwG,6BAA+B,SAACC,GAI9B,MAHIA,GAAUC,iBAAmB1G,EAAKsG,MAAMI,gBAC1ChP,OAAAoO,EAAA,GAAiB9F,EAAK2G,wBAGtBD,eAAgB1G,EAAKsG,MAAMI,eAC3BN,UAAU,IN4jBTpG,EMxjBLuG,gBAAkB,WAAM,GAAAK,GACwB5G,EAAK5E,MAA3C8J,EADc0B,EACd1B,eAAgBX,EADFqC,EACErC,cAAe7L,EADjBkO,EACiBlO,EAGvCsH,GAAKmF,OAASzN,OAAAqO,EAAA,GAAiB/F,EAAKsG,OAAOnB,OAEvCD,GAAkBX,GACpBW,EAAeX,EAAe7L,EAAIsH,EAAKmF,SN8jBtCnF,EM1jBL2G,sBAAwB,WACjB3G,EAAK6G,kBAQV7G,EAAKyB,SAAS,SAACgF,GAAD,OAAkBL,UAAWK,EAAUC,mBN6jBlD1G,EM1jBL8G,UAAY,SAAClG,GACXZ,EAAKY,KAAOA,GNihBLX,EA0CJhG,EAAQwL,IAAwFzF,EAAOC,GA0E5G,MA/HA0F,KAAuEN,EAA6Bc,GAwDpGd,EAA4BpK,UMtoB5B8L,sBNsoB8D,SMtoBvCC,EAAWC,GAAW,GAAA3D,GAAAxI,KACrCoM,GAAgBpM,KAAKnD,MAAM+O,iBAAmB5L,KAAKnD,MAAMyO,UAAYtL,KAAKM,MAAM6J,aAEtF,SAAMiC,KADoBD,EAAUP,iBAAmBO,EAAUb,WAAYY,EAAU/B,iBAMnEiC,EAAehB,EAA6BD,GAC5CkB,MAAM,SAAAC,GAAA,MAAQ1P,QAAAsO,EAAA,IAAGgB,EAAUI,GAAO9D,EAAKlI,MAAMgM,ON6oBnE/B,EAA4BpK,UM1oB5B8G,kBN0oB0D,WM1oBrC,GAAAwB,GACyBzI,KAAKM,MAAzCsF,EADW6C,EACX7C,4BAA6BhI,EADlB6K,EACkB7K,EAErCgI,GAA4B2G,QAC1B3O,EACAoC,KAAK8F,KACL9F,KAAKuL,oBAGPvL,KAAK+L,kBAAmB,GN4oB1BxB,EAA4BpK,UMzoB5BwH,qBNyoB6D,WMzoBrC,GAAA6E,GACsBxM,KAAKM,MAAzCsF,EADc4G,EACd5G,4BAA6BhI,EADf4O,EACe5O,EACrCgI,GAA4B6G,UAAU7O,EAAIoC,KAAK8F,MAE/C9F,KAAK+L,kBAAmB,GN+oB1BxB,EAA4BpK,UMhmB5BC,ONgmB+C,WMhmBrC,GAAAsM,GACkD1M,KAAKM,MAAvDkH,EADAkF,EACAlF,SAAU5J,EADV8O,EACU9O,GAAI2F,EADdmJ,EACcnJ,MAAOiG,EADrBkD,EACqBlD,WAAYW,EADjCuC,EACiCvC,aADjCwC,EAE6B3M,KAAKnD,MAAlC+O,EAFAe,EAEAf,eAAgBN,EAFhBqB,EAEgBrB,QAExB,OAAKM,KAAmBN,IAAYnB,EAgBlCY,EAAAlK,EAAAoI,cAAA,WAASC,IAAKlJ,KAAKgM,UAAWY,gBAAerJ,EAAOsJ,eAAcrD,EAAYsD,UAASlP,EAAImP,SAAS,KACjGvF,GAAYuD,EAAAlK,EAAMmM,aAAaxF,GAAYyF,QAAQ,KAfpDlC,EAAAlK,EAAAoI,cAAA,WACEC,IAAKlJ,KAAKgM,UACVY,gBAAerJ,EACfsJ,eAAcrD,EACd/I,OAAS4J,QAAWrK,KAAKqK,QAAUF,GAA1B,KAA4C+C,QAAS,EAAGC,SAAU,UAC3EL,UAASlP,EACTmP,SAAS,KAERvF,GAAYuD,EAAAlK,EAAMmM,aAAaxF,GAAYyF,QAAQ,MNonBrD1C,GM9tBgDQ,EAAAlK,EAAMuM,YNquBzDC,IACA,SAAUtR,EAAQC,EAAqBC,GAE7C,YO1uBA,SAASqR,GAASC,GAChB,KAAOC,EAAUnI,QAAUkI,EAASE,gBAAkB,GACpDD,EAAUE,SAERF,GAAUnI,OACZsI,oBAAoBL,GAEpBM,GAA6B,EAIjC,QAASC,GAAiBC,GACxBN,EAAUO,KAAKD,GACVF,IACHA,GAA6B,EAC7BD,oBAAoBL,IAxBxB,GAAAU,GAAA/R,EAAA,KAAAgS,EAAAhS,EAAAG,EAAA4R,GAMMR,EAAY,GAAIS,GAAApN,EAClB+M,GAA6B,CAqBjC5R,GAAA,KP0vBMkS,IACA,SAAUnS,EAAQoS,EAASlS,GAEjC,YQpxBA,SAASmS,KACPpO,KAAKqF,OAAS,EAGhB+I,EAAMjO,UAAU4N,KAAO,SAAUM,GAC/B,GAAIvI,IAAQuI,KAAMA,EACdrO,MAAKsO,KACPtO,KAAKsO,KAAOtO,KAAKsO,KAAKC,KAAOzI,EAE7B9F,KAAKsO,KAAOtO,KAAKwO,MAAQ1I,EAE3B9F,KAAKqF,UAGP+I,EAAMjO,UAAUuN,MAAQ,WACtB,GAAI5H,GAAO9F,KAAKwO,KAChB,IAAI1I,EAKF,MAJA9F,MAAKwO,MAAQ1I,EAAKyI,OACVvO,KAAKqF,SACXrF,KAAKsO,SAAOG,IAEP3I,EAAKuI,MAIhBD,EAAMjO,UAAUuO,MAAQ,SAAUC,EAAOC,GACvCD,MAAyB,KAAVA,EAAwB,EAAIA,EAC3CC,MAAqB,KAARA,EAAsBC,IAAWD,CAK9C,KAAK,GAHDE,MAEAC,EAAI,EACCjJ,EAAO9F,KAAKwO,MAAO1I,OACpB8I,EAAM,GADoB9I,EAAOA,EAAKyI,OAG/BQ,EAAIJ,GACfG,EAAOf,KAAKjI,EAAKuI,KAGrB,OAAOS,IAGT/S,EAAOoS,QAAUC,GR8xBXY,IACA,SAAUjT,EAAQC,EAAqBC,GAE7C,YS10BA,SAASgT,GAAiBzD,GACxB,GAAkC,iBAAvB0D,GAAkC,CAC3C,GAAMC,GAAe3D,EAAM4D,OAAOC,wBAC5BC,EAAe9D,EAAM+D,kBAC3BL,GAAqBC,EAAa9E,SAAWiF,EAAajF,QACxD8E,EAAaK,MAAQF,EAAaE,KAClCL,EAAaM,QAAUH,EAAaG,OACpCN,EAAaO,SAAWJ,EAAaI,QACrCP,EAAaQ,OAASL,EAAaK,MACnCR,EAAaS,QAAUN,EAAaM,MAExC,MAAOV,GAAqB1D,EAAM4D,OAAOC,wBAA0B7D,EAAM+D,mBAb3E,GAAIL,SAgBJlT,GAAA,KTg1BM6T,IACA,SAAU9T,EAAQC,EAAqBC,GAE7C,YACqB,IAAIuO,GAAqEvO,EAAoB,GACzFwO,EAA6ExO,EAAoBG,EAAEoO,GUl2BtHsF,EV42B4B,WAChC,QAASA,KACPrF,IAA6EzK,KAAM8P,GAEnF9P,KU92BF+P,aV+2BE/P,KU92BFgQ,mBV+2BEhQ,KU92BFiQ,SAAW,KVg6BX,MA/CAH,GAA4B3P,UU/2B5B2H,QV+2BgD,SU/2BvCoI,GAAS,GAAAhL,GAAAlF,KACVmQ,EAAiB,SAACC,GACtBA,EAAQC,QAAQ,SAAA7E,GACd,GAAM5N,GAAK4N,EAAM4D,OAAOkB,aAAa,UACjCpL,GAAK6K,UAAUnS,IACjBsH,EAAK6K,UAAUnS,GAAI4N,KAKzBxL,MAAKiQ,SAAW,GAAIM,sBAAqBJ,EAAgBD,GACzDlQ,KAAKgQ,gBAAgBK,QAAQ,SAAAvT,GAA4B,GAAzBc,GAAyBd,EAAA,GAArBgJ,EAAqBhJ,EAAA,GAAf0T,EAAe1T,EAAA,EACvDoI,GAAKqH,QAAQ3O,EAAIkI,EAAM0K,KAEzBxQ,KAAKgQ,gBAAkB,MVw3BzBF,EAA4B3P,UUr3B5BoM,QVq3BgD,SUr3BvC3O,EAAIkI,EAAM0K,GACZxQ,KAAKiQ,UAGRjQ,KAAK+P,UAAUnS,GAAM4S,EACrBxQ,KAAKiQ,SAAS1D,QAAQzG,IAHtB9F,KAAKgQ,gBAAgBjC,MAAOnQ,EAAIkI,EAAM0K,KV43B1CV,EAA4B3P,UUr3B5BsM,UVq3BkD,SUr3BvC7O,EAAIkI,GACT9F,KAAKiQ,iBACAjQ,MAAK+P,UAAUnS,GACtBoC,KAAKiQ,SAASxD,UAAU3G,KVy3B5BgK,EAA4B3P,UUr3B5B8H,WVq3BmD,WUp3B7CjI,KAAKiQ,WACPjQ,KAAK+P,aACL/P,KAAKiQ,SAAShI,aACdjI,KAAKiQ,SAAW,OVy3BbH,IUn3BT9T,GAAA,KV03BMyU,IACA,SAAU1U,EAAQC,EAAqBC,GAE7C,YAC+BA,GAAoB+C,EAAEhD,EAAqB,IAAK,WAAa,MAAO0U,IAC9E,IA6BjBxR,GAAQgF,EA7BayM,EAA8D1U,EAAoB,IAClF2U,EAAsE3U,EAAoBG,EAAEuU,GAC5FE,EAA0D5U,EAAoB,GAC9E6U,EAAkE7U,EAAoBG,EAAEyU,GACxFE,EAA8E9U,EAAoB,IAClG+U,EAAsF/U,EAAoBG,EAAE2U,GAC5GE,EAAqEhV,EAAoB,GACzFiV,EAA6EjV,EAAoBG,EAAE6U,GACnGE,EAAgFlV,EAAoB,GACpGmV,EAAwFnV,EAAoBG,EAAE+U,GAC9GE,EAA+DpV,EAAoB,GACnFqV,EAAuErV,EAAoBG,EAAEiV,GAC7FE,EAAsCtV,EAAoB,GAC1DuV,EAA8CvV,EAAoBG,EAAEmV,GACpEE,EAA0DxV,EAAoB,IAC9EyV,EAAkEzV,EAAoBG,EAAEqV,GACxFE,EAA2C1V,EAAoB,GAC/D2V,EAAmD3V,EAAoBG,EAAEuV,GACzEE,EAA6D5V,EAAoB,KACjF6V,EAAgE7V,EAAoB,IACpF8V,EAAwE9V,EAAoBG,EAAE0V,GAC9FE,EAAkD/V,EAAoB,KWr8B1EyU,GXs9BHxM,EAAShF,EAAS,SAAU+S,GAG5C,QAASvB,KACP,GAAIvR,GAAO+F,EAAOC,CAElB+L,KAA6ElR,KAAM0Q,EAEnF,KAAK,GAAItL,GAAOlF,UAAUmF,OAAQC,EAAOC,MAAMH,GAAOI,EAAO,EAAGA,EAAOJ,EAAMI,IAC3EF,EAAKE,GAAQtF,UAAUsF,EAGzB,OAAerG,GAAS+F,EAAQkM,IAAwFpR,KAAMiS,EAAsBxM,KAAKxF,MAAMgS,GAAwBjS,MAAM0F,OAAOJ,KAAiBJ,EW98BvNgN,aAAe,SAAAtU,GACb,GAAMuU,GAAejN,EAAK5E,MAAMlD,UAAUgV,QAAQxU,GAAM,CACxDsH,GAAKmN,aAAaF,IX+8BfjN,EW58BLoN,eAAiB,SAAA1U,GACf,GAAMuU,GAAejN,EAAK5E,MAAMlD,UAAUgV,QAAQxU,GAAM,CACxDsH,GAAKmN,aAAaF,IX68BfjN,EWl8BL2B,OAAS,SAAAC,GACP5B,EAAKY,KAAOgB,GX27BL3B,EAQJhG,EAAQiS,IAAwFlM,EAAOC,GAoC5G,MAvDAmM,KAAuEZ,EAAYuB,GAsBnFvB,EAAWvQ,UW/8BXkS,aX+8BoC,SW/8BtB9O,GACZ,GAAMgP,GAAUvS,KAAK8F,KAAKA,KAAK0M,cAAf,wBAAoDjP,EAAQ,GAA5D,eAEZgP,IACFA,EAAQE,SXm9BZ/B,EAAWvQ,UW38BXC,OX28B8B,WW38BpB,GAAAoI,GAAAxI,KAAAyI,EACwBzI,KAAKM,MAA7BlD,EADAqL,EACArL,UAAcsV,EADd1B,IAAAvI,GAAA,cAEApK,EAAcqU,EAAdrU,UAEFsU,EAAqBtU,GAAajB,EAAUwV,KAAO,EACvDxV,EAAUkM,IAAI,SAACuJ,GAAD,MAAA/B,KACXe,EAAA,GADWjU,GAGNiV,EAHMC,SAIAtK,EAAK0J,aAJLa,WAKEvK,EAAK8J,gBAHZO,KAMP,IAEJ,OACErB,GAAA3Q,EAAAoI,cAAC+I,EAAA,EAADpB,OAAoB8B,GAAOxJ,IAAKlJ,KAAK6G,SAClC8L,IXm9BAjC,GW9gC+BqB,EAAAlR,GX+gCoC3B,EW7gCnE8T,WACLtK,UAAWkJ,EAAA/Q,EAAUoS,OAAOC,WAC5B9V,UAAWsU,EAAA7Q,EAAmBsS,KAAKD,WACnCvU,iBAAkBiT,EAAA/Q,EAAUuS,KAC5BvU,cAAe+S,EAAA/Q,EAAUuS,KACzBtU,SAAU8S,EAAA/Q,EAAUuS,KACpBzK,YAAaiJ,EAAA/Q,EAAUwS,KACvBzK,mBAAoBgJ,EAAA/Q,EAAUuS,KAC9B/U,UAAWuT,EAAA/Q,EAAUwS,KACrB/U,QAASsT,EAAA/Q,EAAUwS,KACnBxK,QAAS+I,EAAA/Q,EAAUiF,KACnBgD,aAAc8I,EAAA/Q,EAAUiF,MX8gCzB5G,EW3gCM6B,cACL4H,aAAa,GX4gCdzE,IAKGoP,IACA,SAAUvX,EAAQC,EAAqBC,GAE7C,YACAW,QAAO2W,eAAevX,EAAqB,cAAgBwX,OAAO,IACnCvX,EAAoB+C,EAAEhD,EAAqB,UAAW,WAAa,MAAOyX,IACpF,IAwBjBC,GAAMxU,EAxBeE,EAA0DnD,EAAoB,GAC9EoD,EAAkEpD,EAAoBG,EAAEgD,GACxFE,EAAqErD,EAAoB,GACzFsD,EAA6EtD,EAAoBG,EAAEkD,GACnGE,EAAgFvD,EAAoB,GACpGwD,EAAwFxD,EAAoBG,EAAEoD,GAC9GE,EAA+DzD,EAAoB,GACnF0D,EAAuE1D,EAAoBG,EAAEsD,GAC7FE,EAAsC3D,EAAoB,GAC1D4D,EAA8C5D,EAAoBG,EAAEwD,GACpE+T,EAA4C1X,EAAoB,GAChE2X,EAAmD3X,EAAoB,IACvE4X,EAAqE5X,EAAoB,KACzF6X,EAAmD7X,EAAoB,IACvE8X,EAA0D9X,EAAoB,IAC9E+X,EAAkD/X,EAAoB,KACtE0F,EAA4C1F,EAAoB,GAChEgY,EAAuEhY,EAAoB,KAC3FiY,EAAkDjY,EAAoB,IYrjCzF4F,EAAWjF,OAAA+E,EAAA,IACfwS,OAAAvW,GAAA,cAAAgD,eAAA,UAGIwT,EAAkB,SAAAvX,GAAA,OACtBwX,UAAWxX,EAAMG,OAAO,YAAa,OAAQ,WAAa,IAKvCyW,GZ4kCDC,EY9kCnB9W,OAAA+W,EAAA,SAAQS,IZ8kCsGlV,EY7kC9GtC,OAAA+E,EAAA,GZ6kC+LzC,EAAS,SAAUa,GAGjN,QAAS0T,KACP,GAAItU,GAAO+F,EAAOC,CAElB5F,KAA6ES,KAAMyT,EAEnF,KAAK,GAAIrO,GAAOlF,UAAUmF,OAAQC,EAAOC,MAAMH,GAAOI,EAAO,EAAGA,EAAOJ,EAAMI,IAC3EF,EAAKE,GAAQtF,UAAUsF,EAGzB,OAAerG,GAAS+F,EAAQzF,IAAwFO,KAAMD,EAAqB0F,KAAKxF,MAAMF,GAAuBC,MAAM0F,OAAOJ,KAAiBJ,EY9kCrNoP,UAAY,WAAM,GAAAxI,GACe5G,EAAK5E,MAA5BiU,EADQzI,EACRyI,SAAU/V,EADFsN,EACEtN,QAGhBA,GADE+V,EACO3X,OAAAoX,EAAA,GAAaO,GAEb3X,OAAAoX,EAAA,GAAU,aZmlClB9O,EY/kCLsP,WAAa,SAACC,GAAQ,GAAAC,GACWxP,EAAK5E,MAA5BiU,EADYG,EACZH,UACR/V,EAFoBkW,EACFlW,UACT5B,OAAAoX,EAAA,GAAWO,EAAUE,KZmlC3BvP,EYhlCLyP,kBAAoB,WAClBzP,EAAK0P,OAAO5O,aZilCTd,EY9kCL2B,OAAS,SAAAC,GACP5B,EAAK0P,OAAS9N,GZ+kCX5B,EY5kCL6B,eAAiB,WACf7B,EAAK5E,MAAM9B,SAAS5B,OAAAgX,EAAA,OZsjCbzO,EAuBJhG,EAAQM,IAAwFyF,EAAOC,GA4C5G,MA9EAxF,KAAuE8T,EAAc1T,GAqCrF0T,EAAatT,UY7kCbC,OZ6kCgC,WY7kCtB,GAAAqI,GAC2CzI,KAAKM,MAAhD8B,EADAqG,EACArG,KAAMiS,EADN5L,EACM4L,UAAWE,EADjB9L,EACiB8L,SAAUM,EAD3BpM,EAC2BoM,YAC7BC,IAAWP,CAEjB,OACE1U,GAAAgB,EAAAoI,cAAC6K,EAAA,GAAO5K,IAAKlJ,KAAK6G,QAAlBxH,IACG0U,EAAA,GADHgB,KAES,OAFTC,OAGYX,EAHZF,MAIW/R,EAAKY,cAAcnB,EAASsS,OAJvCxR,MAKW3C,KAAKsU,UALhBW,OAMYjV,KAAKwU,WANjB7T,QAOaX,KAAK2U,kBAPlBG,OAQYA,EARZD,YASiBA,OATjB,GAAAxV,IAWK4U,EAAA,OAXL5U,IAcGwU,EAAA,GAdHlL,aAekBmM,EAflBpM,UAAA,iBAgBgC6L,EAhBhC7V,SAiBcsB,KAAK+G,eAjBnB3I,WAkBe,OAlBf0K,aAAAzJ,IAmBmBsC,EAAA,GAnBnB/D,GAmBuC,oBAnBvCgD,eAmB0E,iGAnB1E+C,QAmBqLuR,OAAA7V,IAAS6U,EAAA,GAATiB,GAAiB,yBAAjB,GAAA9V,IAAsCsC,EAAA,GAAtC/D,GAA0D,oCAA1DgD,eAA6G,gCZ8lC/R6S,GY3pCiC5T,EAAAgB,EAAMC,iBZ4pCmB5B,IAAWA,GAKxEkW,IACA,SAAUrZ,EAAQoS,EAASlS,GAEjC,Ya1pCA,SAASoZ,GAAuBC,GAAO,MAAOA,IAAOA,EAAIC,WAAaD,GAAQE,QAASF,GAEvF,QAASG,GAAyBH,EAAKI,GAAQ,GAAItG,KAAa,KAAK,GAAIL,KAAKuG,GAAWI,EAAKtD,QAAQrD,IAAM,GAAkBnS,OAAOuD,UAAUwV,eAAelQ,KAAK6P,EAAKvG,KAAcK,EAAOL,GAAKuG,EAAIvG,GAAM,OAAOK,GAEnN,QAASwG,GAAgBC,EAAUC,GAAe,KAAMD,YAAoBC,IAAgB,KAAM,IAAIC,WAAU,qCAEhH,QAASC,GAA2BC,EAAMxQ,GAAQ,IAAKwQ,EAAQ,KAAM,IAAIC,gBAAe,4DAAgE,QAAOzQ,GAAyB,gBAATA,IAAqC,kBAATA,GAA8BwQ,EAAPxQ,EAElO,QAAS0Q,GAAUC,EAAUC,GAAc,GAA0B,kBAAfA,IAA4C,OAAfA,EAAuB,KAAM,IAAIN,WAAU,iEAAoEM,GAAeD,GAASjW,UAAYvD,OAAO0Z,OAAOD,GAAcA,EAAWlW,WAAaoW,aAAe/C,MAAO4C,EAAUI,YAAY,EAAOC,UAAU,EAAMC,cAAc,KAAeL,IAAYzZ,OAAO+Z,eAAiB/Z,OAAO+Z,eAAeP,EAAUC,GAAcD,EAASQ,UAAYP,GAtCjezZ,OAAO2W,eAAepF,EAAS,cAC7BqF,OAAO,GAGT,IAAIqD,GAAWja,OAAOka,QAAU,SAAU1H,GAAU,IAAK,GAAIL,GAAI,EAAGA,EAAI7O,UAAUmF,OAAQ0J,IAAK,CAAE,GAAIgI,GAAS7W,UAAU6O,EAAI,KAAK,GAAIzG,KAAOyO,GAAcna,OAAOuD,UAAUwV,eAAelQ,KAAKsR,EAAQzO,KAAQ8G,EAAO9G,GAAOyO,EAAOzO,IAAY,MAAO8G,IAEnP4H,EAAe,WAAc,QAASC,GAAiB7H,EAAQ9O,GAAS,IAAK,GAAIyO,GAAI,EAAGA,EAAIzO,EAAM+E,OAAQ0J,IAAK,CAAE,GAAImI,GAAa5W,EAAMyO,EAAImI,GAAWV,WAAaU,EAAWV,aAAc,EAAOU,EAAWR,cAAe,EAAU,SAAWQ,KAAYA,EAAWT,UAAW,GAAM7Z,OAAO2W,eAAenE,EAAQ8H,EAAW5O,IAAK4O,IAAiB,MAAO,UAAUpB,EAAaqB,EAAYC,GAAiJ,MAA9HD,IAAYF,EAAiBnB,EAAY3V,UAAWgX,GAAiBC,GAAaH,EAAiBnB,EAAasB,GAAqBtB,MAE5hBuB,EAASpb,EAAQ,GAEjBqb,EAAUjC,EAAuBgC,GAEjCE,EAActb,EAAQ,IAEtBub,EAAenC,EAAuBkC,GAEtCE,EAAaxb,EAAQ,GAErByb,EAAcrC,EAAuBoC,GAErCE,EAAS1b,EAAQ,KAEjB2b,EAAUvC,EAAuBsC,GAEjCE,EAAK5b,EAAQ,KAEb6b,EAAMzC,EAAuBwC,GAE7BE,EAAQ9b,EAAQ,KAYhB+b,EAAS,SAAU/S,GAGrB,QAAS+S,GAAO1X,GACdsV,EAAgB5V,KAAMgY,EAEtB,IAAI9S,GAAQ8Q,EAA2BhW,MAAOgY,EAAOpB,WAAaha,OAAOqb,eAAeD,IAASvS,KAAKzF,KAAMM,GAa5G,OAXA4E,GAAMgT,YAAchT,EAAMgT,YAAYC,KAAKjT,GAC3CA,EAAMkT,iBAAmBlT,EAAMkT,iBAAiBD,KAAKjT,GACrDA,EAAMmT,gBAAkBnT,EAAMmT,gBAAgBF,KAAKjT,GACnDA,EAAMoT,eAAiBpT,EAAMoT,eAAeH,KAAKjT,GACjDA,EAAMqT,YAAcrT,EAAMqT,YAAYJ,KAAKjT,GAC3CA,EAAMsT,WAAatT,EAAMsT,WAAWL,KAAKjT,GACzCA,EAAMuT,qBAAuBnY,EAAMoY,UAAWpY,EAAMqY,gBACpDzT,EAAMrI,OACJ6b,WAAYpY,EAAMoY,UAAWpY,EAAMqY,gBACnCC,UAAU,GAEL1T,EAmKT,MArLAiR,GAAU6B,EAAQ/S,GAqBlB+R,EAAagB,IACX1P,IAAK,4BACLkL,MAAO,SAAmCtH,GACpC,WAAaA,IACflM,KAAK2G,UAAW+R,UAAWxM,EAAUwM,aAIzCpQ,IAAK,cACLkL,MAAO,SAAqBqF,GAC1B,GAAIC,GAAW9Y,KAAK+Y,KACpB,IAAIF,EAAMzJ,SAAW0J,IAAa9Y,KAAKgZ,MAKrC,MAJAhZ,MAAKyY,kBAAoBK,EAASJ,QAClCG,EAAM7R,iBACN8R,EAASrG,YACTqG,GAASG,OAIX,IAAIP,GAAU1Y,KAAKM,MAAMqV,eAAe,WAAa3V,KAAKM,MAAMoY,QAAUI,EAASJ,OAEnF1Y,MAAK2G,UAAW+R,QAASA,OAG3BpQ,IAAK,mBACLkL,MAAO,SAA0BqF,GAC/B7Y,KAAKkZ,QAAS,EAAInB,EAAMoB,cAAcN,GAAOO,EAC7CpZ,KAAKqZ,WAAY,KAGnB/Q,IAAK,kBACLkL,MAAO,SAAyBqF,GAC9B,GAAK7Y,KAAKqZ,YACVrZ,KAAKgZ,OAAQ,EAEThZ,KAAKkZ,QAAQ,CACf,GAAII,IAAW,EAAIvB,EAAMoB,cAAcN,GAAOO,CAC1CpZ,MAAKnD,MAAM6b,SAAWY,EAAW,GAAKtZ,KAAKkZ,QAC7ClZ,KAAK2G,UAAW+R,SAAS,IACzB1Y,KAAKkZ,OAASI,EACdtZ,KAAKqZ,WAAY,GACRC,EAAW,GAAKtZ,KAAKkZ,SAC9BlZ,KAAK2G,UAAW+R,SAAS,IACzB1Y,KAAKkZ,OAASI,EACdtZ,KAAKqZ,UAAYC,EAAWtZ,KAAKkZ,OAAS,OAKhD5Q,IAAK,iBACLkL,MAAO,SAAwBqF,GAC7B,GAAK7Y,KAAKgZ,MAAV,CACA,GAAIF,GAAW9Y,KAAK+Y,KAGpB,IAFAF,EAAM7R,iBAEFhH,KAAKkZ,OAAQ,CACf,GAAIK,IAAO,EAAIxB,EAAMoB,cAAcN,GAAOO,GACX,IAA3BpZ,KAAKyY,mBAA8BzY,KAAKkZ,OAAS,EAAIK,EACnDvZ,KAAKyY,oBAAsBzY,KAAKnD,MAAM6b,UACxC1Y,KAAK2G,UAAW+R,SAAS,IACzB1Y,KAAKyY,kBAAoBzY,KAAKnD,MAAM6b,QACpCI,EAASG,SAEFjZ,KAAKkZ,OAAS,EAAIK,GACvBvZ,KAAKyY,oBAAsBzY,KAAKnD,MAAM6b,UACxC1Y,KAAK2G,UAAW+R,SAAS,IACzB1Y,KAAKyY,kBAAoBzY,KAAKnD,MAAM6b,QACpCI,EAASG,SAIbjZ,KAAKqZ,WAAY,EACjBrZ,KAAKkZ,OAAS,KACdlZ,KAAKgZ,OAAQ,OAIjB1Q,IAAK,cACLkL,MAAO,SAAqBqF,GAC1B,GAAIW,GAAUxZ,KAAKM,MAAMkZ,OAGrBA,IACFA,EAAQX,GAGV7Y,KAAK2G,UAAWiS,UAAU,OAG5BtQ,IAAK,aACLkL,MAAO,SAAoBqF,GACzB,GAAIY,GAASzZ,KAAKM,MAAMmZ,MAGpBA,IACFA,EAAOZ,GAGT7Y,KAAK2G,UAAWiS,UAAU,OAG5BtQ,IAAK,UACLkL,MAAO,SAAiBzW,GACtB,GAAI2c,GAAQ1Z,KAAKM,MAAMoZ,KAEvB,OAAKA,OAGkBjL,KAAhBiL,EAAM3c,GAAsBib,EAAOjX,aAAa2Y,MAAM3c,GAAQ2c,EAAM3c,GAFlE,QAKXuL,IAAK,SACLkL,MAAO,WACL,GAAIhL,GAASxI,KAETyI,EAASzI,KAAKM,MACdC,EAAYkI,EAAOlI,UAEnBoZ,GADSlR,EAAOiR,MACHjE,EAAyBhN,GAAS,YAAa,WAE5DmR,GAAU,EAAIpC,EAAahC,SAAS,gBACtCqE,wBAAyB7Z,KAAKnD,MAAM6b,QACpCoB,sBAAuB9Z,KAAKnD,MAAM+b,SAClCmB,yBAA0B/Z,KAAKM,MAAME,UACpCD,EAEH,OAAO+W,GAAQ9B,QAAQvM,cACrB,OACE1I,UAAWqZ,EACXjZ,QAASX,KAAKkY,YACd8B,aAAcha,KAAKoY,iBACnB6B,YAAaja,KAAKqY,gBAClB6B,WAAYla,KAAKsY,gBACnBhB,EAAQ9B,QAAQvM,cACd,OACE1I,UAAW,sBACb+W,EAAQ9B,QAAQvM,cACd,OACE1I,UAAW,4BACbP,KAAKma,QAAQ,YAEf7C,EAAQ9B,QAAQvM,cACd,OACE1I,UAAW,wBACbP,KAAKma,QAAQ,eAGjB7C,EAAQ9B,QAAQvM,cAAc,OAAS1I,UAAW,uBAClD+W,EAAQ9B,QAAQvM,cAAc,QAAS4N,KAAa8C,GAClDzQ,IAAK,SAAapM,GAChB0L,EAAOuQ,MAAQjc,GAEjB0c,QAASxZ,KAAKuY,YACdkB,OAAQzZ,KAAKwY,WACbjY,UAAW,iCACXxD,KAAM,mBAKPib,GACPX,EAAOvW,cAETqN,GAAQqH,QAAUwC,EAGlBA,EAAOoC,YAAc,SAErBpC,EAAOjX,cACL2Y,OACEhB,QAASpB,EAAQ9B,QAAQvM,cAAc2O,EAAQpC,QAAS,MACxD6E,UAAW/C,EAAQ9B,QAAQvM,cAAc6O,EAAItC,QAAS,QAI1DwC,EAAOhF,WACL0F,QAAShB,EAAYlC,QAAQnC,KAC7B7S,SAAUkX,EAAYlC,QAAQnC,KAC9BsF,eAAgBjB,EAAYlC,QAAQnC,KACpCiH,SAAU5C,EAAYlC,QAAQpC,KAC9BoG,QAAS9B,EAAYlC,QAAQpC,KAC7BqG,OAAQ/B,EAAYlC,QAAQpC,KAC5B7S,UAAWmX,EAAYlC,QAAQvC,OAC/BrP,KAAM8T,EAAYlC,QAAQvC,OAC1BO,MAAOkE,EAAYlC,QAAQvC,OAC3BrV,GAAI8Z,EAAYlC,QAAQvC,OACxBsH,kBAAmB7C,EAAYlC,QAAQvC,OACvCuH,aAAc9C,EAAYlC,QAAQvC,OAClCyG,MAAOhC,EAAYlC,QAAQiF,WAAW/C,EAAYlC,QAAQnC,KAAMqE,EAAYlC,QAAQkF,OAClFhC,QAAShB,EAAYlC,QAAQ1P,KAC7BuU,UAAW3C,EAAYlC,QAAQ1P,Wb6sC7B6U,IACA,SAAU5e,EAAQoS,EAASlS,GAEjC,Yc58CAW,QAAO2W,eAAepF,EAAS,cAC7BqF,OAAO,GAGT,IAAI6D,GAASpb,EAAQ,GAEjBqb,EAEJ,SAAgChC,GAAO,MAAOA,IAAOA,EAAIC,WAAaD,GAAQE,QAASF,IAFlD+B,EAIrClJ,GAAQqH,QAAU,WAChB,MAAO8B,GAAQ9B,QAAQvM,cACrB,OACEwG,MAAO,KAAMpF,OAAQ,KAAMuQ,QAAS,aACtCtD,EAAQ9B,QAAQvM,cACd,QACA,KACA,gBAEFqO,EAAQ9B,QAAQvM,cAAc,QAAUjK,EAAG,yEAA0E6b,KAAM,OAAQC,SAAU,ed88C3IC,IACA,SAAUhf,EAAQoS,EAASlS,GAEjC,Yep+CAW,QAAO2W,eAAepF,EAAS,cAC7BqF,OAAO,GAGT,IAAI6D,GAASpb,EAAQ,GAEjBqb,EAEJ,SAAgChC,GAAO,MAAOA,IAAOA,EAAIC,WAAaD,GAAQE,QAASF,IAFlD+B,EAIrClJ,GAAQqH,QAAU,WAChB,MAAO8B,GAAQ9B,QAAQvM,cACrB,OACEwG,MAAO,KAAMpF,OAAQ,KAAMuQ,QAAS,aACtCtD,EAAQ9B,QAAQvM,cACd,QACA,KACA,YAEFqO,EAAQ9B,QAAQvM,cAAc,QAAUjK,EAAG,yHAA0H6b,KAAM,OAAQC,SAAU,efs+C3LE,IACA,SAAUjf,EAAQoS,EAASlS,GAEjC,YgBp/CA,SAASkd,GAAaN,GAGpB,GAAIA,EAAO,CACT,GAAIoC,GAAiBpC,EAAMoC,cAC3B,IAAIA,GAAkBA,EAAe5V,OAAS,EAAG,CAC/C,GAAI6V,GAAQD,EAAe,EAC3B,QAAS7B,EAAG8B,EAAMC,QAASC,EAAGF,EAAMG,SAEtC,GAAIC,GAAQzC,EAAMyC,KAClB,QAAc7M,KAAV6M,EACF,OAASlC,EAAGkC,EAAOF,EAAGvC,EAAM0C,OAGhC,OAASnC,EAAG,EAAGgC,EAAG,GAtBpBxe,OAAO2W,eAAepF,EAAS,cAC7BqF,OAAO,IAETrF,EAAQgL,aAAeA,GhBuhDjBqC,IACA,SAAUzf,EAAQC,EAAqBC,GAE7C,YAC+BA,GAAoB+C,EAAEhD,EAAqB,IAAK,WAAa,MAAOyf,IAC9E,IAAIrc,GAA0DnD,EAAoB,GAC9EoD,EAAkEpD,EAAoBG,EAAEgD,GACxFE,EAAqErD,EAAoB,GACzFsD,EAA6EtD,EAAoBG,EAAEkD,GACnGE,EAAgFvD,EAAoB,GACpGwD,EAAwFxD,EAAoBG,EAAEoD,GAC9GE,EAA+DzD,EAAoB,GACnF0D,EAAuE1D,EAAoBG,EAAEsD,GAC7FE,EAAsC3D,EAAoB,GAC1D4D,EAA8C5D,EAAoBG,EAAEwD,GiBtiDxE6b,EjB6iDH,SAAU1b,GAG1B,QAAS0b,KACP,GAAItc,GAAO+F,EAAOC,CAElB5F,KAA6ES,KAAMyb,EAEnF,KAAK,GAAIrW,GAAOlF,UAAUmF,OAAQC,EAAOC,MAAMH,GAAOI,EAAO,EAAGA,EAAOJ,EAAMI,IAC3EF,EAAKE,GAAQtF,UAAUsF,EAGzB,OAAerG,GAAS+F,EAAQzF,IAAwFO,KAAMD,EAAqB0F,KAAKxF,MAAMF,GAAuBC,MAAM0F,OAAOJ,KAAiBJ,EiBhjDrNwW,aAAe,SAAChe,GACdwH,EAAK5E,MAAMga,SAASpV,EAAK5E,MAAMqb,WAAYje,EAAE0R,OAAOoE,QjB+iD7CrO,EAEJhG,EAAQM,IAAwFyF,EAAOC,GAoB5G,MAjCAxF,KAAuE8b,EAAa1b,GAgBpF0b,EAAYtb,UiBjjDZC,OjBijD+B,WiBjjDrB,GAAAqI,GACgCzI,KAAKM,MAArCsb,EADAnT,EACAmT,SAAUD,EADVlT,EACUkT,WAAYE,EADtBpT,EACsBoT,KAE9B,OAAAxc,KAAA,kBAAAA,IAAA,QAAAoB,OAEmBqb,QAAS,aAF5B,GAEuCD,GAFvCxc,IAAA,SAAAkB,UAIgB,eAJhBiT,MAKaoI,EAAS5e,MAAM2e,GAL5BrB,SAMgBta,KAAK0b,aANrBK,YAOmBF,MjBwjDdJ,GiB/kDgC5b,EAAAgB,EAAMC,gBjBslDzCkb,IACA,SAAUjgB,EAAQC,EAAqBC,GAE7C,YAC+BA,GAAoB+C,EAAEhD,EAAqB,IAAK,WAAa,MAAOigB,IAC9E,IAAI7c,GAA0DnD,EAAoB,GAC9EoD,EAAkEpD,EAAoBG,EAAEgD,GACxFE,EAAqErD,EAAoB,GACzFsD,EAA6EtD,EAAoBG,EAAEkD,GACnGE,EAAgFvD,EAAoB,GACpGwD,EAAwFxD,EAAoBG,EAAEoD,GAC9GE,EAA+DzD,EAAoB,GACnF0D,EAAuE1D,EAAoBG,EAAEsD,GAC7FE,EAAsC3D,EAAoB,GAC1D4D,EAA8C5D,EAAoBG,EAAEwD,GACpEsc,EAA6CjgB,EAAoB,KACjEkgB,EAAqDlgB,EAAoBG,EAAE8f,GkBrmD/ED,ElB8mDD,SAAUlc,GAG5B,QAASkc,KACP,GAAI9c,GAAO+F,EAAOC,CAElB5F,KAA6ES,KAAMic,EAEnF,KAAK,GAAI7W,GAAOlF,UAAUmF,OAAQC,EAAOC,MAAMH,GAAOI,EAAO,EAAGA,EAAOJ,EAAMI,IAC3EF,EAAKE,GAAQtF,UAAUsF,EAGzB,OAAerG,GAAS+F,EAAQzF,IAAwFO,KAAMD,EAAqB0F,KAAKxF,MAAMF,GAAuBC,MAAM0F,OAAOJ,KAAiBJ,EkB/mDrNoV,SAAW,SAAAxd,GAAgB,GAAbsS,GAAatS,EAAbsS,MACZlK,GAAK5E,MAAMga,SAASpV,EAAK5E,MAAMqb,WAAYvM,EAAOsJ,UlB8mD3CvT,EAIJhG,EAAQM,IAAwFyF,EAAOC,GA4B5G,MA3CAxF,KAAuEsc,EAAelc,GAkBtFkc,EAAc9b,UkBlnDdC,OlBknDiC,WkBlnDvB,GAAAqI,GAC8CzI,KAAKM,MAAnD8b,EADA3T,EACA2T,OAAQR,EADRnT,EACQmT,SAAUD,EADlBlT,EACkBkT,WAAYE,EAD9BpT,EAC8BoT,MAAOQ,EADrC5T,EACqC4T,KACvCze,GAAM,iBAAkBwe,GAAnB1W,OAA8BiW,GAAYhe,OAAO2e,SAASC,KAAK,IAE1E,OAAAld,KAAA,OAAAkB,UACiB,sBADjB,GAAAlB,IAEK8c,EAAAtb,GAFLjD,GAEgBA,EAFhB8a,QAE6BkD,EAAS5e,MAAM2e,GAF5CrB,SAEmEta,KAAKsa,SAFxEkC,UAE6Fxc,KAAKwc,YAFlGnd,IAAA,SAAAod,QAGoB7e,EAHpB2C,UAGkC,6BAHlC,GAG2Dsb,GACtDQ,GAAAhd,IAAAgd,QAAA9b,UAAwB,2BAAxB,GAA+C8b,KlBmoD/CJ,GkB1pDkCpc,EAAAgB,EAAMC,gBlBiqD3C4b,IACA,SAAU3gB,EAAQC,EAAqBC,GAE7C,YACqB,IAAI+N,GAA4C/N,EAAoB,GAChE0gB,EAA4D1gB,EAAoB,KAChF2gB,EAAkD3gB,EAAoB,ImBxqDzFmY,EAAkB,SAAAvX,GAAA,OACtB+e,SAAU/e,EAAMG,OAAO,WAAY,WAG/BuB,EAAqB,SAAAC,GAAA,OAEzB8b,SAFsC,SAE5BhS,EAAKoQ,GACbla,EAAS5B,OAAAggB,EAAA,IAAe,QAAflX,OAA0B4C,GAAMoQ,KAG3CmE,OANsC,WAOpCre,EAAS5B,OAAAggB,EAAA,QAKb5gB,GAAA,EAAeY,OAAAoN,EAAA,SAAQoK,EAAiB7V,GAAoBoe,EAAA,InBkrDtDG,IACA,SAAU/gB,EAAQC,EAAqBC,GAE7C,YAC+BA,GAAoB+C,EAAEhD,EAAqB,IAAK,WAAa,MAAO+gB,IAC9E,IAkBjB7d,GAlBqBE,EAA0DnD,EAAoB,GAC9EoD,EAAkEpD,EAAoBG,EAAEgD,GACxFE,EAAqErD,EAAoB,GACzFsD,EAA6EtD,EAAoBG,EAAEkD,GACnGE,EAAgFvD,EAAoB,GACpGwD,EAAwFxD,EAAoBG,EAAEoD,GAC9GE,EAA+DzD,EAAoB,GACnF0D,EAAuE1D,EAAoBG,EAAEsD,GAC7FE,EAAsC3D,EAAoB,GAC1D4D,EAA8C5D,EAAoBG,EAAEwD,GACpEE,EAA2C7D,EAAoB,GAC/D+gB,EAAyE/gB,EAAoB,KAC7FghB,EAAyDhhB,EAAoB,KoBhtDhG4F,EAAWjF,OAAAkD,EAAA,IACfod,cAAAtf,GAAA,oCAAAgD,eAAA,qCACAgb,UAAAhe,GAAA,gBAAAgD,eAAA,qBAImBmc,EADpBngB,OAAAkD,EAAA,GpBouD2FZ,EAAS,SAAUa,GAG7G,QAASgd,KAGP,MAFAxd,KAA6ES,KAAM+c,GAE5Etd,IAAwFO,KAAMD,EAAqBE,MAAMD,KAAME,YAqDxI,MA1DAP,KAAuEod,EAAgBhd,GAQvFgd,EAAe5c,UoBpuDfC,OpBouDkC,WoBpuDxB,GAAAqI,GAC6BzI,KAAKM,MAAlCsb,EADAnT,EACAmT,SAAUtB,EADV7R,EACU6R,SAAUlY,EADpBqG,EACoBrG,IAE5B,OAAA/C,KAAA,gBAAAA,IAAA,QAAAkB,UAEoB,gCAFpB,GAAAlB,IAEgDS,EAAA,GAFhDlC,GAEoE,6BAFpEgD,eAEgH,WAFhHvB,IAAA,OAAAkB,UAImB,4BAJnB,GAAAlB,IAKO2d,EAAA,GALPZ,OAK4B,gBAL5BR,SAKsDA,EALtDD,YAK6E,QAAS,UALtFrB,SAK2GA,EAL3GuB,MAAAxc,IAK6HS,EAAA,GAL7HlC,GAKiJ,oCALjJgD,eAKoM,mBALpMvB,IAAA,OAAAkB,UAQmB,4BARnB,GAAAlB,IASO2d,EAAA,GATPZ,OAS4B,gBAT5BR,SASsDA,EATtDD,YAS6E,QAAS,SATtFrB,SAS0GA,EAT1GuB,MAAAxc,IAS4HS,EAAA,GAT5HlC,GASgJ,oCAThJgD,eASmM,oBATnMvB,IAAA,QAAAkB,UAYoB,gCAZpB,GAAAlB,IAYgDS,EAAA,GAZhDlC,GAYoE,gCAZpEgD,eAYmH,cAZnHvB,IAAA,OAAAkB,UAcmB,4BAdnB,GAAAlB,IAeO4d,EAAA,GAfPb,OAe0B,gBAf1BR,SAeoDA,EAfpDD,YAe2E,QAAS,QAfpFrB,SAeuGA,EAfvGuB,MAewHzZ,EAAKY,cAAcnB,EAASqb,mBpBowD/IH,GoB9xDmCld,EAAAgB,EAAMC,iBpB+xDiB5B","file":"features/home_timeline-c146f32b0118845677ee.js","sourcesContent":["webpackJsonp([9],{\n\n/***/ 158:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_lodash_debounce__ = __webpack_require__(42);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_lodash_debounce___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_lodash_debounce__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_react_redux__ = __webpack_require__(9);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__components_status_list__ = __webpack_require__(269);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__actions_timelines__ = __webpack_require__(16);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_immutable__ = __webpack_require__(8);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_immutable___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_immutable__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_reselect__ = __webpack_require__(96);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_reselect___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_reselect__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__initial_state__ = __webpack_require__(18);\n\n\n\n\n\n\n\n\n\nvar makeGetStatusIds = function makeGetStatusIds() {\n return Object(__WEBPACK_IMPORTED_MODULE_5_reselect__[\"createSelector\"])([function (state, _ref) {\n var type = _ref.type;\n return state.getIn(['settings', type], Object(__WEBPACK_IMPORTED_MODULE_4_immutable__[\"Map\"])());\n }, function (state, _ref2) {\n var type = _ref2.type;\n return state.getIn(['timelines', type, 'items'], Object(__WEBPACK_IMPORTED_MODULE_4_immutable__[\"List\"])());\n }, function (state) {\n return state.get('statuses');\n }], function (columnSettings, statusIds, statuses) {\n var rawRegex = columnSettings.getIn(['regex', 'body'], '').trim();\n var regex = null;\n\n try {\n regex = rawRegex && new RegExp(rawRegex, 'i');\n } catch (e) {\n // Bad regex, don't affect filters\n }\n\n return statusIds.filter(function (id) {\n var statusForId = statuses.get(id);\n var showStatus = true;\n\n if (columnSettings.getIn(['shows', 'reblog']) === false) {\n showStatus = showStatus && statusForId.get('reblog') === null;\n }\n\n if (columnSettings.getIn(['shows', 'reply']) === false) {\n showStatus = showStatus && (statusForId.get('in_reply_to_id') === null || statusForId.get('in_reply_to_account_id') === __WEBPACK_IMPORTED_MODULE_6__initial_state__[\"e\" /* me */]);\n }\n\n if (showStatus && regex && statusForId.get('account') !== __WEBPACK_IMPORTED_MODULE_6__initial_state__[\"e\" /* me */]) {\n var searchIndex = statusForId.get('reblog') ? statuses.getIn([statusForId.get('reblog'), 'search_index']) : statusForId.get('search_index');\n showStatus = !regex.test(searchIndex);\n }\n\n return showStatus;\n });\n });\n};\n\nvar makeMapStateToProps = function makeMapStateToProps() {\n var getStatusIds = makeGetStatusIds();\n\n var mapStateToProps = function mapStateToProps(state, _ref3) {\n var timelineId = _ref3.timelineId;\n return {\n statusIds: getStatusIds(state, { type: timelineId }),\n isLoading: state.getIn(['timelines', timelineId, 'isLoading'], true),\n hasMore: !!state.getIn(['timelines', timelineId, 'next'])\n };\n };\n\n return mapStateToProps;\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch, _ref4) {\n var timelineId = _ref4.timelineId,\n loadMore = _ref4.loadMore;\n return {\n\n onScrollToBottom: __WEBPACK_IMPORTED_MODULE_0_lodash_debounce___default()(function () {\n dispatch(Object(__WEBPACK_IMPORTED_MODULE_3__actions_timelines__[\"B\" /* scrollTopTimeline */])(timelineId, false));\n loadMore();\n }, 300, { leading: true }),\n\n onScrollToTop: __WEBPACK_IMPORTED_MODULE_0_lodash_debounce___default()(function () {\n dispatch(Object(__WEBPACK_IMPORTED_MODULE_3__actions_timelines__[\"B\" /* scrollTopTimeline */])(timelineId, true));\n }, 100),\n\n onScroll: __WEBPACK_IMPORTED_MODULE_0_lodash_debounce___default()(function () {\n dispatch(Object(__WEBPACK_IMPORTED_MODULE_3__actions_timelines__[\"B\" /* scrollTopTimeline */])(timelineId, false));\n }, 100)\n\n };\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_1_react_redux__[\"connect\"])(makeMapStateToProps, mapDispatchToProps)(__WEBPACK_IMPORTED_MODULE_2__components_status_list__[\"a\" /* default */]));\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/***/ 754:\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 HomeTimeline; });\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__actions_timelines__ = __webpack_require__(16);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__ui_containers_status_list_container__ = __webpack_require__(158);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__components_column__ = __webpack_require__(99);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__components_column_header__ = __webpack_require__(98);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__actions_columns__ = __webpack_require__(273);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_react_intl__ = __webpack_require__(6);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_12__containers_column_settings_container__ = __webpack_require__(888);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_13_react_router_dom__ = __webpack_require__(58);\n\n\n\n\n\nvar _dec, _class;\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 title: {\n 'id': 'column.home',\n 'defaultMessage': 'Home'\n }\n});\n\nvar mapStateToProps = function mapStateToProps(state) {\n return {\n hasUnread: state.getIn(['timelines', 'home', 'unread']) > 0\n };\n};\n\nvar HomeTimeline = (_dec = Object(__WEBPACK_IMPORTED_MODULE_5_react_redux__[\"connect\"])(mapStateToProps), _dec(_class = Object(__WEBPACK_IMPORTED_MODULE_11_react_intl__[\"g\" /* injectIntl */])(_class = function (_React$PureComponent) {\n __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(HomeTimeline, _React$PureComponent);\n\n function HomeTimeline() {\n var _temp, _this, _ret;\n\n __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, HomeTimeline);\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.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_10__actions_columns__[\"f\" /* removeColumn */])(columnId));\n } else {\n dispatch(Object(__WEBPACK_IMPORTED_MODULE_10__actions_columns__[\"d\" /* addColumn */])('HOME', {}));\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_10__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.handleLoadMore = function () {\n _this.props.dispatch(Object(__WEBPACK_IMPORTED_MODULE_6__actions_timelines__[\"t\" /* expandHomeTimeline */])());\n }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n }\n\n HomeTimeline.prototype.render = function render() {\n var _props = this.props,\n intl = _props.intl,\n hasUnread = _props.hasUnread,\n columnId = _props.columnId,\n multiColumn = _props.multiColumn;\n\n var pinned = !!columnId;\n\n return __WEBPACK_IMPORTED_MODULE_4_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_8__components_column__[\"a\" /* default */],\n { ref: this.setRef },\n __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__components_column_header__[\"a\" /* default */], {\n icon: 'home',\n active: hasUnread,\n title: intl.formatMessage(messages.title),\n onPin: this.handlePin,\n onMove: this.handleMove,\n onClick: this.handleHeaderClick,\n pinned: pinned,\n multiColumn: multiColumn\n }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_12__containers_column_settings_container__[\"a\" /* default */], {})),\n __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7__ui_containers_status_list_container__[\"a\" /* default */], {\n trackScroll: !pinned,\n scrollKey: 'home_timeline-' + columnId,\n loadMore: this.handleLoadMore,\n timelineId: 'home',\n emptyMessage: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_11_react_intl__[\"b\" /* FormattedMessage */], {\n id: 'empty_column.home',\n defaultMessage: 'Your home timeline is empty! Visit {public} or use search to get started and meet other users.',\n values: { public: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_13_react_router_dom__[\"b\" /* Link */], {\n to: '/timelines/public'\n }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_11_react_intl__[\"b\" /* FormattedMessage */], {\n id: 'empty_column.home.public_timeline',\n defaultMessage: 'the public timeline'\n })) }\n })\n })\n );\n };\n\n return HomeTimeline;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent)) || _class) || _class);\n\n\n/***/ }),\n\n/***/ 790:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }return target;\n};\n\nvar _createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];descriptor.enumerable = descriptor.enumerable || false;descriptor.configurable = true;if (\"value\" in descriptor) descriptor.writable = true;Object.defineProperty(target, descriptor.key, descriptor);\n }\n }return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);if (staticProps) defineProperties(Constructor, staticProps);return Constructor;\n };\n}();\n\nvar _react = __webpack_require__(0);\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = __webpack_require__(10);\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _propTypes = __webpack_require__(5);\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _check = __webpack_require__(791);\n\nvar _check2 = _interopRequireDefault(_check);\n\nvar _x = __webpack_require__(792);\n\nvar _x2 = _interopRequireDefault(_x);\n\nvar _util = __webpack_require__(793);\n\nfunction _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : { default: obj };\n}\n\nfunction _objectWithoutProperties(obj, keys) {\n var target = {};for (var i in obj) {\n if (keys.indexOf(i) >= 0) continue;if (!Object.prototype.hasOwnProperty.call(obj, i)) continue;target[i] = obj[i];\n }return target;\n}\n\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nfunction _possibleConstructorReturn(self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n}\n\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } });if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n}\n\nvar Toggle = function (_PureComponent) {\n _inherits(Toggle, _PureComponent);\n\n function Toggle(props) {\n _classCallCheck(this, Toggle);\n\n var _this = _possibleConstructorReturn(this, (Toggle.__proto__ || Object.getPrototypeOf(Toggle)).call(this, props));\n\n _this.handleClick = _this.handleClick.bind(_this);\n _this.handleTouchStart = _this.handleTouchStart.bind(_this);\n _this.handleTouchMove = _this.handleTouchMove.bind(_this);\n _this.handleTouchEnd = _this.handleTouchEnd.bind(_this);\n _this.handleFocus = _this.handleFocus.bind(_this);\n _this.handleBlur = _this.handleBlur.bind(_this);\n _this.previouslyChecked = !!(props.checked || props.defaultChecked);\n _this.state = {\n checked: !!(props.checked || props.defaultChecked),\n hasFocus: false\n };\n return _this;\n }\n\n _createClass(Toggle, [{\n key: 'componentWillReceiveProps',\n value: function componentWillReceiveProps(nextProps) {\n if ('checked' in nextProps) {\n this.setState({ checked: !!nextProps.checked });\n }\n }\n }, {\n key: 'handleClick',\n value: function handleClick(event) {\n var checkbox = this.input;\n if (event.target !== checkbox && !this.moved) {\n this.previouslyChecked = checkbox.checked;\n event.preventDefault();\n checkbox.focus();\n checkbox.click();\n return;\n }\n\n var checked = this.props.hasOwnProperty('checked') ? this.props.checked : checkbox.checked;\n\n this.setState({ checked: checked });\n }\n }, {\n key: 'handleTouchStart',\n value: function handleTouchStart(event) {\n this.startX = (0, _util.pointerCoord)(event).x;\n this.activated = true;\n }\n }, {\n key: 'handleTouchMove',\n value: function handleTouchMove(event) {\n if (!this.activated) return;\n this.moved = true;\n\n if (this.startX) {\n var currentX = (0, _util.pointerCoord)(event).x;\n if (this.state.checked && currentX + 15 < this.startX) {\n this.setState({ checked: false });\n this.startX = currentX;\n this.activated = true;\n } else if (currentX - 15 > this.startX) {\n this.setState({ checked: true });\n this.startX = currentX;\n this.activated = currentX < this.startX + 5;\n }\n }\n }\n }, {\n key: 'handleTouchEnd',\n value: function handleTouchEnd(event) {\n if (!this.moved) return;\n var checkbox = this.input;\n event.preventDefault();\n\n if (this.startX) {\n var endX = (0, _util.pointerCoord)(event).x;\n if (this.previouslyChecked === true && this.startX + 4 > endX) {\n if (this.previouslyChecked !== this.state.checked) {\n this.setState({ checked: false });\n this.previouslyChecked = this.state.checked;\n checkbox.click();\n }\n } else if (this.startX - 4 < endX) {\n if (this.previouslyChecked !== this.state.checked) {\n this.setState({ checked: true });\n this.previouslyChecked = this.state.checked;\n checkbox.click();\n }\n }\n\n this.activated = false;\n this.startX = null;\n this.moved = false;\n }\n }\n }, {\n key: 'handleFocus',\n value: function handleFocus(event) {\n var onFocus = this.props.onFocus;\n\n if (onFocus) {\n onFocus(event);\n }\n\n this.setState({ hasFocus: true });\n }\n }, {\n key: 'handleBlur',\n value: function handleBlur(event) {\n var onBlur = this.props.onBlur;\n\n if (onBlur) {\n onBlur(event);\n }\n\n this.setState({ hasFocus: false });\n }\n }, {\n key: 'getIcon',\n value: function getIcon(type) {\n var icons = this.props.icons;\n\n if (!icons) {\n return null;\n }\n return icons[type] === undefined ? Toggle.defaultProps.icons[type] : icons[type];\n }\n }, {\n key: 'render',\n value: function render() {\n var _this2 = this;\n\n var _props = this.props,\n className = _props.className,\n _icons = _props.icons,\n inputProps = _objectWithoutProperties(_props, ['className', 'icons']);\n\n var classes = (0, _classnames2.default)('react-toggle', {\n 'react-toggle--checked': this.state.checked,\n 'react-toggle--focus': this.state.hasFocus,\n 'react-toggle--disabled': this.props.disabled\n }, className);\n\n return _react2.default.createElement('div', { className: classes,\n onClick: this.handleClick,\n onTouchStart: this.handleTouchStart,\n onTouchMove: this.handleTouchMove,\n onTouchEnd: this.handleTouchEnd }, _react2.default.createElement('div', { className: 'react-toggle-track' }, _react2.default.createElement('div', { className: 'react-toggle-track-check' }, this.getIcon('checked')), _react2.default.createElement('div', { className: 'react-toggle-track-x' }, this.getIcon('unchecked'))), _react2.default.createElement('div', { className: 'react-toggle-thumb' }), _react2.default.createElement('input', _extends({}, inputProps, {\n ref: function ref(_ref) {\n _this2.input = _ref;\n },\n onFocus: this.handleFocus,\n onBlur: this.handleBlur,\n className: 'react-toggle-screenreader-only',\n type: 'checkbox' })));\n }\n }]);\n\n return Toggle;\n}(_react.PureComponent);\n\nexports.default = Toggle;\n\nToggle.displayName = 'Toggle';\n\nToggle.defaultProps = {\n icons: {\n checked: _react2.default.createElement(_check2.default, null),\n unchecked: _react2.default.createElement(_x2.default, null)\n }\n};\n\nToggle.propTypes = {\n checked: _propTypes2.default.bool,\n disabled: _propTypes2.default.bool,\n defaultChecked: _propTypes2.default.bool,\n onChange: _propTypes2.default.func,\n onFocus: _propTypes2.default.func,\n onBlur: _propTypes2.default.func,\n className: _propTypes2.default.string,\n name: _propTypes2.default.string,\n value: _propTypes2.default.string,\n id: _propTypes2.default.string,\n 'aria-labelledby': _propTypes2.default.string,\n 'aria-label': _propTypes2.default.string,\n icons: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.shape({\n checked: _propTypes2.default.node,\n unchecked: _propTypes2.default.node\n })])\n};\n\n/***/ }),\n\n/***/ 791:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _react = __webpack_require__(0);\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : { default: obj };\n}\n\nexports.default = function () {\n return _react2.default.createElement('svg', { width: '14', height: '11', viewBox: '0 0 14 11' }, _react2.default.createElement('title', null, 'switch-check'), _react2.default.createElement('path', { d: 'M11.264 0L5.26 6.004 2.103 2.847 0 4.95l5.26 5.26 8.108-8.107L11.264 0', fill: '#fff', fillRule: 'evenodd' }));\n};\n\n/***/ }),\n\n/***/ 792:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _react = __webpack_require__(0);\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : { default: obj };\n}\n\nexports.default = function () {\n return _react2.default.createElement('svg', { width: '10', height: '10', viewBox: '0 0 10 10' }, _react2.default.createElement('title', null, 'switch-x'), _react2.default.createElement('path', { d: 'M9.9 2.12L7.78 0 4.95 2.828 2.12 0 0 2.12l2.83 2.83L0 7.776 2.123 9.9 4.95 7.07 7.78 9.9 9.9 7.776 7.072 4.95 9.9 2.12', fill: '#fff', fillRule: 'evenodd' }));\n};\n\n/***/ }),\n\n/***/ 793:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.pointerCoord = pointerCoord;\n// Copyright 2015-present Drifty Co.\n// http://drifty.com/\n// from: https://github.com/driftyco/ionic/blob/master/src/util/dom.ts\n\nfunction pointerCoord(event) {\n // get coordinates for either a mouse click\n // or a touch depending on the given event\n if (event) {\n var changedTouches = event.changedTouches;\n if (changedTouches && changedTouches.length > 0) {\n var touch = changedTouches[0];\n return { x: touch.clientX, y: touch.clientY };\n }\n var pageX = event.pageX;\n if (pageX !== undefined) {\n return { x: pageX, y: event.pageY };\n }\n }\n return { x: 0, y: 0 };\n}\n\n/***/ }),\n\n/***/ 794:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return SettingText; });\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 SettingText = function (_React$PureComponent) {\n __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(SettingText, _React$PureComponent);\n\n function SettingText() {\n var _temp, _this, _ret;\n\n __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, SettingText);\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.handleChange = function (e) {\n _this.props.onChange(_this.props.settingKey, e.target.value);\n }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n }\n\n SettingText.prototype.render = function render() {\n var _props = this.props,\n settings = _props.settings,\n settingKey = _props.settingKey,\n label = _props.label;\n\n\n return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('label', {}, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('span', {\n style: { display: 'none' }\n }, void 0, label), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('input', {\n className: 'setting-text',\n value: settings.getIn(settingKey),\n onChange: this.handleChange,\n placeholder: label\n }));\n };\n\n return SettingText;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\n\n\n/***/ }),\n\n/***/ 804:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return SettingToggle; });\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_toggle__ = __webpack_require__(790);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react_toggle___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_react_toggle__);\n\n\n\n\n\n\n\n\nvar SettingToggle = function (_React$PureComponent) {\n __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(SettingToggle, _React$PureComponent);\n\n function SettingToggle() {\n var _temp, _this, _ret;\n\n __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, SettingToggle);\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.onChange = function (_ref) {\n var target = _ref.target;\n\n _this.props.onChange(_this.props.settingKey, target.checked);\n }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n }\n\n SettingToggle.prototype.render = function render() {\n var _props = this.props,\n prefix = _props.prefix,\n settings = _props.settings,\n settingKey = _props.settingKey,\n label = _props.label,\n meta = _props.meta;\n\n var id = ['setting-toggle', prefix].concat(settingKey).filter(Boolean).join('-');\n\n return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n className: 'setting-toggle'\n }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_toggle___default.a, {\n id: id,\n checked: settings.getIn(settingKey),\n onChange: this.onChange,\n onKeyDown: this.onKeyDown\n }), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('label', {\n htmlFor: id,\n className: 'setting-toggle__label'\n }, void 0, label), meta && __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('span', {\n className: 'setting-meta__label'\n }, void 0, meta));\n };\n\n return SettingToggle;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\n\n\n/***/ }),\n\n/***/ 888:\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_column_settings__ = __webpack_require__(889);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__actions_settings__ = __webpack_require__(59);\n\n\n\n\nvar mapStateToProps = function mapStateToProps(state) {\n return {\n settings: state.getIn(['settings', 'home'])\n };\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch) {\n return {\n onChange: function onChange(key, checked) {\n dispatch(Object(__WEBPACK_IMPORTED_MODULE_2__actions_settings__[\"c\" /* changeSetting */])(['home'].concat(key), checked));\n },\n onSave: function onSave() {\n dispatch(Object(__WEBPACK_IMPORTED_MODULE_2__actions_settings__[\"d\" /* saveSettings */])());\n }\n };\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_0_react_redux__[\"connect\"])(mapStateToProps, mapDispatchToProps)(__WEBPACK_IMPORTED_MODULE_1__components_column_settings__[\"a\" /* default */]));\n\n/***/ }),\n\n/***/ 889:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return ColumnSettings; });\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/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__notifications_components_setting_toggle__ = __webpack_require__(804);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__components_setting_text__ = __webpack_require__(794);\n\n\n\n\n\nvar _class;\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"f\" /* defineMessages */])({\n filter_regex: {\n 'id': 'home.column_settings.filter_regex',\n 'defaultMessage': 'Filter out by regular expressions'\n },\n settings: {\n 'id': 'home.settings',\n 'defaultMessage': 'Column settings'\n }\n});\n\nvar ColumnSettings = Object(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"g\" /* injectIntl */])(_class = function (_React$PureComponent) {\n __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(ColumnSettings, _React$PureComponent);\n\n function ColumnSettings() {\n __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, ColumnSettings);\n\n return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.apply(this, arguments));\n }\n\n ColumnSettings.prototype.render = function render() {\n var _props = this.props,\n settings = _props.settings,\n onChange = _props.onChange,\n intl = _props.intl;\n\n\n return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {}, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('span', {\n className: 'column-settings__section'\n }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n id: 'home.column_settings.basic',\n defaultMessage: 'Basic'\n })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n className: 'column-settings__row'\n }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6__notifications_components_setting_toggle__[\"a\" /* default */], {\n prefix: 'home_timeline',\n settings: settings,\n settingKey: ['shows', 'reblog'],\n onChange: onChange,\n label: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n id: 'home.column_settings.show_reblogs',\n defaultMessage: 'Show boosts'\n })\n })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n className: 'column-settings__row'\n }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6__notifications_components_setting_toggle__[\"a\" /* default */], {\n prefix: 'home_timeline',\n settings: settings,\n settingKey: ['shows', 'reply'],\n onChange: onChange,\n label: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n id: 'home.column_settings.show_replies',\n defaultMessage: 'Show replies'\n })\n })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('span', {\n className: 'column-settings__section'\n }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n id: 'home.column_settings.advanced',\n defaultMessage: 'Advanced'\n })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n className: 'column-settings__row'\n }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7__components_setting_text__[\"a\" /* default */], {\n prefix: 'home_timeline',\n settings: settings,\n settingKey: ['regex', 'body'],\n onChange: onChange,\n label: intl.formatMessage(messages.filter_regex)\n })));\n };\n\n return ColumnSettings;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent)) || _class;\n\n\n\n/***/ })\n\n});\n\n\n// WEBPACK FOOTER //\n// features/home_timeline-c146f32b0118845677ee.js","import { connect } from 'react-redux';\nimport StatusList from '../../../components/status_list';\nimport { scrollTopTimeline } from '../../../actions/timelines';\nimport { Map as ImmutableMap, List as ImmutableList } from 'immutable';\nimport { createSelector } from 'reselect';\nimport { debounce } from 'lodash';\nimport { me } from '../../../initial_state';\n\nconst makeGetStatusIds = () => createSelector([\n (state, { type }) => state.getIn(['settings', type], ImmutableMap()),\n (state, { type }) => state.getIn(['timelines', type, 'items'], ImmutableList()),\n (state) => state.get('statuses'),\n], (columnSettings, statusIds, statuses) => {\n const rawRegex = columnSettings.getIn(['regex', 'body'], '').trim();\n let regex = null;\n\n try {\n regex = rawRegex && new RegExp(rawRegex, 'i');\n } catch (e) {\n // Bad regex, don't affect filters\n }\n\n return statusIds.filter(id => {\n const statusForId = statuses.get(id);\n let showStatus = true;\n\n if (columnSettings.getIn(['shows', 'reblog']) === false) {\n showStatus = showStatus && statusForId.get('reblog') === null;\n }\n\n if (columnSettings.getIn(['shows', 'reply']) === false) {\n showStatus = showStatus && (statusForId.get('in_reply_to_id') === null || statusForId.get('in_reply_to_account_id') === me);\n }\n\n if (showStatus && regex && statusForId.get('account') !== me) {\n const searchIndex = statusForId.get('reblog') ? statuses.getIn([statusForId.get('reblog'), 'search_index']) : statusForId.get('search_index');\n showStatus = !regex.test(searchIndex);\n }\n\n return showStatus;\n });\n});\n\nconst makeMapStateToProps = () => {\n const getStatusIds = makeGetStatusIds();\n\n const mapStateToProps = (state, { timelineId }) => ({\n statusIds: getStatusIds(state, { type: timelineId }),\n isLoading: state.getIn(['timelines', timelineId, 'isLoading'], true),\n hasMore: !!state.getIn(['timelines', timelineId, 'next']),\n });\n\n return mapStateToProps;\n};\n\nconst mapDispatchToProps = (dispatch, { timelineId, loadMore }) => ({\n\n onScrollToBottom: debounce(() => {\n dispatch(scrollTopTimeline(timelineId, false));\n loadMore();\n }, 300, { leading: true }),\n\n onScrollToTop: debounce(() => {\n dispatch(scrollTopTimeline(timelineId, true));\n }, 100),\n\n onScroll: debounce(() => {\n dispatch(scrollTopTimeline(timelineId, false));\n }, 100),\n\n});\n\nexport default connect(makeMapStateToProps, mapDispatchToProps)(StatusList);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/ui/containers/status_list_container.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 { expandHomeTimeline } from '../../actions/timelines';\nimport PropTypes from 'prop-types';\nimport StatusListContainer from '../ui/containers/status_list_container';\nimport Column from '../../components/column';\nimport ColumnHeader from '../../components/column_header';\nimport { addColumn, removeColumn, moveColumn } from '../../actions/columns';\nimport { defineMessages, injectIntl, FormattedMessage } from 'react-intl';\nimport ColumnSettingsContainer from './containers/column_settings_container';\nimport { Link } from 'react-router-dom';\n\nconst messages = defineMessages({\n title: { id: 'column.home', defaultMessage: 'Home' },\n});\n\nconst mapStateToProps = state => ({\n hasUnread: state.getIn(['timelines', 'home', 'unread']) > 0,\n});\n\n@connect(mapStateToProps)\n@injectIntl\nexport default class HomeTimeline extends React.PureComponent {\n\n static propTypes = {\n dispatch: PropTypes.func.isRequired,\n intl: PropTypes.object.isRequired,\n hasUnread: PropTypes.bool,\n columnId: PropTypes.string,\n multiColumn: PropTypes.bool,\n };\n\n handlePin = () => {\n const { columnId, dispatch } = this.props;\n\n if (columnId) {\n dispatch(removeColumn(columnId));\n } else {\n dispatch(addColumn('HOME', {}));\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 handleLoadMore = () => {\n this.props.dispatch(expandHomeTimeline());\n }\n\n render () {\n const { intl, hasUnread, columnId, multiColumn } = this.props;\n const pinned = !!columnId;\n\n return (\n <Column ref={this.setRef}>\n <ColumnHeader\n icon='home'\n active={hasUnread}\n title={intl.formatMessage(messages.title)}\n onPin={this.handlePin}\n onMove={this.handleMove}\n onClick={this.handleHeaderClick}\n pinned={pinned}\n multiColumn={multiColumn}\n >\n <ColumnSettingsContainer />\n </ColumnHeader>\n\n <StatusListContainer\n trackScroll={!pinned}\n scrollKey={`home_timeline-${columnId}`}\n loadMore={this.handleLoadMore}\n timelineId='home'\n emptyMessage={<FormattedMessage id='empty_column.home' defaultMessage='Your home timeline is empty! Visit {public} or use search to get started and meet other users.' values={{ public: <Link to='/timelines/public'><FormattedMessage id='empty_column.home.public_timeline' defaultMessage='the public timeline' /></Link> }} />}\n />\n </Column>\n );\n }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/home_timeline/index.js","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _check = require('./check');\n\nvar _check2 = _interopRequireDefault(_check);\n\nvar _x = require('./x');\n\nvar _x2 = _interopRequireDefault(_x);\n\nvar _util = require('./util');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Toggle = function (_PureComponent) {\n _inherits(Toggle, _PureComponent);\n\n function Toggle(props) {\n _classCallCheck(this, Toggle);\n\n var _this = _possibleConstructorReturn(this, (Toggle.__proto__ || Object.getPrototypeOf(Toggle)).call(this, props));\n\n _this.handleClick = _this.handleClick.bind(_this);\n _this.handleTouchStart = _this.handleTouchStart.bind(_this);\n _this.handleTouchMove = _this.handleTouchMove.bind(_this);\n _this.handleTouchEnd = _this.handleTouchEnd.bind(_this);\n _this.handleFocus = _this.handleFocus.bind(_this);\n _this.handleBlur = _this.handleBlur.bind(_this);\n _this.previouslyChecked = !!(props.checked || props.defaultChecked);\n _this.state = {\n checked: !!(props.checked || props.defaultChecked),\n hasFocus: false\n };\n return _this;\n }\n\n _createClass(Toggle, [{\n key: 'componentWillReceiveProps',\n value: function componentWillReceiveProps(nextProps) {\n if ('checked' in nextProps) {\n this.setState({ checked: !!nextProps.checked });\n }\n }\n }, {\n key: 'handleClick',\n value: function handleClick(event) {\n var checkbox = this.input;\n if (event.target !== checkbox && !this.moved) {\n this.previouslyChecked = checkbox.checked;\n event.preventDefault();\n checkbox.focus();\n checkbox.click();\n return;\n }\n\n var checked = this.props.hasOwnProperty('checked') ? this.props.checked : checkbox.checked;\n\n this.setState({ checked: checked });\n }\n }, {\n key: 'handleTouchStart',\n value: function handleTouchStart(event) {\n this.startX = (0, _util.pointerCoord)(event).x;\n this.activated = true;\n }\n }, {\n key: 'handleTouchMove',\n value: function handleTouchMove(event) {\n if (!this.activated) return;\n this.moved = true;\n\n if (this.startX) {\n var currentX = (0, _util.pointerCoord)(event).x;\n if (this.state.checked && currentX + 15 < this.startX) {\n this.setState({ checked: false });\n this.startX = currentX;\n this.activated = true;\n } else if (currentX - 15 > this.startX) {\n this.setState({ checked: true });\n this.startX = currentX;\n this.activated = currentX < this.startX + 5;\n }\n }\n }\n }, {\n key: 'handleTouchEnd',\n value: function handleTouchEnd(event) {\n if (!this.moved) return;\n var checkbox = this.input;\n event.preventDefault();\n\n if (this.startX) {\n var endX = (0, _util.pointerCoord)(event).x;\n if (this.previouslyChecked === true && this.startX + 4 > endX) {\n if (this.previouslyChecked !== this.state.checked) {\n this.setState({ checked: false });\n this.previouslyChecked = this.state.checked;\n checkbox.click();\n }\n } else if (this.startX - 4 < endX) {\n if (this.previouslyChecked !== this.state.checked) {\n this.setState({ checked: true });\n this.previouslyChecked = this.state.checked;\n checkbox.click();\n }\n }\n\n this.activated = false;\n this.startX = null;\n this.moved = false;\n }\n }\n }, {\n key: 'handleFocus',\n value: function handleFocus(event) {\n var onFocus = this.props.onFocus;\n\n\n if (onFocus) {\n onFocus(event);\n }\n\n this.setState({ hasFocus: true });\n }\n }, {\n key: 'handleBlur',\n value: function handleBlur(event) {\n var onBlur = this.props.onBlur;\n\n\n if (onBlur) {\n onBlur(event);\n }\n\n this.setState({ hasFocus: false });\n }\n }, {\n key: 'getIcon',\n value: function getIcon(type) {\n var icons = this.props.icons;\n\n if (!icons) {\n return null;\n }\n return icons[type] === undefined ? Toggle.defaultProps.icons[type] : icons[type];\n }\n }, {\n key: 'render',\n value: function render() {\n var _this2 = this;\n\n var _props = this.props,\n className = _props.className,\n _icons = _props.icons,\n inputProps = _objectWithoutProperties(_props, ['className', 'icons']);\n\n var classes = (0, _classnames2.default)('react-toggle', {\n 'react-toggle--checked': this.state.checked,\n 'react-toggle--focus': this.state.hasFocus,\n 'react-toggle--disabled': this.props.disabled\n }, className);\n\n return _react2.default.createElement(\n 'div',\n { className: classes,\n onClick: this.handleClick,\n onTouchStart: this.handleTouchStart,\n onTouchMove: this.handleTouchMove,\n onTouchEnd: this.handleTouchEnd },\n _react2.default.createElement(\n 'div',\n { className: 'react-toggle-track' },\n _react2.default.createElement(\n 'div',\n { className: 'react-toggle-track-check' },\n this.getIcon('checked')\n ),\n _react2.default.createElement(\n 'div',\n { className: 'react-toggle-track-x' },\n this.getIcon('unchecked')\n )\n ),\n _react2.default.createElement('div', { className: 'react-toggle-thumb' }),\n _react2.default.createElement('input', _extends({}, inputProps, {\n ref: function ref(_ref) {\n _this2.input = _ref;\n },\n onFocus: this.handleFocus,\n onBlur: this.handleBlur,\n className: 'react-toggle-screenreader-only',\n type: 'checkbox' }))\n );\n }\n }]);\n\n return Toggle;\n}(_react.PureComponent);\n\nexports.default = Toggle;\n\n\nToggle.displayName = 'Toggle';\n\nToggle.defaultProps = {\n icons: {\n checked: _react2.default.createElement(_check2.default, null),\n unchecked: _react2.default.createElement(_x2.default, null)\n }\n};\n\nToggle.propTypes = {\n checked: _propTypes2.default.bool,\n disabled: _propTypes2.default.bool,\n defaultChecked: _propTypes2.default.bool,\n onChange: _propTypes2.default.func,\n onFocus: _propTypes2.default.func,\n onBlur: _propTypes2.default.func,\n className: _propTypes2.default.string,\n name: _propTypes2.default.string,\n value: _propTypes2.default.string,\n id: _propTypes2.default.string,\n 'aria-labelledby': _propTypes2.default.string,\n 'aria-label': _propTypes2.default.string,\n icons: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.shape({\n checked: _propTypes2.default.node,\n unchecked: _propTypes2.default.node\n })])\n};\n\n\n// WEBPACK FOOTER //\n// ./node_modules/react-toggle/dist/component/index.js","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = function () {\n return _react2.default.createElement(\n 'svg',\n { width: '14', height: '11', viewBox: '0 0 14 11' },\n _react2.default.createElement(\n 'title',\n null,\n 'switch-check'\n ),\n _react2.default.createElement('path', { d: 'M11.264 0L5.26 6.004 2.103 2.847 0 4.95l5.26 5.26 8.108-8.107L11.264 0', fill: '#fff', fillRule: 'evenodd' })\n );\n};\n\n\n// WEBPACK FOOTER //\n// ./node_modules/react-toggle/dist/component/check.js","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = function () {\n return _react2.default.createElement(\n 'svg',\n { width: '10', height: '10', viewBox: '0 0 10 10' },\n _react2.default.createElement(\n 'title',\n null,\n 'switch-x'\n ),\n _react2.default.createElement('path', { d: 'M9.9 2.12L7.78 0 4.95 2.828 2.12 0 0 2.12l2.83 2.83L0 7.776 2.123 9.9 4.95 7.07 7.78 9.9 9.9 7.776 7.072 4.95 9.9 2.12', fill: '#fff', fillRule: 'evenodd' })\n );\n};\n\n\n// WEBPACK FOOTER //\n// ./node_modules/react-toggle/dist/component/x.js","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.pointerCoord = pointerCoord;\n// Copyright 2015-present Drifty Co.\n// http://drifty.com/\n// from: https://github.com/driftyco/ionic/blob/master/src/util/dom.ts\n\nfunction pointerCoord(event) {\n // get coordinates for either a mouse click\n // or a touch depending on the given event\n if (event) {\n var changedTouches = event.changedTouches;\n if (changedTouches && changedTouches.length > 0) {\n var touch = changedTouches[0];\n return { x: touch.clientX, y: touch.clientY };\n }\n var pageX = event.pageX;\n if (pageX !== undefined) {\n return { x: pageX, y: event.pageY };\n }\n }\n return { x: 0, y: 0 };\n}\n\n\n// WEBPACK FOOTER //\n// ./node_modules/react-toggle/dist/component/util.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\n\nexport default class SettingText extends React.PureComponent {\n\n static propTypes = {\n settings: ImmutablePropTypes.map.isRequired,\n settingKey: PropTypes.array.isRequired,\n label: PropTypes.string.isRequired,\n onChange: PropTypes.func.isRequired,\n };\n\n handleChange = (e) => {\n this.props.onChange(this.props.settingKey, e.target.value);\n }\n\n render () {\n const { settings, settingKey, label } = this.props;\n\n return (\n <label>\n <span style={{ display: 'none' }}>{label}</span>\n <input\n className='setting-text'\n value={settings.getIn(settingKey)}\n onChange={this.handleChange}\n placeholder={label}\n />\n </label>\n );\n }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/components/setting_text.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport Toggle from 'react-toggle';\n\nexport default class SettingToggle extends React.PureComponent {\n\n static propTypes = {\n prefix: PropTypes.string,\n settings: ImmutablePropTypes.map.isRequired,\n settingKey: PropTypes.array.isRequired,\n label: PropTypes.node.isRequired,\n meta: PropTypes.node,\n onChange: PropTypes.func.isRequired,\n }\n\n onChange = ({ target }) => {\n this.props.onChange(this.props.settingKey, target.checked);\n }\n\n render () {\n const { prefix, settings, settingKey, label, meta } = this.props;\n const id = ['setting-toggle', prefix, ...settingKey].filter(Boolean).join('-');\n\n return (\n <div className='setting-toggle'>\n <Toggle id={id} checked={settings.getIn(settingKey)} onChange={this.onChange} onKeyDown={this.onKeyDown} />\n <label htmlFor={id} className='setting-toggle__label'>{label}</label>\n {meta && <span className='setting-meta__label'>{meta}</span>}\n </div>\n );\n }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/notifications/components/setting_toggle.js","import { connect } from 'react-redux';\nimport ColumnSettings from '../components/column_settings';\nimport { changeSetting, saveSettings } from '../../../actions/settings';\n\nconst mapStateToProps = state => ({\n settings: state.getIn(['settings', 'home']),\n});\n\nconst mapDispatchToProps = dispatch => ({\n\n onChange (key, checked) {\n dispatch(changeSetting(['home', ...key], checked));\n },\n\n onSave () {\n dispatch(saveSettings());\n },\n\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(ColumnSettings);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/home_timeline/containers/column_settings_container.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { defineMessages, injectIntl, FormattedMessage } from 'react-intl';\nimport SettingToggle from '../../notifications/components/setting_toggle';\nimport SettingText from '../../../components/setting_text';\n\nconst messages = defineMessages({\n filter_regex: { id: 'home.column_settings.filter_regex', defaultMessage: 'Filter out by regular expressions' },\n settings: { id: 'home.settings', defaultMessage: 'Column settings' },\n});\n\n@injectIntl\nexport default class ColumnSettings extends React.PureComponent {\n\n static propTypes = {\n settings: ImmutablePropTypes.map.isRequired,\n onChange: PropTypes.func.isRequired,\n intl: PropTypes.object.isRequired,\n };\n\n render () {\n const { settings, onChange, intl } = this.props;\n\n return (\n <div>\n <span className='column-settings__section'><FormattedMessage id='home.column_settings.basic' defaultMessage='Basic' /></span>\n\n <div className='column-settings__row'>\n <SettingToggle prefix='home_timeline' settings={settings} settingKey={['shows', 'reblog']} onChange={onChange} label={<FormattedMessage id='home.column_settings.show_reblogs' defaultMessage='Show boosts' />} />\n </div>\n\n <div className='column-settings__row'>\n <SettingToggle prefix='home_timeline' settings={settings} settingKey={['shows', 'reply']} onChange={onChange} label={<FormattedMessage id='home.column_settings.show_replies' defaultMessage='Show replies' />} />\n </div>\n\n <span className='column-settings__section'><FormattedMessage id='home.column_settings.advanced' defaultMessage='Advanced' /></span>\n\n <div className='column-settings__row'>\n <SettingText prefix='home_timeline' settings={settings} settingKey={['regex', 'body']} onChange={onChange} label={intl.formatMessage(messages.filter_regex)} />\n </div>\n </div>\n );\n }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/home_timeline/components/column_settings.js"],"sourceRoot":""}